X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2FVideoPort.c;h=3663732aac5fbdcc183c40b0bdfddd0490b4ce8b;hb=4c436138e4f9f49726352c34499a2de76a7c1c79;hp=d027ca3b3f80211e5acd4af378add5678a32d526;hpb=d9fc2fe1ac69169861cb60b62ccc9fbc6e4fd4c6;p=picodrive.git diff --git a/Pico/VideoPort.c b/Pico/VideoPort.c index d027ca3..3663732 100644 --- a/Pico/VideoPort.c +++ b/Pico/VideoPort.c @@ -35,7 +35,9 @@ static void VideoWrite(u16 d) { case 1: if(a&1) d=(u16)((d<<8)|(d>>8)); // If address is odd, bytes are swapped (which game needs this?) Pico.vram [(a>>1)&0x7fff]=d; - rendstatus |= PDRAW_DIRTY_SPRITES; break; + if (a - ((unsigned)(Pico.video.reg[5]&0x7f) << 9) < 0x400) + rendstatus |= PDRAW_DIRTY_SPRITES; + break; case 3: Pico.m.dirtyPal = 1; Pico.cram [(a>>1)&0x003f]=d; break; // wraps (Desert Strike) case 5: Pico.vsram[(a>>1)&0x003f]=d; break; @@ -362,7 +364,8 @@ PICO_INTERNAL_ASM void PicoVideoWrite(unsigned int a,unsigned short d) SekCyclesBurn(32); // penalty // 488/12-8 if (SekCycleCnt>=SekCycleAim) SekEndRun(0); } - elprintf(EL_ASVDP, "VDP data write: %04x {%i} #%i @ %06x", d, Pico.video.type, pvid->lwrite_cnt, SekPc); + elprintf(EL_ASVDP, "VDP data write: %04x [%06x] {%i} #%i @ %06x", d, Pico.video.addr, + Pico.video.type, pvid->lwrite_cnt, SekPc); } VideoWrite(d); } @@ -408,6 +411,7 @@ PICO_INTERNAL_ASM void PicoVideoWrite(unsigned int a,unsigned short d) update_irq = 1; break; case 0x05: + //elprintf(EL_STATUS, "spritep moved to %04x", (unsigned)(Pico.video.reg[5]&0x7f) << 9); if (d^dold) rendstatus |= PDRAW_SPRITES_MOVED; break; case 0x0c: @@ -486,7 +490,7 @@ PICO_INTERNAL_ASM unsigned int PicoVideoRead(unsigned int a) { unsigned int d; int lineCycles; - + lineCycles = (488-SekCyclesLeft)&0x1ff; if (Pico.video.reg[12]&1) d = hcounts_40[lineCycles];