1include $(CLEAR_VARS)
2
3LOCAL_MODULE := plat_mac_permissions.xml
4LOCAL_MODULE_CLASS := ETC
5LOCAL_MODULE_TAGS := optional
6LOCAL_MODULE_PATH := $(TARGET_OUT)/etc/selinux
7
8include $(BUILD_SYSTEM)/base_rules.mk
9
10all_plat_mac_perms_keys := $(call build_policy, keys.conf, $(PLAT_PRIVATE_POLICY) $(SYSTEM_EXT_PRIVATE_POLICY) $(PRODUCT_PRIVATE_POLICY))
11all_plat_mac_perms_files := $(call build_policy, mac_permissions.xml, $(PLAT_PRIVATE_POLICY))
12
13# Build keys.conf
14plat_mac_perms_keys.tmp := $(intermediates)/plat_keys.tmp
15$(plat_mac_perms_keys.tmp): PRIVATE_ADDITIONAL_M4DEFS := $(LOCAL_ADDITIONAL_M4DEFS)
16$(plat_mac_perms_keys.tmp): PRIVATE_KEYS := $(all_plat_mac_perms_keys)
17$(plat_mac_perms_keys.tmp): $(all_plat_mac_perms_keys) $(M4)
18	@mkdir -p $(dir $@)
19	$(hide) $(M4) --fatal-warnings -s $(PRIVATE_ADDITIONAL_M4DEFS) $(PRIVATE_KEYS) > $@
20
21# Should be synced with keys.conf.
22all_plat_keys := platform media networkstack shared testkey
23all_plat_keys := $(all_plat_keys:%=$(dir $(DEFAULT_SYSTEM_DEV_CERTIFICATE))/%.x509.pem)
24
25$(LOCAL_BUILT_MODULE): PRIVATE_MAC_PERMS_FILES := $(all_plat_mac_perms_files)
26$(LOCAL_BUILT_MODULE): $(plat_mac_perms_keys.tmp) $(HOST_OUT_EXECUTABLES)/insertkeys.py \
27$(all_plat_mac_perms_files) $(all_plat_keys)
28	@mkdir -p $(dir $@)
29	$(hide) DEFAULT_SYSTEM_DEV_CERTIFICATE="$(dir $(DEFAULT_SYSTEM_DEV_CERTIFICATE))" \
30		MAINLINE_SEPOLICY_DEV_CERTIFICATES="$(MAINLINE_SEPOLICY_DEV_CERTIFICATES)" \
31		$(HOST_OUT_EXECUTABLES)/insertkeys.py -t $(TARGET_BUILD_VARIANT) -c $(TOP) $< -o $@ $(PRIVATE_MAC_PERMS_FILES)
32
33all_plat_keys :=
34all_plat_mac_perms_files :=
35all_plat_mac_perms_keys :=
36plat_mac_perms_keys.tmp :=
37
38##################################
39include $(CLEAR_VARS)
40
41LOCAL_MODULE := system_ext_mac_permissions.xml
42LOCAL_MODULE_CLASS := ETC
43LOCAL_MODULE_TAGS := optional
44LOCAL_MODULE_PATH := $(TARGET_OUT_SYSTEM_EXT)/etc/selinux
45
46include $(BUILD_SYSTEM)/base_rules.mk
47
48all_system_ext_mac_perms_keys := $(call build_policy, keys.conf, $(SYSTEM_EXT_PRIVATE_POLICY) $(REQD_MASK_POLICY))
49all_system_ext_mac_perms_files := $(call build_policy, mac_permissions.xml, $(SYSTEM_EXT_PRIVATE_POLICY) $(REQD_MASK_POLICY))
50
51# Build keys.conf
52system_ext_mac_perms_keys.tmp := $(intermediates)/system_ext_keys.tmp
53$(system_ext_mac_perms_keys.tmp): PRIVATE_ADDITIONAL_M4DEFS := $(LOCAL_ADDITIONAL_M4DEFS)
54$(system_ext_mac_perms_keys.tmp): PRIVATE_KEYS := $(all_system_ext_mac_perms_keys)
55$(system_ext_mac_perms_keys.tmp): $(all_system_ext_mac_perms_keys)
56	@mkdir -p $(dir $@)
57	$(hide) $(M4) --fatal-warnings -s $(PRIVATE_ADDITIONAL_M4DEFS) $^ > $@
58
59$(LOCAL_BUILT_MODULE): PRIVATE_MAC_PERMS_FILES := $(all_system_ext_mac_perms_files)
60$(LOCAL_BUILT_MODULE): $(system_ext_mac_perms_keys.tmp) $(HOST_OUT_EXECUTABLES)/insertkeys.py \
61$(all_system_ext_mac_perms_files)
62	@mkdir -p $(dir $@)
63	$(hide) $(HOST_OUT_EXECUTABLES)/insertkeys.py -t $(TARGET_BUILD_VARIANT) -c $(TOP) $< -o $@ $(PRIVATE_MAC_PERMS_FILES)
64
65system_ext_mac_perms_keys.tmp :=
66all_system_ext_mac_perms_files :=
67all_system_ext_mac_perms_keys :=
68
69##################################
70include $(CLEAR_VARS)
71
72LOCAL_MODULE := product_mac_permissions.xml
73LOCAL_MODULE_CLASS := ETC
74LOCAL_MODULE_TAGS := optional
75LOCAL_MODULE_PATH := $(TARGET_OUT_PRODUCT)/etc/selinux
76
77include $(BUILD_SYSTEM)/base_rules.mk
78
79all_product_mac_perms_keys := $(call build_policy, keys.conf, $(PRODUCT_PRIVATE_POLICY) $(REQD_MASK_POLICY))
80all_product_mac_perms_files := $(call build_policy, mac_permissions.xml, $(PRODUCT_PRIVATE_POLICY) $(REQD_MASK_POLICY))
81
82# Build keys.conf
83product_mac_perms_keys.tmp := $(intermediates)/product_keys.tmp
84$(product_mac_perms_keys.tmp): PRIVATE_ADDITIONAL_M4DEFS := $(LOCAL_ADDITIONAL_M4DEFS)
85$(product_mac_perms_keys.tmp): PRIVATE_KEYS := $(all_product_mac_perms_keys)
86$(product_mac_perms_keys.tmp): $(all_product_mac_perms_keys)
87	@mkdir -p $(dir $@)
88	$(hide) $(M4) --fatal-warnings -s $(PRIVATE_ADDITIONAL_M4DEFS) $^ > $@
89
90$(LOCAL_BUILT_MODULE): PRIVATE_MAC_PERMS_FILES := $(all_product_mac_perms_files)
91$(LOCAL_BUILT_MODULE): $(product_mac_perms_keys.tmp) $(HOST_OUT_EXECUTABLES)/insertkeys.py \
92$(all_product_mac_perms_files)
93	@mkdir -p $(dir $@)
94	$(hide) $(HOST_OUT_EXECUTABLES)/insertkeys.py -t $(TARGET_BUILD_VARIANT) -c $(TOP) $< -o $@ $(PRIVATE_MAC_PERMS_FILES)
95
96product_mac_perms_keys.tmp :=
97all_product_mac_perms_files :=
98all_product_mac_perms_keys :=
99
100##################################
101include $(CLEAR_VARS)
102
103LOCAL_MODULE := vendor_mac_permissions.xml
104LOCAL_MODULE_CLASS := ETC
105LOCAL_MODULE_TAGS := optional
106LOCAL_MODULE_PATH := $(TARGET_OUT_VENDOR)/etc/selinux
107
108include $(BUILD_SYSTEM)/base_rules.mk
109
110all_vendor_mac_perms_keys := $(call build_policy, keys.conf, $(PLAT_VENDOR_POLICY) $(BOARD_VENDOR_SEPOLICY_DIRS) $(REQD_MASK_POLICY))
111all_vendor_mac_perms_files := $(call build_policy, mac_permissions.xml, $(PLAT_VENDOR_POLICY) $(BOARD_VENDOR_SEPOLICY_DIRS) $(REQD_MASK_POLICY))
112
113# Build keys.conf
114vendor_mac_perms_keys.tmp := $(intermediates)/vendor_keys.tmp
115$(vendor_mac_perms_keys.tmp): PRIVATE_ADDITIONAL_M4DEFS := $(LOCAL_ADDITIONAL_M4DEFS)
116$(vendor_mac_perms_keys.tmp): PRIVATE_KEYS := $(all_vendor_mac_perms_keys)
117$(vendor_mac_perms_keys.tmp): $(all_vendor_mac_perms_keys) $(M4)
118	@mkdir -p $(dir $@)
119	$(hide) $(M4) --fatal-warnings -s $(PRIVATE_ADDITIONAL_M4DEFS) $(PRIVATE_KEYS) > $@
120
121$(LOCAL_BUILT_MODULE): PRIVATE_MAC_PERMS_FILES := $(all_vendor_mac_perms_files)
122$(LOCAL_BUILT_MODULE): $(vendor_mac_perms_keys.tmp) $(HOST_OUT_EXECUTABLES)/insertkeys.py \
123$(all_vendor_mac_perms_files)
124	@mkdir -p $(dir $@)
125	$(hide) DEFAULT_SYSTEM_DEV_CERTIFICATE="$(dir $(DEFAULT_SYSTEM_DEV_CERTIFICATE))" \
126		$(HOST_OUT_EXECUTABLES)/insertkeys.py -t $(TARGET_BUILD_VARIANT) -c $(TOP) $< -o $@ $(PRIVATE_MAC_PERMS_FILES)
127
128vendor_mac_perms_keys.tmp :=
129all_vendor_mac_perms_files :=
130all_vendor_mac_perms_keys :=
131
132##################################
133include $(CLEAR_VARS)
134
135LOCAL_MODULE := odm_mac_permissions.xml
136LOCAL_MODULE_CLASS := ETC
137LOCAL_MODULE_TAGS := optional
138LOCAL_MODULE_PATH := $(TARGET_OUT_ODM)/etc/selinux
139
140include $(BUILD_SYSTEM)/base_rules.mk
141
142all_odm_mac_perms_keys := $(call build_policy, keys.conf, $(BOARD_ODM_SEPOLICY_DIRS) $(REQD_MASK_POLICY))
143all_odm_mac_perms_files := $(call build_policy, mac_permissions.xml, $(BOARD_ODM_SEPOLICY_DIRS) $(REQD_MASK_POLICY))
144
145# Build keys.conf
146odm_mac_perms_keys.tmp := $(intermediates)/odm_keys.tmp
147$(odm_mac_perms_keys.tmp): PRIVATE_ADDITIONAL_M4DEFS := $(LOCAL_ADDITIONAL_M4DEFS)
148$(odm_mac_perms_keys.tmp): PRIVATE_KEYS := $(all_odm_mac_perms_keys)
149$(odm_mac_perms_keys.tmp): $(all_odm_mac_perms_keys) $(M4)
150	@mkdir -p $(dir $@)
151	$(hide) $(M4) --fatal-warnings -s $(PRIVATE_ADDITIONAL_M4DEFS) $(PRIVATE_KEYS) > $@
152
153$(LOCAL_BUILT_MODULE): PRIVATE_MAC_PERMS_FILES := $(all_odm_mac_perms_files)
154$(LOCAL_BUILT_MODULE): $(odm_mac_perms_keys.tmp) $(HOST_OUT_EXECUTABLES)/insertkeys.py \
155$(all_odm_mac_perms_files)
156	@mkdir -p $(dir $@)
157	$(hide) $(HOST_OUT_EXECUTABLES)/insertkeys.py -t $(TARGET_BUILD_VARIANT) -c $(TOP) $< -o $@ $(PRIVATE_MAC_PERMS_FILES)
158
159odm_mac_perms_keys.tmp :=
160all_odm_mac_perms_files :=
161