diff options
author | Paul Mundt <lethal@linux-sh.org> | 2010-02-28 21:52:03 -0500 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-02-28 21:52:03 -0500 |
commit | 105244ec95590f5f12a90d974650ab5c7bc8ec79 (patch) | |
tree | d7f5617900a8b5cdab6a9e5bb714a8b1c3533650 /arch/sh/kernel/hw_breakpoint.c | |
parent | 30ff056c42c665b9ea535d8515890857ae382540 (diff) |
sh: hw-breakpoints: Accept breakpoints on NULL addresses.
This follows the x86 change 84d710926797a6e317e7e94654a3ccd771cfd8a3
("hw-breakpoints: Accept breakpoints on NULL address") and restores the
previous expected ptrace behaviour.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/kernel/hw_breakpoint.c')
-rw-r--r-- | arch/sh/kernel/hw_breakpoint.c | 30 |
1 files changed, 6 insertions, 24 deletions
diff --git a/arch/sh/kernel/hw_breakpoint.c b/arch/sh/kernel/hw_breakpoint.c index e2f1753d275c..675eea7785d9 100644 --- a/arch/sh/kernel/hw_breakpoint.c +++ b/arch/sh/kernel/hw_breakpoint.c | |||
@@ -143,26 +143,6 @@ static int arch_check_va_in_kernelspace(unsigned long va, u8 hbp_len) | |||
143 | return (va >= TASK_SIZE) && ((va + len - 1) >= TASK_SIZE); | 143 | return (va >= TASK_SIZE) && ((va + len - 1) >= TASK_SIZE); |
144 | } | 144 | } |
145 | 145 | ||
146 | /* | ||
147 | * Store a breakpoint's encoded address, length, and type. | ||
148 | */ | ||
149 | static int arch_store_info(struct perf_event *bp) | ||
150 | { | ||
151 | struct arch_hw_breakpoint *info = counter_arch_bp(bp); | ||
152 | |||
153 | /* | ||
154 | * User-space requests will always have the address field populated | ||
155 | * For kernel-addresses, either the address or symbol name can be | ||
156 | * specified. | ||
157 | */ | ||
158 | if (info->name) | ||
159 | info->address = (unsigned long)kallsyms_lookup_name(info->name); | ||
160 | if (info->address) | ||
161 | return 0; | ||
162 | |||
163 | return -EINVAL; | ||
164 | } | ||
165 | |||
166 | int arch_bp_generic_fields(int sh_len, int sh_type, | 146 | int arch_bp_generic_fields(int sh_len, int sh_type, |
167 | int *gen_len, int *gen_type) | 147 | int *gen_len, int *gen_type) |
168 | { | 148 | { |
@@ -276,10 +256,12 @@ int arch_validate_hwbkpt_settings(struct perf_event *bp, | |||
276 | return ret; | 256 | return ret; |
277 | } | 257 | } |
278 | 258 | ||
279 | ret = arch_store_info(bp); | 259 | /* |
280 | 260 | * For kernel-addresses, either the address or symbol name can be | |
281 | if (ret < 0) | 261 | * specified. |
282 | return ret; | 262 | */ |
263 | if (info->name) | ||
264 | info->address = (unsigned long)kallsyms_lookup_name(info->name); | ||
283 | 265 | ||
284 | /* | 266 | /* |
285 | * Check that the low-order bits of the address are appropriate | 267 | * Check that the low-order bits of the address are appropriate |