Merge pull request #605 from mrdudz/4playerfix

4playerfix
This commit is contained in:
Oliver Schmidt
2018-03-08 08:09:24 +00:00
committed by GitHub
2 changed files with 59 additions and 33 deletions

View File

@@ -73,13 +73,22 @@ UNINSTALL:
rts rts
; ------------------------------------------------------------------------ ; ------------------------------------------------------------------------
; IRQ entry point. Is called from the C layer as a subroutine in the ; COUNT: Return the total number of available joysticks in a/x.
; 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.
IRQ: ; cia 2 setup COUNT: lda #<JOY_COUNT
ldx #>JOY_COUNT
rts
; ------------------------------------------------------------------------
; READ: Read a particular joystick passed in A.
;
readadapter:
sei
; cia 2 setup
ldy #$00 ; port b direction ldy #$00 ; port b direction
sty $dd03 ; => input sty $dd03 ; => input
@@ -143,32 +152,24 @@ IRQ: ; cia 2 setup
sta temp4 sta temp4
fire: fire:
; Default Value: $40/64 on PAL ; FIXME: to be really 100% correct this should restore the correct timer
; $42/66 on NTSC ; values for the respective machine (PAL: $4025, NTSC: $4295)
; however, this should hardly be a problem in a real world program
lda #$41 lda #$41
sta $dc05 sta $dc05
; Default Value: $25/37 on PAL
; $95/149 on NTSC
lda #0 lda #0
sta $dc04 sta $dc04
; We do never "handle" the interrupt, we use it just as a timer. cli
clc
rts rts
; ------------------------------------------------------------------------ READ:
; COUNT: Return the total number of available joysticks in a/x. pha
; jsr readadapter
pla
COUNT: lda #<JOY_COUNT tax ; Joystick number into X
ldx #>JOY_COUNT
rts
; ------------------------------------------------------------------------
; READ: Read a particular joystick passed in A.
;
READ: tax ; Joystick number into X
bne joy2 bne joy2
; Read joystick 1 ; Read joystick 1
@@ -214,4 +215,3 @@ joy4: lda temp4
eor #$1F eor #$1F
ldx #0 ldx #0
rts rts

View File

@@ -5,7 +5,6 @@
#include <conio.h> #include <conio.h>
#include <joystick.h> #include <joystick.h>
#ifdef JOYSTICK_DRIVER #ifdef JOYSTICK_DRIVER
/* A statically linked driver was named on the compiler's command line. /* A statically linked driver was named on the compiler's command line.
@@ -13,6 +12,22 @@
*/ */
# undef DYN_DRV # undef DYN_DRV
# define DYN_DRV 0 # define DYN_DRV 0
/*
** link existing drivers like this:
**
** cl65 -DJOYSTICK_DRIVER=c64_hitjoy_joy -o joy-test.prg joy-test.c
**
** for testing a new driver you will have to uncomment the define below, and
** link your driver like this:
**
** co65 ../../target/c64/drv/joy/c64-hitjoy.joy -o hitjoy.s --code-label _hitjoy
** cl65 -DJOYSTICK_DRIVER=hitjoy -o joy-test.prg joy-test.c hitjoy.s
**
*/
/* extern char JOYSTICK_DRIVER; */
#else #else
/* Use a dynamically loaded driver, by default. */ /* Use a dynamically loaded driver, by default. */
@@ -27,13 +42,17 @@ int main (void)
unsigned char j; unsigned char j;
unsigned char count; unsigned char count;
unsigned char i; unsigned char i;
unsigned char Res;
unsigned char ch, kb;
clrscr ();
#if DYN_DRV #if DYN_DRV
unsigned char Res = joy_load_driver (joy_stddrv); Res = joy_load_driver (joy_stddrv);
#elif defined(JOYSTICK_DRIVER) #elif defined(JOYSTICK_DRIVER)
unsigned char Res = joy_install (&JOYSTICK_DRIVER); Res = joy_install (&JOYSTICK_DRIVER);
#else #else
unsigned char Res = joy_install (&joy_static_stddrv); Res = joy_install (&joy_static_stddrv);
#endif #endif
if (Res != JOY_ERR_OK) { if (Res != JOY_ERR_OK) {
@@ -44,7 +63,6 @@ int main (void)
exit (EXIT_FAILURE); exit (EXIT_FAILURE);
} }
clrscr ();
count = joy_count (); count = joy_count ();
#if defined(__ATARI5200__) || defined(__CREATIVISION__) #if defined(__ATARI5200__) || defined(__CREATIVISION__)
cprintf ("JOYSTICKS: %d", count); cprintf ("JOYSTICKS: %d", count);
@@ -56,23 +74,31 @@ int main (void)
gotoxy (0, i+1); gotoxy (0, i+1);
j = joy_read (i); j = joy_read (i);
#if defined(__ATARI5200__) || defined(__CREATIVISION__) #if defined(__ATARI5200__) || defined(__CREATIVISION__)
cprintf ("%1d:%-3s%-3s%-3s%-3s%-3s%-3s", cprintf ("%1d:%-3s%-3s%-3s%-3s%-3s %02x",
i, i,
JOY_UP(j)? " U " : " - ", JOY_UP(j)? " U " : " - ",
JOY_DOWN(j)? " D " : " - ", JOY_DOWN(j)? " D " : " - ",
JOY_LEFT(j)? " L " : " - ", JOY_LEFT(j)? " L " : " - ",
JOY_RIGHT(j)? " R " : " - ", JOY_RIGHT(j)? " R " : " - ",
JOY_BTN_1(j)? " 1 " : " - "); JOY_BTN_1(j)? " 1 " : " - ", j);
#else #else
cprintf ("%2d: %-6s%-6s%-6s%-6s%-6s%-6s", cprintf ("%2d: %-6s%-6s%-6s%-6s%-6s %02x",
i, i,
JOY_UP(j)? " up " : " ---- ", JOY_UP(j)? " up " : " ---- ",
JOY_DOWN(j)? " down " : " ---- ", JOY_DOWN(j)? " down " : " ---- ",
JOY_LEFT(j)? " left " : " ---- ", JOY_LEFT(j)? " left " : " ---- ",
JOY_RIGHT(j)? "right " : " ---- ", JOY_RIGHT(j)? "right " : " ---- ",
JOY_BTN_1(j)? "button" : " ---- "); JOY_BTN_1(j)? "button" : " ---- ", j);
#endif #endif
} }
/* show pressed key, so we can verify keyboard is working */
kb = kbhit ();
ch = kb ? cgetc () : ' ';
gotoxy (1, i+2);
revers (kb);
cprintf ("kbd: %c", ch);
revers (0);
} }
return 0; return 0;
} }