提交 4a1def4e 编写于 作者: A Alexander Graf 提交者: Riku Voipio

linux-user: ppc: mark as long long aligned

The SysV PPC32 ABI dictates that long long (64bit) parameters are pass in odd/even
register pairs. Because unlike ARM and MIPS we start at an odd register number,
we can reuse the same aligning code that ARM and MIPS use.

Clarified inline comment that it is SysV ABI that requires long long aligned
parameters - Riku
Signed-off-by: NAlexander Graf <agraf@suse.de>
Signed-off-by: NRiku Voipio <riku.voipio@linaro.org>
上级 07e10e5d
...@@ -587,12 +587,17 @@ extern int setfsgid(int); ...@@ -587,12 +587,17 @@ extern int setfsgid(int);
extern int setgroups(int, gid_t *); extern int setgroups(int, gid_t *);
/* ARM EABI and MIPS expect 64bit types aligned even on pairs or registers */ /* ARM EABI and MIPS expect 64bit types aligned even on pairs or registers */
#ifdef TARGET_ARM #ifdef TARGET_ARM
static inline int regpairs_aligned(void *cpu_env) { static inline int regpairs_aligned(void *cpu_env) {
return ((((CPUARMState *)cpu_env)->eabi) == 1) ; return ((((CPUARMState *)cpu_env)->eabi) == 1) ;
} }
#elif defined(TARGET_MIPS) #elif defined(TARGET_MIPS)
static inline int regpairs_aligned(void *cpu_env) { return 1; } static inline int regpairs_aligned(void *cpu_env) { return 1; }
#elif defined(TARGET_PPC) && !defined(TARGET_PPC64)
/* SysV AVI for PPC32 expects 64bit parameters to be passed on odd/even pairs
* of registers which translates to the same as ARM/MIPS, because we start with
* r3 as arg1 */
static inline int regpairs_aligned(void *cpu_env) { return 1; }
#else #else
static inline int regpairs_aligned(void *cpu_env) { return 0; } static inline int regpairs_aligned(void *cpu_env) { return 0; }
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册