Commit 779c978f authored by John Johansen's avatar John Johansen Committed by Tim Gardner

UBUNTU: SAUCE: apparmor: Fix: add required locking of __aa_update_replacedby on merge path

BugLink: http://bugs.launchpad.net/bugs/1448912

__aa_update_replacedby needs the ns lock held, this is done for profile
load/replace/remove case and the label_update case but not when called
from the label merge paths.

NOTE: this is just a conceptal "fix", it can not be validly used as
      label_merge is called from atomic context and taking a mutex_lock
      may sleep.
Signed-off-by: default avatarJohn Johansen <john.johansen@canonical.com>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 7a1cf8a9
...@@ -1123,9 +1123,13 @@ struct aa_label *aa_label_merge(struct aa_label *a, struct aa_label *b, ...@@ -1123,9 +1123,13 @@ struct aa_label *aa_label_merge(struct aa_label *a, struct aa_label *b,
} }
/* only label update will set replacedby so ns lock is enough */ /* only label update will set replacedby so ns lock is enough */
new->replacedby = r; new->replacedby = r;
mutex_lock(&labels_ns(a)->lock);
write_lock_irqsave(&ls->lock, flags); write_lock_irqsave(&ls->lock, flags);
label = __label_merge_insert(ls, new, a, b); label = __label_merge_insert(ls, new, a, b);
write_unlock_irqrestore(&ls->lock, flags); write_unlock_irqrestore(&ls->lock, flags);
mutex_unlock(&labels_ns(a)->lock);
if (label != new) { if (label != new) {
/* new may not be fully setup so no put_label */ /* new may not be fully setup so no put_label */
aa_label_free(new); aa_label_free(new);
...@@ -1167,9 +1171,11 @@ struct aa_label *aa_label_vec_merge(struct aa_profile **vec, int len, ...@@ -1167,9 +1171,11 @@ struct aa_label *aa_label_vec_merge(struct aa_profile **vec, int len,
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
new->ent[i] = aa_get_profile(vec[i]); new->ent[i] = aa_get_profile(vec[i]);
} }
mutex_lock(&labels_ns(new)->lock);
write_lock_irqsave(&ls->lock, flags); write_lock_irqsave(&ls->lock, flags);
label = __aa_label_insert(ls, new, false); label = __aa_label_insert(ls, new, false);
write_unlock_irqrestore(&ls->lock, flags); write_unlock_irqrestore(&ls->lock, flags);
mutex_unlock(&labels_ns(new)->lock);
if (label != new) if (label != new)
/* not fully constructed don't put */ /* not fully constructed don't put */
aa_label_free(new); aa_label_free(new);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment