aboutsummaryrefslogtreecommitdiff
path: root/libpcsxcore
diff options
context:
space:
mode:
authormeancoot2013-12-19 16:53:46 -0500
committernotaz2013-12-22 19:54:22 +0200
commit578c68827e20b1e4c0a1a6352dd4a74ab3d05ef2 (patch)
tree34d052c3240f3c09b4ec29f7874d17bcdc41f048 /libpcsxcore
parentc40ab498b5800eb0ccac887b53cd7450a304e2e8 (diff)
downloadpcsx_rearmed-578c68827e20b1e4c0a1a6352dd4a74ab3d05ef2.tar.gz
pcsx_rearmed-578c68827e20b1e4c0a1a6352dd4a74ab3d05ef2.tar.bz2
pcsx_rearmed-578c68827e20b1e4c0a1a6352dd4a74ab3d05ef2.zip
(iOS) Work around clang crash when compiling libpcsxcor/new_dynarec/pcsxmem.c.
Diffstat (limited to 'libpcsxcore')
-rw-r--r--libpcsxcore/new_dynarec/pcsxmem.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/libpcsxcore/new_dynarec/pcsxmem.c b/libpcsxcore/new_dynarec/pcsxmem.c
index 3d14904..0a75442 100644
--- a/libpcsxcore/new_dynarec/pcsxmem.c
+++ b/libpcsxcore/new_dynarec/pcsxmem.c
@@ -30,7 +30,12 @@ static u32 mem_ffwtab[(1+2+4) * 0x1000 / 4];
//static u32 mem_unmrtab[(1+2+4) * 0x1000 / 4];
static u32 mem_unmwtab[(1+2+4) * 0x1000 / 4];
+// When this is called in a loop, and 'h' is a function pointer, clang will crash.
+#ifdef __clang__
+static __attribute__ ((noinline)) void map_item(u32 *out, const void *h, u32 flag)
+#else
static void map_item(u32 *out, const void *h, u32 flag)
+#endif
{
u32 hv = (u32)h;
if (hv & 1) {