9d8f7eac8a
Allow sgdisk to force the kernel to re-read the partition table. Addresses the following denial: avc: denied { ioctl } for path=/dev/block/vold/disk:7,0 dev=tmpfs ino=710640 ioctlcmd=125f scontext=u:r:sgdisk:s0 tcontext=u:object_r:vold_device:s0 tclass=blk_file permissive=0 Bug: 118890056 Test: policy compiles Test: 1) adb shell sm set-force-adoptable on 2) adb shell sm set-virtual-disk true 3) On device, pick the drop-down notification and choose "use as phone/internal storage" to adopt the virtual SD card. Change-Id: I6825cf526cc48aa2a17afab14eadb6134bfc56f9
34 lines
1.4 KiB
Text
34 lines
1.4 KiB
Text
# sgdisk called from vold
|
|
type sgdisk, domain;
|
|
type sgdisk_exec, system_file_type, exec_type, file_type;
|
|
|
|
# Allowed to read/write low-level partition tables
|
|
allow sgdisk block_device:dir search;
|
|
allow sgdisk vold_device:blk_file rw_file_perms;
|
|
# HDIO_GETGEO needed to get the number of disk heads
|
|
# on vold_device. How quaint.
|
|
allowxperm sgdisk vold_device:blk_file ioctl { HDIO_GETGEO };
|
|
# sgdisk also uses BLKGETSIZE and BLKGETSIZE64. BLKGETSIZE64
|
|
# is granted to all block device users in domain.te, so
|
|
# no need to mention it here. sgdisk should not be
|
|
# using the BLKGETSIZE ioctl as it is useless for devices over
|
|
# 2T in size, but we allow it for now and hope that sgdisk
|
|
# will fix their bug.
|
|
allowxperm sgdisk vold_device:blk_file ioctl { BLKGETSIZE };
|
|
# Force a re-read of the partition table.
|
|
allowxperm sgdisk vold_device:blk_file ioctl { BLKRRPART };
|
|
|
|
# Inherit and use pty created by android_fork_execvp()
|
|
allow sgdisk devpts:chr_file { read write ioctl getattr };
|
|
|
|
# Allow stdin/out back to vold
|
|
allow sgdisk vold:fd use;
|
|
allow sgdisk vold:fifo_file { read write getattr };
|
|
|
|
# Used to probe kernel to reload partition tables
|
|
allow sgdisk self:global_capability_class_set sys_admin;
|
|
|
|
# Only allow entry from vold
|
|
neverallow { domain -vold } sgdisk:process transition;
|
|
neverallow * sgdisk:process dyntransition;
|
|
neverallow sgdisk { file_type fs_type -sgdisk_exec }:file entrypoint;
|