diff options
Diffstat (limited to 'include/asm-ppc64/ptrace-common.h')
-rw-r--r-- | include/asm-ppc64/ptrace-common.h | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/include/asm-ppc64/ptrace-common.h b/include/asm-ppc64/ptrace-common.h index af03547f9c7e..bd0f84c27bd0 100644 --- a/include/asm-ppc64/ptrace-common.h +++ b/include/asm-ppc64/ptrace-common.h | |||
@@ -11,6 +11,9 @@ | |||
11 | 11 | ||
12 | #ifndef _PPC64_PTRACE_COMMON_H | 12 | #ifndef _PPC64_PTRACE_COMMON_H |
13 | #define _PPC64_PTRACE_COMMON_H | 13 | #define _PPC64_PTRACE_COMMON_H |
14 | |||
15 | #include <linux/config.h> | ||
16 | |||
14 | /* | 17 | /* |
15 | * Set of msr bits that gdb can change on behalf of a process. | 18 | * Set of msr bits that gdb can change on behalf of a process. |
16 | */ | 19 | */ |
@@ -69,4 +72,73 @@ static inline void clear_single_step(struct task_struct *task) | |||
69 | clear_ti_thread_flag(task->thread_info, TIF_SINGLESTEP); | 72 | clear_ti_thread_flag(task->thread_info, TIF_SINGLESTEP); |
70 | } | 73 | } |
71 | 74 | ||
75 | #ifdef CONFIG_ALTIVEC | ||
76 | /* | ||
77 | * Get/set all the altivec registers vr0..vr31, vscr, vrsave, in one go. | ||
78 | * The transfer totals 34 quadword. Quadwords 0-31 contain the | ||
79 | * corresponding vector registers. Quadword 32 contains the vscr as the | ||
80 | * last word (offset 12) within that quadword. Quadword 33 contains the | ||
81 | * vrsave as the first word (offset 0) within the quadword. | ||
82 | * | ||
83 | * This definition of the VMX state is compatible with the current PPC32 | ||
84 | * ptrace interface. This allows signal handling and ptrace to use the | ||
85 | * same structures. This also simplifies the implementation of a bi-arch | ||
86 | * (combined (32- and 64-bit) gdb. | ||
87 | */ | ||
88 | |||
89 | /* | ||
90 | * Get contents of AltiVec register state in task TASK | ||
91 | */ | ||
92 | static inline int get_vrregs(unsigned long __user *data, | ||
93 | struct task_struct *task) | ||
94 | { | ||
95 | unsigned long regsize; | ||
96 | |||
97 | /* copy AltiVec registers VR[0] .. VR[31] */ | ||
98 | regsize = 32 * sizeof(vector128); | ||
99 | if (copy_to_user(data, task->thread.vr, regsize)) | ||
100 | return -EFAULT; | ||
101 | data += (regsize / sizeof(unsigned long)); | ||
102 | |||
103 | /* copy VSCR */ | ||
104 | regsize = 1 * sizeof(vector128); | ||
105 | if (copy_to_user(data, &task->thread.vscr, regsize)) | ||
106 | return -EFAULT; | ||
107 | data += (regsize / sizeof(unsigned long)); | ||
108 | |||
109 | /* copy VRSAVE */ | ||
110 | if (put_user(task->thread.vrsave, (u32 __user *)data)) | ||
111 | return -EFAULT; | ||
112 | |||
113 | return 0; | ||
114 | } | ||
115 | |||
116 | /* | ||
117 | * Write contents of AltiVec register state into task TASK. | ||
118 | */ | ||
119 | static inline int set_vrregs(struct task_struct *task, | ||
120 | unsigned long __user *data) | ||
121 | { | ||
122 | unsigned long regsize; | ||
123 | |||
124 | /* copy AltiVec registers VR[0] .. VR[31] */ | ||
125 | regsize = 32 * sizeof(vector128); | ||
126 | if (copy_from_user(task->thread.vr, data, regsize)) | ||
127 | return -EFAULT; | ||
128 | data += (regsize / sizeof(unsigned long)); | ||
129 | |||
130 | /* copy VSCR */ | ||
131 | regsize = 1 * sizeof(vector128); | ||
132 | if (copy_from_user(&task->thread.vscr, data, regsize)) | ||
133 | return -EFAULT; | ||
134 | data += (regsize / sizeof(unsigned long)); | ||
135 | |||
136 | /* copy VRSAVE */ | ||
137 | if (get_user(task->thread.vrsave, (u32 __user *)data)) | ||
138 | return -EFAULT; | ||
139 | |||
140 | return 0; | ||
141 | } | ||
142 | #endif | ||
143 | |||
72 | #endif /* _PPC64_PTRACE_COMMON_H */ | 144 | #endif /* _PPC64_PTRACE_COMMON_H */ |