aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornotaz2013-06-05 00:58:22 +0300
committernotaz2013-06-05 00:58:22 +0300
commit88901dd2de7982c765053ec47ef987efbc8ab89e (patch)
tree5e4bc3d2d1946a9274e95c5affc727a81c380e59
parent74ebc05b15569d7745b9ab59f9b289f427abeeac (diff)
downloadpcsx_rearmed-88901dd2de7982c765053ec47ef987efbc8ab89e.tar.gz
pcsx_rearmed-88901dd2de7982c765053ec47ef987efbc8ab89e.tar.bz2
pcsx_rearmed-88901dd2de7982c765053ec47ef987efbc8ab89e.zip
psxmem: handle map failures so that it can be retried
-rw-r--r--libpcsxcore/psxmem.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/libpcsxcore/psxmem.c b/libpcsxcore/psxmem.c
index 4da0cf4..2ca5dd5 100644
--- a/libpcsxcore/psxmem.c
+++ b/libpcsxcore/psxmem.c
@@ -95,7 +95,8 @@ void psxUnmap(void *ptr, size_t size, enum psxMapTag tag)
return;
}
- munmap(ptr, size);
+ if (ptr)
+ munmap(ptr, size);
}
s8 *psxM = NULL; // Kernel & User Memory (2 Meg)
@@ -155,6 +156,7 @@ int psxMemInit() {
if (psxMemRLUT == NULL || psxMemWLUT == NULL ||
psxR == NULL || psxP == NULL || psxH != (void *)0x1f800000) {
SysMessage(_("Error allocating memory!"));
+ psxMemShutdown();
return -1;
}
@@ -208,12 +210,12 @@ void psxMemReset() {
}
void psxMemShutdown() {
- psxUnmap(psxM, 0x00210000, MAP_TAG_RAM);
- psxUnmap(psxH, 0x10000, MAP_TAG_OTHER);
- psxUnmap(psxR, 0x80000, MAP_TAG_OTHER);
+ psxUnmap(psxM, 0x00210000, MAP_TAG_RAM); psxM = NULL;
+ psxUnmap(psxH, 0x10000, MAP_TAG_OTHER); psxH = NULL;
+ psxUnmap(psxR, 0x80000, MAP_TAG_OTHER); psxR = NULL;
- free(psxMemRLUT);
- free(psxMemWLUT);
+ free(psxMemRLUT); psxMemRLUT = NULL;
+ free(psxMemWLUT); psxMemWLUT = NULL;
}
static int writeok = 1;