最近在做一个串口读写回路的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