Wi-Fi: Difference between revisions
("Launching udhcpc through wpa_cli actions" rewrite, removing seemingly unnecessary autoscan modifications (these might be better-suited to a more instance-specific recommendation in a troubleshooting section)) |
m (Sorry doing little edits) |
||
(11 intermediate revisions by 4 users not shown) | |||
Line 11: | Line 11: | ||
== iwd == | == iwd == | ||
{{main|iwd}} | |||
Iwd (iNet wireless daemon) is a wireless daemon written by Intel and aiming at replacing {{Pkg|wpa_supplicant|arch=}}. The core goal of the project is to optimize resource utilization by not depending on any external libraries and instead utilizing features provided by the Linux Kernel to the maximum extent possible. | |||
{{Pkg|iwd}} is supported since [https://alpinelinux.org/posts/Alpine-3.10.0-released.html Alpine Linux 3.10]. | {{Pkg|iwd|arch=}} is supported since [https://alpinelinux.org/posts/Alpine-3.10.0-released.html Alpine Linux 3.10]. | ||
See the [[iwd|iwd article]] for more information | |||
== wpa_supplicant == | == wpa_supplicant == | ||
Line 155: | Line 89: | ||
Manually restart (or '''start''') '''networking'''. | Manually restart (or '''start''') '''networking'''. | ||
{{Cmd|# | {{Cmd|# rc-service networking --quiet restart &}} | ||
<br> | <br> | ||
Line 207: | Line 141: | ||
== Troubleshooting == | == Troubleshooting == | ||
=== Broadcom Wi-Fi Chipset Users === | |||
The Broadcom chipset is quite popular among older computers. The b43 driver is included in the linux-lts or linux-edge kernel packages. However, you might need to compile the firmware manually for this chipset as it is not included in linux-firmware for some | The Broadcom chipset is quite popular among older computers. The b43 driver is included in the linux-lts or linux-edge kernel packages. However, you might need to compile the firmware manually for this chipset as it is not included in linux-firmware for some cards. | ||
Check what chip you have using lspci: | |||
{{Cmd|$ lspci -nn -d 14e4:}} | {{Cmd|$ lspci -nn -d 14e4:}} | ||
Check what driver you need on the: | |||
{{Cmd| | [https://wireless.wiki.kernel.org/en/users/Drivers/b43#list_of_hardware b43 compatibility page] | ||
====B43==== | |||
Download firmware cutter. | |||
{{Cmd|$ apk add b43-fwcutter}} | |||
Now we have everything to download the proprietary driver and extract the firmware from it: | Now we have everything to download the proprietary driver and extract the firmware from it: | ||
Line 224: | Line 164: | ||
$ wget http://www.lwfinger.com/b43-firmware/broadcom-wl-5.100.138.tar.bz2 | $ wget http://www.lwfinger.com/b43-firmware/broadcom-wl-5.100.138.tar.bz2 | ||
$ tar xjf broadcom-wl-5.100.138.tar.bz2 | $ tar xjf broadcom-wl-5.100.138.tar.bz2 | ||
$ b43-fwcutter -w "$FIRMWARE_INSTALL_DIR" broadcom-wl-5.100.138/linux/wl_apsta.o</nowiki>}} | |||
More information can be found [http://linuxwireless.sipsolutions.net/en/users/Drivers/b43/#Other_distributions_not_mentioned_above here]. | More information can be found [http://linuxwireless.sipsolutions.net/en/users/Drivers/b43/#Other_distributions_not_mentioned_above here]. | ||
Line 234: | Line 174: | ||
Now continue with the normal instructions. | Now continue with the normal instructions. | ||
====wl==== | |||
First install the software we need to build a driver[https://unix.stackexchange.com/questions/606073/how-to-build-kernel-modules-in-alpine-3-12 ^]: | |||
{{Cmd|apk add git alpine-sdk linux-headers}} | |||
Then install the driver build repo (this is archived, however it's legacy so that doesn't matter): | |||
{{Cmd|git clone https://github.com/antoineco/broadcom-wl | |||
cd broadcom-wl | |||
}} | |||
Then follow the build instructions listed in the git repo: | |||
{{Cmd|make | |||
doas make install | |||
doas depmod -A | |||
doas modprobe wl | |||
}} | |||
reboot and you have a working wl driver! | |||
Now continue with the normal instructions. | |||
=== Rfkill === | |||
Many laptops have a hardware button (or switch) to turn off wireless card, however, the card can also be blocked by kernel. This can be changed using rfkill. To show the current of your Wi-Fi: | Many laptops have a hardware button (or switch) to turn off wireless card, however, the card can also be blocked by kernel. This can be changed using rfkill. To show the current of your Wi-Fi: | ||
Line 263: | Line 221: | ||
* [[Alpine setup scripts]] | * [[Alpine setup scripts]] | ||
* [[Iwd|iwd]] | * [[Iwd|iwd]] | ||
* [https://wiki.postmarketos.org/wiki/WiFi PostmarketOS Wiki] | |||
* [https://wiki.archlinux.org/title/Network_configuration/Wireless Archwiki] | |||
* [https://wiki.gentoo.org/wiki/Wi-Fi Gentoo Wiki] | |||
[[Category:Networking]] | [[Category:Networking]] |
Revision as of 16:33, 5 May 2024
This page describes how to set up a wireless network connection with WPA encryption.
Choose a wireless daemon between iwd and wpa_supplicant
Prerequisites
Working wireless drivers
If you are using a Broadcom chipset, see the Broadcom Wi-Fi section.)
iwd
Iwd (iNet wireless daemon) is a wireless daemon written by Intel and aiming at replacing wpa_supplicant. The core goal of the project is to optimize resource utilization by not depending on any external libraries and instead utilizing features provided by the Linux Kernel to the maximum extent possible.
iwd is supported since Alpine Linux 3.10.
See the iwd article for more information
wpa_supplicant
To get started install wpa_supplicant
# apk add wpa_supplicant
To list your available network interfaces:
ip link
or
ip a
Bring up the desired interface:
# ip link set wlan0 up
ioctl 0x8914 failed: No error information
, that's busybox ip
's way of saying your wireless radio is rfkill'd. See the Rfkill section for information on how to unblock your wireless radio.
Use this command to add your Wi-Fi network to wpa_supplicant:
# wpa_passphrase 'ExampleWifiSSID' 'ExampleWifiPassword' > /etc/wpa_supplicant/wpa_supplicant.conf
(Access point not broadcasting its SSID requires additional line scan_ssid=1
in the file wpa_supplicant.conf
)
Start wpa_supplicant in the foreground to make sure the connection succeeds.
# wpa_supplicant -i wlan0 -c /etc/wpa_supplicant/wpa_supplicant.conf
If all is well, run it as a daemon in the background by setting the -B option.
# wpa_supplicant -B -i wlan0 -c /etc/wpa_supplicant/wpa_supplicant.conf
Configure the interface with an IP address.
# udhcpc -i wlan0
Sanity check: the interface should have a inet address.
$ ip addr show wlan0
Automatic Configuration on System Boot
Add a entry for the desired interface (e.g. wlan0):
Contents of /etc/network/interfaces
Sanity check: Make sure /etc/wpa_supplicant/wpa_supplicant.conf is the correct configuration for the wireless access point you want to connect to.
Bring the interface down.
# ip link set wlan0 down
Manually restart (or start) networking.
# rc-service networking --quiet restart &
If all is well (feel free to confirm with the sanity checks),
Configure wpa_supplicant to start automatically on boot:
# rc-update add wpa_supplicant boot
Also make sure networking is set to automatically start on boot:
# rc-update add networking boot
Optional security precaution:
By default wpa_supplicant will store your Wi-Fi password in plain text:
Contents of (Example) /etc/wpa_supplicant/wpa_supplicant.conf
this is not necessary and wpa_supplicant should funtion just fine without it, if you dont want your stored password in plain text just delete the line with #psk="<YourPasswordShouldBeHereInPlainText>"
on it.
Launching udhcpc through wpa_cli actions
With the above configuration, udhcpc will only run once at boot. If the Wifi isn't available then, or the network changes after booting, udhcpc needs to be notified. You can automatically notify udhcpc of network changes by using a wpa_cli action file, such as the one installed by default at `/etc/wpa_supplicant/wpa_cli.sh`.
To manually start a wpa_cli daemon with an action file, use the `-a` option:
# wpa_cli -a /etc/wpa_supplicant/wpa_cli.sh
To do this automatically, use the `wpa_cli` service included in wpa_supplicant-openrc:
Contents of /etc/conf.d/wpa_cli
# rc-update add wpa_cli boot
Troubleshooting
Broadcom Wi-Fi Chipset Users
The Broadcom chipset is quite popular among older computers. The b43 driver is included in the linux-lts or linux-edge kernel packages. However, you might need to compile the firmware manually for this chipset as it is not included in linux-firmware for some cards.
Check what chip you have using lspci:
$ lspci -nn -d 14e4:
Check what driver you need on the:
B43
Download firmware cutter.
$ apk add b43-fwcutter
Now we have everything to download the proprietary driver and extract the firmware from it:
# export FIRMWARE_INSTALL_DIR="/lib/firmware" $ wget http://www.lwfinger.com/b43-firmware/broadcom-wl-5.100.138.tar.bz2 $ tar xjf broadcom-wl-5.100.138.tar.bz2 $ b43-fwcutter -w "$FIRMWARE_INSTALL_DIR" broadcom-wl-5.100.138/linux/wl_apsta.o
More information can be found here.
Now you need to use modprobe so the device will show up:
# modprobe b43
Now continue with the normal instructions.
wl
First install the software we need to build a driver^:
apk add git alpine-sdk linux-headers
Then install the driver build repo (this is archived, however it's legacy so that doesn't matter):
git clone https://github.com/antoineco/broadcom-wl cd broadcom-wl
Then follow the build instructions listed in the git repo:
make doas make install doas depmod -A doas modprobe wl
reboot and you have a working wl driver!
Now continue with the normal instructions.
Rfkill
Many laptops have a hardware button (or switch) to turn off wireless card, however, the card can also be blocked by kernel. This can be changed using rfkill. To show the current of your Wi-Fi:
~$ rfkill list 0: phy0: wlan Soft blocked: no Hard blocked: no
If the card is hard-blocked, use the hardware button or switch to unblock it. If the card is not hard-blocked but soft-blocked, use the following command:
# rfkill unblock wifi