蓝牙PAN连接 - ARP无法正常工作

时间:2016-08-25 12:05:20

标签: bluetooth tcp-ip arp

我的设置是一个嵌入式设备,可以通过平板电脑访问(可能是Android或基于iOS)。

通过蓝牙访问设备,它实现了PAN配置文件(NAP角色),这样平板电脑就可以将其视为可以访问互联网的设备。

我使用DBus向Bluez注册NAP服务器。这很好用,Bluez在平板电脑连接时创建一个名为'bnep0'的网络接口。 我在/ etc / network / interfaces中配置了bnep0接口:

iface bnep0 inet static
  address 10.254.239.1
  netmask 255.255.255.0
  post-up service isc-dhcp-server start
  pre-down service isc-dhcp-server stop

我使用udev使用/etc/udev/rules.d/50-bnep.rules中定义的规则来启动/关闭界面:

ACTION=="add", KERNEL=="bnep0" SUBSYSTEM=="net", RUN+="/sbin/ifup bnep0"
ACTION=="remove", KERNEL=="bnep0", SUBSYSTEM=="net", RUN+="/sbin/ifdown bnep0"

如您所见,我使用界面启动/关闭事件来启动/停止为平板电脑提供IP地址的DHCP服务器。

我的DHCP服务器由/etc/dhcp/dhcpd.conf中的以下行配置:

subnet 10.254.239.0 netmask 255.255.255.0 {
  range 10.254.239.2 10.254.239.254;
}

作为旁注,我还在/ etc / network / interfaces中创建了一个网桥br0。为了注册NAP接口,Bluez需要这样做:

iface br0 inet manual
  bridge_ports none
  bridge_fd 0
  bridge_stp off

这一切都很好。平板电脑将与我的设备进行蓝牙配对并成功连接。我还可以观察到平板电脑查询我设备的DHCP服务器并获得地址10.254.239.2

在我的设备上,我从命令'ip addr show'获得输出:

4: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default 
    link/ether 5c:e0:c5:af:7b:f6 brd ff:ff:ff:ff:ff:ff
    inet6 fe80::984d:cdff:fe4b:65be/64 scope link 
       valid_lft forever preferred_lft forever
9: bnep0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UNKNOWN group default qlen 1000
    link/ether 5c:e0:c5:af:7b:f6 brd ff:ff:ff:ff:ff:ff
    inet 10.254.239.1/24 brd 10.254.239.255 scope global bnep0
       valid_lft forever preferred_lft forever
    inet6 fe80::5ee0:c5ff:feaf:7bf6/64 scope link 
   valid_lft forever preferred_lft forever

然后我在我的嵌入式设备上启动一个应用程序,它在地址10.254.239.1,端口15137上打开一个TCP服务器套接字。该应用程序侦听来自平板电脑的传入连接。

现在我尝试从平板电脑打开TCP客户端套接字到IP地址10.254.239.1。我可以观察(使用wireshark)接口bnep0接收IP地址10.254.239.1的ARP请求。但我的设备不会生成任何ARP响应,并且平板电脑应用程序在尝试连接TCP套接字时会超时: - (

同样,如果我尝试从我的嵌入式设备ping平板电脑,我发现我的设备会发送平板电脑正常响应的10.254.239.2的ARP请求。但就好像设备没有收到ARP响应一样,因为它之后不会发送任何ping请求。

因此,症状是未处理接口bnep0上的传入ARP数据包。

我真的无法理解我所缺少的东西。你们有人可以帮助我吗?

1 个答案:

答案 0 :(得分:0)

事实证明,问题是我自己对网桥的工作方式缺乏了解。

我找到了非常丰富的HOWTO Persistently bridge traffic between two or more Ethernet interfaces (Debian),它清楚地表明,一旦网络接口被添加到网桥,它就不能用作IP流量的端点。

因此,我需要做的是更改/ etc / network / interfaces中网络接口的设置,使网桥成为IP端点:

iface br0 inet static
  address 10.254.239.1
  netmask 255.255.255.0
  bridge_ports none
  bridge_fd 0
  bridge_stp off

请注意,bnep0的部分可以完全省略。

还要感谢ELinux - Bluetooth Network的灵感。