2003-09-27 20:14:31 +00:00
|
|
|
;
|
|
|
|
; DXS/HIT-4 Player joystick driver for the C64
|
|
|
|
;
|
|
|
|
; Groepaz/Hitmen, 2002-12-23
|
|
|
|
; obviously based on Ullrichs driver :)
|
|
|
|
;
|
|
|
|
|
|
|
|
.include "zeropage.inc"
|
|
|
|
|
|
|
|
.include "joy-kernel.inc"
|
|
|
|
.include "joy-error.inc"
|
|
|
|
.include "c64.inc"
|
|
|
|
|
|
|
|
.macpack generic
|
2014-06-04 21:50:18 +00:00
|
|
|
.macpack module
|
|
|
|
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; Header. Includes jump table
|
|
|
|
|
2014-06-04 21:50:18 +00:00
|
|
|
module_header _c64_hitjoy_joy
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
; Driver signature
|
|
|
|
|
2013-05-09 11:56:54 +00:00
|
|
|
.byte $6A, $6F, $79 ; "joy"
|
|
|
|
.byte JOY_API_VERSION ; Driver API version number
|
2003-09-27 20:14:31 +00:00
|
|
|
|
2013-05-31 22:36:08 +00:00
|
|
|
; Library reference
|
|
|
|
|
|
|
|
.addr $0000
|
|
|
|
|
2003-09-27 20:14:31 +00:00
|
|
|
; Button state masks (8 values)
|
|
|
|
|
|
|
|
.byte $01 ; JOY_UP
|
|
|
|
.byte $02 ; JOY_DOWN
|
|
|
|
.byte $04 ; JOY_LEFT
|
|
|
|
.byte $08 ; JOY_RIGHT
|
|
|
|
.byte $10 ; JOY_FIRE
|
2004-11-06 13:27:38 +00:00
|
|
|
.byte $00 ; JOY_FIRE2 unavailable
|
2003-09-27 20:14:31 +00:00
|
|
|
.byte $00 ; Future expansion
|
|
|
|
.byte $00 ; Future expansion
|
|
|
|
|
|
|
|
; Jump table.
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
.addr INSTALL
|
|
|
|
.addr UNINSTALL
|
|
|
|
.addr COUNT
|
|
|
|
.addr READ
|
|
|
|
.addr IRQ
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; Constants
|
|
|
|
|
|
|
|
JOY_COUNT = 4 ; Number of joysticks we support
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; Data. Written in the IRQ, read by the READ routine
|
|
|
|
|
|
|
|
.bss
|
|
|
|
|
2013-05-09 11:56:54 +00:00
|
|
|
temp3: .byte 0
|
|
|
|
temp4: .byte 0
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
.code
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; INSTALL routine. Is called after the driver is loaded into memory. If
|
|
|
|
; possible, check if the hardware is present and determine the amount of
|
|
|
|
; memory available.
|
|
|
|
; Must return an JOY_ERR_xx code in a/x.
|
|
|
|
;
|
|
|
|
|
|
|
|
INSTALL:
|
|
|
|
lda #<JOY_ERR_OK
|
|
|
|
ldx #>JOY_ERR_OK
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
; rts ; Run into UNINSTALL instead
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
2004-11-06 13:27:38 +00:00
|
|
|
; UNINSTALL routine. Is called before the driver is removed from memory.
|
2003-09-27 20:14:31 +00:00
|
|
|
; Can do cleanup or whatever. Must not return anything.
|
|
|
|
;
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
UNINSTALL:
|
2003-09-27 20:14:31 +00:00
|
|
|
rts
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
2005-04-25 20:10:10 +00:00
|
|
|
; IRQ entry point. Is called from the C layer as a subroutine in the
|
|
|
|
; interrupt. The routine MUST return carry set if the interrupt has been
|
|
|
|
; 'handled' - which means that the interrupt source is gone. Otherwise it
|
|
|
|
; MUST return carry clear.
|
2004-11-06 13:27:38 +00:00
|
|
|
|
|
|
|
IRQ: ; cia 2 setup
|
|
|
|
|
|
|
|
ldy #$00 ; port b direction
|
|
|
|
sty $dd03 ; => input
|
|
|
|
|
|
|
|
sty $dd05 ; cia2 timer a highbyte
|
|
|
|
sty $dc05 ; cia1 timer a highbyte
|
|
|
|
iny
|
|
|
|
sty $dd04 ; cia2 timer a lowbyte
|
|
|
|
sty $dc04 ; cia1 timer a lowbyte
|
|
|
|
|
|
|
|
lda #%00010001
|
|
|
|
sta $dd0e ; control register a
|
|
|
|
; timer: start
|
|
|
|
; continous
|
|
|
|
; forced load
|
|
|
|
; serial port: input
|
|
|
|
|
|
|
|
; cia 1 setup
|
|
|
|
lda #%01010001
|
|
|
|
sta $dc0e ; control register a
|
|
|
|
; timer: start
|
|
|
|
; continous
|
|
|
|
; forced load
|
|
|
|
; serial port: output
|
|
|
|
|
|
|
|
; read directions 3
|
|
|
|
lda $dd01 ;read cia 2 port b
|
|
|
|
and #$0f
|
|
|
|
sta temp3
|
|
|
|
|
|
|
|
; read button 3
|
|
|
|
lda $dd02 ;cia 2 port a
|
|
|
|
and #%11111011 ;data direction
|
|
|
|
sta $dd02 ;=> bit 2 input
|
|
|
|
|
|
|
|
lda $dd00 ;read cia 2 p.A
|
|
|
|
and #%00000100 ;check bit 2
|
|
|
|
asl a
|
|
|
|
asl a
|
|
|
|
ora temp3
|
|
|
|
sta temp3
|
|
|
|
|
|
|
|
; read directions 4
|
|
|
|
lda $dd01 ;read cia 2 port b
|
|
|
|
lsr a
|
|
|
|
lsr a
|
|
|
|
lsr a
|
|
|
|
lsr a
|
|
|
|
sta temp4
|
|
|
|
|
|
|
|
; read button 4
|
|
|
|
ldx #$ff ;serial data register
|
|
|
|
stx $dc0c ;=> writing $ff causes
|
|
|
|
;cia to output some
|
|
|
|
;count signals at cnt1
|
|
|
|
|
|
|
|
ldx $dd0c ;read cia 2 serial in
|
|
|
|
beq fire ;button press if zero
|
|
|
|
|
|
|
|
lda temp4
|
|
|
|
ora #%00010000
|
|
|
|
sta temp4
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
fire:
|
2004-11-06 13:27:38 +00:00
|
|
|
; Default Value: $40/64 on PAL
|
|
|
|
; $42/66 on NTSC
|
|
|
|
lda #$41
|
|
|
|
sta $dc05
|
|
|
|
; Default Value: $25/37 on PAL
|
|
|
|
; $95/149 on NTSC
|
|
|
|
lda #0
|
|
|
|
sta $dc04
|
2003-09-27 20:14:31 +00:00
|
|
|
|
2005-04-25 20:10:10 +00:00
|
|
|
; We do never "handle" the interrupt, we use it just as a timer.
|
|
|
|
clc
|
2004-11-06 13:27:38 +00:00
|
|
|
rts
|
2003-09-27 20:14:31 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; COUNT: Return the total number of available joysticks in a/x.
|
|
|
|
;
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
COUNT: lda #<JOY_COUNT
|
2003-09-27 20:14:31 +00:00
|
|
|
ldx #>JOY_COUNT
|
|
|
|
rts
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; READ: Read a particular joystick passed in A.
|
|
|
|
;
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
READ: tax ; Joystick number into X
|
2003-09-27 20:14:31 +00:00
|
|
|
bne joy2
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
; Read joystick 1
|
|
|
|
|
|
|
|
joy1: lda #$7F
|
2003-09-27 20:14:31 +00:00
|
|
|
sei
|
|
|
|
sta CIA1_PRA
|
|
|
|
lda CIA1_PRB
|
|
|
|
cli
|
|
|
|
and #$1F
|
|
|
|
eor #$1F
|
|
|
|
rts
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
; Read joystick 2
|
|
|
|
|
|
|
|
joy2: dex
|
2003-09-27 20:14:31 +00:00
|
|
|
bne joy3
|
|
|
|
|
2013-05-09 11:56:54 +00:00
|
|
|
; ldx #0
|
|
|
|
lda #$E0
|
|
|
|
ldy #$FF
|
2003-09-27 20:14:31 +00:00
|
|
|
sei
|
2013-05-09 11:56:54 +00:00
|
|
|
sta CIA1_DDRA
|
|
|
|
lda CIA1_PRA
|
|
|
|
sty CIA1_DDRA
|
2003-09-27 20:14:31 +00:00
|
|
|
cli
|
2013-05-09 11:56:54 +00:00
|
|
|
and #$1F
|
|
|
|
eor #$1F
|
2003-09-27 20:14:31 +00:00
|
|
|
rts
|
|
|
|
|
|
|
|
; Read joystick 3
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
joy3: dex
|
|
|
|
bne joy4
|
2003-09-27 20:14:31 +00:00
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
lda temp3
|
2013-05-09 11:56:54 +00:00
|
|
|
eor #$1F
|
2003-09-27 20:14:31 +00:00
|
|
|
rts
|
|
|
|
|
|
|
|
; Read joystick 4
|
|
|
|
|
2004-11-06 13:27:38 +00:00
|
|
|
joy4: lda temp4
|
2013-05-09 11:56:54 +00:00
|
|
|
eor #$1F
|
2004-11-06 13:27:38 +00:00
|
|
|
ldx #0
|
2003-09-27 20:14:31 +00:00
|
|
|
rts
|
|
|
|
|