Skip to content

Latest commit

 

History

History
86 lines (50 loc) · 2.01 KB

EXTENSIONS.md

File metadata and controls

86 lines (50 loc) · 2.01 KB

BIOS Extensions

Traditionally there are two reserved BIOS functions, RESERVE1(31) and RESERVE2(32), I've claimed the first as virtual syscalls that the emulator will handle.

They can be called like so:

; Set the function-number to call in HL
ld hl, 0x00

; Invoke the BIOS function
ld a, 31
out (0xff), a

We've implemented a small number of custom BIOS calls, documented below.

Function 0x00: CPMUlator?

Test to see if the code is running under cpmulator, the return value is split into two parts:

  • Registers are set to specific values:
    • H -> S
    • L -> K
    • A -> X
  • The DMA buffer is filled with a text-banner, null-terminated.

Function 0x01: Get/Set Ctrl-C Count

  • If C == 0xFF return the value of the Ctrl-C count in A.
  • IF C != 0xFF set the Ctrl-C count to be C.

Example:

;: get the value
LD HL, 0x01
LD C, 0xFF
LD A, 31
OUT (0xFF), A
;; Now A has the result

;; Set the value to 4
LD HL, 0x01
LD C, 0x04
LD A, 31
OUT (0xFF), A

Demonstrated in samples/ctrlc.z80.

Function 0x02: Get/Set Console Driver

On entry DE points to a text-string, terminated by NULL, which represents the name of the console output driver to use.

If DE is 0x0000 then the DMA area is filled with the name of the current driver, NULL-terminated.

Demonstrated in samples/console.z80

Function 0x03: Get/Set CCP

On entry DE points to a text-string, terminated by NULL, which represents the name of the CCP to use.

If DE is 0x0000 then the DMA area is filled with the name of the currently active CCP, NULL-terminated.

Demonstrated in samples/ccp.z80

Function 0x04: Get/Set Quiet

  • If C is 0x00 quiet-mode is enabled.
  • If C is 0x01 quiet-mode is disabled.
  • If C is 0xFF quiet-mode is queried.
    • 0x00 means it is active
    • 0x01 means it is not active.

Quiet mode prevents the display of a banner every time the CCP is restarted.

Demonstrated in samples/quiet.z80