From d0c0a5641a70affb404bfe96afd6cad50f51a5f3 Mon Sep 17 00:00:00 2001 From: rogerman Date: Fri, 17 Nov 2017 00:51:10 -0800 Subject: [PATCH] Cocoa Port: Fix occasional screen flickering on Metal display views whenever a pixel scaler is used. (Regression from commit 7202fb8.) --- .../cocoa/userinterface/MacMetalDisplayView.h | 1 + .../userinterface/MacMetalDisplayView.mm | 34 ++++++++++++++----- 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.h b/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.h index 7d20ae6bc..7f05b1fd2 100644 --- a/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.h +++ b/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.h @@ -37,6 +37,7 @@ class MacMetalDisplayView; struct MetalProcessedFrameInfo { uint8_t bufferIndex; + id tex[2]; bool isMainDisplayProcessed; bool isTouchDisplayProcessed; }; diff --git a/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.mm b/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.mm index c95dcc4c0..cbff28c4c 100644 --- a/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.mm +++ b/desmume/src/frontend/cocoa/userinterface/MacMetalDisplayView.mm @@ -808,6 +808,8 @@ needsHUDVerticesUpdate = YES; processedFrameInfo.bufferIndex = 0; + processedFrameInfo.tex[NDSDisplayID_Main] = nil; + processedFrameInfo.tex[NDSDisplayID_Touch] = nil; processedFrameInfo.isMainDisplayProcessed = false; processedFrameInfo.isTouchDisplayProcessed = false; @@ -839,6 +841,11 @@ [self setBufCPUFilterDstTouch:nil]; [self setTexDisplayPixelScaleMain:nil]; [self setTexDisplayPixelScaleTouch:nil]; + [self setTexDisplayProcessedMain:nil]; + [self setTexDisplayProcessedTouch:nil]; + + [processedFrameInfo.tex[NDSDisplayID_Main] release]; + [processedFrameInfo.tex[NDSDisplayID_Touch] release]; [self setPixelScalePipeline:nil]; [self setOutputRGBAPipeline:nil]; @@ -1121,6 +1128,8 @@ [self setTexDisplayPixelScaleTouch:[[sharedData device] newTextureWithDescriptor:texDisplayPixelScaleDesc]]; [self setTexDisplayProcessedMain:[sharedData texFetchMain]]; [self setTexDisplayProcessedTouch:[sharedData texFetchTouch]]; + processedFrameInfo.tex[NDSDisplayID_Main] = [[self texDisplayProcessedMain] retain]; + processedFrameInfo.tex[NDSDisplayID_Touch] = [[self texDisplayProcessedTouch] retain]; VideoFilter *vfMain = cdp->GetPixelScalerObject(NDSDisplayID_Main); _bufCPUFilterSrcMain = [[[sharedData device] newBufferWithBytesNoCopy:vfMain->GetSrcBufferPtr() @@ -1327,6 +1336,7 @@ if (selectedDisplaySource[NDSDisplayID_Main] == selectedDisplaySource[NDSDisplayID_Touch]) { + [self setTexDisplayProcessedTouch:[self texDisplayProcessedMain]]; isDisplayProcessedTouch = true; } } @@ -1382,6 +1392,7 @@ if (selectedDisplaySource[NDSDisplayID_Main] == selectedDisplaySource[NDSDisplayID_Touch]) { + [self setTexDisplayProcessedTouch:[self texDisplayProcessedMain]]; isDisplayProcessedTouch = true; } } @@ -1491,6 +1502,7 @@ if (selectedDisplaySource[NDSDisplayID_Main] == selectedDisplaySource[NDSDisplayID_Touch]) { + [self setTexDisplayProcessedTouch:[self texDisplayProcessedMain]]; isDisplayProcessedTouch = true; } } @@ -1521,11 +1533,6 @@ [cb commit]; } - if (selectedDisplaySource[NDSDisplayID_Touch] == selectedDisplaySource[NDSDisplayID_Main]) - { - [self setTexDisplayProcessedTouch:[self texDisplayProcessedMain]]; - } - // Update the texture coordinates cdp->SetScreenTextureCoordinates((float)[[self texDisplayProcessedMain] width], (float)[[self texDisplayProcessedMain] height], (float)[[self texDisplayProcessedTouch] width], (float)[[self texDisplayProcessedTouch] height], @@ -1537,7 +1544,16 @@ newFrameInfo.bufferIndex = bufferIndex; newFrameInfo.isMainDisplayProcessed = isDisplayProcessedMain; newFrameInfo.isTouchDisplayProcessed = isDisplayProcessedTouch; + newFrameInfo.tex[NDSDisplayID_Main] = [[self texDisplayProcessedMain] retain]; + newFrameInfo.tex[NDSDisplayID_Touch] = [[self texDisplayProcessedTouch] retain]; + + id oldDisplayProcessedMain = processedFrameInfo.tex[NDSDisplayID_Main]; + id oldDisplayProcessedTouch = processedFrameInfo.tex[NDSDisplayID_Touch]; + [self setProcessedFrameInfo:newFrameInfo]; + + [oldDisplayProcessedMain release]; + [oldDisplayProcessedTouch release]; } - (void) updateRenderBuffers @@ -1836,8 +1852,8 @@ [self renderForCommandBuffer:cb outputPipelineState:[self outputRGBAPipeline] hudPipelineState:[sharedData hudRGBAPipeline] - texDisplayMain:(processedInfo.isMainDisplayProcessed) ? [self texDisplayProcessedMain] : ((cdp->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Main) == NDSDisplayID_Main) ? [sharedData texFetchMain] : [sharedData texFetchTouch] ) - texDisplayTouch:(processedInfo.isTouchDisplayProcessed) ? [self texDisplayProcessedTouch] : ((cdp->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Touch) == NDSDisplayID_Touch) ? [sharedData texFetchTouch] : [sharedData texFetchMain] )]; + texDisplayMain:(processedInfo.isMainDisplayProcessed) ? processedInfo.tex[NDSDisplayID_Main] : ((cdp->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Main) == NDSDisplayID_Main) ? [sharedData texFetchMain] : [sharedData texFetchTouch] ) + texDisplayTouch:(processedInfo.isTouchDisplayProcessed) ? processedInfo.tex[NDSDisplayID_Touch] : ((cdp->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Touch) == NDSDisplayID_Touch) ? [sharedData texFetchTouch] : [sharedData texFetchMain] )]; [cb addCompletedHandler:^(id block) { pthread_mutex_unlock(&_mutexBufferUpdate); @@ -1935,8 +1951,8 @@ [presenterObject renderForCommandBuffer:cb outputPipelineState:[presenterObject outputDrawablePipeline] hudPipelineState:[[presenterObject sharedData] hudPipeline] - texDisplayMain:(processedInfo.isMainDisplayProcessed) ? [presenterObject texDisplayProcessedMain] : (([presenterObject cdp]->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Main) == NDSDisplayID_Main) ? [[presenterObject sharedData] texFetchMain] : [[presenterObject sharedData] texFetchTouch] ) - texDisplayTouch:(processedInfo.isTouchDisplayProcessed) ? [presenterObject texDisplayProcessedTouch] : (([presenterObject cdp]->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Touch) == NDSDisplayID_Touch) ? [[presenterObject sharedData] texFetchTouch] : [[presenterObject sharedData] texFetchMain] )]; + texDisplayMain:(processedInfo.isMainDisplayProcessed) ? processedInfo.tex[NDSDisplayID_Main] : (([presenterObject cdp]->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Main) == NDSDisplayID_Main) ? [[presenterObject sharedData] texFetchMain] : [[presenterObject sharedData] texFetchTouch] ) + texDisplayTouch:(processedInfo.isTouchDisplayProcessed) ? processedInfo.tex[NDSDisplayID_Touch] : (([presenterObject cdp]->GetSelectedDisplaySourceForDisplay(NDSDisplayID_Touch) == NDSDisplayID_Touch) ? [[presenterObject sharedData] texFetchTouch] : [[presenterObject sharedData] texFetchMain] )]; [cb presentDrawable:layerDrawable]; [cb addCompletedHandler:^(id block) {