diff options
author | Paul Mackerras <paulus@samba.org> | 2010-06-28 22:50:32 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2010-06-29 23:54:58 -0400 |
commit | d09ec7387184eba9e3030496f0451204090ff610 (patch) | |
tree | c3a6f251bf695a20009d1cd3f0d7a9115fdb3018 /arch/powerpc/include/asm | |
parent | 76b0f1337690d223811c852ad3a5078eb89276c5 (diff) |
powerpc, hw_breakpoint: Tell generic code we have no instruction breakpoints
At present, hw_breakpoint_slots() returns 1 regardless of what
type of breakpoint is specified in the type argument. Since we
don't define CONFIG_HAVE_MIXED_BREAKPOINTS_REGS, there are
separate values for TYPE_INST and TYPE_DATA, and hw_breakpoint_slots()
returns 1 for both, effectively advertising instruction breakpoint
support which doesn't exist.
This fixes it by making hw_breakpoint_slots return 1 for TYPE_DATA
and 0 for TYPE_INST. This moves hw_breakpoint_slots() from the
powerpc hw_breakpoint.h to hw_breakpoint.c because the definitions
of TYPE_INST and TYPE_DATA aren't available in <asm/hw_breakpoint.h>.
They are defined in <linux/hw_breakpoint.h> but we can't include
that header in <asm/hw_breakpoint.h>, and nor can we rely on
<linux/hw_breakpoint.h> being included before <asm/hw_breakpoint.h>.
Since hw_breakpoint_slots() is only called at boot time, there is
no performance impact from making it a real function rather than
a static inline.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/include/asm')
-rw-r--r-- | arch/powerpc/include/asm/hw_breakpoint.h | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/arch/powerpc/include/asm/hw_breakpoint.h b/arch/powerpc/include/asm/hw_breakpoint.h index ea87f8ae7bdb..1c33ec17ca36 100644 --- a/arch/powerpc/include/asm/hw_breakpoint.h +++ b/arch/powerpc/include/asm/hw_breakpoint.h | |||
@@ -37,10 +37,6 @@ struct arch_hw_breakpoint { | |||
37 | #include <asm/reg.h> | 37 | #include <asm/reg.h> |
38 | #include <asm/system.h> | 38 | #include <asm/system.h> |
39 | 39 | ||
40 | static inline int hw_breakpoint_slots(int type) | ||
41 | { | ||
42 | return HBP_NUM; | ||
43 | } | ||
44 | struct perf_event; | 40 | struct perf_event; |
45 | struct pmu; | 41 | struct pmu; |
46 | struct perf_sample_data; | 42 | struct perf_sample_data; |
@@ -49,6 +45,7 @@ struct perf_sample_data; | |||
49 | /* Maximum permissible length of any HW Breakpoint */ | 45 | /* Maximum permissible length of any HW Breakpoint */ |
50 | #define HW_BREAKPOINT_LEN 0x8 | 46 | #define HW_BREAKPOINT_LEN 0x8 |
51 | 47 | ||
48 | extern int hw_breakpoint_slots(int type); | ||
52 | extern int arch_bp_generic_fields(int type, int *gen_bp_type); | 49 | extern int arch_bp_generic_fields(int type, int *gen_bp_type); |
53 | extern int arch_check_bp_in_kernelspace(struct perf_event *bp); | 50 | extern int arch_check_bp_in_kernelspace(struct perf_event *bp); |
54 | extern int arch_validate_hwbkpt_settings(struct perf_event *bp); | 51 | extern int arch_validate_hwbkpt_settings(struct perf_event *bp); |