aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/sh/kernel/ptrace_32.c2
-rw-r--r--arch/x86/kernel/ptrace.c2
-rw-r--r--include/linux/hw_breakpoint.h6
3 files changed, 8 insertions, 2 deletions
diff --git a/arch/sh/kernel/ptrace_32.c b/arch/sh/kernel/ptrace_32.c
index 7759a9a93211..d4104ce9fe53 100644
--- a/arch/sh/kernel/ptrace_32.c
+++ b/arch/sh/kernel/ptrace_32.c
@@ -85,7 +85,7 @@ static int set_single_step(struct task_struct *tsk, unsigned long addr)
85 85
86 bp = thread->ptrace_bps[0]; 86 bp = thread->ptrace_bps[0];
87 if (!bp) { 87 if (!bp) {
88 hw_breakpoint_init(&attr); 88 ptrace_breakpoint_init(&attr);
89 89
90 attr.bp_addr = addr; 90 attr.bp_addr = addr;
91 attr.bp_len = HW_BREAKPOINT_LEN_2; 91 attr.bp_len = HW_BREAKPOINT_LEN_2;
diff --git a/arch/x86/kernel/ptrace.c b/arch/x86/kernel/ptrace.c
index 055be0afd330..70c4872cd8aa 100644
--- a/arch/x86/kernel/ptrace.c
+++ b/arch/x86/kernel/ptrace.c
@@ -688,7 +688,7 @@ static int ptrace_set_breakpoint_addr(struct task_struct *tsk, int nr,
688 struct perf_event_attr attr; 688 struct perf_event_attr attr;
689 689
690 if (!t->ptrace_bps[nr]) { 690 if (!t->ptrace_bps[nr]) {
691 hw_breakpoint_init(&attr); 691 ptrace_breakpoint_init(&attr);
692 /* 692 /*
693 * Put stub len and type to register (reserve) an inactive but 693 * Put stub len and type to register (reserve) an inactive but
694 * correct bp 694 * correct bp
diff --git a/include/linux/hw_breakpoint.h b/include/linux/hw_breakpoint.h
index c70d27af03f9..a0aa5a9cfb0e 100644
--- a/include/linux/hw_breakpoint.h
+++ b/include/linux/hw_breakpoint.h
@@ -34,6 +34,12 @@ static inline void hw_breakpoint_init(struct perf_event_attr *attr)
34 attr->sample_period = 1; 34 attr->sample_period = 1;
35} 35}
36 36
37static inline void ptrace_breakpoint_init(struct perf_event_attr *attr)
38{
39 hw_breakpoint_init(attr);
40 attr->exclude_kernel = 1;
41}
42
37static inline unsigned long hw_breakpoint_addr(struct perf_event *bp) 43static inline unsigned long hw_breakpoint_addr(struct perf_event *bp)
38{ 44{
39 return bp->attr.bp_addr; 45 return bp->attr.bp_addr;