老化测试app里面可能要去写文件,如果是adb shell里面那就很简单,
直接
echo 255 > /sys/class/leds/aw9106_led/brightness
就可以点亮灯等操作,但是再app里面执行shell命令就有很多权限问题,比如sys的权限是root:root访问,也可能是666的权限,
这些都要去再rc文件里改系统源码。
另外,网上的下面这种,先执行su或者system/xbin/su,也是有avc权限问题的,如下log:
su: type=1400 audit(0.0:865): avc: denied { getattr } for path="/system/xbin/su" dev="mmcblk0p25"
ino=3263 scontext=u:r:system_app:s0 tcontext=u:object_r:su_exec:s0 tclass=file permissive=1
这又要去放开su的selinux权限,这样应该不妥吧
// public void execShell(String cmd){
// try{
// Process p = Runtime.getRuntime().exec("su");
// OutputStream outputStream = p.getOutputStream();
// DataOutputStream dataOutputStream=new DataOutputStream(outputStream);
// dataOutputStream.writeBytes(cmd);
// dataOutputStream.flush();
// dataOutputStream.close();
// outputStream.close();
// }
// catch(Throwable t){
// t.printStackTrace();
// }
// }
// execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");
// execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");
// execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");
---------
后面还是觉得写成c文件,ndk编译成可执行文件,然后推到/system/bin/或者在系统源码里面编译到system/bin/下比较简单,
system/bin下的可执行文件就免除root权限了==,有selinux权限也相对来说好加一些~~
------------------------------------------------------------------------------------
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "itv_assistance_native", __VA_ARGS__)
int main(int argC, char **argV)
{
int value;
if (argC != 2) {
LOGD("argC is not right..\n");
return 0;
}
value=atoi(argV[1]);
if (value==1){
LOGD("led on..\n");
system("echo 255 >/sys/class/leds/aw9106_led/brightness");
}
else if (value==0){
system("echo 0 >/sys/class/leds/aw9106_led/brightness");
LOGD("led off..\n");
}
return 0;
}
--------------------------------------------------------------------------------
app调用就比较方便:
Runtime.getRuntime().exec("ledtest 1");
----
后面想起来,之前想在app里执行"adb shell input tap X Y"模拟点击事件,也没有成功,现在也可以写在c里面,
把x,y坐标通过argv传进去。
没有成功的原因是,输入事件的权限问题,在也要改系统源码或者app成跳权限过去,比较麻烦网上相关答案也比较少,后面没有弄了