RT3070无线网卡AP模式——开发板实现路由功能并使客户端成功联网(WIFI)
主机操作系统:Centos 6.7
交叉编译器环境:arm-linux-gcc-4.5.4
开发板平台: FL2440
Linux内核版本: linux-3.0
开发模块: SIM900 WiFI-AP模式
一、配置内核支持无线网卡softAP模式
如果没有build in RF选项,在使用hostapd命令时会出错
注:在以上的几个目录下反复选,因为会生成新的选项,返回去接着重新选择(多来回选几遍避免遗漏,导致后面各种错误,血的教训啊!!!)
配置无线网络的软件移植
1.移植Openssl-0.9.8e
Hostapd依赖于openssl与libnl这两个库。所以首先要移植openssl与libnl,openssl我们已经移植过了,但我担心版本兼容性的问题,本着学习的心态便又移植了网上普遍使用的openssl-0.9.8e
1.1下载Openssl-0.9.8e
Openssl-0.9.8e
http://download.csdn.net/detail/u010944778/8940135
1.2解压之后直接修改Makefile
[luxibao@centos openssl-0.9.8e]$ mkdir install
[luxibao@centos openssl-0.9.8e]$ vim Makefile
29INSTALLTOP=/home/luxibao/fl2440/kernel/linux-3.0/openssl-0.9.8e/install
62 CC= /opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-gcc
63 CFLAG= -O
64 DEPFLAG= -DOPENSSL_NO_CAMELLIA -DOPENSSL_NO_GMP -DOPENSSL_NO_MDC2 -DOPENSSL_NO_RC5 -DOPENSSL_NO_RFC3779
65 PEX_LIBS=
66 EX_LIBS=
67 EXE_EXT=
68 ARFLAGS=
69 AR=/opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-ar $(ARFLAGS) r
70 RANLIB= /opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-ranlib
[luxibao@centos openssl-0.9.8e]$ sudo make
[luxibao@centos openssl-0.9.8e]$ sudo make install
2.移植libnl
2.1下载libnl
libnl
http://download.csdn.net/detail/u010944778/8940293
[luxibao@centos linux-3.0]$ cd libnl-1.1
[luxibao@centos libnl-1.1]$ mkdir install
[luxibao@centos libnl-1.1]$ ./configure --prefix=/home/luxibao/fl2440/kernel/linux-3.0/libnl-1.1/install --host=arm-linux
[luxibao@centos libnl-1.1]$ make CC=/opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-gcc
[luxibao@centos libnl-1.1]$ make install
移植Hostapd
3.1下载
hostapd-1.0.tar.gz
http://download.csdn.net/detail/u010944778/8940421
3.2解压后修改.config与Makefile
[luxibao@centos linux-3.0]$ cd hostapd-1.0
[luxibao@centos hostapd-1.0]$ ls
COPYING hostapd patches README src
[luxibao@centos hostapd-1.0]$ cd hostapd/
Makefile的修改:
CFLAGS += -I../src
CFLAGS += -I../src/utils
CFLAGS += -I/home/luxibao/fl2440/kernel/linux-3.0/libnl-1.1/install/include/
CFLAGS += -I/home/luxibao/fl2440/kernel/linux-3.0/openssl-0.9.8e/install/include/
LIBS += -L/home/luxibao/fl2440/kernel/linux-3.0/libnl-1.1/install/lib/
LDFLAGS += -L/home/luxibao/fl2440/kernel/linux-3.0/libnl-1.1/install/lib/
LIBS += -L/home/luxibao/fl2440/kernel/linux-3.0/openssl-0.9.8e/install/lib/
LDFLAGS += -L/home/luxibao/fl2440/kernel/linux-3.0/openssl-0.9.8e/install/lib/
# Uncomment following line and set the path to your kernel tree include
[luxibao@centos hostapd]$ cp defconfig .config
.config 修改:
22 # Driver interface for drivers using the nl80211 kernel interface
23 CONFIG_DRIVER_NL80211=y
[luxibao@centos hostapd]$ make CC=/opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-gcc
得到了hostapd和配置文件hostapd.conf,需要tftp到你的开发板上。 hostapd 需要到 /bin 目录下
interface=wlan0 //网络接口设备名称
driver=nl80211 //默认使用nl80211无线驱动
ssid=luxibao //热点名称
channel=3 //设定无线频道
hw_mode=g //使用80211g协议标准ignore_broadcast_ssid=0
auth_algs=1 //指定OSA认证算法
wpa=3 //指定WPA/WPA2类型
wpa_passphrase=12345678 //指定认证密钥
wpa_key_mgmt=WPA-PSK
wpa_pairwise=TKIP //启用了WPA或WPA2则需要指定wpa_pairwise或 rsn_pairwise
rsn_pairwise=CCMP
上面各项解释如下:
(1) ssid:无线路由器发射的wifi名称;
(2) hw_mode:指定802.11协议,包括 a = IEEE 802.11a, b = IEEE 802.11b, g = IEEE 802.11g;
===================================================================
无线局域网标准 IEEE 802.11协议
*IEEE 802.11, 1997年,原始标准(2Mbit/s,工作在2.4GHz)。
*IEEE 802.11a,1999年,物理层补充(54Mbit/s,工作在5GHz)。
*IEEE 802.11b,1999年,物理层补充(11Mbit/s工作在2.4GHz)。
*IEEE 802.11g,2003年,物理层补充(54Mbit/s,工作在2.4GHz)。
使用最多的应该是802.11n标准,工作在2.4GHz频段,可达600Mbps(理论值)
===================================================================
(3)channel:设定无线频道;
(4)interface:接入点设备名称,注意不要包含ap后缀,即如果该设备称为wlan0ap,填写wlan0即可;
(5)driver:设定无线驱动,我这里是nl80211;
(6)auth_algs=1
其中auth_algs指定采用哪种认证算法,采用位域(bit fields)方式来制定,其中第一位表示开放系统认证(Open System Authentication, OSA),第二位表示共享密钥认证(Shared Key Authentication, SKA)。我这里设置alth_algs的值为1,表示只采用OSA;
(7)wpa:指定WPA类型,这是一个位域值(bit fields),第一位表示启用WPA,第二位表示启用WPA2。在我的配置中,无论设置成1、2或3,都可以正常连接
(8)wpa_passphrase:WPA/WPA2加密需要指定密钥,这个选项就是配置WPA/WPA2的密钥。注意wpa_passphrase要求8~63个字符。另外还可以通过配置wpa_psk来制定密钥,不过要设置一个256位的16进制密钥,不适合我们的需求;
wpa_pairwise/rsn_pairwise:如果启用了WPA,需要指定wpa_pairwise;如果启用了WPA2,需要指定 rsn_pairwise,或者采用wpa_pairwise的设定。
接下来将hostapd拷贝到的/bin下,并修改可执行权限,将hostapd.conf也拷贝到开发板的/apps/AP/目录下
在板子上直接执行hostapd -B hostapd.conf 即可
如果编译过程出现缺少库的错误,请自行检查你hostapd所依赖的libnl库和openssl库是否成功交叉编译。
>: ls
Hostapd.conf
>: mv /dev/random /dev/random.org
>: ln -s /dev/urandom /dev/random
>: hostapd -B hostapd.conf
Configuration file: hostapd.conf
phy0 -> rt2x00lib_request_firmware: Info - Loading firmware file 'rt2870.bin'.
phy0 -> rt2x00lib_request_firmware: Info - Firmware detected - version: 0.36.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 0 - CWmin: 3, CWmax: 4, Aifs: 2, TXop: 102.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 1 - CWmin: 4, CWmax: 5, Aifs: 2, TXop: 188.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 2 - CWmin: 5, CWmax: 10, Aifs: 3, TXop: 0.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 3 - CWmin: 5, CWmax: 10, Aifs: 7, TXop: 0.
Using interface wlan0 with hwaddr 00:24:25:50:a9:4d and ssid 'test'
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 0 - CWmin: 2, CWmax: 3, Aifs: 1, TXop: 47.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 1 - CWmin: 3, CWmax: 4, Aifs: 1, TXop: 94.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 2 - CWmin: 4, CWmax: 6, Aifs: 3, TXop: 0.
phy0 -> rt2x00mac_conf_tx: Info - Configured TX queue 3 - CWmin: 4, CWmax: 10, Aifs: 7, TXop: 0.
(9)修改/home/leiyuxing/fl2440/3rdparty/busybox-1.20.2/examples/udhcp /udhcpd.conf 然后拷贝到开发板/etc目录下
1,修改IP池
起始IP的后两位可以随意,但必须在一个网段
192.168.x.y
192.168.x.z
2修改执行dhcp功能的接口
可以用过ifconfig -a或者iwconfig命令来查看接口
3,修改DNS、网关、netmask等
opt dns 8.8.8.8 # DNS地址
option subnet 255.255.255.0 #子网掩码
opt router 192.168.2.1 #网关
其他默认即可
4. 自动分配IP链接wifi
因为udhcpd和udhcpc一样都是busybox里面自带的命令。所以我直接把配置文件放到开发板上再执行命令
因为udhcpd和udhcpc一样都是busybox里面自带的命令。所以我直接把配置文件放到开发板上再执行命令
>: ifconfig wlan0 192.168.2.1 netmask 255.255.255.0 (先把要接入点设备ip设置好)
Udhcpd在执行的时候可能会提示没有一个叫做udhcpd.release的租赁文件,这个只要在相应的文件夹下创建即可。执行下面两条命令:
>: mkdir -p /var/lib/misc/
>: touch /var/lib/misc/udhcpd.leases
再执行:
>: udhcpd -f /etc/udhcpd.conf //就可以启动dhcp服务器了。
udhcpd (v1.20.2) started
Sending OFFER of 192.168.2.10 //这时候就是已经连上你开发板的wifi
Sending ACK to 192.168.2.10 //此时还不能上网!!!
4.iptables移植
iptables简介
iptables是基于内核的防火墙,功能非常强大,iptables内置了filter,nat和mangle三张表。
Filter表负责过滤数据包,包括的规则链有,input,output和forward;
Nat表则涉及到网络地址转换,包括的规则链有,prerouting,postrouting和output;
Mangle表则主要应用在修改数据包内容上,用来做流量整形的。
默认的规则链有:INPUT,OUTPUT,NAT,POSTROUTING,PREROUTING;
INPUT匹配目的IP是本机的数据包,FORWARD匹配流经本机的数据包,PREROUTING用来修改目的地址用来做DNAT,POSTROUTING用来修改源地址用来做SNAT。
===================================================================
4.1下载
iptables-1.4.12.tar.gz
http://download.csdn.net/detail/u010944778/8945513
4.2解压之后进入目录
[luxibao@centos linux-3.0]$ cd iptables-1.4.12
[luxibao@centos iptables-1.4.12]$ mkdir install
[luxibao@centos iptables-1.4.12]$ ./configure --host=arm-linux --enable-static --disable-shared --prefix=/home/luxibao/fl2440/kernel/linux-3.0/iptables-1.4.12/install --disable-ipv6 --disable-largefile
[luxibao@centos iptables-1.4.12]$ make CC=/opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-gcc CFALGS=--static LDFLAGS=-static
[luxibao@centos iptables-1.4.12]$ sudo make install
[luxibao@centos iptables-1.4.12]$ cd install
[luxibao@centos install]$ cd sbin/
[luxibao@centos sbin]$ ls
iptables iptables-restore iptables-save xtables-multi
[luxibao@centos sbin]$ sudo /opt/buildroot-2012.08/arm920t/usr/bin/arm-linux-strip xtables-multi
[luxibao@centos sbin]$ cd ../
[luxibao@centos install]$ ls
bin include lib sbin share
[luxibao@centos install]$ tar -czf lib.tar.gz lib
[luxibao@centos install]$ ls
bin include lib lib.tar.gz sbin share
此时将/install/lib文件夹和xtables-multi打包放到开发板/lib和/bin目录下,赋予权限后将xtables-multi改名为iptables
.使用iptables命令接着配置nat转发表
/*将局域网内地址通过eth0接口伪装后转发出去*/
>:iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
/*开启转发功能,允许已建立连接及相关连接对内转发*/
>: iptables -A FORWARD -i eth0 -o wlan0 -m state --state RELATED,ESTABLISH -j ACCEPT
/*对外转发,数据包从wlan0流向eth0*/
>: iptables -A FORWARD -i wlan0 -o eth0 -j ACCEPT
>:echo "1" >/proc/sys/net/ipv4/ip_forward
>:ifconfig eth0 192.168.199.22
>:route add default gw 192.168.199.1
注:执行上面的iptables那四个命令,再设置eth0的ip(ifconfig eth0 192.168.199.22,注意设置eth0的ip地址应该和连接的路由器ip地址在同一网段!!!这个很重要,关系到能否上外网),接着设置网关route add default gw 192.168.199.1,执行指令udhapd -f etc/udhapd.conf,手机连上wifi后就可以直接上网啦!!!
然后连上的wifi热点就可以上网了。至此使用hostapd+udhcpd+iptables等工具基于内核mac80211驱动框架就实现了RT3070无线网卡的softAP!!!
遇到的问题:
1.
解决:./configure --prefix 遗漏的中间的空格符.
2.tftp 路径不对
解决:修改TFTP路径
3.缺少libnl.so.1
解决:
>: ls
apps data etc init linuxrc proc sbin tmp var
bin dev info lib mnt root sys usr
>: cd lib/
>: tftp -gr libnl.so.1 192.168.1.2
libnl.so.1 100% |*******************************| 1135k 0:00:00 ETA
>: chmod 777 libnl.so.1
4.缺少'rt2870.bin'
解决:
>: ls
apps data etc init linuxrc proc sbin tmp var
bin dev info lib mnt root sys usr
>: cd lib/
>: mkdir firmware
>: cd firmware/
>: tftp -gr rt2870.bin 192.168.1.2
rt2870.bin 100% |*******************************| 8192 0:00:00 ETA
5.
解决:
Udhcpd在执行的时候可能会提示没有一个叫做udhcpd.release的租赁文件,这个只要在相应的文件夹下创建即可。执行下面两条命令:
~>mkdir -p /var/lib/misc/
~>touch /var/lib/misc/udhcpd.leases
再次执行!