| /* |
| * Target-specific parts of semihosting/arm-compat-semi.c. |
| * |
| * Copyright (c) 2005, 2007 CodeSourcery. |
| * Copyright (c) 2019, 2022 Linaro |
| * |
| * SPDX-License-Identifier: GPL-2.0-or-later |
| */ |
| |
| #ifndef TARGET_ARM_COMMON_SEMI_TARGET_H |
| #define TARGET_ARM_COMMON_SEMI_TARGET_H |
| |
| #ifndef CONFIG_USER_ONLY |
| #include "hw/arm/boot.h" |
| #endif |
| |
| static inline target_ulong common_semi_arg(CPUState *cs, int argno) |
| { |
| ARMCPU *cpu = ARM_CPU(cs); |
| CPUARMState *env = &cpu->env; |
| if (is_a64(env)) { |
| return env->xregs[argno]; |
| } else { |
| return env->regs[argno]; |
| } |
| } |
| |
| static inline void common_semi_set_ret(CPUState *cs, target_ulong ret) |
| { |
| ARMCPU *cpu = ARM_CPU(cs); |
| CPUARMState *env = &cpu->env; |
| if (is_a64(env)) { |
| env->xregs[0] = ret; |
| } else { |
| env->regs[0] = ret; |
| } |
| } |
| |
| static inline bool common_semi_sys_exit_extended(CPUState *cs, int nr) |
| { |
| return nr == TARGET_SYS_EXIT_EXTENDED || is_a64(cpu_env(cs)); |
| } |
| |
| static inline bool is_64bit_semihosting(CPUArchState *env) |
| { |
| return is_a64(env); |
| } |
| |
| static inline target_ulong common_semi_stack_bottom(CPUState *cs) |
| { |
| ARMCPU *cpu = ARM_CPU(cs); |
| CPUARMState *env = &cpu->env; |
| return is_a64(env) ? env->xregs[31] : env->regs[13]; |
| } |
| |
| static inline bool common_semi_has_synccache(CPUArchState *env) |
| { |
| /* Ok for A64, invalid for A32/T32 */ |
| return is_a64(env); |
| } |
| |
| #endif |