Iwd: Difference between revisions
(Manually merging content from Wi-Fi article.) |
Prabuanand (talk | contribs) m (typo change) |
||
(20 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{DISPLAYTITLE:iwd}} | {{DISPLAYTITLE:iwd}} | ||
iNet Wireless Daemon (iwd) project aims to provide a comprehensive Wi-Fi connectivity solution for Linux based devices. iwd provides a self-contained environment that only depends on the Linux Kernel and the runtime C library. | |||
{{Note|Alpine Linux supports both wireless daemons i.e [[Wi-Fi#wpa_supplicant|wpa_supplicant]] and [[iwd]]. Using both simultaneously leads to conflicts.}} | |||
== Prerequisites == | |||
* | * Ensure that you have [[Wi-Fi#Prerequisites|working wireless drivers]]. | ||
* | * iwd requires [[D-Bus]] service to be running. | ||
{{Pkg|iwd|arch=}} | == Installation == | ||
Install {{Pkg|iwd|arch=}} package and {{Pkg|iwgtk|arch=}} package for the ''optional'' GUI utility [[#iwgtk|iwgtk]] using the command:{{Cmd|# apk add iwd iwgtk}} | |||
=== iwgtk === | |||
[[File:Iwgtk screenshot.png|thumb|right|100px|alt=iwgtk showing list of networks|iwgtk]] | |||
== | [https://github.com/J-Lentz/iwgtk iwgtk] is a wireless networking GUI utility for iwd with supported functionality similar to that of <code>iwctl</code>. Features include viewing and connecting to available networks, managing known networks, provisioning new networks via WPS or Wi-Fi Easy Connect, and an | ||
indicator (tray) icon displaying connection status and signal strength. | |||
== Network management mode == | |||
Next, choose one among the three modes listed below on how Network management will done with iwd before proceeding further. | |||
=== Standalone mode === | |||
{{Cmd|# apk add {{Pkg|iwd}}}} | To have iwd do all network management on its own upon connecting to a wi-fi network, requires {{pkg|openresolv|arch=}} package, so install it first:{{Cmd|# apk add {{Pkg|openresolv}}}} | ||
Then edit the configuration file {{path|/etc/iwd/main.conf}} and set it as follows: {{cat|/etc/iwd/main.conf|[General] | |||
EnableNetworkConfiguration{{=}}True | |||
[Network] | |||
{{ | NameResolvingService{{=}}resolvconf}} | ||
To | To test {{Pkg|openresolv}} package, issue the command:{{ic|# resolvconf -u}} to update the nameserver information in {{Path|/etc/resolv.conf}} file. | ||
{{ | |||
=== iwd as a networkmanager backend === | |||
{{Main|NetworkManager#iwd_backend}} | |||
[[NetworkManager]] can be used for network management, with [[NetworkManager#iwd_backend|iwd configured as a wireless backend]]. | |||
== | === iwd with ifupdown-ng === | ||
[[ifupdown-ng]] can be used to do network management for iwd. Refer [[#ifupdown-ng configuration|ifupdown-ng configuration]] section. | |||
== Configuration == | |||
{{ | To proceed with the configuration of iwd, ensure that {{ic|wpa_supplicant}} service is stopped before starting iwd service:{{cmd|<nowiki># rc-service wpa_supplicant stop | ||
# rc-service iwd start</nowiki>}} | |||
{{Tip|The configuration steps using {{ic|iwctl}} can be done in GUI using [[#iwgtk|'''iwgtk''']] utility. Other steps have to be done from CLI only.}} | |||
To configure iwd in an interactive mode using the CLI based client program {{ic|iwctl}}, start the client:{{Cmd|$ iwctl}} | |||
To list all available commands: | |||
<span style="color:green;">[iwd]</span># help | <span style="color:green;">[iwd]</span># help | ||
=== | === To connect to a network === | ||
To list all Wi-Fi devices: | |||
<span style="color:green;">[iwd]</span># device list | |||
If your wireless adapter is not listed, refer to [[Wi-Fi#Troubleshooting|Wifi troubleshooting]] page. | |||
If the device or its corresponding adapter is turned off, turn it on: | If the device or its corresponding adapter is turned off, turn it on: | ||
<span style="color:green;">[iwd]</span># device ''device'' set-property Powered on | <span style="color:green;">[iwd]</span># device ''device'' set-property Powered on | ||
Line 55: | Line 66: | ||
Then, to initiate a scan for networks (note that this command will not output anything): | Then, to initiate a scan for networks (note that this command will not output anything): | ||
<span style="color:green;">[iwd]</span># station ''device'' scan | <span style="color:green;">[iwd]</span># station ''device'' scan | ||
You can then list all available networks: | You can then list all available networks: | ||
<span style="color:green;">[iwd]</span># station ''device'' get-networks | <span style="color:green;">[iwd]</span># station ''device'' get-networks | ||
Finally, to connect to a network: | Finally, to connect to a network: | ||
<span style="color:green;">[iwd]</span># station ''device'' connect ''SSID'' | <span style="color:green;">[iwd]</span># station ''device'' connect ''SSID'' | ||
If a passphrase is required, you will be prompted to enter it. Alternatively, you can supply it as a command line argument: | If a passphrase is required, you will be prompted to enter it. Alternatively, you can supply it as a command line argument: {{Cmd|$ iwctl –passphrase ''passphrase'' station ''device'' connect ''SSID''}} | ||
{{Cmd|$ iwctl –passphrase ''passphrase'' station ''device'' connect ''SSID''}} | |||
{{Note| | {{Note| | ||
Line 75: | Line 81: | ||
* To connect to a network with spaces in the SSID, the network name should be double quoted when connecting. | * To connect to a network with spaces in the SSID, the network name should be double quoted when connecting. | ||
* iwd only supports PSK pass-phrases from 8 to 63 ASCII-encoded characters. }} | * iwd only supports PSK pass-phrases from 8 to 63 ASCII-encoded characters. }} | ||
=== Disconnect from a network === | === Disconnect from a network === | ||
Line 117: | Line 116: | ||
* time since the last connect.}} | * time since the last connect.}} | ||
== | === ifupdown-ng configuration === | ||
[[ | If [[ifupdown-ng]] is used for network configuration management with iwd, edit the {{path|/etc/network/interfaces}} file based on instructions in [[Configure_Networking#Interface configuration|Network configuration]] page. | ||
Whenever system wakes up from sleep/suspend, the wireless interface name may change from {{ic|wlan0}} to {{ic|wlan1}}, {{ic|wlan2}} and so on resulting in loss of connectivity when using [[ifupdown-ng]]. To avoid this issue, create and add the following two files. The {{path|/etc/iwd/main.conf}} file should have:{{cat|/etc/iwd/main.conf|<nowiki>[DriverQuirks] | |||
DefaultInterface=wlan0</nowiki>}} | |||
If mac address of {{ic|wlan0}} interface is "50:91:e3:71:83:d2", then file {{Path|/etc/udev/rules.d/70-persistent-net-wlan0.rules}} should be as follows:{{cat|/etc/udev/rules.d/70-persistent-net-wlan0.rules|<nowiki>SUBSYSTEM=="net", ACTION=="add", ATTRS{address}=="50:91:e3:71:83:d2", NAME="wlan0"</nowiki>}} | |||
The command{{ic|cat /sys/class/net/wlan0/address}} shows the mac address of your wireless interface {{ic|wlan0}}. | |||
For the above changes to take immediate effect, reload Udev rules:{{Cmd|<nowiki># udevadm control --reload-rules | |||
# udevadm trigger</nowiki>}} | |||
A reboot is usually necessary for the changes to fully take effect. | |||
=== Service configuration === | |||
{{Seealso|OpenRC}} | |||
Manage iwd service using the standard start, stop and restart options. For eg: To start the iwd service immediately issue the command: {{cmd|# rc-service iwd start}} | |||
Once iwd service has been fully configured and [[Configure_Networking#Connectivity_testing|tested]], add the {{ic|iwd}} service and disable the {{ic|networking}} boot service:{{cmd|<nowiki># rc-update add iwd boot | |||
# rc-update del networking boot</nowiki>}} | |||
== Troubleshooting == | |||
Resolve [[Wi-Fi#Troubleshooting|wireless driver issues]] first, if your wireless device is not detected, when the below command is issued:{{cmd|<nowiki>$ iwctl device list | |||
Devices | |||
-------------------------------------------------------------------------------- | |||
Name Address Powered Adapter Mode | |||
-------------------------------------------------------------------------------- | |||
wlan0 50:91:e3:71:83:d2 on phy0 station | |||
</nowiki>}} | |||
=== "The name net.connman.iwd was not provided by any .service files" === | |||
If {{ic|iwctl}} commands fail with the message {{ic|The name net.connman.iwd was not provided by any .service files Failed to retrieve IWD dbus objects, quitting...}}. | |||
The above error means that the {{ic|iwd}} daemon is not started. Start the [[#Service configuration|iwd daemon]] | |||
=== "ip: ioctl 0x8913 failed: No such device" === | |||
The above error message may occur whenever the networking service gets loaded by openrc after iwd. Refer to [[#Service configuration|Service configuration]] section. | |||
== See also == | == See also == | ||
* [[Wi-Fi]] | * [[Configure Networking|Main Networking page]] | ||
* [[Wi-Fi|wpa_supplicant]] | |||
* [[NetworkManager]] | |||
* [https://archive.kernel.org/oldwiki/iwd.wiki.kernel.org/start.html iwd Wiki] | |||
* [https://wiki.gentoo.org/wiki/Iwd iwd on Gentoo Wiki] | * [https://wiki.gentoo.org/wiki/Iwd iwd on Gentoo Wiki] | ||
* [https://wiki.archlinux.org/title/Iwd iwd on ArchWiki] | * [https://wiki.archlinux.org/title/Iwd iwd on ArchWiki] | ||
* [https:// | * [https://web.git.kernel.org/pub/scm/network/wireless/iwd.git/tree/src/iwd.config.rst iwd.config file] | ||
* [https://github.com/J-Lentz/iwgtk iwgtk: | * [https://github.com/J-Lentz/iwgtk iwgtk: Front-end for iwd] | ||
[[Category:Networking]] | [[Category:Networking]] |
Latest revision as of 07:46, 31 March 2025
iNet Wireless Daemon (iwd) project aims to provide a comprehensive Wi-Fi connectivity solution for Linux based devices. iwd provides a self-contained environment that only depends on the Linux Kernel and the runtime C library.
Prerequisites
- Ensure that you have working wireless drivers.
- iwd requires D-Bus service to be running.
Installation
Install iwd package and iwgtk package for the optional GUI utility iwgtk using the command:
# apk add iwd iwgtk
iwgtk

iwgtk is a wireless networking GUI utility for iwd with supported functionality similar to that of iwctl
. Features include viewing and connecting to available networks, managing known networks, provisioning new networks via WPS or Wi-Fi Easy Connect, and an
indicator (tray) icon displaying connection status and signal strength.
Network management mode
Next, choose one among the three modes listed below on how Network management will done with iwd before proceeding further.
Standalone mode
To have iwd do all network management on its own upon connecting to a wi-fi network, requires openresolv package, so install it first:
# apk add openresolv
Then edit the configuration file /etc/iwd/main.conf and set it as follows:
Contents of /etc/iwd/main.conf
To test openresolv package, issue the command:# resolvconf -u
to update the nameserver information in /etc/resolv.conf file.
iwd as a networkmanager backend
NetworkManager can be used for network management, with iwd configured as a wireless backend.
iwd with ifupdown-ng
ifupdown-ng can be used to do network management for iwd. Refer ifupdown-ng configuration section.
Configuration
To proceed with the configuration of iwd, ensure that wpa_supplicant
service is stopped before starting iwd service:
# rc-service wpa_supplicant stop # rc-service iwd start
iwctl
can be done in GUI using iwgtk utility. Other steps have to be done from CLI only.
To configure iwd in an interactive mode using the CLI based client program iwctl
, start the client:
$ iwctl
To list all available commands:
[iwd]# help
To connect to a network
To list all Wi-Fi devices:
[iwd]# device list
If your wireless adapter is not listed, refer to Wifi troubleshooting page.
If the device or its corresponding adapter is turned off, turn it on:
[iwd]# device device set-property Powered on
[iwd]# adapter adapter set-property Powered on
Then, to initiate a scan for networks (note that this command will not output anything):
[iwd]# station device scan
You can then list all available networks:
[iwd]# station device get-networks
Finally, to connect to a network:
[iwd]# station device connect SSID
If a passphrase is required, you will be prompted to enter it. Alternatively, you can supply it as a command line argument:
$ iwctl –passphrase passphrase station device connect SSID
- iwd automatically stores network passphrases in the /var/lib/iwd directory and uses them to auto-connect in the future.
- If you run diskless Alpine, be sure to commit:
# lbu add /var/lib/iwd && lbu commit -d
- To connect to a network with spaces in the SSID, the network name should be double quoted when connecting.
- iwd only supports PSK pass-phrases from 8 to 63 ASCII-encoded characters.
Disconnect from a network
To disconnect from a network:
[iwd]# station device disconnect
Show device and connection information
To display the details of a WiFi device, like MAC address:
[iwd]# device device show
To display the connection state, including the connected network of a Wi-Fi device:
[iwd]# station device show
Manage known networks
To list networks you have connected to previously:
[iwd]# known-networks list
To forget a known network:
[iwd]# known-networks SSID forget
- signal strength level
- security features
- maximum rate
- channel utilization
- time since the last connect.
ifupdown-ng configuration
If ifupdown-ng is used for network configuration management with iwd, edit the /etc/network/interfaces file based on instructions in Network configuration page.
Whenever system wakes up from sleep/suspend, the wireless interface name may change from wlan0
to wlan1
, wlan2
and so on resulting in loss of connectivity when using ifupdown-ng. To avoid this issue, create and add the following two files. The /etc/iwd/main.conf file should have:
Contents of /etc/iwd/main.conf
If mac address of wlan0
interface is "50:91:e3:71:83:d2", then file /etc/udev/rules.d/70-persistent-net-wlan0.rules should be as follows:
Contents of /etc/udev/rules.d/70-persistent-net-wlan0.rules
The commandcat /sys/class/net/wlan0/address
shows the mac address of your wireless interface wlan0
.
For the above changes to take immediate effect, reload Udev rules:
# udevadm control --reload-rules # udevadm trigger
A reboot is usually necessary for the changes to fully take effect.
Service configuration
Manage iwd service using the standard start, stop and restart options. For eg: To start the iwd service immediately issue the command:
# rc-service iwd start
Once iwd service has been fully configured and tested, add the iwd
service and disable the networking
boot service:
# rc-update add iwd boot # rc-update del networking boot
Troubleshooting
Resolve wireless driver issues first, if your wireless device is not detected, when the below command is issued:
$ iwctl device list Devices -------------------------------------------------------------------------------- Name Address Powered Adapter Mode -------------------------------------------------------------------------------- wlan0 50:91:e3:71:83:d2 on phy0 station
"The name net.connman.iwd was not provided by any .service files"
If iwctl
commands fail with the message The name net.connman.iwd was not provided by any .service files Failed to retrieve IWD dbus objects, quitting...
.
The above error means that the iwd
daemon is not started. Start the iwd daemon
"ip: ioctl 0x8913 failed: No such device"
The above error message may occur whenever the networking service gets loaded by openrc after iwd. Refer to Service configuration section.