X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=fceu.git;a=blobdiff_plain;f=x6502.h;h=3216d50f984152d8890574af723dae27c82344a5;hp=9411108ef63d7e23efc53c432e19e7824b7cf459;hb=8fa5eb3371d902b8d58dba6e6bf62726d7ed8dbc;hpb=92e249b10ad9e479eddb18974555366dba725ef3 diff --git a/x6502.h b/x6502.h index 9411108..3216d50 100644 --- a/x6502.h +++ b/x6502.h @@ -63,6 +63,7 @@ extern void FP_FASTAPASS(1) (*MapIRQHook)(int a); #define X6502_AddCycles X6502_AddCycles_d #define X6502_IRQBegin X6502_IRQBegin_d #define X6502_IRQEnd X6502_IRQEnd_d +#define X6502_Rebase X6502_Rebase_d #define X6502_C #define X6502_A #define X6502_D @@ -76,17 +77,18 @@ extern void FP_FASTAPASS(1) (*MapIRQHook)(int a); #define X6502_AddCycles X6502_AddCycles_a #define X6502_IRQBegin X6502_IRQBegin_a #define X6502_IRQEnd X6502_IRQEnd_a +#define X6502_Rebase X6502_Rebase_a #define X6502_A #define X6502_Run(c) \ { \ int32 cycles = (c) << 4; /* *16 */ \ if (PAL) cycles -= (c); /* *15 */ \ - nes_registers[7]+=cycles; \ - if (nes_registers[7] > 0) { \ - cycles = (int32)nes_registers[7]; \ + nes_registers[7]+=cycles<<16; \ + cycles=(int32)nes_registers[7]>>16; \ + if (cycles > 0) { \ X6502_Run_a(); \ - cycles -= (int32)nes_registers[7]; \ + cycles -= (int32)nes_registers[7]>>16; \ asmcpu_update(cycles); \ } \ } @@ -100,6 +102,7 @@ extern void FP_FASTAPASS(1) (*MapIRQHook)(int a); #define X6502_AddCycles X6502_AddCycles_c #define X6502_IRQBegin X6502_IRQBegin_c #define X6502_IRQEnd X6502_IRQEnd_c +#define X6502_Rebase(...) #define X6502_C #define X6502_Run(c) \ @@ -138,7 +141,7 @@ void X6502_Power_a(void); void X6502_AddCycles_a(int x); void X6502_IRQBegin_a(int w); void X6502_IRQEnd_a(int w); -void X6502_rebase_a(void); +void X6502_Rebase_a(void); #endif // debug @@ -152,5 +155,6 @@ void X6502_Power_d(void); void X6502_AddCycles_d(int x); void X6502_IRQBegin_d(int w); void X6502_IRQEnd_d(int w); +void X6502_Rebase_d(void); #endif