mirror of
https://github.com/trudnai/Steve2.git
synced 2025-01-18 02:31:44 +00:00
- Fixed disk acceleration algorithm
- Some tiny speed optimizations
This commit is contained in:
parent
e18bc9653e
commit
368dd13309
@ -35,7 +35,7 @@ unsigned long long int inst_cnt = 0;
|
|||||||
|
|
||||||
//const unsigned int fps = 30;
|
//const unsigned int fps = 30;
|
||||||
const unsigned long long default_MHz_6502 = 1.023 * M; // 2 * M; // 4 * M; // 8 * M; // 16 * M; // 128 * M; // 256 * M; // 512 * M;
|
const unsigned long long default_MHz_6502 = 1.023 * M; // 2 * M; // 4 * M; // 8 * M; // 16 * M; // 128 * M; // 256 * M; // 512 * M;
|
||||||
const unsigned long long startup_MHz_6502 = 25 * M;
|
const unsigned long long startup_MHz_6502 = 32 * M;
|
||||||
unsigned long long MHz_6502 = default_MHz_6502;
|
unsigned long long MHz_6502 = default_MHz_6502;
|
||||||
unsigned long long clk_6502_per_frm = startup_MHz_6502 / fps;
|
unsigned long long clk_6502_per_frm = startup_MHz_6502 / fps;
|
||||||
unsigned long long clk_6502_per_frm_set = default_MHz_6502 / fps;
|
unsigned long long clk_6502_per_frm_set = default_MHz_6502 / fps;
|
||||||
|
@ -17,9 +17,9 @@ disk_t disk = {
|
|||||||
0, // clk_since_last_read
|
0, // clk_since_last_read
|
||||||
};
|
};
|
||||||
|
|
||||||
const int diskAccelerator_frames = 1;
|
const int diskAccelerator_frames = 2;
|
||||||
int diskAccelerator_count = 10000;
|
int diskAccelerator_count = 15;
|
||||||
int diskAccelerator_speed = 25; // less than actual CPU speed means no acceleration
|
int diskAccelerator_speed = 25 * M / fps; // less than actual CPU speed means no acceleration
|
||||||
//const unsigned long long clk_6502_per_frm_diskAccelerator = 25 * M / fps; // disk acceleration bumps up CPU clock to 25 MHz
|
//const unsigned long long clk_6502_per_frm_diskAccelerator = 25 * M / fps; // disk acceleration bumps up CPU clock to 25 MHz
|
||||||
//const unsigned long long clk_diskAcceleratorTimeout = 1000ULL;
|
//const unsigned long long clk_diskAcceleratorTimeout = 1000ULL;
|
||||||
|
|
||||||
@ -46,8 +46,8 @@ const int position_to_direction[8][8] = {
|
|||||||
|
|
||||||
|
|
||||||
void disk_accelerator_speedup() {
|
void disk_accelerator_speedup() {
|
||||||
if ( diskAccelerator_speed > clk_6502_per_frm ) {
|
if ( diskAccelerator_speed >= clk_6502_per_frm ) {
|
||||||
clk_6502_per_frm = diskAccelerator_speed * M / fps; // clk_6502_per_frm_diskAccelerator;
|
clk_6502_per_frm = diskAccelerator_speed; // clk_6502_per_frm_diskAccelerator;
|
||||||
diskAccelerator_count = diskAccelerator_frames;
|
diskAccelerator_count = diskAccelerator_frames;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -996,7 +996,7 @@ INLINE uint8_t addr_zp() {
|
|||||||
return fetch();
|
return fetch();
|
||||||
}
|
}
|
||||||
INLINE uint8_t src_zp() {
|
INLINE uint8_t src_zp() {
|
||||||
return memread8(addr_zp());
|
return memread8_low(addr_zp());
|
||||||
}
|
}
|
||||||
INLINE uint8_t * dest_zp() {
|
INLINE uint8_t * dest_zp() {
|
||||||
return WRLOMEM + addr_zp();
|
return WRLOMEM + addr_zp();
|
||||||
@ -1059,7 +1059,7 @@ INLINE uint8_t addr_zp_X() {
|
|||||||
return fetch() + m6502.X;
|
return fetch() + m6502.X;
|
||||||
}
|
}
|
||||||
INLINE uint8_t src_zp_X() {
|
INLINE uint8_t src_zp_X() {
|
||||||
return memread8(addr_zp_X());
|
return memread8_low(addr_zp_X());
|
||||||
}
|
}
|
||||||
INLINE uint8_t * dest_zp_X() {
|
INLINE uint8_t * dest_zp_X() {
|
||||||
return WRLOMEM + addr_zp_X();
|
return WRLOMEM + addr_zp_X();
|
||||||
@ -1075,7 +1075,7 @@ INLINE uint8_t addr_zp_Y() {
|
|||||||
return fetch() + m6502.Y;
|
return fetch() + m6502.Y;
|
||||||
}
|
}
|
||||||
INLINE uint8_t src_zp_Y() {
|
INLINE uint8_t src_zp_Y() {
|
||||||
return memread8(addr_zp_Y());
|
return memread8_low(addr_zp_Y());
|
||||||
}
|
}
|
||||||
INLINE uint8_t * dest_zp_Y() {
|
INLINE uint8_t * dest_zp_Y() {
|
||||||
return WRLOMEM + addr_zp_Y();
|
return WRLOMEM + addr_zp_Y();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user