From 4c7e081e158b1d6a56a76b98f61d880f3d8a994d Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Thu, 13 Jul 2017 10:12:54 +0800 Subject: [PATCH] Eliminate the chance to segfault on older Android versions --- rules.c | 2 +- sepolicy.c | 20 ++++++++++---------- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/rules.c b/rules.c index 7b24593cf..12b90ee9e 100644 --- a/rules.c +++ b/rules.c @@ -232,7 +232,7 @@ void sepol_min_rules() { sepol_allow("system_server", "dex2oat_exec", "file", ALL); // xperms - if (policydb->policyvers >= 30) + if (policydb->policyvers >= POLICYDB_VERSION_XPERMS_IOCTL) sepol_allowxperm("domain", "devpts", "chr_file", "0x5400-0x54FF"); } diff --git a/sepolicy.c b/sepolicy.c index a0bf5a1d4..4a45a3064 100644 --- a/sepolicy.c +++ b/sepolicy.c @@ -255,7 +255,7 @@ int dump_policydb(const char *filename) { return 1; } - fd = open(filename, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH); + fd = open(filename, O_RDWR | O_CREAT, 0644); if (fd < 0) { fprintf(stderr, "Can't open '%s': %s\n", filename, strerror(errno)); @@ -290,7 +290,7 @@ int create_domain(char *d) { typedatum->flavor = TYPE_TYPE; uint32_t value = 0; - int r = symtab_insert(policydb, SYM_TYPES, strdup(d), typedatum, SCOPE_DECL, 1, &value); + symtab_insert(policydb, SYM_TYPES, strdup(d), typedatum, SCOPE_DECL, 1, &value); typedatum->s.value = value; if (ebitmap_set_bit(&policydb->global->branch_list->declared.scope[SYM_TYPES], value - 1, 1)) { @@ -303,14 +303,6 @@ int create_domain(char *d) { ebitmap_init(&policydb->attr_type_map[value-1]); ebitmap_set_bit(&policydb->type_attr_map[value-1], value-1, 1); - //Add the domain to all roles - for(unsigned i=0; ip_roles.nprim; ++i) { - //Not sure all those three calls are needed - ebitmap_set_bit(&policydb->role_val_to_struct[i]->types.negset, value-1, 0); - ebitmap_set_bit(&policydb->role_val_to_struct[i]->types.types, value-1, 1); - type_set_expand(&policydb->role_val_to_struct[i]->types, &policydb->role_val_to_struct[i]->cache, policydb, 0); - } - src = hashtab_search(policydb->p_types.table, d); if(!src) return 1; @@ -324,6 +316,14 @@ int create_domain(char *d) { if(policydb_index_others(NULL, policydb, 0)) return 1; + //Add the domain to all roles + for(unsigned i=0; ip_roles.nprim; ++i) { + //Not sure all those three calls are needed + ebitmap_set_bit(&policydb->role_val_to_struct[i]->types.negset, value-1, 0); + ebitmap_set_bit(&policydb->role_val_to_struct[i]->types.types, value-1, 1); + type_set_expand(&policydb->role_val_to_struct[i]->types, &policydb->role_val_to_struct[i]->cache, policydb, 0); + } + return set_attr("domain", value); }