mirror of https://github.com/PCSX2/pcsx2.git
GSdx: Implement SYNCV register bitfields
Add the bitfield structure of the undocumented SYNCV register, potentially might be useful in proper height determination of the output circuit for some weird games which still get it wrong but still haven't figured out how it might be useful. Maybe some sort of black magic formula with the vertical synchronization values? The differential phase value seems to closely resemble the display height value of the video modes (480 for NTSC, 576 for PAL) but after some investigating into the differential phase, I have no clue on how they might be even related. Hopefully the mystery will be unveiled in the near future.
This commit is contained in:
parent
e8f35f0bab
commit
49840bb621
|
@ -511,8 +511,12 @@ REG64_(GSReg, SYNCH2)
|
||||||
REG_END
|
REG_END
|
||||||
|
|
||||||
REG64_(GSReg, SYNCV)
|
REG64_(GSReg, SYNCV)
|
||||||
uint64 _DUMMY;
|
uint32 VFP:10; // Vertical Front Porchinterval (?s)
|
||||||
// TODO
|
uint32 VFPE:10; // Vertical Front Porchinterval End (?s)
|
||||||
|
uint32 VBP:12; // Vertical Back Porchinterval (?s)
|
||||||
|
uint32 VBPE:10; // Vertical Back Porchinterval End (?s)
|
||||||
|
uint32 VDP:11; // Vertical Differential Phase
|
||||||
|
uint32 VS:11; // Vertical Synchronization Timing
|
||||||
REG_END
|
REG_END
|
||||||
|
|
||||||
REG64_SET(GSReg)
|
REG64_SET(GSReg)
|
||||||
|
@ -1357,9 +1361,13 @@ struct GSPrivRegSet
|
||||||
SYNCH2.u32[1]
|
SYNCH2.u32[1]
|
||||||
);
|
);
|
||||||
|
|
||||||
fprintf(fp, "SYNCV %08x_%08x\n",
|
fprintf(fp, "SYNCV VBP=%u VBPE=%u VDP=%u VFP=%u VFPE=%u VS=%u\n",
|
||||||
SYNCV.u32[0],
|
SYNCV.VBP,
|
||||||
SYNCV.u32[1]
|
SYNCV.VBPE,
|
||||||
|
SYNCV.VDP,
|
||||||
|
SYNCV.VFP,
|
||||||
|
SYNCV.VFPE,
|
||||||
|
SYNCV.VS
|
||||||
);
|
);
|
||||||
|
|
||||||
fprintf(fp, "CSR %08x_%08x\n",
|
fprintf(fp, "CSR %08x_%08x\n",
|
||||||
|
|
Loading…
Reference in New Issue