service上层无法获取device设备权限问题解决

service上层无法获取device设备权限问题解决

在调试程序时,出现err log:open /dev/apdu failed: Permission denied
因为init启动的service没有root权限,所以无法获取dev设备的读写等指令。

解决方法:
1.新设备节点增加访问权限
驱动创建了一个新的设备节点,即使权限是777,android层也是没有访问权限的。
下面以一个/dev/apdu节点为示范,让此节点被用户空间的system_server进程访问。

在device相关目录下新增设备节点:

type misc_block_device, dev_type;
type private_block_device, dev_type;
新增:
type apdu_device, dev_type;  

2. 编辑file_contexts.te,将/dev/apdu节点声明为第1步定义的apdu_device:

/dev/block/by-name/misc         u:object_r:misc_block_device:s0
/dev/block/by-name/alog         u:object_r:log_block_device:s0
/dev/block/by-name/private      u:object_r:private_block_device:s0

# We add here  
/dev/apdu              u:object_r:apdu_device:s0  

3. 在system_server.te,允许system_server对wf_bt_device这个节点可读可写:

# Read/Write to /proc/net/xt_qtaguid/ctrl and and /dev/xt_qtaguid.  

allow system_server qtaguid_proc:file rw_file_perms;  
allow system_server qtaguid_device:chr_file rw_file_perms;  

#增加对dev/apdu的读写ioctl、map权限
allow system_server apdu_device:chr_file {read write ioctl map};

如果要增加上层的service对dev的权限,则在.te文件中,增加:

allow hal_secure_element_exec apdu_device:chr_file {read write ioctl map};

4.增加dev/apdu的读写权限
打开Android源代码工程目录下,进入到system/core/rootdir目录,里面有一个名为ueventd.rc文件,往里面添加一行:

/dev/apdu 0666 root root

以上,就可以让system_server访问硬件设备,其他上层进程可以以此类推

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值