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

最近在做一个串口读写回路的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.cpp的selinux_status_from_cmdline函数:

static selinux_enforcing_status selinux_status_from_cmdline() { 

     selinux_enforcing_status status = SELINUX_ENFORCING;

     改为: 

     selinux_enforcing_status status = SELINUX_PERMISSIVE;

}

方案三:

app目前签名为“android:sharedUserId="android.uid.phone"”,根据错误日志提示在radio.te
加入:

allow radio ttyMT_device:chr_file rw_file_perms;

 

你可能感兴趣的:(Android开发)