Support alternate (more accurate) poll timings
This commit is contained in:
parent
de64c85a62
commit
5075da5c4a
6 changed files with 56 additions and 4 deletions
|
@ -13,6 +13,7 @@ Configuration::Configuration() {
|
|||
cpu.ntsc_frequency = 21477272; //315 / 88 * 6000000
|
||||
cpu.pal_frequency = 21281370;
|
||||
cpu.wram_init_value = 0x55;
|
||||
cpu.alt_poll_timings = false;
|
||||
|
||||
smp.ntsc_frequency = 24607104; //32040.5 * 768
|
||||
smp.pal_frequency = 24607104;
|
||||
|
|
|
@ -10,6 +10,7 @@ struct Configuration {
|
|||
unsigned ntsc_frequency;
|
||||
unsigned pal_frequency;
|
||||
unsigned wram_init_value;
|
||||
bool alt_poll_timings;
|
||||
} cpu;
|
||||
|
||||
struct SMP {
|
||||
|
|
|
@ -29,4 +29,44 @@ void CPU::step_auto_joypad_poll() {
|
|||
}
|
||||
}
|
||||
|
||||
//called every 128 clocks; see CPU::add_clocks()
|
||||
void CPU::step_auto_joypad_poll_NEW(bool polarity) {
|
||||
if(status.auto_joypad_counter > 0 && status.auto_joypad_counter <= 34) {
|
||||
if(!status.auto_joypad_latch) {
|
||||
//FIXME: Is this right, busy flag goes on even if not enabled???
|
||||
if(status.auto_joypad_counter == 1)
|
||||
status.auto_joypad_active = true;
|
||||
if(status.auto_joypad_counter == 34)
|
||||
status.auto_joypad_active = false;
|
||||
} else {
|
||||
if(status.auto_joypad_counter == 1) {
|
||||
status.auto_joypad_active = true;
|
||||
input.port1->latch(1);
|
||||
input.port2->latch(1);
|
||||
}
|
||||
if(status.auto_joypad_counter == 3) {
|
||||
input.port1->latch(0);
|
||||
input.port2->latch(0);
|
||||
}
|
||||
if((status.auto_joypad_counter & 1) != 0 && status.auto_joypad_counter != 1) {
|
||||
uint2 port0 = input.port1->data();
|
||||
uint2 port1 = input.port2->data();
|
||||
|
||||
status.joy1 = (status.joy1 << 1) | (bool)(port0 & 1);
|
||||
status.joy2 = (status.joy2 << 1) | (bool)(port1 & 1);
|
||||
status.joy3 = (status.joy3 << 1) | (bool)(port0 & 2);
|
||||
status.joy4 = (status.joy4 << 1) | (bool)(port1 & 2);
|
||||
}
|
||||
if(status.auto_joypad_counter == 34)
|
||||
status.auto_joypad_active = false;
|
||||
}
|
||||
status.auto_joypad_counter++;
|
||||
}
|
||||
if(vcounter() >= (ppu.overscan() == false ? 225 : 240) && status.auto_joypad_counter == 0 && !polarity) {
|
||||
status.auto_joypad_latch = status.auto_joypad_poll;
|
||||
status.auto_joypad_counter = 1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#endif
|
||||
|
|
|
@ -17,10 +17,18 @@ void CPU::add_clocks(unsigned clocks) {
|
|||
|
||||
step(clocks);
|
||||
|
||||
status.auto_joypad_clock += clocks;
|
||||
if(status.auto_joypad_clock >= 256) {
|
||||
status.auto_joypad_clock -= 256;
|
||||
step_auto_joypad_poll();
|
||||
if(config.cpu.alt_poll_timings) {
|
||||
bool opolarity = (status.auto_joypad_clock & 128);
|
||||
status.auto_joypad_clock = (status.auto_joypad_clock + clocks) & 0xFF;
|
||||
bool npolarity = (status.auto_joypad_clock & 128);
|
||||
if(opolarity != npolarity)
|
||||
step_auto_joypad_poll_NEW(opolarity);
|
||||
} else {
|
||||
status.auto_joypad_clock += clocks;
|
||||
if(status.auto_joypad_clock >= 256) {
|
||||
status.auto_joypad_clock -= 256;
|
||||
step_auto_joypad_poll();
|
||||
}
|
||||
}
|
||||
|
||||
if(status.dram_refreshed == false && hcounter() >= status.dram_refresh_position) {
|
||||
|
|
|
@ -22,3 +22,4 @@ alwaysinline bool irq_test();
|
|||
|
||||
//joypad.cpp
|
||||
void step_auto_joypad_poll();
|
||||
void step_auto_joypad_poll_NEW(bool polarity);
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
#ifndef SNES_HPP
|
||||
#define SNES_HPP
|
||||
#define BSNES_SUPPORTS_ALT_TIMINGS
|
||||
|
||||
namespace SNES {
|
||||
namespace Info {
|
||||
|
|
Loading…
Add table
Reference in a new issue