Alex Klyubin | 168435f | 2017-02-16 20:14:56 -0800 | [diff] [blame] | 1 | # HwBinder IPC from clients into server, and callbacks |
| 2 | binder_call(hal_bluetooth_client, hal_bluetooth_server) |
| 3 | binder_call(hal_bluetooth_server, hal_bluetooth_client) |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 4 | |
Alex Klyubin | 53656c1 | 2017-04-13 19:05:27 -0700 | [diff] [blame] | 5 | add_hwservice(hal_bluetooth_server, hal_bluetooth_hwservice) |
| 6 | allow hal_bluetooth_client hal_bluetooth_hwservice:hwservice_manager find; |
| 7 | |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 8 | wakelock_use(hal_bluetooth); |
| 9 | |
Myles Watson | 20b8d6b | 2017-02-22 11:50:20 -0800 | [diff] [blame] | 10 | # The HAL toggles rfkill to power the chip off/on. |
Benjamin Gordon | 9b2e0cb | 2017-11-09 15:51:26 -0700 | [diff] [blame] | 11 | allow hal_bluetooth self:global_capability_class_set net_admin; |
Myles Watson | 20b8d6b | 2017-02-22 11:50:20 -0800 | [diff] [blame] | 12 | |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 13 | # bluetooth factory file accesses. |
| 14 | r_dir_file(hal_bluetooth, bluetooth_efs_file) |
| 15 | |
| 16 | allow hal_bluetooth { uhid_device hci_attach_dev }:chr_file rw_file_perms; |
| 17 | |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 18 | # sysfs access. |
| 19 | r_dir_file(hal_bluetooth, sysfs_type) |
| 20 | allow hal_bluetooth sysfs_bluetooth_writable:file rw_file_perms; |
Benjamin Gordon | 9b2e0cb | 2017-11-09 15:51:26 -0700 | [diff] [blame] | 21 | allow hal_bluetooth self:global_capability2_class_set wake_alarm; |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 22 | |
| 23 | # Allow write access to bluetooth-specific properties |
Jaekyun Seok | 224921d | 2018-04-09 12:07:32 +0900 | [diff] [blame^] | 24 | set_prop(hal_bluetooth, bluetooth_a2dp_offload_prop) |
Andre Eisenbach | be27f92 | 2016-10-12 14:49:56 -0700 | [diff] [blame] | 25 | set_prop(hal_bluetooth, bluetooth_prop) |
Jaekyun Seok | 224921d | 2018-04-09 12:07:32 +0900 | [diff] [blame^] | 26 | set_prop(hal_bluetooth, exported_bluetooth_prop) |
Andre Eisenbach | 6e3a5d0 | 2017-02-07 20:30:40 -0800 | [diff] [blame] | 27 | |
| 28 | # /proc access (bluesleep etc.). |
| 29 | allow hal_bluetooth proc_bluetooth_writable:file rw_file_perms; |
Martijn Coenen | 0d1f7d2 | 2017-05-09 09:53:46 -0700 | [diff] [blame] | 30 | |
| 31 | # allow to run with real-time scheduling policy |
Benjamin Gordon | 9b2e0cb | 2017-11-09 15:51:26 -0700 | [diff] [blame] | 32 | allow hal_bluetooth self:global_capability_class_set sys_nice; |