bootanimation进程property_set属性值设置

一、问题背景

1.1 问题需求

有一个这样的需求要处理,在bootanimation进程中记录一个值,然后在system_server进程中获取。基于Android14。
有好几种方式可以 进行处理:
共享内存;2、通过文件存储 ;3、通过property_set设置一个属性值,然后在system_server进程中进行读取。
第三种看着方便简单,不影响性能。

1.2 值的设置

在bootanimation进程中通过property_set进行值的设置,在system_server进程通过SystemProperties.get进行值的获取。

frameworks/base/cmds/bootanimation/BootAnimation.cpp
#include <sstream>
#include <utils/String16.h>
......
        String8 aaa;
        String8 bbb;
        String8 ccc;
        std::stringstream ss1;
        ss1 << std::to_string(aaa) + "|" <<  std::to_string(bbb) + "|"  << std::to_string(ccc) + "";
        property_set("sys.xxx.anim", ss1.str().c_str());

1.3 值的读取

在system_server进程

SystemProperties.get("sys.xxx.anim","");

发现没有读到值且通过shell命令 getprop sys.xxx.anim 为空,也就是值并没有设置成功。
经过抓取log查看是不是哪里报错了,尤其是否存在selinux权限问题。log中并没有显示异常情况。但有一条警告,比如我们随意设置了一个自带声明的属性

libc      :Unable to set property "persist.vendor.sys.anim" to "111111" : error code: 0x18

怀疑是selinux问题,但没有出现 "avc: denied"等相关字眼

二、问题分析过程

2.1 关闭selinux进行测试

system/core/init/selinux.cpp
void SelinuxSetEnforcement() {
    bool kernel_enforcing = (security_getenforce() == 1);
    bool is_enforcing_bat = IsEnforcing(); //把is_enforcing 任意修改一个名字
    bool is_enforcing = false; // is_enforcing赋值 为 false
    if (kernel_enforcing != is_enforcing) {
        if (security_setenforce(is_enforcing)) {
            PLOG(FATAL) << "security_setenforce(" << (is_enforcing ? "true" : "false")
                        << ") failed";
        }
    }
}

在 system/core/init 进行mm编译,编译后的产物 out_sys\target\product\xxx\system\bin 目录下的init执行文件,
替换机子中的init文件,push init /system/bin/ 接着重启。
shell环境中输入

getenforce  
Permissive

可以看到 selinux权限已经关闭

2.2 进行字符串属性值设置

property_set("sys.xxx.anim", ss1.str().c_str());  //ss1的字符个数超过了92,也没有设置成功

经过分析查看

system/core/libcutils/include/cutils/properties.h
#define PROP_VALUE_MAX 92
可以看到 property_set定义的最大的value 值是92

2.3 关闭了selinux,属性值设置在92字符内

bootanimation进程值设置,system_server值获取是成功的。

三、selinux属性相关

原生的selinux属性设置在
system/sepolicy/public/*
system/sepolicy/private/*
我们一般自己修改的在目录
device/xxx/sepolicy下
通过观察,发现surfaceflinger、system_server进程是可以进行属性值设置的。他们共有的特征是set_prop(xxx,system_prop)

在system/sepolicy/ 目录下 grep -rnw " system_prop" 。set_prop的有如下
private/charger.te:6:set_prop(charger, system_prop)
private/system_server.te:726:set_prop(system_server, system_prop)
private/surfaceflinger.te:59:set_prop(surfaceflinger, system_prop)
private/system_app.te:43:set_prop(system_app, system_prop)

set_prop(xxx, system_prop)的意思就是允许 xxx进程对system_prop上下文属性进行设置
\color{gray} {\small{exported_system_prop 上层设置,底层读取}}
\color{gray}{\small{exported_default_prop 底层设置,上层读取}}
\color{blue}{setprop属性是可以进行叠加的。}

四、解决方法

在相关的private/bootanim.te中添加setprop设置

....../private/bootanim.te
set_prop(bootanim, system_prop)

....../private/property_contexts
sys.xxx.xxx  u:object_r:system_prop:s0 exact string

这样就可以在bootanimation进程中property_set("sys.xxx.xxx","yyy"),在system_server进程中SystemProperties.get("sys.xxx.xxx","")进行读取。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容