2017-03-16 450 views
1

在adb shell中运行,并由NDK编译。套接字(AF_INET,SOCK_DGRAM,IPPROTO_ICMP)失败,errno = 13(权限被拒绝)

我的代码:

#include <sys/socket.h> 
#include <errno.h> 
#include <linux/netlink.h> 
#include <linux/in.h> 
#include <string.h> 
#include <stdio.h> 
int main() 
{ 
    int sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_ICMP); 
    printf("sock = %d and errno = %d\n", sock, errno); 
    return 0; 
} 

输出:

[email protected]:/data/local/tmp $ ./poc 
sock = -1 and errno = 13 

有谁知道为什么吗?

+0

你有没有把你的SELinux设置为'enforced'或'permissive'模式?另外,运行你的程序后('dmesg')什么是内核输出? –

+0

vbox86p:/数据/本地的/ tmp#getenforce 残疾人 – jptang

+0

的dmesg:<6> [8.208501] qtaguid:ctrl_counterset(S 1 10023):从PID = 466 TGID = 279 UID PRIV不足= 1000 <3> [9.362826] INIT: sys_prop:permission denied uid:1003 name:service.bootanim.exit <7> [10.959880] eth0:没有IPv6路由器存在 <7> [20.643991] eth1:没有IPv6路由器存在 – jptang

回答

相关问题