mirror of
https://github.com/SELinuxProject/selinux
synced 2024-12-18 12:14:33 +00:00
libsepol: do not check decl->symtab[i].nprim
Commit02a7d77ef2
("libsepol: make parsing symbol table headers more robust") broke refpolicy build, because checkmodule generates avrule decl blocks with "decl->symtab[i].nprim = 0" for all possible i, even when decl->symtab[SYM_ROLES] and decl->symtab[SYM_TYPES] are not empty. More precisely, decl->symtab[i].nprim seems to be only updated in libsepol/src/link.c (in *_copy_callback() functions). Revert the buggy part of commit02a7d77ef2
to fix this regression. Signed-off-by: Nicolas Iooss <nicolas.iooss@m4x.org>
This commit is contained in:
parent
86bad3dbf9
commit
73313a7528
@ -3510,10 +3510,6 @@ static int avrule_decl_read(policydb_t * p, avrule_decl_t * decl,
|
||||
return -1;
|
||||
nprim = le32_to_cpu(buf[0]);
|
||||
nel = le32_to_cpu(buf[1]);
|
||||
if (nel && !nprim) {
|
||||
ERR(fp->handle, "unexpected items in decl symbol table with no symbol");
|
||||
return -1;
|
||||
}
|
||||
for (j = 0; j < nel; j++) {
|
||||
if (read_f[i] (p, decl->symtab[i].table, fp)) {
|
||||
return -1;
|
||||
|
Loading…
Reference in New Issue
Block a user