Blame SOURCES/0004-libsepol-cil-cil_reset_classperms_set-should-not-res.patch

212ad1
From 52bf0fe9ce922229e8bb3b99faa7c7dce2c3531f Mon Sep 17 00:00:00 2001
212ad1
From: James Carter <jwcart2@gmail.com>
212ad1
Date: Thu, 8 Apr 2021 13:32:06 -0400
212ad1
Subject: [PATCH] libsepol/cil: cil_reset_classperms_set() should not reset
212ad1
 classpermission
212ad1
212ad1
In struct cil_classperms_set, the set field is a pointer to a
212ad1
struct cil_classpermission which is looked up in the symbol table.
212ad1
Since the cil_classperms_set does not create the cil_classpermission,
212ad1
it should not reset it.
212ad1
212ad1
Set the set field to NULL instead of resetting the classpermission
212ad1
that it points to.
212ad1
212ad1
Signed-off-by: James Carter <jwcart2@gmail.com>
212ad1
212ad1
(cherry-picked from SElinuxProject
212ad1
 commit: c49a8ea09501ad66e799ea41b8154b6770fec2c8)
212ad1
---
212ad1
 libsepol/cil/src/cil_reset_ast.c | 6 +++++-
212ad1
 1 file changed, 5 insertions(+), 1 deletion(-)
212ad1
212ad1
diff --git a/libsepol/cil/src/cil_reset_ast.c b/libsepol/cil/src/cil_reset_ast.c
212ad1
index f321b396..7bf0391b 100644
212ad1
--- a/libsepol/cil/src/cil_reset_ast.c
212ad1
+++ b/libsepol/cil/src/cil_reset_ast.c
212ad1
@@ -57,7 +57,11 @@ static void cil_reset_classpermission(struct cil_classpermission *cp)
212ad1
 
212ad1
 static void cil_reset_classperms_set(struct cil_classperms_set *cp_set)
212ad1
 {
212ad1
-	cil_reset_classpermission(cp_set->set);
212ad1
+	if (cp_set == NULL) {
212ad1
+		return;
212ad1
+	}
212ad1
+
212ad1
+	cp_set->set = NULL;
212ad1
 }
212ad1
 
212ad1
 static inline void cil_reset_classperms_list(struct cil_list *cp_list)
212ad1
-- 
212ad1
2.30.2
212ad1