diff options
-rw-r--r-- | arch/x86/include/asm/trace/mpx.h | 32 | ||||
-rw-r--r-- | arch/x86/mm/mpx.c | 2 |
2 files changed, 34 insertions, 0 deletions
diff --git a/arch/x86/include/asm/trace/mpx.h b/arch/x86/include/asm/trace/mpx.h index 5c3af06a2ae1..c13c6fa3fa92 100644 --- a/arch/x86/include/asm/trace/mpx.h +++ b/arch/x86/include/asm/trace/mpx.h | |||
@@ -63,6 +63,38 @@ TRACE_EVENT(bounds_exception_mpx, | |||
63 | __entry->bndstatus) | 63 | __entry->bndstatus) |
64 | ); | 64 | ); |
65 | 65 | ||
66 | DECLARE_EVENT_CLASS(mpx_range_trace, | ||
67 | |||
68 | TP_PROTO(unsigned long start, | ||
69 | unsigned long end), | ||
70 | TP_ARGS(start, end), | ||
71 | |||
72 | TP_STRUCT__entry( | ||
73 | __field(unsigned long, start) | ||
74 | __field(unsigned long, end) | ||
75 | ), | ||
76 | |||
77 | TP_fast_assign( | ||
78 | __entry->start = start; | ||
79 | __entry->end = end; | ||
80 | ), | ||
81 | |||
82 | TP_printk("[0x%p:0x%p]", | ||
83 | (void *)__entry->start, | ||
84 | (void *)__entry->end | ||
85 | ) | ||
86 | ); | ||
87 | |||
88 | DEFINE_EVENT(mpx_range_trace, mpx_unmap_zap, | ||
89 | TP_PROTO(unsigned long start, unsigned long end), | ||
90 | TP_ARGS(start, end) | ||
91 | ); | ||
92 | |||
93 | DEFINE_EVENT(mpx_range_trace, mpx_unmap_search, | ||
94 | TP_PROTO(unsigned long start, unsigned long end), | ||
95 | TP_ARGS(start, end) | ||
96 | ); | ||
97 | |||
66 | #else | 98 | #else |
67 | 99 | ||
68 | /* | 100 | /* |
diff --git a/arch/x86/mm/mpx.c b/arch/x86/mm/mpx.c index 75e5d7043f65..55729ee9263e 100644 --- a/arch/x86/mm/mpx.c +++ b/arch/x86/mm/mpx.c | |||
@@ -668,6 +668,7 @@ static int zap_bt_entries(struct mm_struct *mm, | |||
668 | 668 | ||
669 | len = min(vma->vm_end, end) - addr; | 669 | len = min(vma->vm_end, end) - addr; |
670 | zap_page_range(vma, addr, len, NULL); | 670 | zap_page_range(vma, addr, len, NULL); |
671 | trace_mpx_unmap_zap(addr, addr+len); | ||
671 | 672 | ||
672 | vma = vma->vm_next; | 673 | vma = vma->vm_next; |
673 | addr = vma->vm_start; | 674 | addr = vma->vm_start; |
@@ -840,6 +841,7 @@ static int mpx_unmap_tables(struct mm_struct *mm, | |||
840 | long __user *bd_entry, *bde_start, *bde_end; | 841 | long __user *bd_entry, *bde_start, *bde_end; |
841 | unsigned long bt_addr; | 842 | unsigned long bt_addr; |
842 | 843 | ||
844 | trace_mpx_unmap_search(start, end); | ||
843 | /* | 845 | /* |
844 | * "Edge" bounds tables are those which are being used by the region | 846 | * "Edge" bounds tables are those which are being used by the region |
845 | * (start -> end), but that may be shared with adjacent areas. If they | 847 | * (start -> end), but that may be shared with adjacent areas. If they |