2005-04-16 22:20:36 +00:00
|
|
|
#ifndef __ASM_SH_PTRACE_H
|
|
|
|
#define __ASM_SH_PTRACE_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 1999, 2000 Niibe Yutaka
|
|
|
|
*
|
|
|
|
*/
|
2008-07-25 08:47:34 +00:00
|
|
|
#if defined(__SH5__)
|
2007-11-09 07:57:27 +00:00
|
|
|
struct pt_regs {
|
|
|
|
unsigned long long pc;
|
|
|
|
unsigned long long sr;
|
2009-04-27 08:05:38 +00:00
|
|
|
long long syscall_nr;
|
2007-11-09 07:57:27 +00:00
|
|
|
unsigned long long regs[63];
|
|
|
|
unsigned long long tregs[8];
|
|
|
|
unsigned long long pad[2];
|
|
|
|
};
|
|
|
|
#else
|
2005-04-16 22:20:36 +00:00
|
|
|
/*
|
|
|
|
* GCC defines register number like this:
|
|
|
|
* -----------------------------
|
|
|
|
* 0 - 15 are integer registers
|
|
|
|
* 17 - 22 are control/special registers
|
|
|
|
* 24 - 39 fp registers
|
|
|
|
* 40 - 47 xd registers
|
|
|
|
* 48 - fpscr register
|
|
|
|
* -----------------------------
|
|
|
|
*
|
|
|
|
* We follows above, except:
|
|
|
|
* 16 --- program counter (PC)
|
|
|
|
* 22 --- syscall #
|
|
|
|
* 23 --- floating point communication register
|
|
|
|
*/
|
|
|
|
#define REG_REG0 0
|
|
|
|
#define REG_REG15 15
|
|
|
|
|
|
|
|
#define REG_PC 16
|
|
|
|
|
|
|
|
#define REG_PR 17
|
|
|
|
#define REG_SR 18
|
2007-11-09 07:57:27 +00:00
|
|
|
#define REG_GBR 19
|
2005-04-16 22:20:36 +00:00
|
|
|
#define REG_MACH 20
|
|
|
|
#define REG_MACL 21
|
|
|
|
|
|
|
|
#define REG_SYSCALL 22
|
|
|
|
|
|
|
|
#define REG_FPREG0 23
|
|
|
|
#define REG_FPREG15 38
|
|
|
|
#define REG_XFREG0 39
|
|
|
|
#define REG_XFREG15 54
|
|
|
|
|
|
|
|
#define REG_FPSCR 55
|
|
|
|
#define REG_FPUL 56
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This struct defines the way the registers are stored on the
|
|
|
|
* kernel stack during a system call or other kernel entry.
|
|
|
|
*/
|
|
|
|
struct pt_regs {
|
|
|
|
unsigned long regs[16];
|
|
|
|
unsigned long pc;
|
|
|
|
unsigned long pr;
|
|
|
|
unsigned long sr;
|
|
|
|
unsigned long gbr;
|
|
|
|
unsigned long mach;
|
|
|
|
unsigned long macl;
|
|
|
|
long tra;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This struct defines the way the DSP registers are stored on the
|
|
|
|
* kernel stack during a system call or other kernel entry.
|
|
|
|
*/
|
|
|
|
struct pt_dspregs {
|
|
|
|
unsigned long a1;
|
|
|
|
unsigned long a0g;
|
|
|
|
unsigned long a1g;
|
|
|
|
unsigned long m0;
|
|
|
|
unsigned long m1;
|
|
|
|
unsigned long a0;
|
|
|
|
unsigned long x0;
|
|
|
|
unsigned long x1;
|
|
|
|
unsigned long y0;
|
|
|
|
unsigned long y1;
|
|
|
|
unsigned long dsr;
|
|
|
|
unsigned long rs;
|
|
|
|
unsigned long re;
|
|
|
|
unsigned long mod;
|
|
|
|
};
|
2008-12-10 11:14:15 +00:00
|
|
|
#endif
|
2005-04-16 22:20:36 +00:00
|
|
|
|
2008-09-12 10:52:36 +00:00
|
|
|
#define PTRACE_GETREGS 12 /* General registers */
|
|
|
|
#define PTRACE_SETREGS 13
|
|
|
|
|
|
|
|
#define PTRACE_GETFPREGS 14 /* FPU registers */
|
|
|
|
#define PTRACE_SETFPREGS 15
|
|
|
|
|
2008-05-19 04:40:12 +00:00
|
|
|
#define PTRACE_GETFDPIC 31 /* get the ELF fdpic loadmap address */
|
|
|
|
|
|
|
|
#define PTRACE_GETFDPIC_EXEC 0 /* [addr] request the executable loadmap */
|
|
|
|
#define PTRACE_GETFDPIC_INTERP 1 /* [addr] request the interpreter loadmap */
|
|
|
|
|
2008-09-12 10:52:36 +00:00
|
|
|
#define PTRACE_GETDSPREGS 55 /* DSP registers */
|
2005-04-16 22:20:36 +00:00
|
|
|
#define PTRACE_SETDSPREGS 56
|
|
|
|
|
2010-02-12 06:40:00 +00:00
|
|
|
#define PT_TEXT_END_ADDR 240
|
|
|
|
#define PT_TEXT_ADDR 244 /* &(struct user)->start_code */
|
|
|
|
#define PT_DATA_ADDR 248 /* &(struct user)->start_data */
|
2009-05-08 14:48:15 +00:00
|
|
|
#define PT_TEXT_LEN 252
|
|
|
|
|
2005-04-16 22:20:36 +00:00
|
|
|
#ifdef __KERNEL__
|
2007-11-09 07:57:27 +00:00
|
|
|
#include <asm/addrspace.h>
|
2010-02-12 06:40:00 +00:00
|
|
|
#include <asm/page.h>
|
|
|
|
#include <asm/system.h>
|
2007-11-09 07:57:27 +00:00
|
|
|
|
|
|
|
#define user_mode(regs) (((regs)->sr & 0x40000000)==0)
|
2007-11-20 09:08:06 +00:00
|
|
|
#define instruction_pointer(regs) ((unsigned long)(regs)->pc)
|
2007-11-09 07:57:27 +00:00
|
|
|
|
2005-04-16 22:20:36 +00:00
|
|
|
extern void show_regs(struct pt_regs *);
|
|
|
|
|
2008-07-30 10:09:31 +00:00
|
|
|
/*
|
|
|
|
* These are defined as per linux/ptrace.h.
|
|
|
|
*/
|
|
|
|
struct task_struct;
|
|
|
|
|
|
|
|
#define arch_has_single_step() (1)
|
|
|
|
extern void user_enable_single_step(struct task_struct *);
|
|
|
|
extern void user_disable_single_step(struct task_struct *);
|
|
|
|
|
2009-12-28 08:53:47 +00:00
|
|
|
struct perf_event;
|
|
|
|
struct perf_sample_data;
|
|
|
|
|
|
|
|
extern void ptrace_triggered(struct perf_event *bp, int nmi,
|
|
|
|
struct perf_sample_data *data, struct pt_regs *regs);
|
|
|
|
|
2006-01-12 09:05:44 +00:00
|
|
|
#define task_pt_regs(task) \
|
2009-02-23 07:16:34 +00:00
|
|
|
((struct pt_regs *) (task_stack_page(task) + THREAD_SIZE) - 1)
|
2006-01-12 09:05:44 +00:00
|
|
|
|
2005-04-16 22:20:36 +00:00
|
|
|
static inline unsigned long profile_pc(struct pt_regs *regs)
|
|
|
|
{
|
|
|
|
unsigned long pc = instruction_pointer(regs);
|
|
|
|
|
2010-02-17 07:28:00 +00:00
|
|
|
if (virt_addr_uncached(pc))
|
|
|
|
return CAC_ADDR(pc);
|
2007-11-09 07:57:27 +00:00
|
|
|
|
2005-04-16 22:20:36 +00:00
|
|
|
return pc;
|
|
|
|
}
|
2007-11-09 07:57:27 +00:00
|
|
|
#endif /* __KERNEL__ */
|
2005-04-16 22:20:36 +00:00
|
|
|
|
|
|
|
#endif /* __ASM_SH_PTRACE_H */
|