The ATOM operating system contains several routines which can be called by user programs to provide input and output facilities. The routines are defined so that they are compatible with the other Acorn operating systems; in particular, if the ATOM is expanded to include a Disk Operating System the same routines will automatically function with the disk.
OSCLI Command line interpreter
This subroutine interprets a string of characters at address #0100 and terminated by carriage return as an operating system command. Detected errors are met with a BRK. All processor registers are used, and the decimal-mode flag is set to binary on exit.
OSWRCH Write character
This subroutine sends the byte in the accumulator to the output channel. Control characters are normally recognised as detailed in Section 18.1.3. All registers are preserved.
OSCRLF Carriage return -- line feed
This subroutine generates a line feed followed by a carriage return using OSWRCH. On exit A will contain #0D, N and Z will be 0, and all other registers are preserved.
OSECHO Read character with echo
This subroutine reads a byte using OSRDCH and then writes it out using OSWRCH. The routine converts carriage returns to a line feed followed by a carriage return. On exit A will contain the byte read, N, Z, and C are undefined, and all other registers are preserved.
OSRDCH Read character
This subroutine reads a byte from the input channel and returns it in A. The state of N, Z, and C is undefined; all other reqisters are preserved.
OSLOAD Load file
This subroutine loads a complete file into a specified area of
memory.
On entry X must point to the following data in zero page:
X+0 address of string of characters, terminated by #0D, which
is the file name.
X+2 Address in memory of the first byte of the destination.
X+4 Flag byte: if bit 7 = 0 use the file's start address.
All processor registers are used. A break will occur if the file cannot be found. In interrupt or DMA driven systems a wait until completion should be performed if the carry flag was set on entry.
OSSAVE, Save file
This subroutine saves all of an area of memory to a specified file. On entry X must point to the following data in zero page:
X+0 Address of string of characters, terminated by #0D, which
is the file name.
X+2 Address for data to be reloaded to.
X+4 Execution address if data is to be executed
X+6 Start address of data in memory
X+8 End address + 1 of data in memory
The data is copied by the operating system without being altered. All registers are used. In interrupt or DMA driven operating systems a wait until completion should be performed if the carry flag was set on entry. A break will occur if no storage space large enough can be found.
OSBPUT Put byte
This subroutine outputs the byte in the accumulator to a sequential write file. Registers X and Y are saved. In the ATOM operatinq system interrupts are disabled during OSBPUT but interrupt status is restored on exit. In the Disk Operating System the file's sequential file pointer will be incremented after the byte has been saved.
OSBGET Get byte
The subroutine returns, in A, the next byte from a sequential read file. Registers X and Y are retained. In the ATOM operating system interrupts are disabled during OSBGET but interrupt status is restored on exit. In the Disk Operating System the file's sequential file pointer will be incremented after the byte has been read.
OSFIND Find file
This subroutine returns, in A, a 'handle' for a file. The X register points to zero page locations containing the address of the first character of the file name; the file name is terminated by a #0D byte. The 'handle' is zero if the file does not exist; otherwise it is a byte uniquely specifying the file. If the file is to be used for sequential input the carry should be set, or if for sequential output the carry should be clear. In the ATOM operating system the file handle is set to 13, and the message "PLAY TAPE" or "RECORD TAPE" is produced. In the Disk Operating Systam the file's sequential pointer is set to zero.
OSSHUT Shut file
This subroutine removes a reference to a file whose handle is in the Y register. If a handle of zero is supplied, all files are shut. In the ATOM operating system the call does nothing.
The following subroutines are not used in the cassette system, and cause an error if called:
OSRDAR Read file's arguments
OSSTAR Store file's arguments
The following table gives the addresses of all the operating system calls:
Address: Subroutine: Instruction: #FFCB OSSHUT JMP (SHTVEC) #FFCE OSFIND JMP (FNDVEC) #FFD1 OSBPUT JMP (BPTVEC) #FFD4 OSBGET JMP (BGTVEC) #FFD7 OSSTAR JMP (STRVEC) #FFDA OSRDAR JMP (RDRVEC) #FFDD OSSAVE JMP (SAVVEC) #FFED OSLOAD JMP (LODVEC) #FFE3 OSRDCH JMP (RDCVEC) #FFE6 OSECHO JSR OSRDCH #FFE9 OSASCI CMP @#0D #FFEB BNE OSWRCH #FFED OSCRLF LDA @#0A #FFEF JSR OSWRCH #FFF2 LDA @#0D #FFF4 OSWRCH JMP (WRCVEC) #FFF7 OSCLI JMP (COMVEC)
The operating system calls are all indirected via addresses held in RAM, and these addresses may be changed to the addresses of user-supplied routines. The addresses are initialised on reset as follows:
Address: Subroutine: Function: #0200 NMIVEC NMI service routine #0202 BRKVEC BRK service routine #0204 IRQVEC IRQ service routine #0206 COMVEC Command line interpreter #0208 WRCVEC Write character #020A RDCVEC Read character #020C LODVEC Load file #020E SAVVEC Save file #0210 RDRVEC Error #0212 STRVEC Error #0214 BGTVEC Get byte from tape #0216 BPTVEC Put byte to tape #0218 FNDVEC Print message #021A SHTVEC Dummy
A call to one of the routines OSRDAR or OSSTAR will cause the message:
COM?
to be output, followed by a BRK.
The following action is taken on interrupts:
NMI PHA JMP (NMIVEC)
IRQ/BRQ STA #FF PLA PHA AND @#10 which interrupt was it BNE BRK LDA #FF PHA JMP (IRQVEC)
BRK LDA #FF PLP PHP JMP (BRKVEC)
Note that the accumulator is pushed before the jump occurs.
Hexadecimal: Decimal: Function: #0 0 Error number #1, #2 1, 2 BASIC line number. #8 - #C 8 - 12 Random number seed #10, #11 16, 17 Pointer to BASIC error handler #12 18 Text-space pointer #00 - #6F 0 - 111 BASIC zero-page workspace #70 - #7F 112 - 143 Floating-point workspace #80 - #AF 144 - 175 Free #B0 - #FF 176 - 255 Cassette system workspace #FE 254 Character not sent to printer #100 - #13F 256 - 319 Input line buffer #140 - #17F 320 - 383 Strinq processing & INPUT statement buffer #180 - #1FF 384 - 511 Stack #200 - #21B 512 - 539 Operating system vectors #21C - #23F 540 - 575 Free #240 - #3FF 576 - 1023 BASIC workspace #3FE, #3FF 1022, 1023 Address of point-plotting routine
The 8255 Programmable Peripheral Interface Adapter contains three 8-bit ports, and all but one of these lines is used by the ATOM.
Port A - #B000 Output bits: Function: 0 - 3 Keyboard row 4 - 7 Graphics mode Port B - #B001 Input bits: Function: 0 - 5 Keyboard column 6 CTRL key (low when pressed) 7 SHIFT keys {low when pressed) Port C - #B002 Output bits: Function: 0 Tape output 1 Enable 2.4 kHz to cassette output 2 Loudspeaker 3 Not used Input bits: Function: 4 2.4 kHz input 5 Cassette input 6 REPT key (low when pressed) 7 60 Hz sync signal (low during flyback)
The port C output lines, bits 0 to 3, may be used for user applications when the cassette interface is not being used.
The following diagram shows how the ATOM's address space is allocated. Sections shown shaded are present in the minimal-system ATOM. The map includes the addresses of devices on the Acorn cards, which may be fitted inside the ATOM case.
#0000 | Block Zero RAM |
#0400 | Teletext VDU RAM |
#0800 | VDU CRT Controller |
#0900 | |
#0A00 | Optional FDC |
#0A80 | |
#1000 | Peripherals space |
#2000 | Catalogue buffer |
#2200 | Sequential File buffers |
#2800 | Floating point variables |
#2900 | Extension Text space RAM |
#3C00 | Off-board Extension RAM |
#8000 | VDU Screen RAM |
#8200 | Graphics Mode 1 |
#8400 | Graphics Mode 2 |
#8600 | Graphics Mode 3 |
#8C00 | Graphics Mode 4 |
#9800 | |
#A000 | Optional Utility ROM |
#B000 | PPIA I/O Device |
#B800 | Optional VIA I/O Device for Printer Interface |
#C000 | ATOM BASIC Interpreter |
#D000 | Optional Extension ROM |
#E000 | Optional Disk Operating System |
#F000 | Assembler |
Cassette Operating System |
Next chapter