Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 46be14d2 authored by Markus Elfring's avatar Markus Elfring Committed by Paul Moore
Browse files

selinux: Return an error code only as a constant in sidtab_insert()



* Return an error code without storing it in an intermediate variable.

* Delete the local variable "rc" and the jump label "out" which became
  unnecessary with this refactoring.

Signed-off-by: default avatarMarkus Elfring <elfring@users.sourceforge.net>
Signed-off-by: default avatarPaul Moore <paul@paul-moore.com>
parent 62934ffb
Loading
Loading
Loading
Loading
+10 −17
Original line number Diff line number Diff line
@@ -32,13 +32,11 @@ int sidtab_init(struct sidtab *s)

int sidtab_insert(struct sidtab *s, u32 sid, struct context *context)
{
	int hvalue, rc = 0;
	int hvalue;
	struct sidtab_node *prev, *cur, *newnode;

	if (!s) {
		rc = -ENOMEM;
		goto out;
	}
	if (!s)
		return -ENOMEM;

	hvalue = SIDTAB_HASH(sid);
	prev = NULL;
@@ -48,21 +46,17 @@ int sidtab_insert(struct sidtab *s, u32 sid, struct context *context)
		cur = cur->next;
	}

	if (cur && sid == cur->sid) {
		rc = -EEXIST;
		goto out;
	}
	if (cur && sid == cur->sid)
		return -EEXIST;

	newnode = kmalloc(sizeof(*newnode), GFP_ATOMIC);
	if (!newnode) {
		rc = -ENOMEM;
		goto out;
	}
	if (!newnode)
		return -ENOMEM;

	newnode->sid = sid;
	if (context_cpy(&newnode->context, context)) {
		kfree(newnode);
		rc = -ENOMEM;
		goto out;
		return -ENOMEM;
	}

	if (prev) {
@@ -78,8 +72,7 @@ int sidtab_insert(struct sidtab *s, u32 sid, struct context *context)
	s->nel++;
	if (sid >= s->next_sid)
		s->next_sid = sid + 1;
out:
	return rc;
	return 0;
}

static struct context *sidtab_search_core(struct sidtab *s, u32 sid, int force)