From bfe105a1887e662e17f03f364efee77ceaee1c59 Mon Sep 17 00:00:00 2001 From: rogerman Date: Wed, 18 Mar 2015 03:25:14 +0000 Subject: [PATCH] GFX3D: - Workaround a bug specific to GCC v4.9 where allocating the VERTLIST blocks would cause a std::bad_alloc exception. (Fixes bug #1438.) --- desmume/src/gfx3d.cpp | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/desmume/src/gfx3d.cpp b/desmume/src/gfx3d.cpp index ab6ad7cf0..1ca26f086 100644 --- a/desmume/src/gfx3d.cpp +++ b/desmume/src/gfx3d.cpp @@ -521,8 +521,22 @@ void gfx3d_init() //printf("SPEED TEST %d %d\n",diff,diff2); - if(polylists == NULL) { polylists = new POLYLIST[2]; polylist = &polylists[0]; } - if(vertlists == NULL) { vertlists = new VERTLIST[2]; vertlist = &vertlists[0]; } + // Use malloc() instead of new because, for some unknown reason, GCC 4.9 has a bug + // that causes a std::bad_alloc exception on certain memory allocations. Right now, + // POLYLIST and VERTLIST are POD-style structs, so malloc() can substitute for new + // in this case. + if(polylists == NULL) + { + polylists = (POLYLIST *)malloc(sizeof(POLYLIST)*2); + polylist = &polylists[0]; + } + + if(vertlists == NULL) + { + vertlists = (VERTLIST *)malloc(sizeof(VERTLIST)*2); + vertlist = &vertlists[0]; + } + makeTables(); gfx3d_reset(); }