aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/trace/trace_uprobe.c36
1 files changed, 18 insertions, 18 deletions
diff --git a/kernel/trace/trace_uprobe.c b/kernel/trace/trace_uprobe.c
index c082a7441345..51bd071eaca0 100644
--- a/kernel/trace/trace_uprobe.c
+++ b/kernel/trace/trace_uprobe.c
@@ -1009,54 +1009,54 @@ uprobe_filter_event(struct trace_uprobe *tu, struct perf_event *event)
1009 return __uprobe_perf_filter(&tu->filter, event->hw.tp_target->mm); 1009 return __uprobe_perf_filter(&tu->filter, event->hw.tp_target->mm);
1010} 1010}
1011 1011
1012static int uprobe_perf_open(struct trace_uprobe *tu, struct perf_event *event) 1012static int uprobe_perf_close(struct trace_uprobe *tu, struct perf_event *event)
1013{ 1013{
1014 bool done; 1014 bool done;
1015 1015
1016 write_lock(&tu->filter.rwlock); 1016 write_lock(&tu->filter.rwlock);
1017 if (event->hw.tp_target) { 1017 if (event->hw.tp_target) {
1018 /* 1018 list_del(&event->hw.tp_list);
1019 * event->parent != NULL means copy_process(), we can avoid
1020 * uprobe_apply(). current->mm must be probed and we can rely
1021 * on dup_mmap() which preserves the already installed bp's.
1022 *
1023 * attr.enable_on_exec means that exec/mmap will install the
1024 * breakpoints we need.
1025 */
1026 done = tu->filter.nr_systemwide || 1019 done = tu->filter.nr_systemwide ||
1027 event->parent || event->attr.enable_on_exec || 1020 (event->hw.tp_target->flags & PF_EXITING) ||
1028 uprobe_filter_event(tu, event); 1021 uprobe_filter_event(tu, event);
1029 list_add(&event->hw.tp_list, &tu->filter.perf_events);
1030 } else { 1022 } else {
1023 tu->filter.nr_systemwide--;
1031 done = tu->filter.nr_systemwide; 1024 done = tu->filter.nr_systemwide;
1032 tu->filter.nr_systemwide++;
1033 } 1025 }
1034 write_unlock(&tu->filter.rwlock); 1026 write_unlock(&tu->filter.rwlock);
1035 1027
1036 if (!done) 1028 if (!done)
1037 uprobe_apply(tu->inode, tu->offset, &tu->consumer, true); 1029 uprobe_apply(tu->inode, tu->offset, &tu->consumer, false);
1038 1030
1039 return 0; 1031 return 0;
1040} 1032}
1041 1033
1042static int uprobe_perf_close(struct trace_uprobe *tu, struct perf_event *event) 1034static int uprobe_perf_open(struct trace_uprobe *tu, struct perf_event *event)
1043{ 1035{
1044 bool done; 1036 bool done;
1045 1037
1046 write_lock(&tu->filter.rwlock); 1038 write_lock(&tu->filter.rwlock);
1047 if (event->hw.tp_target) { 1039 if (event->hw.tp_target) {
1048 list_del(&event->hw.tp_list); 1040 /*
1041 * event->parent != NULL means copy_process(), we can avoid
1042 * uprobe_apply(). current->mm must be probed and we can rely
1043 * on dup_mmap() which preserves the already installed bp's.
1044 *
1045 * attr.enable_on_exec means that exec/mmap will install the
1046 * breakpoints we need.
1047 */
1049 done = tu->filter.nr_systemwide || 1048 done = tu->filter.nr_systemwide ||
1050 (event->hw.tp_target->flags & PF_EXITING) || 1049 event->parent || event->attr.enable_on_exec ||
1051 uprobe_filter_event(tu, event); 1050 uprobe_filter_event(tu, event);
1051 list_add(&event->hw.tp_list, &tu->filter.perf_events);
1052 } else { 1052 } else {
1053 tu->filter.nr_systemwide--;
1054 done = tu->filter.nr_systemwide; 1053 done = tu->filter.nr_systemwide;
1054 tu->filter.nr_systemwide++;
1055 } 1055 }
1056 write_unlock(&tu->filter.rwlock); 1056 write_unlock(&tu->filter.rwlock);
1057 1057
1058 if (!done) 1058 if (!done)
1059 uprobe_apply(tu->inode, tu->offset, &tu->consumer, false); 1059 uprobe_apply(tu->inode, tu->offset, &tu->consumer, true);
1060 1060
1061 return 0; 1061 return 0;
1062} 1062}