From fb7dbca344d9183cc4986a069dbe3701a6daf958 Mon Sep 17 00:00:00 2001 From: rogerman Date: Sat, 27 Oct 2018 19:25:15 -0700 Subject: [PATCH] GPU: Fix bug with main memory display mode when running 18-bit or 24-bit color depth. (Fixes #211.) --- desmume/src/GPU.cpp | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/desmume/src/GPU.cpp b/desmume/src/GPU.cpp index 2717fef7c..53103ef6a 100644 --- a/desmume/src/GPU.cpp +++ b/desmume/src/GPU.cpp @@ -7944,18 +7944,13 @@ void GPUEngineA::_HandleDisplayModeVRAM(const size_t l) template void GPUEngineA::_HandleDisplayModeMainMemory(const size_t l) { - // Native rendering only. - // - //this has not been tested since the dma timing for dispfifo was changed around the time of - //newemuloop. it may not work. - - u32 *dstColorLine = (u32 *)((u16 *)this->nativeBuffer + (l * GPU_FRAMEBUFFER_NATIVE_WIDTH)); - + // Displays video using color data directly read from main memory. + // Doing this should always result in an output line that is at the native size (192px x 1px). switch (OUTPUTFORMAT) { case NDSColorFormat_BGR555_Rev: { - u32 *dst = dstColorLine; + u32 *dst = (u32 *)((u16 *)this->nativeBuffer + (l * GPU_FRAMEBUFFER_NATIVE_WIDTH)); #ifdef ENABLE_SSE2 const __m128i alphaBit = _mm_set1_epi16(0x8000); @@ -7975,7 +7970,7 @@ void GPUEngineA::_HandleDisplayModeMainMemory(const size_t l) case NDSColorFormat_BGR666_Rev: { - FragmentColor *dst = (FragmentColor *)dstColorLine; + FragmentColor *dst = (FragmentColor *)this->nativeBuffer + (l * GPU_FRAMEBUFFER_NATIVE_WIDTH); for (size_t i = 0; i < GPU_FRAMEBUFFER_NATIVE_WIDTH; i+=2) { @@ -7988,7 +7983,7 @@ void GPUEngineA::_HandleDisplayModeMainMemory(const size_t l) case NDSColorFormat_BGR888_Rev: { - FragmentColor *dst = (FragmentColor *)dstColorLine; + FragmentColor *dst = (FragmentColor *)this->nativeBuffer + (l * GPU_FRAMEBUFFER_NATIVE_WIDTH); for (size_t i = 0; i < GPU_FRAMEBUFFER_NATIVE_WIDTH; i+=2) {