2 ; Ullrich von Bassewitz, 2002-12-20
4 ; Common functions of the joystick API.
10 .interruptor joy_irq ; Export as IRQ handler
12 .include "joy-kernel.inc"
13 .include "joy-error.inc"
16 ;----------------------------------------------------------------------------
21 _joy_drv: .res 2 ; Pointer to driver
23 _joy_masks: .res .sizeof(JOY_HDR::MASKS)
25 ; Jump table for the driver functions.
28 joy_install: jmp $0000
29 joy_uninstall: jmp $0000
32 joy_irq: .byte $60, $00, $00 ; RTS plus two dummy bytes
34 ; Driver header signature
36 joy_sig: .byte $6A, $6F, $79, JOY_API_VERSION ; "joy", version
39 ;----------------------------------------------------------------------------
40 ; unsigned char __fastcall__ joy_install (void* driver);
41 ; /* Install the driver once it is loaded */
50 ; Check the driver signature
52 ldy #.sizeof(joy_sig)-1
61 ldy #JOY_HDR::MASKS + .sizeof(JOY_HDR::MASKS) - 1
62 ldx #.sizeof(JOY_HDR::MASKS)-1
69 ; Copy the jump vectors
73 @L2: inx ; Skip the JMP opcode
74 jsr copy ; Copy one byte
75 jsr copy ; Copy one byte
76 cpy #(JOY_HDR::JUMPTAB + .sizeof(JOY_HDR::JUMPTAB))
79 jsr joy_install ; Call driver install routine
81 ; Install the IRQ vector if the driver needs it. A/X contains the error code
82 ; from joy_install, so don't use it.
84 ldy joy_irq+2 ; Check high byte of IRQ vector
85 beq @L3 ; Jump if vector invalid
87 sty joy_irq ; Activate IRQ routine
90 ; Driver signature invalid
93 lda #JOY_ERR_INV_DRIVER
97 ; Copy one byte from the jump vectors
101 set: sta joy_vectors,x
105 ;----------------------------------------------------------------------------
106 ; unsigned char __fastcall__ joy_uninstall (void);
107 ; /* Uninstall the currently loaded driver. Note: This call does not free
108 ; * allocated memory.
112 lda #$60 ; RTS opcode
113 sta joy_irq ; Disable IRQ entry point
115 jsr joy_uninstall ; Call the driver routine
117 joy_clear_ptr: ; External entry point
120 sta _joy_drv+1 ; Clear the driver pointer