2002-12-21 08:53:39 +00:00
|
|
|
;
|
2003-02-10 22:19:53 +00:00
|
|
|
; Standard joystick driver for the Plus/4. May be used multiple times when linked
|
|
|
|
; to the statically application.
|
2002-12-21 08:53:39 +00:00
|
|
|
;
|
|
|
|
; Ullrich von Bassewitz, 2002-12-21
|
|
|
|
;
|
|
|
|
|
|
|
|
.include "zeropage.inc"
|
|
|
|
|
|
|
|
.include "joy-kernel.inc"
|
|
|
|
.include "joy-error.inc"
|
2009-09-24 17:44:22 +00:00
|
|
|
.include "plus4.inc"
|
2002-12-21 08:53:39 +00:00
|
|
|
|
|
|
|
.macpack generic
|
|
|
|
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; Header. Includes jump table
|
|
|
|
|
|
|
|
.segment "JUMPTABLE"
|
|
|
|
|
|
|
|
; Driver signature
|
|
|
|
|
|
|
|
.byte $6A, $6F, $79 ; "joy"
|
2003-12-16 22:38:12 +00:00
|
|
|
.byte JOY_API_VERSION ; Driver API version number
|
2002-12-21 08:53:39 +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
|
2002-12-21 08:53:39 +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 0 ; IRQ entry unused
|
2002-12-21 08:53:39 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
2003-12-16 22:38:12 +00:00
|
|
|
; Constants
|
2002-12-21 08:53:39 +00:00
|
|
|
|
|
|
|
JOY_COUNT = 2 ; Number of joysticks we support
|
|
|
|
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; Data.
|
|
|
|
|
|
|
|
|
|
|
|
.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
|
2003-12-16 22:38:12 +00:00
|
|
|
; rts ; Run into UNINSTALL instead
|
2002-12-21 08:53:39 +00:00
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
2003-02-10 22:19:53 +00:00
|
|
|
; UNINSTALL routine. Is called before the driver is removed from memory.
|
2002-12-21 08:53:39 +00:00
|
|
|
; Can do cleanup or whatever. Must not return anything.
|
|
|
|
;
|
|
|
|
|
2003-02-10 22:19:53 +00:00
|
|
|
UNINSTALL:
|
2002-12-21 08:53:39 +00:00
|
|
|
rts
|
|
|
|
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; COUNT: Return the total number of available joysticks in a/x.
|
|
|
|
;
|
|
|
|
|
|
|
|
COUNT:
|
|
|
|
lda #<JOY_COUNT
|
|
|
|
ldx #>JOY_COUNT
|
|
|
|
rts
|
|
|
|
|
|
|
|
; ------------------------------------------------------------------------
|
|
|
|
; READ: Read a particular joystick passed in A.
|
|
|
|
;
|
|
|
|
|
|
|
|
READ: ldy #$FA ; Load index for joystick #1
|
|
|
|
tax ; Test joystick number
|
|
|
|
beq @L1
|
|
|
|
ldy #$FB ; Load index for joystick #2
|
|
|
|
@L1: sei
|
|
|
|
sty TED_KBD
|
|
|
|
lda TED_KBD
|
|
|
|
cli
|
|
|
|
ldx #$00 ; Clear high byte
|
|
|
|
and #$1F
|
|
|
|
eor #$1F
|
|
|
|
rts
|
|
|
|
|