diff options
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/auditfilter.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/kernel/auditfilter.c b/kernel/auditfilter.c index 0d6a8fc21f17..e4cafc11c510 100644 --- a/kernel/auditfilter.c +++ b/kernel/auditfilter.c | |||
@@ -914,7 +914,7 @@ static void audit_update_watch(struct audit_parent *parent, | |||
914 | } | 914 | } |
915 | 915 | ||
916 | ab = audit_log_start(NULL, GFP_KERNEL, AUDIT_CONFIG_CHANGE); | 916 | ab = audit_log_start(NULL, GFP_KERNEL, AUDIT_CONFIG_CHANGE); |
917 | audit_log_format(ab, "audit updated rules specifying watch="); | 917 | audit_log_format(ab, "audit updated rules specifying path="); |
918 | audit_log_untrustedstring(ab, owatch->path); | 918 | audit_log_untrustedstring(ab, owatch->path); |
919 | audit_log_format(ab, " with dev=%u ino=%lu\n", dev, ino); | 919 | audit_log_format(ab, " with dev=%u ino=%lu\n", dev, ino); |
920 | audit_log_end(ab); | 920 | audit_log_end(ab); |
@@ -937,19 +937,28 @@ static void audit_remove_parent_watches(struct audit_parent *parent) | |||
937 | struct audit_watch *w, *nextw; | 937 | struct audit_watch *w, *nextw; |
938 | struct audit_krule *r, *nextr; | 938 | struct audit_krule *r, *nextr; |
939 | struct audit_entry *e; | 939 | struct audit_entry *e; |
940 | struct audit_buffer *ab; | ||
940 | 941 | ||
941 | mutex_lock(&audit_filter_mutex); | 942 | mutex_lock(&audit_filter_mutex); |
942 | parent->flags |= AUDIT_PARENT_INVALID; | 943 | parent->flags |= AUDIT_PARENT_INVALID; |
943 | list_for_each_entry_safe(w, nextw, &parent->watches, wlist) { | 944 | list_for_each_entry_safe(w, nextw, &parent->watches, wlist) { |
944 | list_for_each_entry_safe(r, nextr, &w->rules, rlist) { | 945 | list_for_each_entry_safe(r, nextr, &w->rules, rlist) { |
945 | e = container_of(r, struct audit_entry, rule); | 946 | e = container_of(r, struct audit_entry, rule); |
947 | |||
948 | ab = audit_log_start(NULL, GFP_KERNEL, AUDIT_CONFIG_CHANGE); | ||
949 | audit_log_format(ab, "audit implicitly removed rule path="); | ||
950 | audit_log_untrustedstring(ab, w->path); | ||
951 | if (r->filterkey) { | ||
952 | audit_log_format(ab, " key="); | ||
953 | audit_log_untrustedstring(ab, r->filterkey); | ||
954 | } else | ||
955 | audit_log_format(ab, " key=(null)"); | ||
956 | audit_log_format(ab, " list=%d", r->listnr); | ||
957 | audit_log_end(ab); | ||
958 | |||
946 | list_del(&r->rlist); | 959 | list_del(&r->rlist); |
947 | list_del_rcu(&e->list); | 960 | list_del_rcu(&e->list); |
948 | call_rcu(&e->rcu, audit_free_rule_rcu); | 961 | call_rcu(&e->rcu, audit_free_rule_rcu); |
949 | |||
950 | audit_log(NULL, GFP_KERNEL, AUDIT_CONFIG_CHANGE, | ||
951 | "audit implicitly removed rule from list=%d\n", | ||
952 | AUDIT_FILTER_EXIT); | ||
953 | } | 962 | } |
954 | audit_remove_watch(w); | 963 | audit_remove_watch(w); |
955 | } | 964 | } |