diff --git a/modules/ROOT/nav.adoc b/modules/ROOT/nav.adoc index 324d9f4f..bca75f2b 100644 --- a/modules/ROOT/nav.adoc +++ b/modules/ROOT/nav.adoc @@ -27,6 +27,7 @@ ** xref:storage.adoc[Configuring Storage] ** xref:managing-files.adoc[Managing Files] ** xref:sysconfig-network-configuration.adoc[Network Configuration] +** xref:sysconfig-enabling-wifi.adoc[Enabling Wi-Fi] ** xref:sysctl.adoc[Kernel Tuning] ** xref:running-containers.adoc[Running Containers] ** xref:authentication.adoc[Configuring Users and Groups] @@ -43,7 +44,6 @@ ** xref:time-zone.adoc[Configuring Time Zone] ** xref:grub-password.adoc[Setting a GRUB password] ** xref:audit.adoc[Managing the audit daemon] -** xref:wifi.adoc[Wi-Fi Network configuration] * OS updates ** xref:update-streams.adoc[Update Streams] ** xref:auto-updates.adoc[Auto-Updates] diff --git a/modules/ROOT/pages/faq.adoc b/modules/ROOT/pages/faq.adoc index a681a50e..a5637b24 100644 --- a/modules/ROOT/pages/faq.adoc +++ b/modules/ROOT/pages/faq.adoc @@ -310,3 +310,18 @@ xref:storage.adoc[Configuring Storage] page for examples. See the xref:faq.adoc#_why_is_the_dnsmasq_service_systemd_unit_masked[Why is the `dnsmasq.service` systemd unit masked] entry for an example config to unmask this unit. + +== How do I keep dropped wireless firmware? + +Some Wi-Fi firmware blbos were split into sub-packages in Fedora 39 and Fedora 40. Fedora Cores OS will keep them in until Fedora 41, but display a warning message in the console if NetworkManager-wifi is layered without any other wifi firmware packages having a layering request. + +If `NetworkManager-wifi` is a requested layered package, a warning is displayed to encourage users to also request a WiFi firmware package to prevent disrupted connectivity. + +To request the Wi-Fi firmware stay installed even when Fedora CoreOS drops these packages please follow the xref:sysconfig-enabling-wifi.adoc#_on_an_existing_fedora_coreos_system[steps to perform Wi-Fi enablement on an existing system]. + +Once the packages are requested you can now disable the warning so it won't be checked on subsequent boots. + +[source, text] +---- +sudo systemctl disable coreos-check-wireless-firmwares.service +---- diff --git a/modules/ROOT/pages/sysconfig-enabling-wifi.adoc b/modules/ROOT/pages/sysconfig-enabling-wifi.adoc new file mode 100644 index 00000000..5c515844 --- /dev/null +++ b/modules/ROOT/pages/sysconfig-enabling-wifi.adoc @@ -0,0 +1,122 @@ += Enabling Wi-Fi + +The primary use for Fedora CoreOS has been driving server hardware in individual datacenters or cloud environments, which have high speed wired networking without the need for Wi-Fi enablement. Since there are many different types of wireless cards, link:https://github.com/coreos/fedora-coreos-tracker/issues/862[adding Wi-Fi enablement to Fedora CoreOS by default] would require many large firmware binaries to be installed for a non-standard use, which isn't ideal. + +On the other hand, Fedora CoreOS is versatile enough to run on smaller devices in IoT applications or in home labs where Wi-Fi may be required. In these cases it is easy enough to add a layer with the needed tools and firmware. + +== Adding Wi-Fi tools and firmware + +Typically enabling Wi-Fi on Fedora CoreOS involves adding the `NetworkManager-wifi` package along with the firmware package that corresponds to the wireless card in your system. Here is a list of some of the wireless firmware packages in Fedora: + +.Wi-Fi firmware packages in Fedora +[source, text] +---- +atheros-firmware - Firmware for Qualcomm Atheros WiFi/Bluetooth adapters +b43-fwcutter - Firmware extraction tool for Broadcom wireless driver +b43-openfwwf - Open firmware for some Broadcom 43xx series WLAN chips +brcmfmac-firmware - Firmware for Broadcom/Cypress brcmfmac WiFi/Bluetooth adapters +iwlegacy-firmware - Firmware for Intel(R) Wireless WiFi Link 3945(A)BG and 4965AGN adapters +iwlwifi-dvm-firmware - DVM Firmware for Intel(R) Wireless WiFi adapters +iwlwifi-mvm-firmware - MVM Firmware for Intel(R) Wireless WiFi adapters +libertas-firmware - Firmware for Marvell Libertas SD/USB WiFi Network Adapters +mt7xxx-firmware - Firmware for Mediatek 7600/7900 series WiFi/Bluetooth adapters +nxpwireless-firmware - Firmware for NXP WiFi/Bluetooth/UWB adapters +realtek-firmware - Firmware for Realtek WiFi/Bluetooth adapters +tiwilink-firmware - Firmware for Texas Instruments WiFi/Bluetooth adapters +atmel-firmware - Firmware for Atmel at76c50x wireless network chips +zd1211-firmware - Firmware for wireless devices based on zd1211 chipset +---- + +For example, if a system has a Qualcomm wireless card then adding the `NetworkManager-wifi` and `atheros-firmware` packages would sufficiently enable the system for connecting to Wi-Fi. + + +== When installing Fedora CoreOS + +For new systems the packages can be added using the xref:os-extensions.adoc[Adding OS Extensions] workflow. A NetworkManager configuration for the Wi-Fi connection will also need to be added so the system knows which wireless network to connect to. For more information on network configuration in Fedora CoreOS see xref:sysconfig-network-configuration.adoc[Network Configuration]. + +An example Butane config that combines the extension and network configuration is shown below. + +.Butane config for Wi-Fi enablement +[source,yaml,subs="attributes"] +---- +variant: fcos +version: {butane-latest-stable-spec} +systemd: + units: + # Enable Wi-Fi in NetworkManager for an Intel wireless card + - name: rpm-ostree-install-wifi.service + enabled: true + contents: | + [Unit] + Description=Enable Wi-Fi + Wants=network-online.target + After=network-online.target + Before=zincati.service + ConditionPathExists=!/var/lib/%N.stamp + [Service] + Type=oneshot + RemainAfterExit=yes + ExecStart=/usr/bin/rpm-ostree install --apply-live --allow-inactive NetworkManager-wifi iwlwifi-dvm-firmware + ExecStart=/bin/touch /var/lib/%N.stamp + [Install] + WantedBy=multi-user.target +storage: + files: + - path: /etc/NetworkManager/system-connections/wifi-guest.nmconnection + mode: 0600 + contents: + inline: | + [connection] + id=wifi-guest + type=wifi + autoconnect=true + [wifi] + cloned-mac-address=permanent + mode=infrastructure + ssid=guest + mac-address=ab:cd:01:02:03:04 + [wifi-security] + auth-alg=open + key-mgmt=wpa-psk + psk=PASSWORD + [ipv4] + method=auto +---- + +NOTE: When installing a system and adding WiFi enablement in this way the system will need to be on a wired network for the initial install since it will need to use the network to retrieve the WiFi enabling packages. + + +== On an existing Fedora CoreOS system + +If you have a system up already and want to add Wi-Fi capabilities (i.e. if you want to move it to a location without wired access) you can request the required packages. + +.Request NetworkManager-wifi and a specific Wi-Fi firmware +[source, text] +---- +$ sudo rpm-ostree install -y --allow-inactive \ + NetworkManager-wifi iwlwifi-dvm-firmware +---- + +If you don't know what firmware to request you can request all the wireless firmware available in Fedora. Please note this approach is sub-optimal as it will add many uneeded packages on your system. + +.Request NetworkManager-wifi and all available Wi-Fi firmware +---- +$ sudo rpm-ostree install -y --allow-inactive \ + NetworkManager-wifi \ + atheros-firmware \ + b43-fwcutter \ + b43-openfwwf \ + brcmfmac-firmware \ + iwlegacy-firmware \ + iwlwifi-dvm-firmware \ + iwlwifi-mvm-firmware \ + libertas-firmware \ + mt7xxx-firmware \ + nxpwireless-firmware \ + realtek-firmware \ + tiwilink-firmware \ + atmel-firmware \ + zd1211-firmware +---- + +Then reboot the system. diff --git a/modules/ROOT/pages/wifi.adoc b/modules/ROOT/pages/wifi.adoc deleted file mode 100644 index 5d6148b2..00000000 --- a/modules/ROOT/pages/wifi.adoc +++ /dev/null @@ -1,66 +0,0 @@ - -== How do I add the missing wifi-firmwares? - -Some wifi-firmwares will be split into sub-packages in Fedora 39 and Fedora 40. -Fedora Cores OS will keep them in until Fedora 41, but display a -warning message in the console if NetworkManager-wifi is layered without -any other wifi firmware packages having a layering request. - -If NetworkManager-wifi is a requested layered package, a warning is -displayed to encourage users to also add a wifi-firmware. - -If you know what wifi firmware your system needs then request that package specifically. -The available wifi firmware packages are: ---- -atheros-firmware - Firmware for Qualcomm Atheros WiFi/Bluetooth adapters -b43-fwcutter - Firmware extraction tool for Broadcom wireless driver -b43-openfwwf - Open firmware for some Broadcom 43xx series WLAN chips -brcmfmac-firmware - Firmware for Broadcom/Cypress brcmfmac WiFi/Bluetooth adapters -iwlegacy-firmware - Firmware for Intel(R) Wireless WiFi Link 3945(A)BG and 4965AGN adapters -iwlwifi-dvm-firmware - DVM Firmware for Intel(R) Wireless WiFi adapters -iwlwifi-mvm-firmware - MVM Firmware for Intel(R) Wireless WiFi adapters -libertas-firmware - Firmware for Marvell Libertas SD/USB WiFi Network Adapters -mt7xxx-firmware - Firmware for Mediatek 7600/7900 series WiFi/Bluetooth adapters -nxpwireless-firmware - Firmware for NXP WiFi/Bluetooth/UWB adapters -realtek-firmware - Firmware for Realtek WiFi/Bluetooth adapters -tiwilink-firmware - Firmware for Texas Instruments WiFi/Bluetooth adapters -atmel-firmware - Firmware for Atmel at76c50x wireless network chips -zd1211-firmware - Firmware for wireless devices based on zd1211 chipset ---- - -.Request the required firmware for your hardware: -[source, text] ----- -$ sudo rpm-ostree install -y iwlwifi-dvm-firmware --allow-inactive ----- - -If you don't know what firmware to request you can request -all the wireless firmware available in Fedora. -Please note this approach is sub-optimal as it will add a lot -of uneeded packages on your system. -.Request all available wifi firmware ----- -$ sudo rpm-ostree install -y --allow-inactive \ - atheros-firmware \ - b43-fwcutter \ - b43-openfwwf \ - brcmfmac-firmware \ - iwlegacy-firmware \ - iwlwifi-dvm-firmware \ - iwlwifi-mvm-firmware \ - libertas-firmware \ - mt7xxx-firmware \ - nxpwireless-firmware \ - realtek-firmware \ - tiwilink-firmware \ - atmel-firmware \ - zd1211-firmware ----- - -You can now disable the warning with: -[source, text] ----- -sudo systemctl disable coreos-check-wireless-firmwares.service ----- - -Then reboot the system.