Differences between revisions 52 and 53
Revision 52 as of 2008-11-17 21:21:55
Size: 9216
Editor: FranklinPiat
Comment: Can't see any network
Revision 53 as of 2008-12-21 11:58:21
Size: 9287
Editor: FranklinPiat
Comment: add link to upstream in "see also" section.
Deletions are marked like this. Additions are marked like this.
Line 176: Line 176:
 * [:WiFi/HowToUse:HowToUse] Wifi adapter.  * ["WiFi/HowToUse"] - HowToUse Wifi adapter.
 * [http://www.intellinuxwireless.org/] - iwlwifi driver homepage.

This page describes how to use iwl-wifi ([http://www.intellinuxwireless.org/ Intel Wireless WiFi Link driver]) with an iwl3945 or iwl4965.

  • ?TableOfContents(2)

Introduction

The iwl-wifi drivers are open-source drivers supported by Intel, replacing the older Intel drivers ["ipw3945"] which needed some userspace daemon (see ?FootNote(ipw3945-vs-iwl3945: The Intel code in ipw3945 implements a number of non-free algorithms which are not realized in iwl3945, including automatic calibration of the radio power based on temperature variations, and dynamic tuning of the radio sensitivity based on received signal strength. These may extend the operating range of the adapter, improve throughput in various environmental conditions, and reduce power consumption, but they are kept secret by Intel.)).

Supported hardware :

  • Intel 3945 and 4965 : since Debian 2.6.23 and later kernels (Etch's kernel 2.6.18 had ["ipw3945"]).
  • Intel 5100 and 5300 : not supported currently (module iwlagn is planned for kernel 2.6.27, see 501157).

Installation

  • Install 2.6.24 (or later) kernel, available in :
    • ["EtchAndAHalf"]'s 2.6.24 kernel (not installed by default).
    • [:DebianLenny:Debian Lenny].

  • Install Firmware. (You will need to add non-free repository to /etc/apt/source.list)
     aptitude install firmware-iwlwifi

Loading the iwl3945 / iwl4965 modules

  • The module should be loaded automatically by udev when the system starts.
  • Most laptops have a radio kill switch (or a function key combination) to physically disable the radio (when inside an airplane for example). Make sure to enable the radio.
  • If the module isn't loaded automatically, issue this command:

    iwl4965 :

    modprobe iwl4965

    iwl3945 :

    modprobe iwl3945

?Anchor(using)

Using iwlWifi

Gnome Network Manager

  • Gnome- Double click on Network Connection (If you don't have an icon click on add to panel, then Select "Network Monitor" and click add)
  • Name: Wlan0
  • Click on configure
  • Select Wireless connection
  • Properties
  • Pick a network, add a password, select dhcp and click ok
  • You should be connected.

Alternatively,

  • Those who prefer using ifup/ifdown from the command line, I used the following stanza in /etc/network/interfaces/:

    iface wlan0 inet dhcp
      pre-up ip link set wlan0 up
      wireless_essid MakeTeaNotWar

Note the magic pre-up line, which I needed to make the card associate with the access point. As a bonus, with this stanza the interface works after an S3 resume (i.e. suspend/resume to RAM)!

?Anchor(wpa)

Interfaces

Once the module is loaded, ip a should show two interfaces (wlan0 is the "main" one).

  • 3: wmaster0: <BROADCAST,MULTICAST,UP,10000> mtu 1500 qdisc ieee80211 qlen 1000
        link/ieee802.11 00:13:e8:70:69:fb brd ff:ff:ff:ff:ff:ff
    4: wlan0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc pfifo_fast qlen 1000
        link/ether 00:13:e8:70:69:fb brd ff:ff:ff:ff:ff:ff

?Anchor(ipw3945d-to-iwl)

Switching from ipw3945 to iwl3945

  • Install as explained above.
  • Check for the line generated by udev for ipw3945 in /etc/udev/rules.d/z25_persistent-net.rules. If it is there, remove it (more explanation in "Common problems and errors" below).
  • Optionally, change the configuration in /etc/network/interfaces by replacing eth2 (or whatever the old name for wireless interface is) with wlan0.
  • Reboot into the new kernel.
  • Verify that wireless networking is functional. If you can connect, but you cannot send/receive anything you might want to check your firewall configuration. For example, if you have configured your firewall using shorewall, you have to change all occurrences of eth2 in the files in /etc/shorewall with wlan0.
  • Remove the ipw3945-modules-* and ipw3945d packages.

Common problems and errors

?Anchor(wlan0_rename)

Another symptom is that Network-manager don't handle the wireless card.

/var/log/syslog may show :

  • kernel: iwl3945: Intel(R) PRO/Wireless 3945ABG/BG Network Connection driver for Linux, 0.1.15ks
    kernel: iwl3945: Copyright(c) 2003-2007 Intel Corporation
    kernel: ACPI: PCI Interrupt 0000:03:00.0[A] -> GSI 17 (level, low) -> IRQ 22
    kernel: PCI: Setting latency timer of device 0000:03:00.0 to 64
    kernel: iwl3945: Detected Intel PRO/Wireless 3945ABG Network Connection
    kernel: iwl3945: Tunable channels: 13 802.11bg, 23 802.11a channels
    kernel: wmaster0: Selected rate control algorithm 'iwl-3945-rs'
    kernel: net eth2: device_rename: sysfs_create_symlink failed (-17)
    kernel: udev: renamed network interface wmaster0 to eth2
    kernel: net wlan0_rename: device_rename: sysfs_create_symlink failed (-17)
  • This may occur if you had used ipw3945 module before.

Resolution

in /etc/udev/rules.d/z25_persistent-net.rules remove the line like

  • # PCI device 0x8086:0x4227 (ipw3945)
    SUBSYSTEM=="net", DRIVERS=="?*", ATTRS{address}=="00:13:02:4c:12:12", NAME="eth2"

then remove the module and re-insert it.

  • rmmod iwl3945
    modprobe iwl3945

in /etc/udev/rules.d/z25_persistent-net.rules you should now have a line like :

  • # PCI device 0x8086:0x4227 (iwl3945)
    SUBSYSTEM=="net", DRIVERS=="?*", ATTR{address}=="00:13:02:4c:12:12", ATTR{type}=="1", NAME="wlan0"

Card does not associate to the access point

If the card accepts the essid, for example, by doing :

  • iwconfig wlan0 essid YourESSID

but does not associate to the access point even when no encryption is needed: The driver seems to need the interface to be in the up state when it gets the essid. So first do

  • ip link set wlan0 up

then set the essid as before.

If the card still does not associate to the access point even with essid and encryption keys set, try

  • iwconfig wlan0 ap any

If you configured you card in /etc/network/interfaces and you cannot associate to you access point, you might want to try different values for wpa-scan-ssid and wpa-ap-scan. The former accepts either 0 or 1, the latter 0, 1 or 2. Setting wpa-scan-ssid to 0 and wpa-ap-scan to 1 is a good first bet, but make sure to try other configurations if it doesn't work.

You may also find that setting a high retry value helps with WEP enabled access points that appear to work or that work with other cards but send repeated disassociates. Try something like this and insert an arbitrary retry value. It may take a few tries with dhclient to get an IP:

  • iwconfig wlan0 retry <value>

Can't see any network

If networkmanager seems to detect the card, but can't "see" any network, it might be because the firmware isn't installed. make sure you have installed the firmware, then unloaded and reloaded the module.

  • ACPI: PCI Interrupt 0000:03:00.0[A] -> GSI 17 (level, low) -> IRQ 17
    kernel: PM: Writing back config space on device 0000:03:00.0 at offset 1 (was 100102, writing 40100106)
    kernel: firmware: requesting iwlwifi-4965-1.ucode
    kernel: iwl4965: iwlwifi-4965-1.ucode firmware file req failed: Reason -2
    kernel: iwl4965: Could not read microcode: -2

You are able to associate, but you cannot send nor receive anything on the interface

If this happens, your firewall might be blocking your traffic. This will mostly happen if you switch from ipw3945/ipw4945 to iwlwifi because the name of the interface changes from eth2 to wlan0. Check your firewall configuration, e.g. if you are using shorewall check the files in /etc/shorewall/ and change the name of the interface to wlan0.

Identify iwl wireless cards

Running  lspci -nn  should list one of :

  • 03:00.0 Network controller [0280]: Intel Corporation PRO/Wireless 3945ABG Network Connection [8086:4222] (rev 02)
    03:00.0 Network controller [0280]: Intel Corporation PRO/Wireless 3945ABG Network Connection [8086:4227] (rev 02)
    03:00.0 Network controller [0280]: Intel Corporation PRO/Wireless 4965 AG or AGN Network Connection [8086:4229]
    03:00.0 Network controller [0280]: Intel Corporation PRO/Wireless 4965 AG or AGN Network Connection [8086:4230]

or PCIids (not seen yet;)

  • Intel Corporation Wifi Link 5100 BG/ABG/ABGN Wireless Adapter [8086:4232]
    Intel Corporation Wifi Link 5300 ABGN Wireless Adapter [8086:4235]
    Intel Corporation Wifi Link 5300 ABGN Wireless Adapter [8086:4236]
    Intel Corporation Wifi Link 5100 ABG/ABGN Wireless Adapter [8086:4237]

See also