diff --git a/private/bpfloader.te b/private/bpfloader.te index 1ae5430126700f2a4798796726dd529a42f5fee9..d9b29ce8a6eeb0dbf7953f33a66b15470ae5a52c 100644 --- a/private/bpfloader.te +++ b/private/bpfloader.te @@ -26,3 +26,5 @@ neverallow { domain -system_server -netd -bpfloader} *:bpf { map_read map_write # No domain should be allowed to ptrace bpfloader neverallow { domain userdebug_or_eng(`-llkd') } bpfloader:process ptrace; + +set_prop(bpfloader, bpf_progs_loaded_prop) diff --git a/private/compat/28.0/28.0.ignore.cil b/private/compat/28.0/28.0.ignore.cil index 569ea1eefbded91024ad53563fabfeb741bce648..57e6876c46d91c91d4b6af7617c32ed1c3aec05d 100644 --- a/private/compat/28.0/28.0.ignore.cil +++ b/private/compat/28.0/28.0.ignore.cil @@ -18,6 +18,7 @@ apexd_prop apexd_tmpfs biometric_service + bpf_progs_loaded_prop content_capture_service content_suggestions_service cpu_variant_prop diff --git a/private/netd.te b/private/netd.te index 67c2e9ec3154489fbdc46302f351cae2a92e4a89..65c74ceb86702ef7e48c1caa6640e2b437da1571 100644 --- a/private/netd.te +++ b/private/netd.te @@ -11,3 +11,5 @@ domain_auto_trans(netd, clatd_exec, clatd) # give netd permission to setup iptables rule with xt_bpf, attach program to cgroup, and read/write # the map created by bpfloader allow netd bpfloader:bpf { prog_run map_read map_write }; + +get_prop(netd, bpf_progs_loaded_prop) diff --git a/private/property_contexts b/private/property_contexts index 66c98bcf097fff54eb45cb197c1c2e4e15f7b1e1..06c28220d3a4dd3cf79adbcab44f96f6fa4d2d50 100644 --- a/private/property_contexts +++ b/private/property_contexts @@ -173,3 +173,5 @@ persist.device_config.global_settings.native_flags_health_check_enabled u:object apexd. u:object_r:apexd_prop:s0 persist.apexd. u:object_r:apexd_prop:s0 + +bpf.progs_loaded u:object_r:bpf_progs_loaded_prop:s0 diff --git a/public/property.te b/public/property.te index 6ee568c84b30ceb8124204f24b14fda47c9e1c98..5a22340cd7617ade3526ad8ce5dc18dcafd17312 100644 --- a/public/property.te +++ b/public/property.te @@ -3,6 +3,7 @@ type audio_prop, property_type, core_property_type; type boottime_prop, property_type; type bluetooth_a2dp_offload_prop, property_type; type bluetooth_prop, property_type; +type bpf_progs_loaded_prop, property_type; type bootloader_boot_reason_prop, property_type; type config_prop, property_type, core_property_type; type cppreopt_prop, property_type, core_property_type; @@ -342,6 +343,7 @@ compatible_property_only(` -bluetooth_prop -bootloader_boot_reason_prop -boottime_prop + -bpf_progs_loaded_prop -config_prop -cppreopt_prop -ctl_adbd_prop