Wireless Setup (日本語)

From ArchWiki
Jump to: navigation, search

Template:Article summary start Template:Article summary text Template:Article summary heading Template:Article summary text Template:Article summary end

ワイヤレスネットワークの設定は2段階で行います; まずワイヤレスデバイスを使うために正しいドライバがインストールされているか確認し(インストールメディアにある場合はそれらをインストールします)、インターフェースを設定します。次に、ワイヤレス接続を管理する方法を選びます。この記事では両方をカバーしています。また、ワイヤレス管理ツールへの追加リンクもあります。

新しい Arch Linux システムについて: Arch をセットアップするにあたって、ワイヤレスドライバやツールのほとんどが base グループ下で利用できます。あなたのカードに合った正しいドライバをインストールしてください。Udev は通常、インストーラのライブ環境だけでなく、新しくインストールするハードドライブ上の環境でも、適切なモジュールをロードしワイヤレスインターフェースを作成します。Arch Linux インストール後にワイヤレス機能を設定するには、必要なパッケージ(ドライバ、ファームウェア、wireless_toolsiwwpa_supplicant、など)を pacman でインストールして下のガイドラインに従って下さい。あなたのワイヤレスハードウェアの年式によっては wireless_tools は任意になるかもしれません。

Contents

Part I: カードの確認/ドライバのインストール

カードを確認しサポートされているか調べる

まず、Linux カーネルがあなたのカードをサポートしているかどうか、ユーザースペースのドライバが利用できるかどうか確認する必要があります。

カードを確認する

カードの種類を確認するには次のコマンドを実行します:

# lspci | grep -i net

もしくは、USB デバイスの場合:

# lsusb
Note: ラップトップ内蔵の Wi-Fi カードでも USB デバイスの可能性があります、両方のコマンドをチェックしてください。

カードがサポートされているか調べる

  • Ubuntu Wiki にはワイヤレスカードの一覧と、Linux カーネル・ユーザースペースドライバによってサポートされているかの情報があります(ドライバ名含む)。
  • Linux Wireless Support と Linux Questions の Hardware Compatibility List (HCL) にもカーネルで利用できるハードウェアのデータベースがあります。
  • さらに kernel page にはサポートされているハードウェアの表が存在します。

あなたのカードがリストされてなかった場合

ワイヤレスハードウェアが上記のリストになかった場合、おそらくサポートしているのが Windows のみだと思われます (Broadcom, 3com, etc)。そういったカードについては、ndiswrapper を使う必要があります。

Ndiswrapper は Windows ドライバを Linux で使うためのラッパースクリプトです。対応しているハードウェアの一覧を見て下さい。Windows 用のインストールファイルに含まれている .inf.sys ファイルが必要です。Ndiswrapper を使う前に、新しめのカードやマイナーなカードを持っている場合、インターネットで正しいモデル名に 'linux' を付けて検索したほうがいいかもしれません。

ユーザースペースツールをインストールする

有線のインターネット接続が利用できる場合

すでに有線の Ethernet を利用できていてワイヤレス機能をシステムに加えるだけの場合、または最初のインストールに wireless_tools を含めなかった場合、wireless_tools パッケージをインストールしてください。

Note: あなたのハードウェアの年式、ハードウェアやドライバによる wpa_supplicant のサポートの如何によっては wireless_tools は必要ないかもしれません。wpa_supplicant だけを使って設定して十分に動く場合は、wpa_supplicant のみ使うことが推奨されます。

このページではドライバの適切なパッケージ名は 太字等幅フォント を使って強調しています。パッケージは最初の Arch Linux インストールメディア上でインストールすることも、後からインストールすることもできます。

ワイヤレスインターネットしか利用できない場合

現在ベースシステムの一部として wireless_tools パッケージが base-devel グループで live インストールメディア (CD/USB イメージ) からも利用できます。

これらのユーザースペースツールなしではワイヤレスハードウェアを初期化できないので、特にワイヤレス以外にネットワーク接続する方法がない場合、インストールメディアからインストールするようにしてください。さもなければ、新しくインストールした Arch Linux システムを再起動したときに矛盾している状況になって ("catch 22") 困ることになるでしょう: wireless_tools とドライバが必要なのに、それらを手に入れるには、wireless_tools とドライバが必要になるというわけです。

ドライバとファームウェア

デフォルトの Arch Linux カーネルはモジュール式です、つまりマシンに必要なドライバの多くはハードドライブに置かれ、モジュールとして利用されます。起動時に、udev はハードウェアの棚卸を実施します。Udev はハードウェアに必要である適切なモジュール(ドライバ)をロードし、次に、ドライバをロードしてカーネルインターフェースを作成します。

インターフェースの名前はドライバやチップセットによって変わります。例: wlan0, eth1, ath0

Note: Udev は完全ではありません。起動時に udev が正しいモジュールをロードしなかった場合、それを modprobe してモジュール名を /etc/modules-load.d/ 内の .conf ファイルに追加してください。また、場合によっては udev が1つのデバイスに複数のドライバをロードし、それが衝突を生んで設定が完了できなくなることがあります。要らないモジュールをブラックリスト化するようにしてください。

様々なチップセットのカーネルモジュールをインストールする方法が以下でカバーされています。また、チップセットによっては適切なファームウェアをインストールする必要があります(これも以下で述べています)。モジュールの操作についての一般的な情報は Kernel modules (日本語) を見て下さい。

rt2860 と rt2870

From Linux kernel 3.0, the staging driver rt2860sta is replaced by the mainline driver rt2800pci, and rt2870sta is replaced by rt2800usb. As a result, the staging drivers are deleted. Source: Kernel commit. The rt2800 driver automatically works with devices using the rt2870 chipset.

It has a wide range of options that can be configured with iwpriv. These are documented in the source tarballs available from Ralink.

rt3090

For devices which are using the rt3090 chipset it should be possible to use rt2860sta driver. The mainline driver rt2800pci is not working with this chipset very well (e.g. sometimes it's not possible to use higher rate than 2Mb/s).

The best way is to use the rt3090AUR driver from AUR. Compile the rt3090AUR driver from AUR, delete/move the /etc/Wireless/RT2860STA/RT2860STA.dat firmware file to allow installation of the compiled RT3090 package, blacklist the rt2860sta module and setup the rt3090sta module to load at boot.

Note: This driver also works for rt3062 chipsets.

rt2x00

Unified driver for Ralink chipsets (replaces rt2500, rt61, rt73, etc). This driver has been in the Linux kernel since 2.6.24, but some devices may require extra firmware. It can be configured using the standard wpa_supplicant and iwconfig tools.

Some chips require a firmware file, which is installed by default in Arch Linux via the package linux-firmware.

See: Using the new rt2x00 beta driver

rt3573

New chipset as of 2012. It may require proprietary drivers from Ralink. Different manufacturers use it, see Belkin N750 example

rt5572

New chipset as of 2012 with support for 5 Ghz bands. It may require proprietary drivers from Ralink and some effort to compile them. At the time of writing a how-to on compilation is available for a DLINK DWA-160 rev. B2 here.

w322u

Treat this Tenda card as an rt2870sta device. See: rt2870

rtl8180

Realtek rtl8180 PCI/Cardbus 802.11b is now fully supported in the kernel. It can be configured using the standard wpa_supplicant and iwconfig tools.

rtl8187

See: rtl8187

rtl8192e

The driver is part of the current kernel package. It can be configured using the standard wpa_supplicant and iwconfig tools.

Note: wicd may cause excessive dropped connections with this driver, while NetworkManager appears to work better.
モジュールの初期化が失敗する

The module initialization may fail at boot giving this error message :

rtl819xE:ERR in CPUcheck_firmware_ready()
rtl819xE:ERR in init_firmware() step 2
rtl819xE:ERR!!! _rtl8192_up(): initialization is failed!
r8169 0000:03:00.0: eth0: link down

A workaround is to simply unload the module:

# modprobe -r r8192e_pci

and reload the module (after a pause):

# modprobe r8192e_pci

rtl8192s

The driver is part of the current kernel package. Firmware may need to be added manually if /usr/lib/firmware/RTL8192SU/rtl8192sfw.bin does not exist. (dmesg will report "rtl819xU:FirmwareRequest92S(): failed" if the firmware is missing)

To download and install firmware:

$ wget http://launchpadlibrarian.net/33927923/rtl8192se_linux_2.6.0010.1012.2009.tar.gz
# mkdir /lib/firmware/RTL8192SU
# tar -xzOf rtl8192se_linux_2.6.0010.1012.2009.tar.gz \
 rtl8192se_linux_2.6.0010.1012.2009/firmware/RTL8192SE/rtl8192sfw.bin > \
 /lib/firmware/RTL8192SU/rtl8192sfw.bin
Note: An alternate version of the firmware may be found here, but this version may cause dropped connections.
Note: wicd may cause excessive dropped connections with this driver, while NetworkManager appears to work better.

madwifi-ng

MadWifi チームによって、3つのモジュールがメンテナンスされています:

  • ath_pci は古いドライバです
  • ath5k はゆくゆく ath_pci を置き換えるものです。現在、チップセットによってはより良い選択肢ですが、全てのチップセットがサポートされているわけではありません(下を見て下さい)
  • ath9k は新しい Atheros ハードウェア(下を見て下さい)に対応した、新しく、公式の、より優れたドライバです

For old ath_pci driver, install package madwifiAUR and optionally madwifi-utils-svnAUR. Then:

# modprobe ath_pci

If using ath_pci, you may need to blacklist ath5k. See Kernel_modules#Blacklisting for instructions.

Some users may need to use the countrycode option when loading the MadWifi driver in order to use channels and transmit power settings that are legal in their country/region. In the Netherlands, for example, you would load the module like this:

# modprobe ath_pci countrycode=528

You can verify the settings with the iwlist command. See man iwlist and the CountryCode page on the MadWifi wiki. To have this setting automatically applied during boot, refer to Kernel_modules#Configuration, and note the following module option setting:

options ath_pci countrycode=528

ath5k

ath5k is the preferred driver for AR5xxx chipsets including those which are already working with madwifi-ng and for some chipsets older than AR5xxx.

If ath5k is conflicting with ath_pci on your system, blacklist (and unload using rmmod or reboot) the following drivers:

ath_hal
ath_pci
ath_rate_amrr
ath_rate_onoe
ath_rate_sample
wlan
wlan_acl
wlan_ccmp
wlan_scan_ap
wlan_scan_sta
wlan_tkip
wlan_wep
wlan_xauth

then modprobe ath5k manually or reboot. wlan0 (or wlanX) in sta mode should spawn and become ready to use.

Info:

Note: Some laptop have problems with their wireless LED indicator flickering red and blue. To solve this problem, do:
echo none > "/sys/class/leds/ath5k-phy0::tx/trigger"
echo none > "/sys/class/leds/ath5k-phy0::rx/trigger"
For alternatives, look here.
Note: If you find web pages randomly loading very slow in Firefox/Opera/Chromium try to switch from hardware to software encryption:
rmmod ath5k
modprobe ath5k nohwcrypt

And restart your connection. If it helps, make the change permanent by adding into /etc/modprobe.d/010-ath5k.conf:

options ath5k nohwcrypt
More about modprobe options: Modprobe#Options

ath9k

ath9k is Atheros' officially supported driver for the newer 802.11n chipsets. All of the chips with 802.11n capabilities are supported, with a maximum throughput around 180 Mbps. To see a complete list of supported hardware, check this page.

Working modes: Station, AP and Adhoc.

ath9k has been part of the Linux kernel as of v2.6.27. (In the unlikely event that you have stability issues that trouble you, you could try using the compat-wireless package. An ath9k mailing list exists for support and development related discussions.)

Info:

ath9k_htc

ath9k_htc is Atheros' officially supported driver for 802.11n USB devices. Station and Ad-Hoc modes are supported. The driver is included in the kernel. For more information, see http://wireless.kernel.org/en/users/Drivers/ath9k_htc .

ipw2100 と ipw2200

These modules are fully supported in the kernel, but they require additional firmware. It can be configured using the standard wpa_supplicant and iwconfig tools.

Depending on which of the chipsets you have, install either ipw2100-fw or ipw2200-fw.

If installing after initial Arch Linux installation, the module may need to be reloaded for the firmware to be loaded; run the following as root:

rmmod ipw2200
modprobe ipw2200
radiotap インターフェースを有効にする

Launch the following as root:

rmmod ipw2200
modprobe ipw2200 rtap_iface=1
LED を有効にする

Most laptops will have a front LED to indicate when the wireless is connected (or not). Add the following to /etc/modprobe.d/ipw2200.conf:

options ipw2200 led=1

iwl3945, iwl4965, iwl5000-シリーズ

Intel's open source Wi-Fi drivers for Linux (See iwlwifi) will work for both the 3945 and 4965 chipsets since kernel 2.6.24. And iwl5000-series chipsets (including 5100BG, 5100ABG, 5100AGN, 5300AGN and 5350AGN) have been supported since kernel 2.6.27, by the in-tree driver iwlagn.

Since the 2.6.34 kernel update, the firmware files were moved to the linux-firmware package. Manually installing firmware packages is not required.

ドライバをロードする

udev should load the driver automatically. To manually load the driver at start-up, read Kernel modules#Loading, and add iwl3945 or iwl4965 respectively to the new file. For example:

# Load Intel Wi-Fi modules
iwl3945

The drivers should now load after a reboot, and running ip addr from a terminal should report wlan0 as a new network interface.

LED の点滅を無効化する

The default settings on the module are to have the LED blink on activity. Some people find this extremely annoying. To have the LED on solid when Wi-Fi is active:

# echo 'w /sys/class/leds/phy0-led/trigger - - - - phy0radio' > /etc/tmpfiles.d/phy0-led.conf
# systemd-tmpfiles --create phy0-led.conf

To see all the possible trigger values for this LED:

# cat /sys/class/leds/phy0-led/trigger

Here is an example for the old way, if you do not have /sys/class/leds/phy0-led:

# echo "options iwlcore led_mode=1" >> /etc/modprobe.d/modprobe.conf
# rmmod iwlagn
# rmmod iwlcore
# modprobe iwlcore
# modprobe iwlagn

On Linux kernels 2.6.39.1-1 and up, the iwlcore module was deprecated. Use options iwlagn led_mode=1 or options iwl_legacy led_mode=1 instead (find out what module is loaded with lsmod).

Note: iwl_legacy was renamed iwlegacy in Linux kernel 3.3.1. For this version, use options iwlegacy led_mode=1.
Other Notes
  • The MS Windows NETw4x32 driver can be used with ndiswrapper as an alternative to the iwl3945 and ipw3945 drivers.
  • In some cases (specifically a Dell Latitude D620 with Arch 2008.06, though it could happen elsewhere), after installation you may have both iwl3945 and ipw3945 modules loaded. The card will not work with both modules loaded, so you will have to blacklist the ipw3945 module.
  • By default, iwl3945 is configured to only work with networks on channels 1-11. Higher frequency bands are not allowed in some parts of the world (e.g. the US). In the EU however, channels 12 and 13 are used quite commonly (and Japan allows for channel 14). To make iwl3945 scan for all channels, add options cfg80211 ieee80211_regdom=EU to /etc/modprobe.d/modprobe.conf. With iwlist f you can check which channels are allowed.
  • If you want to enable more channels on Intel Wifi 5100 (and quite possible other cards too), you can do that with the crda package. After installing the package, edit /etc/conf.d/wireless-regdom and uncomment the line where your country code is found. When executing sudo iwlist wlan0 channel, you should now have access to more channels (depending on your location).

orinoco

This should be a part of the kernel package and be installed already.

Note: Some Orinoco chipsets are Hermes I/II. You can use the AUR package wl_lkmAUR to replace the orinoco driver and gain WPA support. See this post for more information.

To use the driver, blacklist orinoco_cs, and then add wlags49_h1_cs.

ndiswrapper

Ndiswrapper は実際のドライバではありませんが、あなたのワイヤレスチップセットをサポートしているネイティブ Linux カーネルドライバが存在しない場合に使うことができ、場合によってはとても役に立ちます。これを使うには、Windows のドライバーに含まれる *.inf ファイルが必要です (*.sys ファイルも同じディレクトリにあるはずです)。ドライバがあなたのアーキテクチャ (例: 32/64 ビット) に適合しているかも確認してください。*.exe ファイルからこれらのファイルを展開する必要がある場合は、cabextract を使って下さい。

ndiswrapper を設定するには以下の手順に従って下さい。

1. ドライバを /etc/ndiswrapper/* にインストールします

ndiswrapper -i ファイル名.inf

2. ndiswrapper にインストールされたドライバを全て一覧します

ndiswrapper -l

3. /etc/modprobe.d/ndiswrapper.conf 内に設定ファイルを書き出します

ndiswrapper -m
depmod -a

これで ndiswrapper のインストールはほぼ完了です; あとは Kernel modules (日本語)#ロード の指示に従って起動時に自動でモジュールをロードするようにしてください。

重要なことは ndiswrapper が他のモジュールと一緒にロードされることです。ndiswrapper がロードされているかテストするには、次を実行してください:

modprobe ndiswrapper
iwconfig

wlan0 が表示されるはずです。問題が起こった場合は次のページを見て下さい: Ndiswrapper installation wiki.

prism54

Download the firmware driver for your appropriate card from this site. Rename the firmware file to isl3890. If non-existent, create the directory /usr/lib/firmware and move the file isl3890 inside it. This should do the trick. [1]

If that did not work, try this:

  • Reload the prism module (modprobe p54usb or modprobe p54pci, depending on your hardware)

Alternatively, remove your Wi-Fi card and then reconnect it.

  • Use the dmesg command, and look at the end of the output it prints out.

Look for a section similar to this:

firmware: requesting isl3887usb_bare
p54: LM86 firmware
p54: FW rev 2.5.8.0 - Softmac protocol 3.0

and try renaming the firmware file to the name corresponding to the part bolded here.

If you get the message

SIOCSIFFLAGS: Operation not permitted

when performing ip link set wlan0 up OR

prism54: Your card/socket may be faulty, or IRQ line too busy :(

appears in dmesg's output this may be because you have both the deprecated kernel module prism54 and one of the newer kernel modules (p54pci or p54usb) loaded at the same time and they are fighting over ownership of the IRQ. Use the command lsmod | grep prism54 to see if the deprecated module is being loaded. If so, you need to stop prism54 from loading by blacklisting it (there are several ways to do this which are described elsewhere). Once blacklisted, you may find you have to rename the firmware as prism54 and p54pci/p54usb look for different firmware filenames (i.e. recheck the dmesg output after performing ip link set eth0 up).

ACX100/111

Packages: tiacx tiacx-firmware

The driver should tell you which firmware it needs; check /var/log/messages.log or use the dmesg command.

Link the appropriate firmware to /usr/lib/firmware:

ln -s /usr/share/tiacx/acx111_2.3.1.31/tiacx111c16 /usr/lib/firmware

For another way to determine which firmware revision number to use, see the "Which firmware" section of the acx100.sourceforge wiki. For ACX100, you can follow the links provided there to a table of card model numbers vs. "firmware files known to work"; you can figure out the rev. number you need, by looking at the suffix there. For example, a dlink_dwl650+ uses "1.9.8.b", in which case you would do this:

ln -s /usr/share/tiacx/acx100_1.9.8.b/* /usr/lib/firmware

If you find that the driver is spamming your kernel log, for example because you are running Kismet with channel-hopping, you could put this in /etc/modprobe.d/modprobe.conf:

options acx debug=0
Note: The open-source acx driver does not support WPA/RSN encryption. Ndiswrapper will have to be used with the Windows driver to enable the enhanced encryption. See ndiswrapper, this page, for more details.

b43, broadcom-wl, brcmsmac (以前の brcm80211)

Broadcom wireless ページを見て下さい。

zd1211rw

zd1211rw is a driver for the ZyDAS ZD1211 802.11b/g USB WLAN chipset, and it is included in recent versions of the Linux kernel. See [2] for a list of supported devices. You only need to install the firmware for the device, provided by the zd1211-firmware package.

carl9170

carl9170 is the 802.11n USB driver with GPLv2 firmware for Atheros USB AR9170 devices. It supports these devices. The firmware is not yet part of the linux-firmware package; it is available in the AUR (carl9170-fwAUR). The driver is a part of the Linux kernel v2.6.37 and higher.

In order to use this driver, the following older driver modules must be blacklisted:

  • arusb_lnx
  • ar9170usb

hostap_cs

Host AP is the Linux driver for Prism2/2.5/3 like WCP11. hostap_cs should be a part of the linux package and should be installed already.

orinico_cs can cause problems, so it must be blacklisted. After blacklisting, the driver should work.

More information:Home page

compat-wireless-patched

Patched compat wireless drivers correct the "fixed-channel -1" issue, whilst providing better injection. Please install the compat-wireless-patchedAUR package from the AUR.

compat-wireless-patchedAUR does not conflict with any other package and the modules built reside in /usr/lib/modules/your_kernel_version/updates.

These patched drivers come from the Linux Wireless project and support many of the above mentioned chips such as:

ath5k ath9k_htc carl9170 b43 zd1211rw rt2x00 wl1251 wl12xx ath6kl brcm80211

Supported groups:

atheros ath iwlagn rtl818x rtlwifi wl12xx atlxx bt

It is also possible to build a specific module/driver or a group of drivers by editing the PKGBUILD, particularly uncommenting the line #46. Here is an example of building the atheros group:

scripts/driver-select atheros

Please read the package's PKGBUILD for any other possible modifications prior to compilation and installation.

テストインストール

ドライバをロードした後、ip link を実行することでワイヤレスインターフェース (例: wlanX, ethX, athX) が作成されたか確認することができます。

インターフェースが表示されない場合、modprobe することで働くかもしれません。ドライバを起動するには、rmmodmodprobe コマンドを使って下さい。rmmod が失敗したときでも、続けて modprobe をしてください。詳しくは Kernel modules (日本語) を見て下さい。

サンプル: ドライバの名前が "driverXXX" の場合、次のコマンドを実行します:

# rmmod driverXXX
# modprobe driverXXX

インターフェースを ip link set <interface> up で起動します。例えば、インターフェースが wlan0 だと仮定して:

# ip link set wlan0 up

次のエラーメッセージが表示される場合: SIOCSIFFLAGS: No such file or directory、あなたのワイヤレスチップセットを機能させるにはファームウェアが必要なことを表しています、上記で説明されているようにインストールしてください。

Part II: ワイヤレス管理

ドライバがインストールされ正しく動作しているとして、次にワイヤレス接続を管理するための方法を選ぶ必要があります。次のサブセクションが方法を決めるのに役立つでしょう。

複数の理由によってプロシージャとツールが必要になるでしょう:

  • 望む設定管理の種類; 完全な手動なコマンドラインによる設定から、ソフトウェアによる自動設定まで。
  • ワイヤレスネットワークを保護する暗号化方式。
  • コンピュータが使うネットワークを頻繁に変える場合(ラップトップなど)の、ネットワークプロファイルの必要性。

マニュアル設定はあなたに多くの仕事を課しますが、設定のよりよいコントロールが得られます。 一般に、永続的な効果のないコマンドセットを入力する必要があるでしょう、つまり、再起動後に適用はされないでしょう。 起動毎にコマンドを入力するのがやっかいな場合は、コマンドをシェルスクリプトに入れて手順を自動化することができます。スクリプトは起動時に自動で実行されるでしょう。Arch Boot Process を見て下さい。

管理方法

The following table shows the different methods that can be used to activate and manage a wireless network connection, depending on the encryption and management types, and the various tools that are required. Although there may be other possibilities, these are the most frequently used:

管理方法 暗号化なし/WEP WPA/WPA2 PSK
手動 iproute2 + iwconfig + dhcpcd/iproute2 iproute2 + iwconfig + wpa_supplicant + dhcpcd/iproute2
自動管理、ネットワークプロファイルサポート netcfg, Wicd, NetworkManager, など.

More choice guide:

- netcfg Wicd NetworkManager + network-manager-applet
起動時の自動接続 net-profiles サービスを使う yes yes
auto connect if dropped
or changed location
net-auto-wireless サービスを使う yes yes
3G モデムのサポート yes
GUI (システムトレイアイコンからの
接続・切断するプロファイルの管理
自動ワイヤレス検知も可能)
ArchAssistant yes yes
コンソールツール wifi-select wicd-curses (wicd パッケージ) nmcli

Linux のワイヤレスエクステンションや iwconfig などのコマンドはすでに推奨されておらず、core-リポジトリとは別にインストールする必要がある、iw に取って代わられていることに注意してください。このことはまだ wiki 内で完全には反映されていません。一般的なコマンドの比較は Linuxwireless にあります。

どの方法を選んだにせよ、まずは手動で接続を試行するべきです。 This will help you understand the different steps that are required and debug them in case a problem arose. Another tip: if possible (e.g. if you manage your Wi-Fi access point), try connecting with no encryption, to check everything works. Then try using encryption, either WEP (simpler to configure -- but crackable in a matter of seconds, so it is hardly more secure than an unencrypted connection), WPA, or WPA2.

When it comes to ease of use, NetworkManager (with GNOME's network-manager-applet) and wicd have good GUI's and can provide a list of available networks to connect, and they prompt for passwords, which is straightforward and highly recommended. WPA Supplicant has also a GUI configuration tool, wpa_supplicant_gui.

Note: GNOME's network-manager-applet also works under Xfce if you install xfce4-xfapplet-pluginAUR first. xfce4-xfapplet-pluginAUR is in the AUR, but it is orphaned and may not work. Additionally, there are applets available for KDE.

手動セットアップ

The programs provided by the package wireless_tools are the basic set of tools to set up a wireless network. Additionally the iw package provides the new tool. Moreover, if you use WPA/WPA2 encryption, you will need the package wpa_supplicant. These powerful user-space console tools work extremely well and allow complete, manual control from the shell.

These examples assume your wireless device is wlan0. Replace wlan0 with the appropriate device name.

Note: Depending on your hardware and encryption type, some of these steps may not be necessary. Some cards are known to require interface activation and/or access point scanning before being associated to an access point and being given an IP address. Some experimentation may be required. For instance, WPA/WPA2 users may directly try to activate their wireless network from step 3.

Operating mode

(Optional, may be required) At this step you may need to set the proper operating mode of the wireless card. More specifically, if you are going to connect an ad-hoc network, you might need to set the operating mode to ad-hoc:

# iw wlan0 set type ibss
Note: Ideally, you should already know which type of network you are going to connect to. If you do not, scan the network as described in step 2 below, then, if necessary, return back to this step and change the mode. Also, please keep in mind that changing the operating mode might require the wireless interface to be down (ip link set wlan0 down).

インターフェースの有効化

(Also optional, may be required) カードによっては wireless_tools を使う前にカーネルインターフェースを初期化する必要があります:

# ip link set wlan0 up

アクセスポイント検索

利用できるアクセスポイントを見るには:

# iw dev wlan0 scan | less
Note: "Interface doesn't support scanning" と表示される場合、おそらくファームウェアのインストールを忘れています。ポイント 1 で示されているようにインターフェースの有効かも試してみてください。場合によっては、iwlist が root 権限で実行されていない時にこのメッセージが表示されることもあります。 また、あなたのワイヤレスネットワークカードがブロックされているのかもしれません。rfkill をインストールしてチェックするために rfkill list all を実行してみてください。

The important points to check:

  • ESSID: そのアクセスポイントの"名前"。
  • Quality: 一般的に 40/70 以上が望ましい値です。
  • Encryption key: これが "on" の場合、check if you can see any line regarding
    • WEP, WPA, RSN。RSN と WPA2 は同じプロトコルの別名です。
    • Group cipher: value in TKIP, CCMP, both, others.
    • Pairwise ciphers: value in TKIP, CCMP, both, others. Not necessarily the same value than Group cipher.
    • Authentication Suites: value in PSK, 802.1x, others. For home router, you'll usually find PSK (i.e. passphrase). In universities, you are more likely to find 802.1x suite which requires login and password. Then you will need to know which key management is in use (e.g. EAP), and what encapsulation it uses (e.g. PEAP). Find more details at Wikipedia:List_of_authentication_protocols and the sub-articles.

Association

Depending on the encryption, you need to associate your wireless device with the access point to use and pass the encryption key.

Assuming you want to use the ESSID MyEssid:

Note: The essid is usually just the name of the network you want to connect to.
  • 暗号化なし
# iwconfig wlan0 essid "MyEssid"

Or, alternatively, for the new netlink interface

# iw wlan0 connect MyEssid
  • WEP

十六進数キーを使う:

# iwconfig wlan0 essid "MyEssid" key 1234567890

ASCII キーを使う:

# iwconfig wlan0 essid "MyEssid" key s:asciikey
  • WPA/WPA2

You need to edit the /etc/wpa_supplicant.conf file as described in WPA_Supplicant and according to what you got from #Access point discovery. Then, issue this command:

# wpa_supplicant -i wlan0 -c /etc/wpa_supplicant.conf

This is assuming your device uses the wext driver. If this does not work, you may need to adjust these options. If connected successfully, continue in a new terminal (or quit wpa_supplicant with Template:Keypress and add the -B switch to the above command to run it in the background). WPA_Supplicant contains more information and troubleshooting.

Regardless of the method used, you can check if you have associated successfully as follows:

# iwconfig wlan0

Or, alternatively, for the new netlink interface

# iw dev wlan0 link
Note: In some setups it may still display "Access Point: Not-Associated", continue on to the next step.

IP アドレスを取得

最後に、ネットワークインターフェースに IP アドレスを与えます。例として DHCP の場合:

# dhcpcd wlan0

もしくは固定 IP アドレスの場合:

# ip addr add 192.168.0.2/24 dev wlan0
# ip route add default via 192.168.0.1
Note: If you get a timeout error due to a waiting for carrier problem, then you might have to set the channel mode to auto for the specific device.
# iwconfig wlan0 channel auto 

Before changing the channel to auto, make sure your wireless interface (in this case, 'wlan0') is down. After it has successfully changed it, you can again bring the interface up and continue from there.

Note: Although the manual configuration method will help troubleshoot wireless problems, you will have to re-type every command each time you reboot. You can also quickly write a shell script to automate the whole process, which is still a quite convenient way of managing networks while keeping full control over your configuration.

systemd と dhcpcd を使って起動時に手動でワイヤレス接続

起動時に systemd を使って手動で設定したワイヤレスネットワークに接続するには:

インターフェース、もしくは固定 IP 設定を含んだ /etc/conf.d/network を作成します:

/etc/conf.d/network
interface=wlan0
address=192.168.0.10
netmask=24
broadcast=192.168.0.255
gateway=192.168.0.1

systemctl ユニットを作成します。例: /etc/systemd/system/network.service。この例では dhcpcd と WPA supplicant を使っています。

/etc/systemd/system/network.service
[Unit]
Description=Network Connectivity
Wants=network.target
Before=network.target
BindsTo=sys-subsystem-net-devices-${interface}.device
After=sys-subsystem-net-devices-${interface}.device
       
[Service]
Type=oneshot
RemainAfterExit=yes
EnvironmentFile=/etc/conf.d/network
ExecStart=/sbin/ip link set dev ${interface} up
ExecStart=/usr/sbin/wpa_supplicant -B -i ${interface} -c /etc/wpa_supplicant.conf
ExecStart=/sbin/dhcpcd ${interface}
         
[Install]
WantedBy=multi-user.target

Or without /etc/conf.d/network:

/etc/systemd/system/network.service
[Unit]
Description=Network Connectivity
Wants=network.target
Before=network.target
BindsTo=sys-subsystem-net-devices-wlan0.device
After=sys-subsystem-net-devices-wlan0.device
       
[Service]
Type=oneshot
RemainAfterExit=yes
ExecStart=/sbin/ip link set dev wlan0 up
ExecStart=/usr/sbin/wpa_supplicant -B -i wlan0 -c /etc/wpa_supplicant.conf
ExecStart=/sbin/dhcpcd wlan0
        
[Install]
WantedBy=multi-user.target

有効化するのを忘れないで下さい!

# systemctl enable network

テストするには、再起動するか他の全てのネットワークデーモンを止めて、管理者権限で次を実行します

# systemctl start network

Systemd with wpa_supplicant and static IP

/etc/conf.d/network を作成します

/etc/conf.d/network
interface=wlan0
address=192.168.0.10
netmask=24
broadcast=192.168.0.255
gateway=192.168.0.1

/etc/wpa_supplicant.conf を作成します。WPA supplicant を見て下さい。

インターフェースの名前が入った systemd ユニットファイルを作成します: /etc/systemd/system/network@wlan0.service

/etc/systemd/system/network@wlan0.service
[Unit]
Description=Network Connectivity (%i)
Wants=network.target
Before=network.target
BindsTo=sys-subsystem-net-devices-%i.device
After=sys-subsystem-net-devices-%i.device

[Service]
Type=oneshot
RemainAfterExit=yes
EnvironmentFile=/etc/conf.d/network
ExecStart=/usr/sbin/ip link set dev ${interface} up
ExecStart=/usr/sbin/wpa_supplicant -B -i ${interface} -c /etc/wpa_supplicant.conf
ExecStart=/usr/sbin/ip addr add ${address}/${netmask} broadcast ${broadcast} dev ${interface}
ExecStart=/usr/sbin/ip route add default via ${gateway}
ExecStop=/usr/sbin/ip addr flush dev ${interface}
ExecStop=/usr/sbin/ip link set dev ${interface} down

[Install]
WantedBy=multi-user.target

ユニットを有効にして実行します。

# systemctl enable network@wlan0.service
# systemctl start network@wlan0.service

自動セットアップ

様々な方法を選ぶことができますが、相互に相容れないことを忘れないで下さい; 2つのデーモンを同時に実行してはいけません。

Netcfg

netcfg は Arch Linux での多目的の、強固で高速なネットワーク接続ソリューションを提供します。

netcfg はプロファイルを使って設定して、幅広い種類のネットワークを検知・接続することができます。グラフィカルツールを使うのと難易度は変わりません。

参照: Netcfg (日本語)

Wicd

Wicd is a network manager that can handle both wireless and wired connections. It is written in Python and Gtk with fewer dependencies than NetworkManager, making it an ideal solution for lightweight desktop users. Wicd is available in the official repositories.

参照: Wicd

NetworkManager

NetworkManager は高度なネットワーク管理ツールであり、ほとんどの人気のある GNU/Linux ディストーションでデフォルトで有効にされています。有線接続に加えて、NetworkManager は、使いやすい GUI プログラムで利用したいネットワークを選択する、心配のないワイヤレスローミングを提供します。

GNOME ではなく Openboxxmonad などのウィンドウマネージャを使っている場合、WEP、WPA、WPA2 接続を管理するために polkit-gnomegnome-keyringlibgnome-keyringpyxdgインストールすることを忘れないで下さい。

参照: NetworkManager

WiFi Radar

WiFi Radar is a Python/PyGTK2 utility for managing wireless profiles (and only wireless). It enables you to scan for available networks and create profiles for your preferred networks.

参照: Wifi Radar

wlassistant

wlassistant is a very intuitive and straight-forward GUI application for managing your wireless connections.

Install the wlassistantAUR package from the AUR.

wlassistant must be run with root privileges:

# wlassistant

Tango-view-refresh-red.pngThis article or section is out of date.Tango-view-refresh-red.png

Reason: References /etc/rc.conf which is deprecated and does not give clear instructions for configuration outside of /etc/rc.conf. (Discuss in Talk:Wireless Setup (日本語)#)

One method of using wlassistant is to configure your wireless card within /etc/rc.conf, specifying the access point you use most often. On start-up, your card will automatically be configured for this ESSID, but if other wireless networks are needed/available, wlassistant can then be invoked to access them. Background the network daemon in /etc/rc.conf, by prefixing it with a @ to avoid boot-up delays.

パワーセーブ

Power_saving#Wireless_power_saving を見て下さい。

参照

外部リンク