diff options
author | notaz | 2011-01-04 19:42:40 +0200 |
---|---|---|
committer | notaz | 2011-01-04 19:42:40 +0200 |
commit | ad6b70be1fa93d6639afb76a9a047eafc5455519 (patch) | |
tree | 07d424c328f478ca4d24ba69a963e8ac139c6546 /plugins/gpu_unai | |
parent | 297b3d633ad25797a4f355c57964b7ce3aee6936 (diff) | |
download | pcsx_rearmed-ad6b70be1fa93d6639afb76a9a047eafc5455519.tar.gz pcsx_rearmed-ad6b70be1fa93d6639afb76a9a047eafc5455519.tar.bz2 pcsx_rearmed-ad6b70be1fa93d6639afb76a9a047eafc5455519.zip |
gpu_unai: freeze display size and position
this avoids some glitches and makes savestates compatible with
Pete's plugins.
Diffstat (limited to 'plugins/gpu_unai')
-rw-r--r-- | plugins/gpu_unai/gpu.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/plugins/gpu_unai/gpu.cpp b/plugins/gpu_unai/gpu.cpp index 3e69aaa..f9f7c41 100644 --- a/plugins/gpu_unai/gpu.cpp +++ b/plugins/gpu_unai/gpu.cpp @@ -182,6 +182,10 @@ long GPU_freeze(unsigned int bWrite, GPUFreeze_t* p2) if (bWrite) { p2->GPU_gp1 = GPU_GP1; + memset(p2->Control, 0, sizeof(p2->Control)); + p2->Control[5] = DisplayArea[0] | (DisplayArea[1] << 10); + p2->Control[7] = DisplayArea[4] | (DisplayArea[5] << 10); + p2->Control[8] = ((GPU_GP1 >> 17) & 0x3f) | ((GPU_GP1 >> 10) & 0x40); memcpy(p2->FrameBuffer, (u16*)GPU_FrameBuffer, FRAME_BUFFER_SIZE); return (1); } @@ -189,6 +193,10 @@ long GPU_freeze(unsigned int bWrite, GPUFreeze_t* p2) { GPU_GP1 = p2->GPU_gp1; memcpy((u16*)GPU_FrameBuffer, p2->FrameBuffer, FRAME_BUFFER_SIZE); + GPU_writeStatus((5 << 24) | p2->Control[5]); + GPU_writeStatus((7 << 24) | p2->Control[7]); + GPU_writeStatus((8 << 24) | p2->Control[8]); + gpuSetTexture(GPU_GP1); return (1); } return (0); |