Commit 33f242ed authored by Paul Mundt's avatar Paul Mundt

sh: SH-5 pt_regs.

Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent fe51bc9e
...@@ -5,7 +5,16 @@ ...@@ -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 @@ ...@@ -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 { ...@@ -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) ...@@ -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;
#endif
return pc; return pc;
} }
#endif #endif /* __KERNEL__ */
#endif /* __ASM_SH_PTRACE_H */ #endif /* __ASM_SH_PTRACE_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment