From 6076316f38a6d72081f6b90998ced0b7b7abe209 Mon Sep 17 00:00:00 2001 From: Marco van den Heuvel Date: Sat, 14 Apr 2018 10:40:13 -0700 Subject: [PATCH 1/5] Added c64dtv accelerator code and documentation. --- asminc/accelerator.inc | 8 +++ doc/c64.sgml | 7 ++- doc/funcref.sgml | 67 ++++++++++++++++++++++++++ include/accelerator.h | 38 +++++++++++++++ libsrc/c64/acc_c64dtv_speed.s | 64 ++++++++++++++++++++++++ libsrc/c64/acc_detect_c64dtv.s | 43 +++++++++++++++++ testcode/lib/accelerator/Makefile | 6 ++- testcode/lib/accelerator/c64dtv-test.c | 8 +++ 8 files changed, 238 insertions(+), 3 deletions(-) create mode 100755 libsrc/c64/acc_c64dtv_speed.s create mode 100755 libsrc/c64/acc_detect_c64dtv.s create mode 100755 testcode/lib/accelerator/c64dtv-test.c diff --git a/asminc/accelerator.inc b/asminc/accelerator.inc index f86ce8b2d..1008b49c1 100644 --- a/asminc/accelerator.inc +++ b/asminc/accelerator.inc @@ -32,3 +32,11 @@ SuperCPU_Fast := $D07B SuperCPU_Speed_Mode := $D0B8 SuperCPU_Detect := $D0BC + +; --------------------------------------------------------------------------- +; C64DTV + +C64DTV_Extended_Regs := $D03F + +C64DTV_Slow = $00 +C64DTV_Fast = $03 diff --git a/doc/c64.sgml b/doc/c64.sgml index 05b87a22b..f1e678c72 100644 --- a/doc/c64.sgml +++ b/doc/c64.sgml @@ -175,9 +175,12 @@ The functions listed below are accelerator functions for the C64. See the for declaration and usage. +detect_c64dtv detect_scpu -scpu_get_speed -scpu_set_speed +get_c64dtv_speed +get_scpu_speed +set_c64dtv_speed +set_scpu_speed diff --git a/doc/funcref.sgml b/doc/funcref.sgml index e47a0c0a9..4dfbf29e0 100644 --- a/doc/funcref.sgml +++ b/doc/funcref.sgml @@ -68,8 +68,11 @@ function.

+ + + @@ -2920,6 +2923,26 @@ used in presence of a prototype. +detect_c64dtv

+ + + +/ + +The function is specific to the C64. + +, +, + + + + detect_scpu

@@ -3479,6 +3502,28 @@ header files define constants that can be used to check the return code. +get_c64dtv_speed

+ + + +/ + +The function is specific to the C64. +The function does not check for the presence of the cartridge. +See the accelerator.h header for the speed definitions. + +, +, + + + + get_scpu_speed

@@ -6052,6 +6097,28 @@ clean-up when exitting the program. +set_c64dtv_speed

+ + + +/ + +The function is specific to the C64. +The function does not check for the presence of the C64DTV. +See the accelerator.h header for the speed definitions. + +, +, + + + + set_scpu_speed

diff --git a/include/accelerator.h b/include/accelerator.h index 7d1244233..336bbb036 100644 --- a/include/accelerator.h +++ b/include/accelerator.h @@ -98,5 +98,43 @@ extern unsigned char detect_scpu (void); * 0x01 : SuperCPU cartridge present */ + +/* C64DTV */ + +extern unsigned char __fastcall__ set_c64dtv_speed (unsigned char speed); + +/* Set the speed of the C64DTV, using SPEED_SLOW will switch to + * slow mode, SPEED_2X or SPEED_FAST will switch to fast mode. + * + * Note that any value higher or equal to SPEED_2X 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 switch should not fail. + * + * This function does not check for the presence of the C64DTV, + * make sure you use 'detect_c64dtv();' before using. + */ + +extern unsigned char get_c64dtv_speed (void); + +/* Get the speed of the C64DTV. + * + * Possible return values: + * SPEED_1X : slow mode + * SPEED_2X : fast mode + * + * This function does not check for the presence of the C64DTV, + * make sure you use 'detect_c64dtv();' before using. + */ + +extern unsigned char detect_c64dtv (void); + +/* Check for the presence of the C64DTV. + * + * Possible return values: + * 0x00 : C64DTV not present + * 0x01 : C64DTV present + */ + /* End of accelerator.h */ #endif diff --git a/libsrc/c64/acc_c64dtv_speed.s b/libsrc/c64/acc_c64dtv_speed.s new file mode 100755 index 000000000..9cf49673e --- /dev/null +++ b/libsrc/c64/acc_c64dtv_speed.s @@ -0,0 +1,64 @@ +; +; Marco van den Heuvel, 2018-04-14 +; + +; extern unsigned char __fastcall__ set_c64dtv_speed (unsigned char speed); +; +;/* Set the speed of the C64DTV, using SPEED_SLOW will switch to +; * slow mode, SPEED_2X or SPEED_FAST will switch to fast mode. +; * +; * Note that any value higher or equal to SPEED_2X 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 this should not happen. +; * +; * This function does not check for the presence of the C64DTV, +; * make sure you use 'detect_c64dtv();' before using. +; */ + +; extern unsigned char get_c64dtv_speed (void); +; +;/* Get the speed of the C64DTV. +; * +; * Possible return values: +; * SPEED_1X : slow mode +; * SPEED_2X : fast mode +; * +; * This function does not check for the presence of the C64DTV, +; * make sure you use 'detect_c64dtv();' before using. +; */ + + .export _set_c64dtv_speed + .export _get_c64dtv_speed + + .include "accelerator.inc" + +_set_c64dtv_speed: + cmp #SPEED_2X + bcs high_speed +low_speed: + ldx #C64DTV_Slow +set_speed: + .byte $32,$99 ; SAC #$99 set accumulator to reg 9 (cpu control) + txa ; (re)set skip and burst bits + .byte $32,$00 ; SAC #$99 set accumulator back to reg 0 + jmp _get_c64dtv_speed + +high_speed: + ldx #C64DTV_Fast + bne set_speed + + +_get_c64dtv_speed: + .byte $32,$99 ; SAC #$99 set accumulator to reg 9 (cpu control) + tax + .byte $32,$00 ; SAC #$99 set accumulator back to reg 0 + txa + and #C64DTV_Fast + bne in_fast_mode + lda #$00 + .byte $2C +in_fast_mode: + lda #$01 + ldx #$00 + rts diff --git a/libsrc/c64/acc_detect_c64dtv.s b/libsrc/c64/acc_detect_c64dtv.s new file mode 100755 index 000000000..ce30806db --- /dev/null +++ b/libsrc/c64/acc_detect_c64dtv.s @@ -0,0 +1,43 @@ +; +; Marco van den Heuvel, 2018-04-14 +; + +; unsigned char detect_c64dtv (void); +; +;/* Check for the presence of the C64DTV. +; * +; * Possible return values: +; * 0x00 : C64DTV not present +; * 0x01 : C64DTV present +; */ + + .export _detect_c64dtv + + .include "accelerator.inc" + +_detect_c64dtv: + ldy C64DTV_Extended_Regs + lda #$00 + tax + +; Make sure the CPU is a 6510 + .byte $1A ; NOP on 8502, INA on 65(S)C(E)02, 4510 and 65816 + bne not_found + lda #$01 + sta C64DTV_Extended_Regs + +; Check if $D000 is mirrored at $D040 + lda $D040 + cmp $D000 + bne found + inc $D040 + cmp $D000 + bne not_found +found: + lda #$01 + .byte $2C +not_found: + lda #$00 + sty C64DTV_Extended_Regs + rts + diff --git a/testcode/lib/accelerator/Makefile b/testcode/lib/accelerator/Makefile index ece54ec36..a9fe5f78d 100644 --- a/testcode/lib/accelerator/Makefile +++ b/testcode/lib/accelerator/Makefile @@ -1,9 +1,13 @@ CL ?= cl65 -all: c64-scpu-test.prg c128-scpu-test.prg +all: c64-scpu-test.prg c128-scpu-test.prg c64dtv-test.prg c64-scpu-test.prg: c64-c128-scpu-test.c $(CL) -t c64 c64-c128-scpu-test.c -o c64-scpu-test.prg c128-scpu-test.prg: c64-c128-scpu-test.c $(CL) -t c128 c64-c128-scpu-test.c -o c128-scpu-test.prg + +c64dtv-test.prg: c64dtv-test.c + $(CL) -t c64 c64dtv-test.c -o c64dtv-test.prg + diff --git a/testcode/lib/accelerator/c64dtv-test.c b/testcode/lib/accelerator/c64dtv-test.c new file mode 100755 index 000000000..34f0410d9 --- /dev/null +++ b/testcode/lib/accelerator/c64dtv-test.c @@ -0,0 +1,8 @@ +/* C64DTV accelerator test code. */ + +#define ACC_DETECT detect_c64dtv +#define ACC_GET_SPEED get_c64dtv_speed +#define ACC_SET_SPEED set_c64dtv_speed +#define ACC_NAME "C64DTV" + +#include "turbo-test.c" From cb04bc54655c0b6e66e54cf924a9cee017872af9 Mon Sep 17 00:00:00 2001 From: Marco van den Heuvel Date: Sat, 14 Apr 2018 11:31:28 -0700 Subject: [PATCH 2/5] Fixed an issue with the changing the d040 value while detecting. --- libsrc/c64/acc_detect_c64dtv.s | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/libsrc/c64/acc_detect_c64dtv.s b/libsrc/c64/acc_detect_c64dtv.s index ce30806db..1734095b1 100755 --- a/libsrc/c64/acc_detect_c64dtv.s +++ b/libsrc/c64/acc_detect_c64dtv.s @@ -18,7 +18,7 @@ _detect_c64dtv: ldy C64DTV_Extended_Regs lda #$00 - tax + ldx $D000 ; Make sure the CPU is a 6510 .byte $1A ; NOP on 8502, INA on 65(S)C(E)02, 4510 and 65816 @@ -27,17 +27,18 @@ _detect_c64dtv: sta C64DTV_Extended_Regs ; Check if $D000 is mirrored at $D040 - lda $D040 - cmp $D000 + cpx $D040 bne found - inc $D040 - cmp $D000 + inc $D000 + cpx $D040 bne not_found found: lda #$01 .byte $2C not_found: lda #$00 + stx $D000 + ldx #$00 sty C64DTV_Extended_Regs rts From c5f15fa1d54fd476e9b3a852bb6699ccd57183a0 Mon Sep 17 00:00:00 2001 From: Marco van den Heuvel Date: Sun, 15 Apr 2018 11:55:58 -0700 Subject: [PATCH 3/5] Fixed some comment and documentation errors. --- doc/funcref.sgml | 10 +++++----- libsrc/c64/acc_c64dtv_speed.s | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/doc/funcref.sgml b/doc/funcref.sgml index 4dfbf29e0..268c210fe 100644 --- a/doc/funcref.sgml +++ b/doc/funcref.sgml @@ -2936,8 +2936,8 @@ used in presence of a prototype. , -, +, +, @@ -3512,7 +3512,7 @@ header files define constants that can be used to check the return code. The function is specific to the C64. -The function does not check for the presence of the cartridge. +The function does not check for the presence of the C64DTV. See the accelerator.h header for the speed definitions. / - The function is specific to the C64. @@ -6125,7 +6125,7 @@ clean-up when exitting the program. / - The function is specific to the C128 and C64. diff --git a/libsrc/c64/acc_c64dtv_speed.s b/libsrc/c64/acc_c64dtv_speed.s index 9cf49673e..03bff8aa6 100755 --- a/libsrc/c64/acc_c64dtv_speed.s +++ b/libsrc/c64/acc_c64dtv_speed.s @@ -41,7 +41,7 @@ low_speed: set_speed: .byte $32,$99 ; SAC #$99 set accumulator to reg 9 (cpu control) txa ; (re)set skip and burst bits - .byte $32,$00 ; SAC #$99 set accumulator back to reg 0 + .byte $32,$00 ; SAC #$00 set accumulator back to reg 0 jmp _get_c64dtv_speed high_speed: From 0aa2735d4e12017de3dc834f3504da5116f0716a Mon Sep 17 00:00:00 2001 From: Marco van den Heuvel Date: Sun, 15 Apr 2018 12:15:19 -0700 Subject: [PATCH 4/5] Fixed another comment. --- libsrc/c64/acc_c64dtv_speed.s | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libsrc/c64/acc_c64dtv_speed.s b/libsrc/c64/acc_c64dtv_speed.s index 03bff8aa6..ff86751a5 100755 --- a/libsrc/c64/acc_c64dtv_speed.s +++ b/libsrc/c64/acc_c64dtv_speed.s @@ -10,7 +10,7 @@ ; * Note that any value higher or equal to SPEED_2X 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 this should not happen. +; * to set the requested speed, to my knowlegde the switching should not fail. ; * ; * This function does not check for the presence of the C64DTV, ; * make sure you use 'detect_c64dtv();' before using. From ef73310ccef82ec6ed4e2b48fcc354c747468423 Mon Sep 17 00:00:00 2001 From: Marco van den Heuvel Date: Mon, 16 Apr 2018 11:05:52 -0700 Subject: [PATCH 5/5] Fixed more comments. --- libsrc/c64/acc_c64dtv_speed.s | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/libsrc/c64/acc_c64dtv_speed.s b/libsrc/c64/acc_c64dtv_speed.s index ff86751a5..6a8371a9c 100755 --- a/libsrc/c64/acc_c64dtv_speed.s +++ b/libsrc/c64/acc_c64dtv_speed.s @@ -10,7 +10,7 @@ ; * Note that any value higher or equal to SPEED_2X 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 knowlegde the switching should not fail. +; * to set the requested speed, to my knowledge the switching should not fail. ; * ; * This function does not check for the presence of the C64DTV, ; * make sure you use 'detect_c64dtv();' before using. @@ -52,7 +52,7 @@ high_speed: _get_c64dtv_speed: .byte $32,$99 ; SAC #$99 set accumulator to reg 9 (cpu control) tax - .byte $32,$00 ; SAC #$99 set accumulator back to reg 0 + .byte $32,$00 ; SAC #$00 set accumulator back to reg 0 txa and #C64DTV_Fast bne in_fast_mode