]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - arch/sh/include/asm/ptrace.h
sh: PMB tidying.
[mirror_ubuntu-bionic-kernel.git] / arch / sh / include / asm / ptrace.h
CommitLineData
1da177e4
LT
1#ifndef __ASM_SH_PTRACE_H
2#define __ASM_SH_PTRACE_H
3
1da177e4
LT
4/*
5 * Copyright (C) 1999, 2000 Niibe Yutaka
6 *
7 */
f22ab814 8#if defined(__SH5__)
33f242ed
PM
9struct pt_regs {
10 unsigned long long pc;
11 unsigned long long sr;
ecd4ca52 12 long long syscall_nr;
33f242ed
PM
13 unsigned long long regs[63];
14 unsigned long long tregs[8];
15 unsigned long long pad[2];
16};
17#else
1da177e4
LT
18/*
19 * GCC defines register number like this:
20 * -----------------------------
21 * 0 - 15 are integer registers
22 * 17 - 22 are control/special registers
23 * 24 - 39 fp registers
24 * 40 - 47 xd registers
25 * 48 - fpscr register
26 * -----------------------------
27 *
28 * We follows above, except:
29 * 16 --- program counter (PC)
30 * 22 --- syscall #
31 * 23 --- floating point communication register
32 */
33#define REG_REG0 0
34#define REG_REG15 15
35
36#define REG_PC 16
37
38#define REG_PR 17
39#define REG_SR 18
33f242ed 40#define REG_GBR 19
1da177e4
LT
41#define REG_MACH 20
42#define REG_MACL 21
43
44#define REG_SYSCALL 22
45
46#define REG_FPREG0 23
47#define REG_FPREG15 38
48#define REG_XFREG0 39
49#define REG_XFREG15 54
50
51#define REG_FPSCR 55
52#define REG_FPUL 56
53
1da177e4
LT
54/*
55 * This struct defines the way the registers are stored on the
56 * kernel stack during a system call or other kernel entry.
57 */
58struct pt_regs {
59 unsigned long regs[16];
60 unsigned long pc;
61 unsigned long pr;
62 unsigned long sr;
63 unsigned long gbr;
64 unsigned long mach;
65 unsigned long macl;
66 long tra;
67};
68
69/*
70 * This struct defines the way the DSP registers are stored on the
71 * kernel stack during a system call or other kernel entry.
72 */
73struct pt_dspregs {
74 unsigned long a1;
75 unsigned long a0g;
76 unsigned long a1g;
77 unsigned long m0;
78 unsigned long m1;
79 unsigned long a0;
80 unsigned long x0;
81 unsigned long x1;
82 unsigned long y0;
83 unsigned long y1;
84 unsigned long dsr;
85 unsigned long rs;
86 unsigned long re;
87 unsigned long mod;
88};
dd76279b 89#endif
1da177e4 90
934135c1
PM
91#define PTRACE_GETREGS 12 /* General registers */
92#define PTRACE_SETREGS 13
93
94#define PTRACE_GETFPREGS 14 /* FPU registers */
95#define PTRACE_SETFPREGS 15
96
3bc24a1a
PM
97#define PTRACE_GETFDPIC 31 /* get the ELF fdpic loadmap address */
98
99#define PTRACE_GETFDPIC_EXEC 0 /* [addr] request the executable loadmap */
100#define PTRACE_GETFDPIC_INTERP 1 /* [addr] request the interpreter loadmap */
101
934135c1 102#define PTRACE_GETDSPREGS 55 /* DSP registers */
1da177e4
LT
103#define PTRACE_SETDSPREGS 56
104
b0f3ae03
PM
105#define PT_TEXT_END_ADDR 240
106#define PT_TEXT_ADDR 244 /* &(struct user)->start_code */
107#define PT_DATA_ADDR 248 /* &(struct user)->start_data */
be6514c6
KB
108#define PT_TEXT_LEN 252
109
1da177e4 110#ifdef __KERNEL__
33f242ed 111#include <asm/addrspace.h>
b0f3ae03
PM
112#include <asm/page.h>
113#include <asm/system.h>
33f242ed
PM
114
115#define user_mode(regs) (((regs)->sr & 0x40000000)==0)
5a4f7c66 116#define instruction_pointer(regs) ((unsigned long)(regs)->pc)
33f242ed 117
1da177e4
LT
118extern void show_regs(struct pt_regs *);
119
c459dbf2
PM
120/*
121 * These are defined as per linux/ptrace.h.
122 */
123struct task_struct;
124
125#define arch_has_single_step() (1)
126extern void user_enable_single_step(struct task_struct *);
127extern void user_disable_single_step(struct task_struct *);
128
34d0b5af
PM
129struct perf_event;
130struct perf_sample_data;
131
132extern void ptrace_triggered(struct perf_event *bp, int nmi,
133 struct perf_sample_data *data, struct pt_regs *regs);
134
3cf0f4ec 135#define task_pt_regs(task) \
4f099ebb 136 ((struct pt_regs *) (task_stack_page(task) + THREAD_SIZE) - 1)
3cf0f4ec 137
1da177e4
LT
138static inline unsigned long profile_pc(struct pt_regs *regs)
139{
140 unsigned long pc = instruction_pointer(regs);
141
b0f3ae03
PM
142#ifdef CONFIG_UNCACHED_MAPPING
143 /*
144 * If PC points in to the uncached mapping, fix it up and hand
145 * back the cached equivalent.
146 */
147 if ((pc >= (memory_start + cached_to_uncached)) &&
148 (pc < (memory_start + cached_to_uncached + uncached_size)))
149 pc -= cached_to_uncached;
33f242ed
PM
150#endif
151
1da177e4
LT
152 return pc;
153}
33f242ed 154#endif /* __KERNEL__ */
1da177e4
LT
155
156#endif /* __ASM_SH_PTRACE_H */