天天看点

linux -- Linux下USB无线网卡WL-167G、TL-WN321G驱动安装过程详解

网卡 华硕WL-167G、TP-LINK TL-WN321G

驱动 RT73_Linux_STA_Drv1.0.3.6

下载地址

http://dlsvr01.asus.com/pub/ASUS/wireless/WL-167g/Linux_1218.zip

一、 准备工作 解压内核源码,拷贝对应内核的makefile,并更改文件属性

[[email protected] RT73_Linux_STA_Drv1.0.3.6]# chmod 777 Module

[[email protected] RT73_Linux_STA_Drv1.0.3.6]# ls -al

总用量 16

。。。。。。。。。。

drwxrwxrwx 2 root root 4096 2006-07-04 Module

##确保文件对任何用户是可读可执行的,否则可能不能make config,777可以保证所有权限

二、 添加对WL-167G ASUS 网卡的支持,注意官方的1218版本以前驱动包括网卡自带的光盘里没有对此说明,否则驱动加载后会说找不到设备

[[email protected] Module]# gedit rtmp_def.h

##add support for WL-167G ASUS

{USB_DEVICE(0x0B05,0x1723)}, /

{USB_DEVICE(0x0B05,0x1724)}, /

三、 配置、编译 确保对应目录下存在/usr/src当前系统运行的内核源码,其他位置不行

1> $make config

## ensure there are such directories as /usr/src/linux-2.4.20-8 and /lib/modules/2.4.20-8/kernel/drivers/net, but they are your own kernel

2> $make all # compile driver source code

## ensure no problems occur

四、修改自启动配置文件ifcfg-rausb0并安装RT73.o及添加alias rausb0 rt73

1> 修改当前目录下的ifcfg-rausb0,若是动态IP则不需要修改

[[email protected] Module]# gedit ifcfg-rausb0

## edit the file according to your network system, and it can be auto loaded when booting system. and the file is as follows:

DEVICE=rausb0

ONBOOT=yes

## static for fixed ip

BOOTPROTO=static

IPADDR=192.168.0.31 ## 你自己的IP及其他相关设置

NETMASK=255.255.255.0

GATEWAY=192.168.0.1

2> 安装模块及其他自启动设置

[[email protected] Module]# make install

install -m 755 -o 0 -g 0 -d /lib/modules/2.4.20-8/extra

………………

## 安装完毕后请确认对应目录下存在下列文件

## 安装完毕后modules.conf内容如下:

...............

alias rausb0 rt73

##安装完毕后 ifcfg-rausb0 内容如gedit ifcfg-rausb0所设

五、拷贝系统固件及默认自启动时的默认配置文件

1> $cp rt73.bin /etc/Wireless/RT73STA/ # copy firmware

[[email protected] Module]# cp rt73.bin /etc/Wireless/RT73STA/

##必须先逐层建立目录/etc/Wireless/RT73STA/后,再执行拷贝操作,否则报错

2> $dos2unix rt73sta.dat

$cp rt73sta.dat /etc/Wireless/RT73STA/rt73sta.dat

[[email protected] Module]# dos2unix rt73sta.dat

dos2unix: converting file rt73sta.dat to UNIX format ...

## 拷贝完毕上述目录确认存在此两个文件

# Use "vi -b rt73sta.dat" to modify settings according to your need.

六、动态加载模块 用相关命令确认模块加载成功

[[email protected] Module]# insmod rt73.o

[[email protected] Module]# cat /var/log/messages | tail

。。。。。。。。。。

Apr 14 14:05:44 dding kernel: rtusb init ====>

Apr 14 14:05:44 dding kernel: usb.c: registered new driver rt73

[[email protected] Module]# dmesg | tail

。。。。。。。。。。

rtusb init ====>

usb.c: registered new driver rt73

[[email protected] Module]# lsmod

Module Size Used by Not tainted

rt73 233632 0 (unused)

...............

usbcore 78784 1 [rt73 hid usb-uhci ehci-hcd]

## 也可以确认模块是否加载成功

 七、插入网卡,看是否能够识别

## insert the WL-167G card

[[email protected] Module]# cat /var/log/messages | tail

。。。。。。。。。。

Apr 14 14:07:58 dding kernel: idVendor = 0xb05, idProduct = 0x1723

Apr 14 14:07:59 dding /etc/hotplug/net.agent: invoke ifup rausb0

。。。。。。。。。。。

Apr 14 14:08:02 dding /etc/hotplug/usb.agent: Setup rt73 for USB product b05/1723/1

[[email protected] Module]# dmesg | tail

。。。。。。。。。。。

## pop out the WL-167G card insert the TL-WN321G card

[[email protected] Module]# cat /var/log/messages | tail

。。。。。。。。。。。。。

Apr 14 14:11:02 dding /etc/hotplug/usb.agent: Setup rt73 for USB product 148f/2573/1

Apr 14 14:11:02 dding devlabel: devlabel service started/restarted

## support for USB product 148f/2573/1, and all is ok

[[email protected] Module]# dmesg | tail

。。。。。。。。。。。。。。。

八、成功识别后,用iwconfig查看无线网络并进行相关设置

[[email protected] Module]# iwconfig

rausb0 RT73 WLAN ESSID:"lab706"

Mode:Ad-Hoc Channel:1 Cell: 00:18:F3:E5:9D:66

。。。。。。。。。。。。

[[email protected] Module]# iwconfig rausb0 mode managed

[[email protected] Module]# iwconfig

rausb0 RT73 WLAN ESSID:""

。。。。。。。。。。。。。

## Infrustructure mod, 默认ESSID:""为空,

[[email protected] Module]# iwlist rausb0 scan

rausb0 Scan completed :

Cell 01 - Address: 00:18:F3:E5:9D:66

ESSID:"lab706"

。。。。。。。。。。。。

Cell 02 - Address: 00:C0:02:0A:8D:52

ESSID:"A509-ID"

。。。。。。。。。。。

##将自动接收周围的信标帧,并比较信号值自动进行联接,也可以扫描手动设置

[[email protected] Module]# iwconfig

rausb0 RT73 WLAN ESSID:"lab706"

Mode:Managed Channel:1 Access Point: 00:18:F3:E5:9D:66

。。。。。。。。。。。。。

## AP端设置好后,TL-WN321G自动联接到AP上了,太爽了,WL-167G还可以当AP用

## 在AP端加上了MAC控制列表防止其他用户联接到此网络上

问题:驱动安装完毕后,无线网卡ping不通AP

过程:

1、IP未配置

这是iwconfig的结果:

rausb0    RT73 WLAN  ESSID:"VeryBT" 

          Mode:Managed  Channel:6  Access Point: 00:19:E0:D8:E2:A8 

          Bit Rate=54Mb/s  

          RTS thr:off   Fragment thr:off

          Encryption key:7461-6E67-796F-6E67-3730-324C-42

          Link Quality:100/100  Signal level:-32 dBm  Noise level:-79 dBm

          Rx invalid nwid:0  Rx invalid crypt:0  Rx invalid frag:0

          Tx excessive retries:0  Invalid misc:0   Missed beacon:

这是ipconfig的结果:

rausb0    Link encap:Ethernet  HWaddr 00:1B:FC:45:54:58 

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:273 errors:0 dropped:0 overruns:0 frame:0

          TX packets:839 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:100

          RX bytes:30678 (29.9 Kb)  TX bytes:60322 (58.9 Kb

在ifcfg-rausb0里面动态获取的

BOOTPROTO=dhcp

但无线和有线不一样,在该无线网卡未连入系统时,其可能无法和DHCP服务器通信以获得IP

上面的ifconfig的结果也证实了IP未能获取成功

因此对于Linux下面的无线网卡要静态配置Ip

#xuxunlin add follow

#BOOTPROTO=static

#IPADDR=192.168.1.101

#NETMASK=255.255.255.0

#GATEWAY=192.168.1.1                                                 

#add end

确保上面无线网卡的IP和AP的IP在同一个网段

2、扫描AP,确保已经连到对应的无线网络上了

iwlist rausb0 scan

rausb0    Scan completed :

          Cell 01 - Address: 00:0F:66:B0:8F:84

                    ESSID:"WLANLAB"

                    Mode:Managed

                    Channel:11

                    Encryption key:off

                    Bit Rate:0kb/s

          Cell 02 - Address: 00:19:E0:D8:E2:A8

                    ESSID:"VeryBT"

                    Mode:Managed

                    Channel:6

                    Encryption key:on

                    Bit Rate:0kb/

iwconfig:

rausb0    RT73 WLAN  ESSID:"VeryBT" 

          Mode:Managed  Channel:6  Access Point: 00:19:E0:D8:E2:A8 

          Bit Rate=54Mb/s  

          RTS thr:off   Fragment thr:off

          Encryption key:7461-6E67-796F-6E67-3730-324C-42

          Link Quality:100/100  Signal level:-32 dBm  Noise level:-79 dBm

          Rx invalid nwid:0  Rx invalid crypt:0  Rx invalid frag:0

          Tx excessive retries:0  Invalid misc:0   Missed beacon:

ifconfig:

eth0      Link encap:Ethernet  HWaddr 00:0C:29:A5:8D:CD 

          inet addr:202.115.27.234  Bcast:202.115.27.255  Mask:255.255.255.0

          。。。。。。

lo        Link encap:Local Loopback 

       。。。。。。。。。。

rausb0    Link encap:Ethernet  HWaddr 00:1B:FC:45:54:58 

          inet addr:192.168.1.101  Bcast:192.168.1.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:32973 errors:0 dropped:0 overruns:0 frame:0

          TX packets:1555 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:100

          RX bytes:3840399 (3.6 Mb)  TX bytes:100306 (97.9 Kb

上述相关命令显示IP地址设置正确,网卡已经连接到AP了

Access Point: 00:19:E0:D8:E2:A8  和

Cell 02 - Address: 00:19:E0:D8:E2:A8匹配

但仍然ping不通

PING 192.168.1.1 (192.168.1.1) 56(84) bytes of data.

From 192.168.1.101 icmp_seq=1 Destination Host Unreachable

3、一般情况下Destination Host Unreachable是路由有问题,即数据包不能找到一条合适的路径发送出去,因此确认网关正确

在图形化界面里面未找到rausb0的配置项,只能通过命令配置

route add default gw 192.168.1.1

仍然不通,用netstat -r查看当前存在的路由表项

Kernel IP routing table

Destination     Gateway         Genmask         Flags Metric Ref    Use Iface

192.168.1.0     *               255.255.255.0   U     0      0        0 rausb0

169.254.0.0     *               255.255.0.0     U     0      0        0 rausb0

127.0.0.0       *               255.0.0.0       U     0      0        0 lo

default         192.168.1.1     0.0.0.0         UG    0      0        0 rausb

192.168.1.0     *               255.255.255.0   U     0      0        0 rausb0

对应的网关为空

而default         192.168.1.1     0.0.0.0         UG    0      0        0 rausb

对应的网络接口不是rausb0,但是以太网的default项接口肯定是eth0的,不是eth

因此添加完整的路由表项

route add -net 192.168.1.10 netmask 255.255.255.0 gw 192.168.1.1 

提示

route:netmask does‘t match route address

命令格式用错了

-net指定网络号,而非IP地址

route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1

netstat -r

Kernel IP routing table

Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface

192.168.1.0     192.168.1.1     255.255.255.0   UG        0 0          0 rausb0

192.168.1.0     *               255.255.255.0   U         0 0          0 rausb0

127.0.0.0       *               255.0.0.0       U         0 0          0 lo

default         192.168.1.1     0.0.0.0         UG        0 0          0 rausb

现在192.168.1.0     192.168.1.1     255.255.255.0   UG        0 0          0 rausb0表项完整了

ping 192.168.1.1的报文可以确定是通过上述表项对应的rasub0发送出去的

当有线和无线网卡在同一个网段时,可能存在无线对应的网段数据是通过eth0发送的,这个时候肯定是无法reach host的

配置好了上述路由后,仍然不通

Destination Host Unreachable

4、用traceroute追踪路由

traceroute 192.168.1.1

 1  192.168.1.10 (192.168.1.10)  2653.335 ms !H  2998.934 ms !H  2999.653 ms !

没有出现类似windows下面的

Trace complete提示

因此也没有搞明白错误出现在哪一环

5、IP已经配置,连上AP了,路由表也配了,实在想不到还有什么不对的地方,采用最原始的办法:确保防火墙已关闭、网卡本身硬件没问题,在windows下面尝试确认是无线网卡驱动的问题还是网络本身的问题

windows下面尝试的结果是也无法ping通

因为windows的驱动是不用怀疑的,相关配置都是自动的

问题的原因进一步缩小,xuxunlin 很快找到了密码的问题

重新更改密码后,在Linux下面添加密匙

iwconfig rausb0 essid "xx" key s:xxx

即可ping通了

6、疑惑

因为看到iwlist之后iwconfig的结果中已经连接到AP了

总是觉得无线网络本身是没有问题的

因为按照无线的协议,扫描》认证》关联,密匙不对是无法经过认证阶段的

但现在iwconfig的结果却显示连接上了?

期待哪位大虾解释下iwconfig的结果

iwconfig:

rausb0    RT73 WLAN  ESSID:"VeryBT" 

          Mode:Managed  Channel:6  Access Point: 00:19:E0:D8:E2:A8 

          Bit Rate=54Mb/s  

          RTS thr:off   Fragment thr:off

          Encryption key:7461-6E67-796F-6E67-3730-324C-42

          Link Quality:100/100  Signal level:-32 dBm  Noise level:-79 dBm

          Rx invalid nwid:0  Rx invalid crypt:0  Rx invalid frag:0

          Tx excessive retries:0  Invalid misc:0   Missed beacon

继续阅读