xref: /aosp_15_r20/external/selinux/libsepol/fuzz/secilc-fuzzer.c (revision 2d543d20722ada2425b5bdab9d0d1d29470e7bba)
1*2d543d20SAndroid Build Coastguard Worker #include <stdlib.h>
2*2d543d20SAndroid Build Coastguard Worker #include <stdio.h>
3*2d543d20SAndroid Build Coastguard Worker #include <stdint.h>
4*2d543d20SAndroid Build Coastguard Worker #include <string.h>
5*2d543d20SAndroid Build Coastguard Worker #include <getopt.h>
6*2d543d20SAndroid Build Coastguard Worker #include <sys/stat.h>
7*2d543d20SAndroid Build Coastguard Worker 
8*2d543d20SAndroid Build Coastguard Worker #include <sepol/cil/cil.h>
9*2d543d20SAndroid Build Coastguard Worker #include <sepol/policydb.h>
10*2d543d20SAndroid Build Coastguard Worker 
log_handler(int lvl,const char * msg)11*2d543d20SAndroid Build Coastguard Worker static void log_handler(__attribute__((unused)) int lvl, __attribute__((unused)) const char *msg) {
12*2d543d20SAndroid Build Coastguard Worker 	/* be quiet */
13*2d543d20SAndroid Build Coastguard Worker }
14*2d543d20SAndroid Build Coastguard Worker 
LLVMFuzzerTestOneInput(const uint8_t * data,size_t size)15*2d543d20SAndroid Build Coastguard Worker int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
16*2d543d20SAndroid Build Coastguard Worker 	enum cil_log_level log_level = CIL_ERR;
17*2d543d20SAndroid Build Coastguard Worker 	struct sepol_policy_file *pf = NULL;
18*2d543d20SAndroid Build Coastguard Worker 	FILE *dev_null = NULL;
19*2d543d20SAndroid Build Coastguard Worker 	int target = SEPOL_TARGET_SELINUX;
20*2d543d20SAndroid Build Coastguard Worker 	int disable_dontaudit = 0;
21*2d543d20SAndroid Build Coastguard Worker 	int multiple_decls = 0;
22*2d543d20SAndroid Build Coastguard Worker 	int disable_neverallow = 0;
23*2d543d20SAndroid Build Coastguard Worker 	int preserve_tunables = 0;
24*2d543d20SAndroid Build Coastguard Worker 	int policyvers = POLICYDB_VERSION_MAX;
25*2d543d20SAndroid Build Coastguard Worker 	int mls = -1;
26*2d543d20SAndroid Build Coastguard Worker 	int attrs_expand_generated = 0;
27*2d543d20SAndroid Build Coastguard Worker 	struct cil_db *db = NULL;
28*2d543d20SAndroid Build Coastguard Worker 	sepol_policydb_t *pdb = NULL;
29*2d543d20SAndroid Build Coastguard Worker 
30*2d543d20SAndroid Build Coastguard Worker 	cil_set_log_level(log_level);
31*2d543d20SAndroid Build Coastguard Worker 	cil_set_log_handler(log_handler);
32*2d543d20SAndroid Build Coastguard Worker 
33*2d543d20SAndroid Build Coastguard Worker 	cil_db_init(&db);
34*2d543d20SAndroid Build Coastguard Worker 	cil_set_disable_dontaudit(db, disable_dontaudit);
35*2d543d20SAndroid Build Coastguard Worker 	cil_set_multiple_decls(db, multiple_decls);
36*2d543d20SAndroid Build Coastguard Worker 	cil_set_disable_neverallow(db, disable_neverallow);
37*2d543d20SAndroid Build Coastguard Worker 	cil_set_preserve_tunables(db, preserve_tunables);
38*2d543d20SAndroid Build Coastguard Worker 	cil_set_mls(db, mls);
39*2d543d20SAndroid Build Coastguard Worker 	cil_set_target_platform(db, target);
40*2d543d20SAndroid Build Coastguard Worker 	cil_set_policy_version(db, policyvers);
41*2d543d20SAndroid Build Coastguard Worker 	cil_set_attrs_expand_generated(db, attrs_expand_generated);
42*2d543d20SAndroid Build Coastguard Worker 
43*2d543d20SAndroid Build Coastguard Worker 	if (cil_add_file(db, "fuzz", (const char *)data, size) != SEPOL_OK)
44*2d543d20SAndroid Build Coastguard Worker 		goto exit;
45*2d543d20SAndroid Build Coastguard Worker 
46*2d543d20SAndroid Build Coastguard Worker 	if (cil_compile(db) != SEPOL_OK)
47*2d543d20SAndroid Build Coastguard Worker 		goto exit;
48*2d543d20SAndroid Build Coastguard Worker 
49*2d543d20SAndroid Build Coastguard Worker 	if (cil_build_policydb(db, &pdb) != SEPOL_OK)
50*2d543d20SAndroid Build Coastguard Worker 		goto exit;
51*2d543d20SAndroid Build Coastguard Worker 
52*2d543d20SAndroid Build Coastguard Worker 	if (sepol_policydb_optimize(pdb) != SEPOL_OK)
53*2d543d20SAndroid Build Coastguard Worker 		goto exit;
54*2d543d20SAndroid Build Coastguard Worker 
55*2d543d20SAndroid Build Coastguard Worker 	dev_null = fopen("/dev/null", "w");
56*2d543d20SAndroid Build Coastguard Worker 	if (dev_null == NULL)
57*2d543d20SAndroid Build Coastguard Worker 		goto exit;
58*2d543d20SAndroid Build Coastguard Worker 
59*2d543d20SAndroid Build Coastguard Worker 	if (sepol_policy_file_create(&pf) != 0)
60*2d543d20SAndroid Build Coastguard Worker 		goto exit;
61*2d543d20SAndroid Build Coastguard Worker 
62*2d543d20SAndroid Build Coastguard Worker 	sepol_policy_file_set_fp(pf, dev_null);
63*2d543d20SAndroid Build Coastguard Worker 
64*2d543d20SAndroid Build Coastguard Worker 	if (sepol_policydb_write(pdb, pf) != 0)
65*2d543d20SAndroid Build Coastguard Worker 		goto exit;
66*2d543d20SAndroid Build Coastguard Worker exit:
67*2d543d20SAndroid Build Coastguard Worker 	if (dev_null != NULL)
68*2d543d20SAndroid Build Coastguard Worker 		fclose(dev_null);
69*2d543d20SAndroid Build Coastguard Worker 
70*2d543d20SAndroid Build Coastguard Worker 	cil_db_destroy(&db);
71*2d543d20SAndroid Build Coastguard Worker 	sepol_policydb_free(pdb);
72*2d543d20SAndroid Build Coastguard Worker 	sepol_policy_file_free(pf);
73*2d543d20SAndroid Build Coastguard Worker 	return 0;
74*2d543d20SAndroid Build Coastguard Worker }
75