mirror of https://gitee.com/openkylin/linux.git
arm64: don't use asm-generic/ptrace.h
Doing the indirection through macros for the regs accessors just makes them harder to read, so implement the helpers directly. Note that only the helpers actually used are implemented now. Signed-off-by: Christoph Hellwig <hch@lst.de> Acked-by: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
f2c7c76c5d
commit
56a5d00328
|
@ -228,11 +228,12 @@ static inline void forget_syscall(struct pt_regs *regs)
|
||||||
#define fast_interrupts_enabled(regs) \
|
#define fast_interrupts_enabled(regs) \
|
||||||
(!((regs)->pstate & PSR_F_BIT))
|
(!((regs)->pstate & PSR_F_BIT))
|
||||||
|
|
||||||
#define GET_USP(regs) \
|
static inline unsigned long user_stack_pointer(struct pt_regs *regs)
|
||||||
(!compat_user_mode(regs) ? (regs)->sp : (regs)->compat_sp)
|
{
|
||||||
|
if (compat_user_mode(regs))
|
||||||
#define SET_USP(ptregs, value) \
|
return regs->compat_sp;
|
||||||
(!compat_user_mode(regs) ? ((regs)->sp = value) : ((regs)->compat_sp = value))
|
return regs->sp;
|
||||||
|
}
|
||||||
|
|
||||||
extern int regs_query_register_offset(const char *name);
|
extern int regs_query_register_offset(const char *name);
|
||||||
extern unsigned long regs_get_kernel_stack_nth(struct pt_regs *regs,
|
extern unsigned long regs_get_kernel_stack_nth(struct pt_regs *regs,
|
||||||
|
@ -331,13 +332,20 @@ static inline unsigned long regs_get_kernel_argument(struct pt_regs *regs,
|
||||||
struct task_struct;
|
struct task_struct;
|
||||||
int valid_user_regs(struct user_pt_regs *regs, struct task_struct *task);
|
int valid_user_regs(struct user_pt_regs *regs, struct task_struct *task);
|
||||||
|
|
||||||
#define GET_IP(regs) ((unsigned long)(regs)->pc)
|
static inline unsigned long instruction_pointer(struct pt_regs *regs)
|
||||||
#define SET_IP(regs, value) ((regs)->pc = ((u64) (value)))
|
{
|
||||||
|
return regs->pc;
|
||||||
|
}
|
||||||
|
static inline void instruction_pointer_set(struct pt_regs *regs,
|
||||||
|
unsigned long val)
|
||||||
|
{
|
||||||
|
regs->pc = val;
|
||||||
|
}
|
||||||
|
|
||||||
#define GET_FP(ptregs) ((unsigned long)(ptregs)->regs[29])
|
static inline unsigned long frame_pointer(struct pt_regs *regs)
|
||||||
#define SET_FP(ptregs, value) ((ptregs)->regs[29] = ((u64) (value)))
|
{
|
||||||
|
return regs->regs[29];
|
||||||
#include <asm-generic/ptrace.h>
|
}
|
||||||
|
|
||||||
#define procedure_link_pointer(regs) ((regs)->regs[30])
|
#define procedure_link_pointer(regs) ((regs)->regs[30])
|
||||||
|
|
||||||
|
@ -347,7 +355,6 @@ static inline void procedure_link_pointer_set(struct pt_regs *regs,
|
||||||
procedure_link_pointer(regs) = val;
|
procedure_link_pointer(regs) = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
#undef profile_pc
|
|
||||||
extern unsigned long profile_pc(struct pt_regs *regs);
|
extern unsigned long profile_pc(struct pt_regs *regs);
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
Loading…
Reference in New Issue