2 ; Extended memory driver for the Apple II auxiliary memory
4 ; Stefan Haubenthal, 2003-12-12
5 ; Ullrich von Bassewitz, 2002-12-02
8 .include "zeropage.inc"
10 .include "em-kernel.inc"
11 .include "em-error.inc"
13 ; ------------------------------------------------------------------------
14 ; Header. Includes jump table
20 .byte $65, $6d, $64 ; "emd"
21 .byte EMD_API_VERSION ; EM API version number
34 ; ------------------------------------------------------------------------
38 AUXCARD = $C30C ; Card signature
39 AUXMOVE = $C311 ; Auxiliary move routine
40 PAGES = ($C000 - BASE) / 256
42 ; ------------------------------------------------------------------------
46 curpage: .byte $FF ; Current page number (invalid)
49 window: .res 256 ; Memory "window"
53 ; ------------------------------------------------------------------------
54 ; INSTALL routine. Is called after the driver is loaded into memory. If
55 ; possible, check if the hardware is present and determine the amount of
57 ; Must return an EM_ERR_xx code in a/x.
68 @L1: lda #EM_ERR_NO_DEVICE
71 ; ------------------------------------------------------------------------
72 ; DEINSTALL routine. Is called before the driver is removed from memory.
73 ; Can do cleanup or whatever. Must not return anything.
80 ; ------------------------------------------------------------------------
81 ; PAGECOUNT: Return the total number of available pages in a/x.
89 ; ------------------------------------------------------------------------
90 ; MAP: Map the page in a/x into memory and return a pointer to the page in
91 ; a/x. The contents of the currently mapped page (if any) may be discarded
95 MAP: sta curpage ; Remember the new page
111 jsr transfer ; Transfer one page
113 ; Return the memory window
116 ldx #>window ; Return the window address
122 ; ------------------------------------------------------------------------
123 ; USE: Tell the driver that the window is now associated with a given page.
125 USE: sta curpage ; Remember the page
127 ldx #>window ; Return the window
130 ; ------------------------------------------------------------------------
131 ; COMMIT: Commit changes in the memory window to extended storage.
133 COMMIT: lda curpage ; Get the current page
135 beq done ; Jump if no page mapped
153 ; Transfer one page/all bytes
173 ; ------------------------------------------------------------------------
174 ; COPYFROM: Copy from extended into linear memory. A pointer to a structure
175 ; describing the request is passed in a/x.
176 ; The function must not return anything.
181 stx ptr3+1 ; Save the passed em_copy pointer
200 common: ldy #EM_COPY::COUNT
201 lda (ptr3),y ; Get bytes in last page
204 lda (ptr3),y ; Get number of pages
209 ; ------------------------------------------------------------------------
210 ; COPYTO: Copy from linear into extended memory. A pointer to a structure
211 ; describing the request is passed in a/x.
212 ; The function must not return anything.
216 stx ptr3+1 ; Save the passed em_copy pointer