mirror of
https://github.com/xemu-project/xemu.git
synced 2025-02-02 10:12:03 +00:00
tcg/ppc: Handle _CALL_DARWIN being undefined on Darwin
powerpc-apple-darwin9-gcc-4.2.1 (GCC) 4.2.1 (Apple Inc. build 5577) does not define _CALL_DARWIN, leading to unexpected behavior w.r.t. register clobbering and stack frame layout. Since _CALL_DARWIN is a reserved identifier, define a custom TCG_TARGET_CALL_DARWIN based on either _CALL_DARWIN or __APPLE__. Signed-off-by: Andreas F?rber <andreas.faerber@web.de> Signed-off-by: malc <av1474@comtv.ru>
This commit is contained in:
parent
aeb29b6459
commit
24f50d7ea5
@ -24,7 +24,11 @@
|
||||
|
||||
static uint8_t *tb_ret_addr;
|
||||
|
||||
#ifdef _CALL_DARWIN
|
||||
#if defined _CALL_DARWIN || defined __APPLE__
|
||||
#define TCG_TARGET_CALL_DARWIN
|
||||
#endif
|
||||
|
||||
#ifdef TCG_TARGET_CALL_DARWIN
|
||||
#define LINKAGE_AREA_SIZE 24
|
||||
#define LR_OFFSET 8
|
||||
#elif defined _CALL_AIX
|
||||
@ -99,7 +103,7 @@ static const int tcg_target_reg_alloc_order[] = {
|
||||
TCG_REG_R29,
|
||||
TCG_REG_R30,
|
||||
TCG_REG_R31,
|
||||
#ifdef _CALL_DARWIN
|
||||
#ifdef TCG_TARGET_CALL_DARWIN
|
||||
TCG_REG_R2,
|
||||
#endif
|
||||
TCG_REG_R3,
|
||||
@ -110,7 +114,7 @@ static const int tcg_target_reg_alloc_order[] = {
|
||||
TCG_REG_R8,
|
||||
TCG_REG_R9,
|
||||
TCG_REG_R10,
|
||||
#ifndef _CALL_DARWIN
|
||||
#ifndef TCG_TARGET_CALL_DARWIN
|
||||
TCG_REG_R11,
|
||||
#endif
|
||||
TCG_REG_R12,
|
||||
@ -140,7 +144,7 @@ static const int tcg_target_call_oarg_regs[2] = {
|
||||
};
|
||||
|
||||
static const int tcg_target_callee_save_regs[] = {
|
||||
#ifdef _CALL_DARWIN
|
||||
#ifdef TCG_TARGET_CALL_DARWIN
|
||||
TCG_REG_R11,
|
||||
TCG_REG_R13,
|
||||
#endif
|
||||
@ -1965,7 +1969,7 @@ static void tcg_target_init(TCGContext *s)
|
||||
tcg_regset_set32(tcg_target_available_regs[TCG_TYPE_I32], 0, 0xffffffff);
|
||||
tcg_regset_set32(tcg_target_call_clobber_regs, 0,
|
||||
(1 << TCG_REG_R0) |
|
||||
#ifdef _CALL_DARWIN
|
||||
#ifdef TCG_TARGET_CALL_DARWIN
|
||||
(1 << TCG_REG_R2) |
|
||||
#endif
|
||||
(1 << TCG_REG_R3) |
|
||||
@ -1983,7 +1987,7 @@ static void tcg_target_init(TCGContext *s)
|
||||
tcg_regset_clear(s->reserved_regs);
|
||||
tcg_regset_set_reg(s->reserved_regs, TCG_REG_R0);
|
||||
tcg_regset_set_reg(s->reserved_regs, TCG_REG_R1);
|
||||
#ifndef _CALL_DARWIN
|
||||
#ifndef TCG_TARGET_CALL_DARWIN
|
||||
tcg_regset_set_reg(s->reserved_regs, TCG_REG_R2);
|
||||
#endif
|
||||
#ifdef _CALL_SYSV
|
||||
|
Loading…
x
Reference in New Issue
Block a user