Commit 9b2eacd8 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'Smack-for-5.15' of git://github.com/cschaufler/smack-next

Pull smack updates from Casey Schaufler:
 "There is a variable used only during start-up that's now marked
  __initdata and a change where the code was working by sheer luck that
  is now done properly.

  Both have been in next for several weeks and pass the Smack testsuite"

* tag 'Smack-for-5.15' of git://github.com/cschaufler/smack-next:
  smack: mark 'smack_enabled' global variable as __initdata
  Smack: Fix wrong semantics in smk_access_entry()
parents 8e0cd952 bfc3cac0
...@@ -302,7 +302,7 @@ int smack_populate_secattr(struct smack_known *skp); ...@@ -302,7 +302,7 @@ int smack_populate_secattr(struct smack_known *skp);
/* /*
* Shared data. * Shared data.
*/ */
extern int smack_enabled; extern int smack_enabled __initdata;
extern int smack_cipso_direct; extern int smack_cipso_direct;
extern int smack_cipso_mapped; extern int smack_cipso_mapped;
extern struct smack_known *smack_net_ambient; extern struct smack_known *smack_net_ambient;
......
...@@ -81,23 +81,22 @@ int log_policy = SMACK_AUDIT_DENIED; ...@@ -81,23 +81,22 @@ int log_policy = SMACK_AUDIT_DENIED;
int smk_access_entry(char *subject_label, char *object_label, int smk_access_entry(char *subject_label, char *object_label,
struct list_head *rule_list) struct list_head *rule_list)
{ {
int may = -ENOENT;
struct smack_rule *srp; struct smack_rule *srp;
list_for_each_entry_rcu(srp, rule_list, list) { list_for_each_entry_rcu(srp, rule_list, list) {
if (srp->smk_object->smk_known == object_label && if (srp->smk_object->smk_known == object_label &&
srp->smk_subject->smk_known == subject_label) { srp->smk_subject->smk_known == subject_label) {
may = srp->smk_access; int may = srp->smk_access;
break; /*
* MAY_WRITE implies MAY_LOCK.
*/
if ((may & MAY_WRITE) == MAY_WRITE)
may |= MAY_LOCK;
return may;
} }
} }
/* return -ENOENT;
* MAY_WRITE implies MAY_LOCK.
*/
if ((may & MAY_WRITE) == MAY_WRITE)
may |= MAY_LOCK;
return may;
} }
/** /**
......
...@@ -54,7 +54,7 @@ ...@@ -54,7 +54,7 @@
static DEFINE_MUTEX(smack_ipv6_lock); static DEFINE_MUTEX(smack_ipv6_lock);
static LIST_HEAD(smk_ipv6_port_list); static LIST_HEAD(smk_ipv6_port_list);
struct kmem_cache *smack_rule_cache; struct kmem_cache *smack_rule_cache;
int smack_enabled; int smack_enabled __initdata;
#define A(s) {"smack"#s, sizeof("smack"#s) - 1, Opt_##s} #define A(s) {"smack"#s, sizeof("smack"#s) - 1, Opt_##s}
static struct { static struct {
......
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