blob: 001d53adfcf8b7b377a80452dd62c998472d5680 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
# kickstart processes and scripts
type kickstart, domain;
type kickstart_exec, exec_type, file_type;
# kickstart_checker.sh talks to init over the property socket
unix_socket_connect(kickstart, property, init)
# Start /system/bin/qcks from init
init_daemon_domain(kickstart)
# Spawn /system/bin/efsks and /system/bin/ks
allow kickstart kickstart_exec:file { open execute_no_trans getattr };
allow kickstart rild_exec:file { open execute_no_trans getattr };
# Run dd on m9kefs[123] block devices; write to /data/qcks/
# Run cat on firmware and m9kefs[123] data; write to /data/qcks/
allow kickstart boot_block_device:blk_file { getattr read write open };
allow kickstart kickstart_data_file:file create_file_perms;
allow kickstart kickstart_data_file:dir rw_dir_perms;
allow kickstart radio_efs_file:file r_file_perms;
allow kickstart radio_efs_file:dir search;
# Let qcks access /dev/mdm node (modem driver)
allow kickstart radio_device:chr_file rw_file_perms;
# Allow /dev/ttyUSB0 access
allow kickstart radio_device:chr_file { write ioctl getattr };
# Allow to run toolbox commands
allow kickstart shell_exec:file rx_file_perms;
# Toolbox commands for firmware dd
allow kickstart system_file:file execute_no_trans;
# Access to /dev/block/platform/msm_sdcc.1/by-name/m9kefs2
allow kickstart block_device:dir { getattr write search };
# Set system property key
allow kickstart radio_prop:property_service set;
allow kickstart shell_exec:file entrypoint;
# ls on /data/qcks/
allow kickstart self:capability { dac_override setuid };
# XXX Label sysfs files with a specific type?
allow kickstart sysfs:file rw_file_perms;
allow kickstart unlabeled:file { setattr getattr read write open };
allow kickstart vfat:file { getattr read open };
allow kickstart kickstart:process { execmem };
allow kickstart usbfs:dir { search };
allow kickstart vfat:dir { search };
allow kickstart log_device:chr_file { open write };
allow kickstart rild_exec:file { getattr execute read open };
|