关于mtk Android打开串口权限问题

在开发Android串口读写应用时,遇到了权限问题。本文介绍了两种解决方案:1. 禁止Selinux权限判断,通过修改`init.cpp`中的`selinux_status_from_cmdline`函数设置为宽容模式。2. 调整应用签名,使用`android:sharedUserId="android.uid.phone"`,并在`radio.te`中添加相应权限规则。
摘要由CSDN通过智能技术生成

最近在做一个串口读写回路的APK,jni代码部分遇到一个小小问题:

fd_com = open(ptty, O_RDWR | O_NOCTTY | O_NONBLOCK | O_NDELAY);
返回值是-1,要么就是权限问题,要么就是文件不存在
所以需要打印错误信息,所以继续打LOG:
    fd_com = open(ptty, O_RDWR | O_NOCTTY | O_NONBLOCK | O_NDELAY);
    if(fd_com < 0)
    {
        LOGD("open %s fail, %s\n", ptty, strerror(errno));
        return -1;
    }
其中strerror为系统函数,errno为系统全局变量
打印错误log:
avc: denied { read write } for name="ttyMT0" dev="tmpfs" ino=7869 scontext=u:r:radio:s0 tcontext=u:object_r:ttyMT_device:s0 tclass=chr_file permissive=0
D/JNILOG: open /dev/ttyMT0 fail, Permission denied

后来发现确实是权限问题,但是我已经chmod 666 /dev/ttyMT0

所以问题的关键来了:android为了防止用户获得root权限后,误操作引起的风险,特别设置一道关卡用来控制用户的读写操作.
即setenforce 0,其中0表示关闭这道防护措施,1表示打开这道防护措施.
方案一:
在adb shell下执行命令 setenforce 0

方案二:

代码上禁止Selinux权限判断

修改system/core/init/init.cp

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值