mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-18 22:35:39 +00:00
PGXP: Don't abort() on vertex cache alloc fail
This commit is contained in:
parent
22b2963bfe
commit
a47686a313
|
@ -20,10 +20,12 @@
|
||||||
|
|
||||||
#include "pgxp.h"
|
#include "pgxp.h"
|
||||||
#include "bus.h"
|
#include "bus.h"
|
||||||
|
#include "common/log.h"
|
||||||
#include "cpu_core.h"
|
#include "cpu_core.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include <climits>
|
#include <climits>
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
|
Log_SetChannel(PGXP);
|
||||||
|
|
||||||
namespace PGXP {
|
namespace PGXP {
|
||||||
// pgxp_types.h
|
// pgxp_types.h
|
||||||
|
@ -356,6 +358,9 @@ void Initialize()
|
||||||
PGXP_InitMem();
|
PGXP_InitMem();
|
||||||
PGXP_InitCPU();
|
PGXP_InitCPU();
|
||||||
PGXP_InitGTE();
|
PGXP_InitGTE();
|
||||||
|
|
||||||
|
if (vertexCache)
|
||||||
|
std::memset(vertexCache, 0, sizeof(PGXP_value) * VERTEX_CACHE_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Shutdown()
|
void Shutdown()
|
||||||
|
@ -576,21 +581,20 @@ unsigned int IsSessionID(unsigned int vertID)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void InitPGXPVertexCache()
|
static bool InitPGXPVertexCache()
|
||||||
{
|
{
|
||||||
|
if (vertexCache)
|
||||||
|
std::free(vertexCache);
|
||||||
|
|
||||||
|
vertexCache = static_cast<PGXP_value*>(std::calloc(VERTEX_CACHE_SIZE, sizeof(PGXP_value)));
|
||||||
if (!vertexCache)
|
if (!vertexCache)
|
||||||
{
|
{
|
||||||
vertexCache = static_cast<PGXP_value*>(std::calloc(VERTEX_CACHE_SIZE, sizeof(PGXP_value)));
|
Log_ErrorPrint("Failed to allocate memory for vertex cache, disabling.");
|
||||||
if (!vertexCache)
|
g_settings.gpu_pgxp_vertex_cache = false;
|
||||||
{
|
return false;
|
||||||
std::fprintf(stderr, "Failed to allocate PGXP vertex cache memory\n");
|
|
||||||
std::abort();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
memset(vertexCache, 0x00, VERTEX_CACHE_SIZE * sizeof(PGXP_value));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PGXP_CacheVertex(short sx, short sy, const PGXP_value* _pVertex)
|
void PGXP_CacheVertex(short sx, short sy, const PGXP_value* _pVertex)
|
||||||
|
@ -605,8 +609,8 @@ void PGXP_CacheVertex(short sx, short sy, const PGXP_value* _pVertex)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialise cache on first use
|
// Initialise cache on first use
|
||||||
if (!vertexCache)
|
if (!vertexCache && !InitPGXPVertexCache())
|
||||||
InitPGXPVertexCache();
|
return;
|
||||||
|
|
||||||
// if (bGteAccuracy)
|
// if (bGteAccuracy)
|
||||||
{
|
{
|
||||||
|
@ -650,15 +654,15 @@ PGXP_value* PGXP_GetCachedVertex(short sx, short sy)
|
||||||
if (cacheMode != mode_read)
|
if (cacheMode != mode_read)
|
||||||
{
|
{
|
||||||
if (cacheMode == mode_fail)
|
if (cacheMode == mode_fail)
|
||||||
return NULL;
|
return nullptr;
|
||||||
|
|
||||||
// First vertex of read session (frame?)
|
// First vertex of read session (frame?)
|
||||||
cacheMode = mode_read;
|
cacheMode = mode_read;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialise cache on first use
|
// Initialise cache on first use
|
||||||
if (!vertexCache)
|
if (!vertexCache && !InitPGXPVertexCache())
|
||||||
InitPGXPVertexCache();
|
return nullptr;
|
||||||
|
|
||||||
if (sx >= -0x800 && sx <= 0x7ff && sy >= -0x800 && sy <= 0x7ff)
|
if (sx >= -0x800 && sx <= 0x7ff && sy >= -0x800 && sy <= 0x7ff)
|
||||||
{
|
{
|
||||||
|
@ -667,7 +671,7 @@ PGXP_value* PGXP_GetCachedVertex(short sx, short sy)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ALWAYS_INLINE_RELEASE float TruncateVertexPosition(float p)
|
static ALWAYS_INLINE_RELEASE float TruncateVertexPosition(float p)
|
||||||
|
|
Loading…
Reference in a new issue