mirror of
https://github.com/cc65/cc65.git
synced 2025-01-02 09:34:22 +00:00
70 lines
1.9 KiB
ArmAsm
70 lines
1.9 KiB
ArmAsm
;
|
|
; 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
|