aosp:android派(android-9.0.0_r16)
制造:PQ1A.181105.017.A1
设备:像素2
我正在尝试使用dhcptool(重命名为dhcpdbg)和rndis模式下的android 9 pie连接蜂窝调制解调器。同样的设置在以前版本的android上运行良好,但对于pie,它在ioctl(3,siocaddrt,0x7ffb9b8030)上失败。它说“网络是无法到达的”。
我已经检查了ifconfig中的端口,即usb0,它枚举正确,但是dhcpdbg调用失败,网络无法ping。
设备上的sepolicy处于允许模式。此外,dmesg日志中没有权限或其他错误。
注意:默认情况下,rndis驱动程序没有在android pie内核中配置,因此我们在内核中启用了rndis模式,并在aosp源代码中集成了已更改的内核。
以下是“strace dhcpdbg usb0”中的一些日志
ioctl(3, SIOCGIFFLAGS, {ifr_name="usb0", ifr_flags=IFF_UP|IFF_BROADCAST|IFF_RUNNING|IFF_MULTICAST}) = 0
ioctl(3, SIOCSIFFLAGS, {ifr_name="usb0", ifr_flags=IFF_UP|IFF_BROADCAST|IFF_RUNNING|IFF_MULTICAST}) = 0
ioctl(3, SIOCSIFADDR, {ifr_name="usb0", ifr_addr={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("192.168.1.100")}}) = 0
ioctl(3, SIOCSIFNETMASK, {ifr_name="usb0", ifr_netmask={sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("255.255.255.0")}}) = 0
ioctl(3, SIOCADDRT, 0x7ffb9b8030) = -1 ENETUNREACH (Network is unreachable)
close(3) = 0
getuid() = 0
writev(5, [{iov_base="\0\355\25o\6X\\=\267\254%", iov_len=11}, {iov_base=&