mirror of https://github.com/PCSX2/pcsx2.git
gsdx: by default new will throw std::bad_alloc
So catch/use it and don't bother with GSDXErrorOOM
This commit is contained in:
parent
c440c7c93a
commit
fbf7ccbdda
|
@ -526,9 +526,6 @@ GSTexture* GSDevice11::CreateSurface(int type, int w, int h, bool msaa, int form
|
||||||
if(SUCCEEDED(hr))
|
if(SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
t = new GSTexture11(texture);
|
t = new GSTexture11(texture);
|
||||||
if (t == NULL) {
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(type)
|
switch(type)
|
||||||
{
|
{
|
||||||
|
@ -540,6 +537,10 @@ GSTexture* GSDevice11::CreateSurface(int type, int w, int h, bool msaa, int form
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
|
@ -718,17 +718,11 @@ GSTexture* GSDevice9::CreateSurface(int type, int w, int h, bool msaa, int forma
|
||||||
if(surface)
|
if(surface)
|
||||||
{
|
{
|
||||||
t = new GSTexture9(surface);
|
t = new GSTexture9(surface);
|
||||||
if (t == NULL) {
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(texture)
|
if(texture)
|
||||||
{
|
{
|
||||||
t = new GSTexture9(texture);
|
t = new GSTexture9(texture);
|
||||||
if (t == NULL) {
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(t)
|
if(t)
|
||||||
|
@ -743,6 +737,10 @@ GSTexture* GSDevice9::CreateSurface(int type, int w, int h, bool msaa, int forma
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
|
@ -229,11 +229,7 @@ GSTexture* GSDeviceOGL::CreateSurface(int type, int w, int h, bool msaa, int fmt
|
||||||
GL_PUSH("Create surface");
|
GL_PUSH("Create surface");
|
||||||
|
|
||||||
// A wrapper to call GSTextureOGL, with the different kind of parameter
|
// A wrapper to call GSTextureOGL, with the different kind of parameter
|
||||||
GSTextureOGL* t = NULL;
|
GSTextureOGL* t = new GSTextureOGL(type, w, h, fmt, m_fbo_read, m_mipmap > 1 || m_filter > 2);
|
||||||
t = new GSTextureOGL(type, w, h, fmt, m_fbo_read, m_mipmap > 1 || m_filter > 2);
|
|
||||||
if (t == NULL) {
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
|
|
||||||
// NOTE: I'm not sure RenderTarget always need to be cleared. It could be costly for big upscale.
|
// NOTE: I'm not sure RenderTarget always need to be cleared. It could be costly for big upscale.
|
||||||
// FIXME: it will be more logical to do it in FetchSurface. This code is only called at first creation
|
// FIXME: it will be more logical to do it in FetchSurface. This code is only called at first creation
|
||||||
|
|
|
@ -50,7 +50,7 @@ bool GSDeviceSW::Reset(int w, int h)
|
||||||
|
|
||||||
GSTexture* GSDeviceSW::CreateSurface(int type, int w, int h, bool msaa, int format)
|
GSTexture* GSDeviceSW::CreateSurface(int type, int w, int h, bool msaa, int format)
|
||||||
{
|
{
|
||||||
if(format != 0) return NULL; // there is only one format
|
ASSERT(format == 0);
|
||||||
|
|
||||||
return new GSTextureSW(type, w, h);
|
return new GSTextureSW(type, w, h);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1590,7 +1590,7 @@ void GSState::FlushPrim()
|
||||||
Draw();
|
Draw();
|
||||||
} catch (GSDXRecoverableError&) {
|
} catch (GSDXRecoverableError&) {
|
||||||
// could be an unsupported draw call
|
// could be an unsupported draw call
|
||||||
} catch (GSDXErrorOOM&) {
|
} catch (const std::bad_alloc& e) {
|
||||||
// Texture Out Of Memory
|
// Texture Out Of Memory
|
||||||
PurgePool();
|
PurgePool();
|
||||||
fprintf(stderr, "GSDX OUT OF MEMORY\n");
|
fprintf(stderr, "GSDX OUT OF MEMORY\n");
|
||||||
|
|
|
@ -1110,7 +1110,6 @@ GSTextureCache::Source* GSTextureCache::CreateSource(const GIFRegTEX0& TEX0, con
|
||||||
{
|
{
|
||||||
const GSLocalMemory::psm_t& psm = GSLocalMemory::m_psm[TEX0.PSM];
|
const GSLocalMemory::psm_t& psm = GSLocalMemory::m_psm[TEX0.PSM];
|
||||||
Source* src = new Source(m_renderer, TEX0, TEXA, m_temp);
|
Source* src = new Source(m_renderer, TEX0, TEXA, m_temp);
|
||||||
if (src == NULL) throw GSDXErrorOOM();
|
|
||||||
|
|
||||||
int tw = 1 << TEX0.TW;
|
int tw = 1 << TEX0.TW;
|
||||||
int th = 1 << TEX0.TH;
|
int th = 1 << TEX0.TH;
|
||||||
|
@ -1431,11 +1430,7 @@ GSTextureCache::Source* GSTextureCache::CreateSource(const GIFRegTEX0& TEX0, con
|
||||||
src->m_texture = m_renderer->m_dev->CreateTexture(tw, th);
|
src->m_texture = m_renderer->m_dev->CreateTexture(tw, th);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(src->m_texture == NULL)
|
ASSERT(src->m_texture);
|
||||||
{
|
|
||||||
delete src;
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
|
|
||||||
if(psm.pal > 0)
|
if(psm.pal > 0)
|
||||||
{
|
{
|
||||||
|
@ -1449,8 +1444,9 @@ GSTextureCache::Source* GSTextureCache::CreateSource(const GIFRegTEX0& TEX0, con
|
||||||
|
|
||||||
GSTextureCache::Target* GSTextureCache::CreateTarget(const GIFRegTEX0& TEX0, int w, int h, int type)
|
GSTextureCache::Target* GSTextureCache::CreateTarget(const GIFRegTEX0& TEX0, int w, int h, int type)
|
||||||
{
|
{
|
||||||
|
ASSERT(type == RenderTarget || type == DepthStencil);
|
||||||
|
|
||||||
Target* t = new Target(m_renderer, TEX0, m_temp, CanConvertDepth());
|
Target* t = new Target(m_renderer, TEX0, m_temp, CanConvertDepth());
|
||||||
if (t == NULL) throw GSDXErrorOOM();
|
|
||||||
|
|
||||||
// FIXME: initial data should be unswizzled from local mem in Update() if dirty
|
// FIXME: initial data should be unswizzled from local mem in Update() if dirty
|
||||||
|
|
||||||
|
@ -1467,12 +1463,6 @@ GSTextureCache::Target* GSTextureCache::CreateTarget(const GIFRegTEX0& TEX0, int
|
||||||
t->m_texture = m_renderer->m_dev->CreateDepthStencil(w, h, true);
|
t->m_texture = m_renderer->m_dev->CreateDepthStencil(w, h, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(t->m_texture == NULL)
|
|
||||||
{
|
|
||||||
delete t;
|
|
||||||
throw GSDXErrorOOM();
|
|
||||||
}
|
|
||||||
|
|
||||||
m_dst[type].push_front(t);
|
m_dst[type].push_front(t);
|
||||||
|
|
||||||
return t;
|
return t;
|
||||||
|
@ -1880,7 +1870,6 @@ void GSTextureCache::Target::Update()
|
||||||
TEXA.TA1 = 0x80;
|
TEXA.TA1 = 0x80;
|
||||||
|
|
||||||
GSTexture* t = m_renderer->m_dev->CreateTexture(w, h);
|
GSTexture* t = m_renderer->m_dev->CreateTexture(w, h);
|
||||||
if (t == NULL) return;
|
|
||||||
|
|
||||||
const GSOffset* off = m_renderer->m_mem.GetOffset(m_TEX0.TBP0, m_TEX0.TBW, m_TEX0.PSM);
|
const GSOffset* off = m_renderer->m_mem.GetOffset(m_TEX0.TBP0, m_TEX0.TBW, m_TEX0.PSM);
|
||||||
|
|
||||||
|
|
|
@ -246,7 +246,7 @@ GSTextureOGL::GSTextureOGL(int type, int w, int h, int format, GLuint fbo_read,
|
||||||
fprintf(stderr, "Available VRAM is very low (%lld), a crash is expected ! Disable Larger framebuffer or reduce upscaling!\n", GLState::available_vram);
|
fprintf(stderr, "Available VRAM is very low (%lld), a crash is expected ! Disable Larger framebuffer or reduce upscaling!\n", GLState::available_vram);
|
||||||
every_512++;
|
every_512++;
|
||||||
// Pull emergency break
|
// Pull emergency break
|
||||||
throw GSDXErrorOOM();
|
throw std::bad_alloc();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only 32 bits input texture will be supported for mipmap
|
// Only 32 bits input texture will be supported for mipmap
|
||||||
|
|
|
@ -84,6 +84,5 @@ public:
|
||||||
|
|
||||||
struct GSDXError {};
|
struct GSDXError {};
|
||||||
struct GSDXRecoverableError : GSDXError {};
|
struct GSDXRecoverableError : GSDXError {};
|
||||||
struct GSDXErrorOOM : GSDXError {};
|
|
||||||
|
|
||||||
extern GSdxApp theApp;
|
extern GSdxApp theApp;
|
||||||
|
|
Loading…
Reference in New Issue