2 ; DXS/HIT-4 Player joystick driver for the C64
4 ; Groepaz/Hitmen, 2002-12-23
5 ; obviously based on Ullrichs driver :)
8 .include "zeropage.inc"
10 .include "joy-kernel.inc"
11 .include "joy-error.inc"
18 ; ------------------------------------------------------------------------
19 ; Header. Includes jump table
21 module_header _c64_hitjoy_joy
25 .byte $6A, $6F, $79 ; "joy"
26 .byte JOY_API_VERSION ; Driver API version number
40 ; ------------------------------------------------------------------------
43 JOY_COUNT = 4 ; Number of joysticks we support
45 ; ------------------------------------------------------------------------
46 ; Data. Written in the IRQ, read by the READ routine
55 ; ------------------------------------------------------------------------
56 ; INSTALL routine. Is called after the driver is loaded into memory. If
57 ; possible, check if the hardware is present and determine the amount of
59 ; Must return an JOY_ERR_xx code in a/x.
66 ; rts ; Run into UNINSTALL instead
68 ; ------------------------------------------------------------------------
69 ; UNINSTALL routine. Is called before the driver is removed from memory.
70 ; Can do cleanup or whatever. Must not return anything.
76 ; ------------------------------------------------------------------------
77 ; IRQ entry point. Is called from the C layer as a subroutine in the
78 ; interrupt. The routine MUST return carry set if the interrupt has been
79 ; 'handled' - which means that the interrupt source is gone. Otherwise it
80 ; MUST return carry clear.
84 ldy #$00 ; port b direction
87 sty $dd05 ; cia2 timer a highbyte
88 sty $dc05 ; cia1 timer a highbyte
90 sty $dd04 ; cia2 timer a lowbyte
91 sty $dc04 ; cia1 timer a lowbyte
94 sta $dd0e ; control register a
102 sta $dc0e ; control register a
106 ; serial port: output
109 lda $dd01 ;read cia 2 port b
114 lda $dd02 ;cia 2 port a
115 and #%11111011 ;data direction
116 sta $dd02 ;=> bit 2 input
118 lda $dd00 ;read cia 2 p.A
119 and #%00000100 ;check bit 2
126 lda $dd01 ;read cia 2 port b
134 ldx #$ff ;serial data register
135 stx $dc0c ;=> writing $ff causes
137 ;count signals at cnt1
139 ldx $dd0c ;read cia 2 serial in
140 beq fire ;button press if zero
147 ; Default Value: $40/64 on PAL
151 ; Default Value: $25/37 on PAL
156 ; We do never "handle" the interrupt, we use it just as a timer.
160 ; ------------------------------------------------------------------------
161 ; COUNT: Return the total number of available joysticks in a/x.
164 COUNT: lda #<JOY_COUNT
168 ; ------------------------------------------------------------------------
169 ; READ: Read a particular joystick passed in A.
172 READ: tax ; Joystick number into X