mirror of https://gitee.com/openkylin/linux.git
sh: SH-5 pt_regs.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
fe51bc9eaf
commit
33f242ed11
|
@ -5,7 +5,16 @@
|
||||||
* Copyright (C) 1999, 2000 Niibe Yutaka
|
* Copyright (C) 1999, 2000 Niibe Yutaka
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#if defined(__SH5__) || defined(CONFIG_SUPERH64)
|
||||||
|
struct pt_regs {
|
||||||
|
unsigned long long pc;
|
||||||
|
unsigned long long sr;
|
||||||
|
unsigned long long syscall_nr;
|
||||||
|
unsigned long long regs[63];
|
||||||
|
unsigned long long tregs[8];
|
||||||
|
unsigned long long pad[2];
|
||||||
|
};
|
||||||
|
#else
|
||||||
/*
|
/*
|
||||||
* GCC defines register number like this:
|
* GCC defines register number like this:
|
||||||
* -----------------------------
|
* -----------------------------
|
||||||
|
@ -28,7 +37,7 @@
|
||||||
|
|
||||||
#define REG_PR 17
|
#define REG_PR 17
|
||||||
#define REG_SR 18
|
#define REG_SR 18
|
||||||
#define REG_GBR 19
|
#define REG_GBR 19
|
||||||
#define REG_MACH 20
|
#define REG_MACH 20
|
||||||
#define REG_MACL 21
|
#define REG_MACL 21
|
||||||
|
|
||||||
|
@ -80,10 +89,14 @@ struct pt_dspregs {
|
||||||
|
|
||||||
#define PTRACE_GETDSPREGS 55
|
#define PTRACE_GETDSPREGS 55
|
||||||
#define PTRACE_SETDSPREGS 56
|
#define PTRACE_SETDSPREGS 56
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
#ifdef __KERNEL__
|
||||||
#define user_mode(regs) (((regs)->sr & 0x40000000)==0)
|
#include <asm/addrspace.h>
|
||||||
#define instruction_pointer(regs) ((regs)->pc)
|
|
||||||
|
#define user_mode(regs) (((regs)->sr & 0x40000000)==0)
|
||||||
|
#define instruction_pointer(regs) ((regs)->pc)
|
||||||
|
|
||||||
extern void show_regs(struct pt_regs *);
|
extern void show_regs(struct pt_regs *);
|
||||||
|
|
||||||
#ifdef CONFIG_SH_DSP
|
#ifdef CONFIG_SH_DSP
|
||||||
|
@ -100,10 +113,13 @@ static inline unsigned long profile_pc(struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
unsigned long pc = instruction_pointer(regs);
|
unsigned long pc = instruction_pointer(regs);
|
||||||
|
|
||||||
if (pc >= 0xa0000000UL && pc < 0xc0000000UL)
|
#ifdef P2SEG
|
||||||
|
if (pc >= P2SEG && pc < P3SEG)
|
||||||
pc -= 0x20000000;
|
pc -= 0x20000000;
|
||||||
return pc;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
return pc;
|
||||||
|
}
|
||||||
|
#endif /* __KERNEL__ */
|
||||||
|
|
||||||
#endif /* __ASM_SH_PTRACE_H */
|
#endif /* __ASM_SH_PTRACE_H */
|
||||||
|
|
Loading…
Reference in New Issue