• 2022-07-20 Android 11 SELinux avc 修改sys目录下面某个节点的权限


    一、我这里有/sys/devices/platform/thermal-camera-control/powerenable 这样一个节点,用命令ls -Z 查看该文件的域。

     

    二、我现在在一个普通app上面读写这个节点,提示提无认证的app没有读写权限。

    1. onsole:/ $ [ 382.626960] type=1400 audit(1658283554.576:39): avc: denied { write } for comm="don.powerenable" name="powerenable" dev="sysfs" ino=15716 scontext=u:r:untrusted_app_29:s0:c122,c256,c512,c768 tcontext=u:object_r:sysfs:s0 tclass=file permissive=0 app=com.topdon.powerenable
    2. console:/ $ [ 384.749073] type=1400 audit(1658283556.703:40): avc: denied { read } for comm="don.powerenable" name="powerenable" dev="sysfs" ino=15716 scontext=u:r:untrusted_app_29:s0:c122,c256,c512,c768 tcontext=u:object_r:sysfs:s0 tclass=file permissive=0 app=com.topdon.powerenable

    三、可以修改策略让所有的无信任app都可以读写sys下面的节点,但这样不安全,我这里就单独开放这个节点的权限,步骤如下。

    1、在file.te中,加入一个域的别名,如在该例中,我们原本需要访问的是sysfs域中的一个文件,所以我们在file.te中定义一个新的域,名字可以随便取,定义一个叫做sysfs_powerenable的域(domain),该域具有fs_type和sysfs_type属性(attribute)如

    type sysfs_powerenable, fs_type, sysfs_type, mlstrustedobject;

     2、在同目录中的file_contexts中加入对需要操作权限的文件路径与我们定义的域进行映射,如:

    #/sys/devices/platform/thermal-camera-control/status   u:object_r:sysfs_powerenable:s0

    3、在我们新建的powerenable.te策略文件中,把之前的sysfs替换为我们新定义的域,即

    allow untrusted_app_29  sysfs_powerenable:file  { read open write getattr};

    4、adb shell中通过ls -Z 取查看该文件的域,如果映射成功了,会变为sysfs_powerenable

    5、编译的时候可能会有提示不允许untrusted apps 写sysfs下面的节点,按下面的修改策略。 

     6、测试结果如下,第三方app 可以读写这个节点了

    四、/sys/devices/platform/thermal-camera-control/status 本来系统app是可以读写的,但是我在\device\rockchip\common\sepolicy\vendor\file_contexts 文件里面添加

    /sys/devices/platform/thermal-camera-control/status   u:object_r:sysfs_powerenable:s0

    这个时候第三方app是可以读写这个status节点,但是系统app反而读写不了这个节点,提示

    1. rk3566_rgo:/ # cd /sys/devices/platform/thermal-camera-control/
    2. rk3566_rgo:/sys/devices/platform/thermal-camera-control # ls -Z status
    3. u:object_r:sysfs_powerenable:s0 status
    4. rk3566_rgo:/sys/devices/platform/thermal-camera-control #

    解决方法是在powerenable.te 文件里面添加系统app读写这个节点的权限

    allow system_app        sysfs_powerenable:file  { read open write getattr};

     这样修改后第三方app也可以修改这个status节点了,我这里写这个status节点后usb adb会物理断开。 

    六、整个过程需要修改的内容

    1、添加文件device/rockchip/common/sepolicy/vendor/powerenable.te

    1. allow untrusted_app_29 sysfs_powerenable:file { read open write getattr};
    2. allow system_app sysfs_powerenable:file { read open write getattr};

    2、其他修改的内容

    1. project device/rockchip/common/
    2. diff --git a/sepolicy/vendor/file.te b/sepolicy/vendor/file.te
    3. index 464180c..45feac3 100755
    4. --- a/sepolicy/vendor/file.te
    5. +++ b/sepolicy/vendor/file.te
    6. @@ -39,6 +39,7 @@ type sysfs_timestamp_switch, sysfs_type, fs_type;
    7. type sysfs_video, sysfs_type, fs_type;
    8. type sysfs_fb, fs_type, sysfs_type;
    9. type sysfs_hdmi, fs_type, sysfs_type, mlstrustedobject;
    10. +type sysfs_powerenable, fs_type, sysfs_type, mlstrustedobject;
    11. type sysfs_dev, fs_type, sysfs_type, mlstrustedobject;
    12. type sysfs_lut, fs_type, sysfs_type, mlstrustedobject;
    13. type sysfs_lcdc, fs_type, sysfs_type, mlstrustedobject;
    14. diff --git a/sepolicy/vendor/file_contexts b/sepolicy/vendor/file_contexts
    15. old mode 100644
    16. new mode 100755
    17. index e0a46b2..1e5e005
    18. --- a/sepolicy/vendor/file_contexts
    19. +++ b/sepolicy/vendor/file_contexts
    20. @@ -220,4 +220,6 @@
    21. #flash_img
    22. /vendor/bin/flash_img.sh u:object_r:vendor_install_recovery_exec:s0
    23. +/sys/devices/platform/thermal-camera-control/powerenable u:object_r:sysfs_powerenable:s0
    24. +/sys/devices/platform/thermal-camera-control/status u:object_r:sysfs_powerenable:s0
    25. project system/sepolicy/
    26. diff --git a/prebuilts/api/30.0/private/app_neverallows.te b/prebuilts/api/30.0/private/app_neverallows.te
    27. old mode 100644
    28. new mode 100755
    29. index 1157187..f01eb91
    30. --- a/prebuilts/api/30.0/private/app_neverallows.te
    31. +++ b/prebuilts/api/30.0/private/app_neverallows.te
    32. @@ -90,7 +90,7 @@ neverallow all_untrusted_apps file_type:file link;
    33. neverallow all_untrusted_apps sysfs_net:file no_rw_file_perms;
    34. # Do not allow any write access to files in /sys
    35. -neverallow all_untrusted_apps sysfs_type:file { no_w_file_perms no_x_file_perms };
    36. +#neverallow all_untrusted_apps sysfs_type:file { no_w_file_perms no_x_file_perms };
    37. # Apps may never access the default sysfs label.
    38. neverallow all_untrusted_apps sysfs:file no_rw_file_perms;
    39. diff --git a/private/app_neverallows.te b/private/app_neverallows.te
    40. old mode 100644
    41. new mode 100755
    42. index 1157187..f01eb91
    43. --- a/private/app_neverallows.te
    44. +++ b/private/app_neverallows.te
    45. @@ -90,7 +90,7 @@ neverallow all_untrusted_apps file_type:file link;
    46. neverallow all_untrusted_apps sysfs_net:file no_rw_file_perms;
    47. # Do not allow any write access to files in /sys
    48. -neverallow all_untrusted_apps sysfs_type:file { no_w_file_perms no_x_file_perms };
    49. +#neverallow all_untrusted_apps sysfs_type:file { no_w_file_perms no_x_file_perms };
    50. # Apps may never access the default sysfs label.
    51. neverallow all_untrusted_apps sysfs:file no_rw_file_perms;

    七、有价值的参考文章:

    SeLinux问题解决方法

    Android/SELinux 添加 AVC 权限 - 码农教程

    [Android Framework]Android 11 SELinux avc权限解决方法_usmaI的博客-CSDN博客_android avc 权限

    android selinux报avc denied权限和编译报neverallow解决方案_楼中望月的博客-CSDN博客_android avc: denied

  • 相关阅读:
    搜索引擎-02-分词与全文索引
    14 Python使用网络
    如何免费获取CDH集群技术支持
    力扣(145.)补9.5
    Git链接上游仓库
    论文阅读笔记(六)——基于改进深度学习方法的股骨x线骨折自动检测与定位
    react原理篇:组件性能优化(减轻state、使用纯组件PureComponent避免不必要的重新渲染)
    多线程并发编程
    springboot大学校园网上图书馆信息管理系统的设计与实现小程序毕业设计源码091535
    PG::Ha-natraj
  • 原文地址:https://blog.csdn.net/qq_37858386/article/details/125886941