为什么 ping 在我的无线接口中不起作用?

为什么 ping 在我的无线接口中不起作用?

我正在 Yocto 映像中集成 wifi 模块,我想用它创建一个 AP 并从此类接口转发流量,但连接无法正常工作。我可以看到界面正在运行ifconfig

uap0      Link encap:Ethernet  HWaddr cc:f9:57:e0:15:81  
          inet addr:192.168.33.1  Bcast:192.168.33.255  Mask:255.255.255.0
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

我正在用这个界面创建一个wifi热点。我可以用手机查看 wifi 网络并连接到它(全部使用静态 IP)。为了验证接口是否正常工作,我从 yocto 机器向手机发出 ping 命令。但是我没有得到任何回应。

我已经设置了第三台机器也连接到无线网络。这台机器正在使用wireshark以监控模式嗅探流量。但是我没有看到 ARP 或 ICMP 数据包离开 wifi 接口。

路由表看起来不错:

route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         10.13.229.156   0.0.0.0         UG    0      0        0 inm0
192.168.32.0    0.0.0.0         255.255.255.0   U     0      0        0 usb0
192.168.33.0    0.0.0.0         255.255.255.0   U     0      0        0 uap0
192.168.201.0   0.0.0.0         255.255.255.0   U     0      0        0 usb0.1

但是,该链接似乎不起作用。我可以看到ip link showuap0接口有无载体

ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: sit0@NONE: <NOARP> mtu 1480 qdisc noop state DOWN mode DEFAULT group default 
    link/sit 0.0.0.0 brd 0.0.0.0
3: inm0: <BROADCAST,MULTICAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN mode DEFAULT group default qlen 1000
    link/ether 00:49:4e:4d:30:00 brd ff:ff:ff:ff:ff:ff
4: inm1: <BROADCAST,MULTICAST,NOARP> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
...
...
15: usb0.4@usb0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP mode DEFAULT group default 
    link/ether d4:ca:6e:f2:00:01 brd ff:ff:ff:ff:ff:ff
16: mlan0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
    link/ether cc:f9:57:e0:14:81 brd ff:ff:ff:ff:ff:ff
17: uap0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN mode DEFAULT group default qlen 1000
    link/ether cc:f9:57:e0:15:81 brd ff:ff:ff:ff:ff:ff

ifconfig uap0 down然后执行此操作ifconfig uap0 up会产生此错误消息。

root:$~ dmesg -wH
     +26.612727] IPv6: ADDRCONF(NETDEV_UP): uap0: link is not ready

您是否知道为什么 ping 可能无法正常工作,或者我可以进行哪些其他测试来评估哪一部分无法正常工作?

可能有帮助的其他信息:

ethtool -i uap0  
driver: wlan_sdio
version: 3.14.55-yocto-standard
firmware-version: N/A
bus-info: mmc1:0001:1
supports-statistics: no
supports-test: no
supports-eeprom-access: no
supports-register-dump: no
supports-priv-flags: no

答案1

其不工作的原因与 SD/MMC 时钟速度的变化有关。

wifi模块的驱动程序最初会以一定的速度下载固件。下载固件后,SD/MMC 的时钟增加到 200MHz。由于硬件限制,这导致与模块的通信不一致。

我将速度更改为 25MHz,现在可以正常工作了。

相关内容