32X poll detection fix
authorkub <derkub@gmail.com>
Sun, 16 Feb 2020 07:42:45 +0000 (08:42 +0100)
committerkub <derkub@gmail.com>
Sun, 16 Feb 2020 07:42:45 +0000 (08:42 +0100)
pico/32x/memory.c

index 30d9b57..f772d28 100644 (file)
@@ -239,7 +239,7 @@ static NOINLINE void sh2_poll_write(u32 a, u32 d, unsigned int cycles, SH2 *sh2)
   // NB this can take an eternity on m68k: mov.b <addr1.l>,<addr2.l> needs
   // 28 m68k-cycles (~80 sh2-cycles) to complete (observed in Metal Head)
   q = &fifo[(sh2_poll_wr[hix]-1) % PFIFO_SZ];
-  if (rd != wr && q->a == a && !CYCLES_GT(cycles,q->cycles+30)) {
+  if (cpu < 0 && rd != wr && q->a == a && !CYCLES_GT(cycles,q->cycles+30)) {
     q->d = d;
   } else {
     // store write to poll address in fifo