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;
|
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 LINKAGE_AREA_SIZE 24
|
||||||
#define LR_OFFSET 8
|
#define LR_OFFSET 8
|
||||||
#elif defined _CALL_AIX
|
#elif defined _CALL_AIX
|
||||||
@ -99,7 +103,7 @@ static const int tcg_target_reg_alloc_order[] = {
|
|||||||
TCG_REG_R29,
|
TCG_REG_R29,
|
||||||
TCG_REG_R30,
|
TCG_REG_R30,
|
||||||
TCG_REG_R31,
|
TCG_REG_R31,
|
||||||
#ifdef _CALL_DARWIN
|
#ifdef TCG_TARGET_CALL_DARWIN
|
||||||
TCG_REG_R2,
|
TCG_REG_R2,
|
||||||
#endif
|
#endif
|
||||||
TCG_REG_R3,
|
TCG_REG_R3,
|
||||||
@ -110,7 +114,7 @@ static const int tcg_target_reg_alloc_order[] = {
|
|||||||
TCG_REG_R8,
|
TCG_REG_R8,
|
||||||
TCG_REG_R9,
|
TCG_REG_R9,
|
||||||
TCG_REG_R10,
|
TCG_REG_R10,
|
||||||
#ifndef _CALL_DARWIN
|
#ifndef TCG_TARGET_CALL_DARWIN
|
||||||
TCG_REG_R11,
|
TCG_REG_R11,
|
||||||
#endif
|
#endif
|
||||||
TCG_REG_R12,
|
TCG_REG_R12,
|
||||||
@ -140,7 +144,7 @@ static const int tcg_target_call_oarg_regs[2] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const int tcg_target_callee_save_regs[] = {
|
static const int tcg_target_callee_save_regs[] = {
|
||||||
#ifdef _CALL_DARWIN
|
#ifdef TCG_TARGET_CALL_DARWIN
|
||||||
TCG_REG_R11,
|
TCG_REG_R11,
|
||||||
TCG_REG_R13,
|
TCG_REG_R13,
|
||||||
#endif
|
#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_available_regs[TCG_TYPE_I32], 0, 0xffffffff);
|
||||||
tcg_regset_set32(tcg_target_call_clobber_regs, 0,
|
tcg_regset_set32(tcg_target_call_clobber_regs, 0,
|
||||||
(1 << TCG_REG_R0) |
|
(1 << TCG_REG_R0) |
|
||||||
#ifdef _CALL_DARWIN
|
#ifdef TCG_TARGET_CALL_DARWIN
|
||||||
(1 << TCG_REG_R2) |
|
(1 << TCG_REG_R2) |
|
||||||
#endif
|
#endif
|
||||||
(1 << TCG_REG_R3) |
|
(1 << TCG_REG_R3) |
|
||||||
@ -1983,7 +1987,7 @@ static void tcg_target_init(TCGContext *s)
|
|||||||
tcg_regset_clear(s->reserved_regs);
|
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_R0);
|
||||||
tcg_regset_set_reg(s->reserved_regs, TCG_REG_R1);
|
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);
|
tcg_regset_set_reg(s->reserved_regs, TCG_REG_R2);
|
||||||
#endif
|
#endif
|
||||||
#ifdef _CALL_SYSV
|
#ifdef _CALL_SYSV
|
||||||
|
Loading…
x
Reference in New Issue
Block a user