mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
Merge pull request #634 from blackystardust/master
Added C65/C64DX accelerator code and documentation.
This commit is contained in:
commit
5c07db3a74
@ -60,3 +60,12 @@ CHAMELEON_DISABLE_REGS = $FF
|
|||||||
CHAMELEON_CFGTUR_LIMIT_1MHZ = %00001100
|
CHAMELEON_CFGTUR_LIMIT_1MHZ = %00001100
|
||||||
CHAMELEON_CFGTUR_LIMIT_NONE = %10000000
|
CHAMELEON_CFGTUR_LIMIT_NONE = %10000000
|
||||||
|
|
||||||
|
|
||||||
|
; ---------------------------------------------------------------------------
|
||||||
|
; C65/C64DX in C64 mode
|
||||||
|
|
||||||
|
C65_VICIII_KEY := $D02F
|
||||||
|
C65_VICIII_CTRL_B := $D031
|
||||||
|
|
||||||
|
C65_VICIII_UNLOCK_1 = $A5
|
||||||
|
C65_VICIII_UNLOCK_2 = $96
|
||||||
|
@ -177,14 +177,17 @@ url="funcref.html" name="function reference"> for declaration and usage.
|
|||||||
<itemize>
|
<itemize>
|
||||||
<item>detect_c128
|
<item>detect_c128
|
||||||
<item>detect_c64dtv
|
<item>detect_c64dtv
|
||||||
|
<item>detect_c65
|
||||||
<item>detect_chameleon
|
<item>detect_chameleon
|
||||||
<item>detect_scpu
|
<item>detect_scpu
|
||||||
<item>get_c128_speed
|
<item>get_c128_speed
|
||||||
<item>get_c64dtv_speed
|
<item>get_c64dtv_speed
|
||||||
|
<item>get_c65_speed
|
||||||
<item>get_chameleon_speed
|
<item>get_chameleon_speed
|
||||||
<item>get_scpu_speed
|
<item>get_scpu_speed
|
||||||
<item>set_c128_speed
|
<item>set_c128_speed
|
||||||
<item>set_c64dtv_speed
|
<item>set_c64dtv_speed
|
||||||
|
<item>set_c65_speed
|
||||||
<item>set_chameleon_speed
|
<item>set_chameleon_speed
|
||||||
<item>set_scpu_speed
|
<item>set_scpu_speed
|
||||||
</itemize>
|
</itemize>
|
||||||
|
@ -70,14 +70,17 @@ function.
|
|||||||
<itemize>
|
<itemize>
|
||||||
<item><ref id="detect_c128" name="detect_c128">
|
<item><ref id="detect_c128" name="detect_c128">
|
||||||
<item><ref id="detect_c64dtv" name="detect_c64dtv">
|
<item><ref id="detect_c64dtv" name="detect_c64dtv">
|
||||||
|
<item><ref id="detect_c65" name="detect_c65">
|
||||||
<item><ref id="detect_chameleon" name="detect_chameleon">
|
<item><ref id="detect_chameleon" name="detect_chameleon">
|
||||||
<item><ref id="detect_scpu" name="detect_scpu">
|
<item><ref id="detect_scpu" name="detect_scpu">
|
||||||
<item><ref id="get_c128_speed" name="get_c128_speed">
|
<item><ref id="get_c128_speed" name="get_c128_speed">
|
||||||
<item><ref id="get_c64dtv_speed" name="get_c64dtv_speed">
|
<item><ref id="get_c64dtv_speed" name="get_c64dtv_speed">
|
||||||
|
<item><ref id="get_c65_speed" name="get_c65_speed">
|
||||||
<item><ref id="get_chameleon_speed" name="get_chameleon_speed">
|
<item><ref id="get_chameleon_speed" name="get_chameleon_speed">
|
||||||
<item><ref id="get_scpu_speed" name="get_scpu_speed">
|
<item><ref id="get_scpu_speed" name="get_scpu_speed">
|
||||||
<item><ref id="set_c128_speed" name="set_c128_speed">
|
<item><ref id="set_c128_speed" name="set_c128_speed">
|
||||||
<item><ref id="set_c64dtv_speed" name="set_c64dtv_speed">
|
<item><ref id="set_c64dtv_speed" name="set_c64dtv_speed">
|
||||||
|
<item><ref id="set_c65_speed" name="set_c65_speed">
|
||||||
<item><ref id="set_chameleon_speed" name="set_chameleon_speed">
|
<item><ref id="set_chameleon_speed" name="set_chameleon_speed">
|
||||||
<item><ref id="set_scpu_speed" name="set_scpu_speed">
|
<item><ref id="set_scpu_speed" name="set_scpu_speed">
|
||||||
</itemize>
|
</itemize>
|
||||||
@ -2969,6 +2972,26 @@ used in presence of a prototype.
|
|||||||
</quote>
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
|
<sect1>detect_c65<label id="detect_c65"><p>
|
||||||
|
|
||||||
|
<quote>
|
||||||
|
<descrip>
|
||||||
|
<tag/Function/Check for the presence of a C65/C64DX in C64 mode.
|
||||||
|
<tag/Header/<tt/<ref id="accelerator.h" name="accelerator.h">/
|
||||||
|
<tag/Declaration/<tt/unsigned char detect_c65 (void);/
|
||||||
|
<tag/Description/The function returns a 1 if a C65/C64DX in C64 mode has been detected.
|
||||||
|
<tag/Notes/<itemize>
|
||||||
|
<item>The function is specific to the C64.
|
||||||
|
</itemize>
|
||||||
|
<tag/Availability/cc65 (not all platforms)
|
||||||
|
<tag/See also/
|
||||||
|
<ref id="get_c65_speed" name="get_c65_speed">,
|
||||||
|
<ref id="set_c65_speed" name="set_c65_speed">,
|
||||||
|
<tag/Example/None.
|
||||||
|
</descrip>
|
||||||
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
<sect1>detect_chameleon<label id="detect_chameleon"><p>
|
<sect1>detect_chameleon<label id="detect_chameleon"><p>
|
||||||
|
|
||||||
<quote>
|
<quote>
|
||||||
@ -3592,6 +3615,28 @@ header files define constants that can be used to check the return code.
|
|||||||
</quote>
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
|
<sect1>get_c65_speed<label id="get_c65_speed"><p>
|
||||||
|
|
||||||
|
<quote>
|
||||||
|
<descrip>
|
||||||
|
<tag/Function/Get the current speed of the C65/C64DX in C64 mode.
|
||||||
|
<tag/Header/<tt/<ref id="accelerator.h" name="accelerator.h">/
|
||||||
|
<tag/Declaration/<tt/unsigned char get_c65_speed (void);/
|
||||||
|
<tag/Description/The function returns the current speed of the C65/C64DX in C64 mode.
|
||||||
|
<tag/Notes/<itemize>
|
||||||
|
<item>The function is specific to the C64.
|
||||||
|
<item>The function does not check for the presence of a C65/C64DX in C64 mode.
|
||||||
|
<item>See the accelerator.h header for the speed definitions.
|
||||||
|
</itemize>
|
||||||
|
<tag/Availability/cc65 (not all platforms)
|
||||||
|
<tag/See also/
|
||||||
|
<ref id="detect_c65" name="detect_c65">,
|
||||||
|
<ref id="set_c65_speed" name="set_c65_speed">,
|
||||||
|
<tag/Example/None.
|
||||||
|
</descrip>
|
||||||
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
<sect1>get_chameleon_speed<label id="get_chameleon_speed"><p>
|
<sect1>get_chameleon_speed<label id="get_chameleon_speed"><p>
|
||||||
|
|
||||||
<quote>
|
<quote>
|
||||||
@ -6231,6 +6276,28 @@ clean-up when exitting the program.
|
|||||||
</quote>
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
|
<sect1>set_c65_speed<label id="set_c65_speed"><p>
|
||||||
|
|
||||||
|
<quote>
|
||||||
|
<descrip>
|
||||||
|
<tag/Function/Set the current speed of the C65/C64DX in C64 mode.
|
||||||
|
<tag/Header/<tt/<ref id="accelerator.h" name="accelerator.h">/
|
||||||
|
<tag/Declaration/<tt/unsigned char __fastcall__ set_c65_speed (unsigned char speed);/
|
||||||
|
<tag/Description/The function returns the speed after trying to set the speed of the C65/C64DX in C64 mode.
|
||||||
|
<tag/Notes/<itemize>
|
||||||
|
<item>The function is specific to the C64.
|
||||||
|
<item>The function does not check for the presence of a C65/C64DX in C64 mode.
|
||||||
|
<item>See the accelerator.h header for the speed definitions.
|
||||||
|
</itemize>
|
||||||
|
<tag/Availability/cc65 (not all platforms)
|
||||||
|
<tag/See also/
|
||||||
|
<ref id="detect_c65" name="detect_c65">,
|
||||||
|
<ref id="get_c65_speed" name="get_c65_speed">,
|
||||||
|
<tag/Example/None.
|
||||||
|
</descrip>
|
||||||
|
</quote>
|
||||||
|
|
||||||
|
|
||||||
<sect1>set_chameleon_speed<label id="set_chameleon_speed"><p>
|
<sect1>set_chameleon_speed<label id="set_chameleon_speed"><p>
|
||||||
|
|
||||||
<quote>
|
<quote>
|
||||||
|
@ -226,6 +226,43 @@ unsigned char detect_chameleon (void);
|
|||||||
* 0x01 : C64 Chameleon cartridge present
|
* 0x01 : C64 Chameleon cartridge present
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* C65/C64DX in C64 mode */
|
||||||
|
|
||||||
|
unsigned char __fastcall__ set_c65_speed (unsigned char speed);
|
||||||
|
|
||||||
|
/* Set the speed of the C65/C64DX CPU, using SPEED_SLOW will switch to
|
||||||
|
* 1 Mhz mode, SPEED_3X or SPEED_FAST will switch to 3.5 Mhz (fast) mode.
|
||||||
|
*
|
||||||
|
* Note that any value higher or equal to SPEED_3X will switch to fast mode.
|
||||||
|
*
|
||||||
|
* This function will return the actual speed the CPU is at after trying
|
||||||
|
* to set the requested speed, to my knowledge the switching should not fail.
|
||||||
|
*
|
||||||
|
* This function does not check for the presence of a C65/C64DX in C64 mode,
|
||||||
|
* make sure you use 'detect_c65();' before using.
|
||||||
|
*/
|
||||||
|
|
||||||
|
unsigned char get_c65_speed (void);
|
||||||
|
|
||||||
|
/* Get the speed of the C65/C64DX CPU.
|
||||||
|
*
|
||||||
|
* Possible return values:
|
||||||
|
* SPEED_SLOW : Slow mode
|
||||||
|
* SPEED_3X : Fast mode
|
||||||
|
*
|
||||||
|
* This function does not check for the presence of a C65/C64DX in C64 mode,
|
||||||
|
* make sure you use 'detect_c65();' before using.
|
||||||
|
*/
|
||||||
|
|
||||||
|
unsigned char detect_c65 (void);
|
||||||
|
|
||||||
|
/* Check for the presence of a C65/C64DX in C64 mode.
|
||||||
|
*
|
||||||
|
* Possible return values:
|
||||||
|
* 0x00 : C65/C64DX in C64 mode not present
|
||||||
|
* 0x01 : C65/C64DX in C64 mode present
|
||||||
|
*/
|
||||||
/* End of accelerator.h */
|
/* End of accelerator.h */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
69
libsrc/c64/acc_c65_speed.s
Executable file
69
libsrc/c64/acc_c65_speed.s
Executable file
@ -0,0 +1,69 @@
|
|||||||
|
;
|
||||||
|
; Marco van den Heuvel, 2018-04-27
|
||||||
|
;
|
||||||
|
|
||||||
|
; unsigned char __fastcall__ set_c65_speed (unsigned char speed);
|
||||||
|
;
|
||||||
|
;/* Set the speed of the C65 CPU, using SPEED_SLOW will switch to
|
||||||
|
; * 1 Mhz mode, SPEED_3X or SPEED_FAST will switch to 3.5 Mhz (fast) mode.
|
||||||
|
; *
|
||||||
|
; * Note that any value higher or equal to SPEED_3X will switch to fast mode.
|
||||||
|
; *
|
||||||
|
; * This function will return the actual speed the CPU is at after trying
|
||||||
|
; * to set the requested speed, to my knowledge the switching should not fail.
|
||||||
|
; *
|
||||||
|
; * This function does not check for the presence of a C65/C64DX in C64 mode,
|
||||||
|
; * make sure you use 'detect_c65();' before using.
|
||||||
|
; */
|
||||||
|
|
||||||
|
; unsigned char get_c65_speed (void);
|
||||||
|
;
|
||||||
|
;/* Get the speed of the C65 CPU.
|
||||||
|
; *
|
||||||
|
; * Possible return values:
|
||||||
|
; * SPEED_SLOW : 1 Mhz mode
|
||||||
|
; * SPEED_3X : 3.5 Mhz mode
|
||||||
|
; *
|
||||||
|
; * This function does not check for the presence of a C65/C64DX in C64 mode,
|
||||||
|
; * make sure you use 'detect_c65();' before using.
|
||||||
|
; */
|
||||||
|
|
||||||
|
.export _set_c65_speed
|
||||||
|
.export _get_c65_speed
|
||||||
|
|
||||||
|
.include "accelerator.inc"
|
||||||
|
|
||||||
|
_set_c65_speed:
|
||||||
|
tay
|
||||||
|
jsr activate_new_vic_mode
|
||||||
|
cpy #SPEED_3X
|
||||||
|
bcs high_speed
|
||||||
|
low_speed:
|
||||||
|
and #$BF
|
||||||
|
store_speed:
|
||||||
|
sta C65_VICIII_CTRL_B
|
||||||
|
lda C65_VICIII_CTRL_B
|
||||||
|
jmp return_c65_speed
|
||||||
|
|
||||||
|
high_speed:
|
||||||
|
ora #$40
|
||||||
|
bne store_speed
|
||||||
|
|
||||||
|
_get_c65_speed:
|
||||||
|
jsr activate_new_vic_mode
|
||||||
|
return_c65_speed:
|
||||||
|
sta C65_VICIII_KEY
|
||||||
|
and #$40
|
||||||
|
beq speed_is_slow ; when this branch is taken then register A is already set to SPEED_SLOW
|
||||||
|
lda #SPEED_3X
|
||||||
|
speed_is_slow:
|
||||||
|
ldx #$00
|
||||||
|
rts
|
||||||
|
|
||||||
|
activate_new_vic_mode:
|
||||||
|
lda #C65_VICIII_UNLOCK_1
|
||||||
|
sta C65_VICIII_KEY
|
||||||
|
lda #C65_VICIII_UNLOCK_2
|
||||||
|
sta C65_VICIII_KEY
|
||||||
|
lda C65_VICIII_CTRL_B
|
||||||
|
rts
|
55
libsrc/c64/acc_detect_c65.s
Executable file
55
libsrc/c64/acc_detect_c65.s
Executable file
@ -0,0 +1,55 @@
|
|||||||
|
;
|
||||||
|
; Marco van den Heuvel, 2018-04-27
|
||||||
|
;
|
||||||
|
|
||||||
|
; unsigned char detect_c65 (void);
|
||||||
|
;
|
||||||
|
;/* Check for the presence of a C65/C64DX in C64 mode.
|
||||||
|
; *
|
||||||
|
; * Possible return values:
|
||||||
|
; * 0x00 : C65/C64DX in C64 mode not present
|
||||||
|
; * 0x01 : C65/C64DX in C64 mode present
|
||||||
|
; */
|
||||||
|
|
||||||
|
.export _detect_c65
|
||||||
|
|
||||||
|
.include "accelerator.inc"
|
||||||
|
|
||||||
|
_detect_c65:
|
||||||
|
ldy $D000
|
||||||
|
|
||||||
|
; Make sure the CPU is not a 65816
|
||||||
|
clc
|
||||||
|
.byte $E2,$01 ; NOP #$01 on 6510 and 65(S)C02, LDA $(01,S),Y on 65CE02 and 4510, SEP #$01 on 65816
|
||||||
|
lda #$00
|
||||||
|
tax
|
||||||
|
bcs not_found ; carry will be set on 65816
|
||||||
|
|
||||||
|
; Make sure the CPU is not a 6510
|
||||||
|
.byte $1A ; NOP on 6510, INA on 65(S)C(E)02
|
||||||
|
beq not_found
|
||||||
|
txa
|
||||||
|
|
||||||
|
; Make sure the CPU is a 65CE02/4510
|
||||||
|
.byte $A3,$A3 ; NOP NOP on 65(S)C02, LDZ #$A3 on 65CE02 and 4510
|
||||||
|
.byte $6B ; NOP on 65(S)C02, TZA on 65CE02 and 4510
|
||||||
|
cmp #$A3
|
||||||
|
bne not_found
|
||||||
|
|
||||||
|
; Switch to VICIII mode and check if $D040 is a mirror of $D000
|
||||||
|
ldy #C65_VICIII_UNLOCK_1
|
||||||
|
sty C65_VICIII_KEY
|
||||||
|
ldy #C65_VICIII_UNLOCK_2
|
||||||
|
sty C65_VICIII_KEY
|
||||||
|
cpy $D040
|
||||||
|
bne found
|
||||||
|
inc $D000
|
||||||
|
cpy $D040
|
||||||
|
bne not_found
|
||||||
|
|
||||||
|
found:
|
||||||
|
lda #$01
|
||||||
|
not_found:
|
||||||
|
sty $D000
|
||||||
|
sta C65_VICIII_KEY
|
||||||
|
rts
|
@ -1,7 +1,8 @@
|
|||||||
CL ?= cl65
|
CL ?= cl65
|
||||||
|
|
||||||
all: c64-scpu-test.prg c128-scpu-test.prg c64dtv-test.prg \
|
all: c64-scpu-test.prg c128-scpu-test.prg c64dtv-test.prg \
|
||||||
c64-c128-test.prg c128-test.prg chameleon-test.prg
|
c64-c128-test.prg c128-test.prg chameleon-test.prg \
|
||||||
|
c65-test.prg
|
||||||
|
|
||||||
c64-scpu-test.prg: c64-c128-scpu-test.c
|
c64-scpu-test.prg: c64-c128-scpu-test.c
|
||||||
$(CL) -t c64 c64-c128-scpu-test.c -o c64-scpu-test.prg
|
$(CL) -t c64 c64-c128-scpu-test.c -o c64-scpu-test.prg
|
||||||
@ -20,3 +21,6 @@ c128-test.prg: c64-c128-test.c
|
|||||||
|
|
||||||
chameleon-test.prg: chameleon-test.c
|
chameleon-test.prg: chameleon-test.c
|
||||||
$(CL) -t c64 chameleon-test.c -o chameleon-test.prg
|
$(CL) -t c64 chameleon-test.c -o chameleon-test.prg
|
||||||
|
|
||||||
|
c65-test.prg: c65-test.c
|
||||||
|
$(CL) -t c64 c65-test.c -o c65-test.prg
|
||||||
|
8
testcode/lib/accelerator/c65-test.c
Normal file
8
testcode/lib/accelerator/c65-test.c
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
/* C65/C64DX in C64 mode accelerator test code. */
|
||||||
|
|
||||||
|
#define ACC_DETECT detect_c65
|
||||||
|
#define ACC_GET_SPEED get_c65_speed
|
||||||
|
#define ACC_SET_SPEED set_c65_speed
|
||||||
|
#define ACC_NAME "C65"
|
||||||
|
|
||||||
|
#include "turbo-test.c"
|
Loading…
x
Reference in New Issue
Block a user