Merge pull request #737 from Azaezel/queryStallPrevention

Query Stall Prevention
This commit is contained in:
Areloch 2014-10-01 23:48:53 -05:00
commit 4716f76d5e
3 changed files with 15 additions and 4 deletions

View file

@ -124,9 +124,16 @@ GFXD3D9OcclusionQuery::OcclusionQueryStatus GFXD3D9OcclusionQuery::getStatus( bo
DWORD dwOccluded = 0;
if ( block )
{
{
while( ( hRes = mQuery->GetData( &dwOccluded, sizeof(DWORD), D3DGETDATA_FLUSH ) ) == S_FALSE )
;
{
//If we're stalled out, proceed with worst-case scenario -BJR
if(GFX->mFrameTime->getElapsedMs()>4)
{
this->end();
return NotOccluded;
}
}
}
else
{

View file

@ -180,7 +180,7 @@ GFXDevice::GFXDevice()
// Initialize our drawing utility.
mDrawer = NULL;
mFrameTime = PlatformTimer::create();
// Add a few system wide shader macros.
GFXShader::addGlobalMacro( "TORQUE", "1" );
GFXShader::addGlobalMacro( "TORQUE_VERSION", String::ToString(getVersionNumber()) );
@ -804,7 +804,7 @@ inline bool GFXDevice::beginScene()
// Send the start of frame signal.
getDeviceEventSignal().trigger( GFXDevice::deStartOfFrame );
mFrameTime->reset();
return beginSceneInternal();
}

View file

@ -54,6 +54,9 @@
#include "math/util/frustum.h"
#endif
#ifndef _PLATFORM_PLATFORMTIMER_H_
#include "platform/platformTimer.h"
#endif
class FontRenderBatcher;
class GFont;
@ -743,6 +746,7 @@ public:
virtual void endScene();
virtual void beginField();
virtual void endField();
PlatformTimer *mFrameTime;
virtual GFXTexHandle & getFrontBuffer(){ return mFrontBuffer[mCurrentFrontBufferIdx]; }