Android9 Sepolicy规则基础 - MTK平台

1. SELinux的基础原则

默认拒绝原则 - 任何未经明确允许的行为都会被拒绝(即:白名单制)

 

2. SELinux的两种执行模式

宽容模式 - 权限拒绝事件会被记录下来,但不会被强制执行。(权限不够时,仅警告)

强制模式 - 权限拒绝事件会被记录下来并强制执行。(权限不够时,拒绝执行)

 

3. SELinux在安卓平台上的演变

低于安卓4.3 - 默认不支持SELinux

安卓4.3 - 宽容模式

安卓4.4 - 部分强制模式(多数设备依然是宽容模式)

安卓5.1 - 默认强制模式

高于安卓8.0 - 强制模式且Sepolicy规则被分成多个部分

 

4. 核心规则

路径:system/sepolicy

核心规则会被所有设备使用。

 

5. 设备规则

路径:device/<vendor>/<board>/sepolicy

设备规则会被对应的产品使用。

 

6. 添加规则目录

在Android.mk中设置BOARD_SEPOLICY_DIRS可以添加Sepolicy的搜寻目录,如:

BOARD_SEPOLICY_DIRS += device/samsung/tuna/sepolicy

 

7. 关于多部分规则

从安卓8.0开始,sepolicy规则被分成了多个部分。

笔者个人认为:是进行了可移植性改造,及多版本兼容,因此将规则分散到了多个目录中以增强其可移植性,及兼容性。

public - PLAT_PUBLIC_POLICY,平台公开规则,会被导出给其他非平台相关的规则。

private - PLAT_PRIVATE_POLICY,平台私有规则,不会向vendor部分暴露。

vendor - PLAT_VENDOR_POLICY,厂商规则,可引用public的规则,不能引用private的规则。

mapping - 规则映射表,将旧版本的public规则映射到当前规则中,来保证旧版本可用,如xxx.cil文件。

 

8. Sepolicy编译过程

1) 将所有规则转换成CIL

- private + public platform policy 转换到CIL

- mapping文件转储到CIL

- non-platform public policy 转换到CIL

- non-platform public policy + private policy 转换到CIL

2) 属性化规则

3) 合并规则文件

- 合并 mapping,platform 及 non-platform 规则

- 合并输出二进制规则文件

 

9. Sepolicy的编译目标

selinux_policy

 

10. Sepolicy写法实操

10.1 重要文件:

te_macros - 相当于宏定义,定义了一些语句的组合,如:init_daemon_domain

#####################################
# init_daemon_domain(domain)
# Set up a transition from init to the daemon domain
# upon executing its binary.
define(`init_daemon_domain', `
domain_auto_trans(init, $1_exec, $1)
tmpfs_domain($1)
')

attributes - 定义了所有的属性,相当于类型定义,如:exec_type

# All types used for files that can exist on a labeled fs. 
# Do not use for pseudo file types. 
# On change, update CHECK_FC_ASSERT_ATTRS 
# definition in tools/checkfc.c. 
attribute file_type;

# All types used for domain entry points.
attribute exec_type;

global_macros - 相当于宏定义,将一些对象及权限的组合定义成一组,如:

define(`devfile_class_set', `{ chr_file blk_file }')

define(`r_file_perms', `{ getattr open read ioctl lock map }')
define(`w_file_perms', `{ open append write lock map }')
define(`rw_file_perms', `{ r_file_perms w_file_perms }')

file_contexts - 为指定路径的目录或文件设置其type,如:

/dev/enginectrl  u:object_r:enginectrl_device:s0 
/storage(/.*)?   u:object_r:storage_file:s0

file.te - 文件type名在这里定义,并制定type所属的属性,如:

type storage_file, file_type;
type logcat_exec, exec_type, file_type;

 

笔者备注:属性相当于一个组如“file_type”,type是最小权限单位,不同type的东西可以在同一个属性下面,如上的storage_file和logcat_exec这两个type都同属于file_type属性,因此对于有些针对file_type的规则就能同时限制到这两个type。

xxx.te - 针对xxx这个type的权限定义,包含了type定义以及这个type的权限配置,以atcid.te为例:

type atcid, domain;  # 定义type:atcid,指定其属于domain
type atcid_exec, exec_type, file_type, vendor_file_type; 

#...
# 配置允许atcid访问ttyGS_device的chr_file:read/write/ioctl/open权限
allow atcid ttyGS_device:chr_file { read write ioctl open }; 

#...
# 配置允许atcid访问所有的mtk_atci_prop类属性
set_prop(atcid, mtk_atci_prop); 
#...

property.te - 这个文件里定义了property属性的type,以及type所属的属性:

type persist_service_atci_prop, property_type, mtk_core_property_type; 
type mtk_atci_prop, property_type, mtk_core_property_type;

property_contexts - 这个文件里规定了各个property的type:

persist.vendor.service.atci   u:object_r:persist_service_atci_prop:s0 
vendor.mtk.atci   u:object_r:mtk_atci_prop:s0

 

10.2 类型定义:

进程、资源,都被抽象成类型了。

type 类型名 [alias 别名集] [,属性集];

一个简单的实例:

type rootfs, fs_type;

此例中定义了一个名为rootfs的类型,这个类型属于fs_type属性(笔者认为,将这里的attribute翻译为“属性组”更为贴切)。

可以将多个类型指定到同一属性组,这样配置权限时就可以针对一组属性来设置权限,而不必精确的去针对每个类型设置权限。

除了在定义类型的时候关联属性,也可以用typeattribute来设置类型的属性。

 

10.3 属性定义:

attribute 属性名;

实例:

# All types used for filesystems. 
# On change, update CHECK_FC_ASSERT_ATTRS 
# definition in tools/checkfc.c. 
attribute fs_type;

此例定义了一个名为fs_type的属性组。

 

10.4 访问向量(Access Vector):

访问规则名 源类型 目标类型 : 权限类 权限集;

用来描述主体(源)对客体(目标)的访问规则

示例:

allow atcid ttyGS_device:chr_file { read write ioctl open };

10.4.1 访问规则名

通常有4种:

allow - 允许主体对客体执行许可的操作。

neverallow - 表示不允许主体对客体执行制定的操作。

auditallow - 表示允许操作并记录访问决策信息。

dontaudit - 表示不记录违反规则的决策信息,切违反规则不影响运行。

 

10.4.2 源类型和目标类型

是由type定义的,分散在各个te文件中,如:

type platform_app, domain;

这个是定义在platform_app.te中的

10.4.3 权限类

是由class所定义的权限类,如access_vectors文件中定义的:

class service_manager { add find list }

 

10.4.4 权限集

指定此条规则的权限范围,权限集必须是权限类所支持权限的子集,如:

allow platform_app recovery_service:service_manager find;

这条规则的意思:允许platform_app访问recovery_serviceservice_manager:find权限。

更直白的意思是:让platform_app可以找到recovery_service

 

后话:

type 是起名,比如小明,小红。

attribute 是属性组,比如:人类,男性,女性,有驾照。

权限类是特定场景的权限,比如:洗浴,驾驶

权限集是针对某场景的各种可能的限制,如:洗浴这个场景,权限有:前往大门,交费,进入男浴室,进入女浴室

然后我们可以这样定义一个权限规则来定义小明与小红的权限:

# 下面定义了此系统中的属性
attribute 人类;
attribute 男性;
attribute 女性;
attribute 有驾照;
attribute 洗浴中心;
attribute 机动车;

# 下面定义了此系统中的type(权限对象)
type 小红, 女性, 人类;
type 小明, 有驾照, 男性, 人类;
type 大浪淘沙澡堂, 洗浴中心;
type 本田缤智, 机动车;

# 下面定义了此系统中的权限类
class 洗浴 { 前往大门, 交费, 进入男浴室, 进入女浴室 }
class 驾乘 { 开车门, 驾驶, 乘坐 }

############################################
# 下面定义了小明和小红在此系统中的权限
############################################
# 小红不能进男浴室
allow 小红 大浪淘沙澡堂:洗浴 {前往大门, 交费, 进入女浴室};

# 小红没有驾照不能开车
allow 小红 本田缤智:驾乘 {开车门, 乘坐};

# 小明不能进女浴室
allow 小明 大浪淘沙澡堂:洗浴 {前往大门, 交费, 进入男浴室};

# 小明有驾照可以开车
allow 小明 本田缤智:驾乘 {开车门, 驾驶, 乘坐};

# 禁止所有没有驾照的人驾驶机动车
neverallow {人类 -有驾照} {机动车}:驾乘 {驾驶};

 

参考材料:

[1] system\sepolicy\README

[2] system\sepolicy\Android.mk

[3] https://www.jianshu.com/p/e95cd0c17adc

[4] https://blog.youkuaiyun.com/kongbaidepao/article/details/61416862

[5] https://www.jianshu.com/p/72061c66a176

[6] https://source.android.com/security/selinux/concepts

 

 

<think>嗯,用户问的是“android 13mtk”,看起来是想了解关于Android 13和联发科(MTK)芯片的相关信息。首先,我需要确认用户的具体需求。可能的情况包括:用户想知道MTK芯片在Android 13上的适配情况,或者他们遇到了升级到Android 13的问题,或者是想了解MTK设备升级Android 13的特性。 接下来,我需要分析用户的历史对话。之前的提问是关于OTA升级报错,特别是签名验证失败的问题。这可能意味着用户可能正在尝试升级他们的MTK设备到Android 13,但遇到了问题。因此,用户现在可能想了解如何正确升级,或者MTK设备在Android 13上的支持情况,以及可能遇到的兼容性问题。 然后,我需要考虑用户的身份。用户可能是一个普通用户,正在尝试自己升级设备,或者是一个开发者,希望了解MTK平台Android 13上的开发变化。根据之前的提问,用户可能属于前者,遇到升级问题,需要解决方案。 用户可能没有明确表达的需求可能包括:如何解决MTK设备升级Android 13时的特定错误,或者寻找支持Android 13的MTK设备型号列表,或者希望了解升级后的新功能。因此,在回答时,我需要覆盖这些潜在的问题点,并提供详细的解决方案和相关信息。 另外,考虑到联发科芯片常用于中低端设备,用户可能关心性能优化、新功能适配情况,以及厂商的更新策略。同时,用户可能对如何手动升级或使用第三方工具感兴趣,但需要注意警告风险,避免设备变砖。 最后,要确保回答结构清晰,分点说明,涵盖关键信息如平台变化、升级情况、常见问题、注意事项等,帮助用户全面理解Android 13在MTK设备上的情况,并指导他们正确操作。</think>### Android 13与联发科(MTK)芯片解析 #### 一、MTK平台Android 13适配概况 联发科(MediaTek)芯片在Android 13的适配中呈现以下特点: - **主流芯片支持**: - 天玑9000/8000系列:首批适配(2022 Q4) - 天玑700/800系列:逐步推送(2023 Q1-Q2) - Helio G系列:部分机型延迟支持 - **内核版本要求**: - 最低需基于**Linux Kernel 5.10**(天玑9000系列使用5.15) - **Vendor分区变化**: - 新增`vendor_boot`分区管理硬件驱动 - 需配合`MTK-SUPPORT`扩展包使用 --- #### 二、关键特性适配情况 | 功能模块 | MTK实现方案 | 兼容性备注 | |---------|------------|-----------| | **动态分区** | MTK Dynamic Partitions 2.0 | 需更新`mtk_ota_merge_tool` | | **光子引擎** | 仅天玑9000/8000支持 | 需配合MTK HyperEngine 5.0 | | **隐私沙盒** | 强制使用MTK SecGuard | 可能影响双卡功能 | | **蓝牙LE Audio** | MTK BLE 5.3定制驱动 | 需更新Firmware | --- #### 三、典型升级问题与解决方案 ##### 1. **VINTF兼容性报错** ```log E Vintf: Skipping incompatible manifest ... ``` **处理步骤**: 1. 检查`compatibility_matrix.xml`版本 2. 更新`mtk-hardware-interfaces`库 3. 重新生成VNDK 33镜像 ##### 2. **DRM密钥失效** - 现象:Widevine L1降级为L3 - 修复方案: ```bash fastboot flash provison prov.img fastboot oem drm-key-inject ``` ##### 3. **Modem异常** - 天玑芯片常见基带问题: - 5G SA模式断流 - VoNR通话回声 - 需更新`md1dg.img`和`md1img.img` --- #### 四、开发者注意事项 1. **ABI兼容性**: - 强制使用`armeabi-v8a`,移除32位库支持 - 需在`Android.bp`添加: ```makefile compile_multilib: "64" ``` 2. **SEPolicy更新**: - MTK新增`mtk_hal_attrs`标签 - 相机相关规则需使用: ```te allow mtk_hal_camera_default ... ``` 3. **性能调优工具**: - MTK Logger 3.0(需ENG工程模式) - `mtkperf`命令行工具: ```bash adb shell mtkperf -gpu -freq 800000 ``` --- #### 五、设备升级指南 1. **官方OTA条件**: - BL版本≥2022.11 - `/vendor`分区剩余≥512MB - 未修改`lk.img`或`preloader` 2. **手动升级风险点**: - 必须使用**MTK SP Flash Tool v6.2212** - 需配套`MTK_AllInOne_DA.bin`引导文件 - 禁止跳过`md_udc`校验 3. **救砖方案**: - 强制进入BROM模式: 1. 断开USB 2. 按住**Vol+ & Power** 15秒 3. 插入数据线 - 使用`MTKClient`开源工具重写分区表 --- #### 六、厂商支持现状 - **优先更新品牌**: - 小米/Redmi(天玑版MIUI 14) - realme(realme UI 4.0) - OPPO(ColorOS 13.1) - **延迟更新机型**: - 采用Helio G95/G96设备 - 2021年前发布的平板设备 若遇到MTK平台专属问题,建议通过`*#*#3646633#*#*`进入工程模式获取详细日志,或联系厂商获取`MTK_SOC_DEBUG`调试包。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值