Wi-Fi (Wireless LAN)¶
Infix includes comprehensive Wi-Fi support for both client (Station) and Access Point modes. When a compatible Wi-Fi adapter is detected, the system automatically creates a WiFi radio (PHY) in factory-config, that can host virtual interfaces.
Architecture Overview¶
Infix uses a two-layer WiFi architecture:
-
WiFi Radio (PHY layer): Represents the physical wireless hardware
- Configured via
ietf-hardwaremodule - Controls channel, transmit power, regulatory domain
- One radio can host multiple virtual interfaces
- Configured via
-
WiFi Interface (Network layer): Virtual interface on a radio
- Configured via
infix-interfacesmodule - Can operate in Station (client) or Access Point mode
- Each interface references a parent radio
- Configured via
Naming Conventions¶
Like other interface types in Infix, WiFi components follow naming conventions that allow the CLI to automatically infer types:
| Name Pattern | Type | Description |
|---|---|---|
radioN |
WiFi Radio | Hardware component for WiFi PHY |
wifiN |
WiFi Interface | Virtual WiFi interface on a radio |
Where N is a number (0, 1, 2, ...).
Tip
Using these naming conventions simplifies configuration since type/class
settings are automatically inferred. For example, creating a hardware
component named radio0 automatically sets its class to wifi, enabling
the wifi-radio configuration container.
Note: This inference only works with the CLI. Configuring WiFi over NETCONF or RESTCONF requires setting the class/type explicitly.
Current Limitations¶
- USB hotplug is not supported - adapters must be present at boot
- Interface naming may be inconsistent with multiple USB Wi-Fi adapters
- AP and Station modes cannot be mixed on the same radio
Supported Wi-Fi Adapters¶
Wi-Fi support is primarily tested with Realtek chipset-based adapters.
Known Working Chipsets¶
- Built-in Wi-Fi on Banana Pi BPi-R3
- Built-in Wi-Fi on Raspberry Pi 4/CM4
- Realtek:
- RTL8188CU
- RTL8188FU
- RTL8821CU
Other Realtek chipsets may work but are not tested.
Note
Some Realtek chipsets require proprietary drivers not included in the standard kernel.
- Firmware requirements vary by chipset
- Check kernel logs if your adapter is not detected
USB WiFi Dongles¶
USB WiFi dongles may be slow to initialize at boot due to firmware
loading. If your USB dongle is not detected reliably, configure a
probe-timeout on the radio to wait for the PHY:
admin@example:/> configure
admin@example:/config/> edit hardware component radio0 wifi-radio
admin@example:/config/hardware/component/radio0/wifi-radio/> set probe-timeout 30
admin@example:/config/hardware/component/radio0/wifi-radio/> leave
This waits up to 30 seconds for the radio PHY to appear before creating WiFi interfaces. If the PHY is not detected within the timeout, a dummy interface is created as a placeholder, allowing IP configuration to proceed. Reboot when the radio becomes available.
Radio Configuration¶
Before configuring WiFi interfaces, you must first configure the WiFi radio.
Radios are automatically discovered and named radio0, radio1, etc.
Country Code ⚠¶
The radio defaults to "00" for World domain, but some systems may ship with a factory default country code (typically "DE" for the BPi-R3).
Legal notice!
The country-code setting is legally required and determines
which WiFi channels and power levels are permitted in your
location. Using an incorrect country code may violate local wireless
regulations.
Common country codes, see ISO 3166-1 alpha-2 for the complete list:
- Europe:
- DE: Germany
- SE: Sweden
- GB: UK
- FR: France
- ES: Spain
- Americas:
- US: United States
- CA: Canada
- BR: Brazil
- Asia-Pacific:
- JP: Japan
- AU: Australia
- CN: China
Basic Radio Setup¶
Configure the radio with channel, power, and regulatory domain.
For Station (client) mode:
admin@example:/> configure
admin@example:/config/> edit hardware component radio0 wifi-radio
admin@example:/config/hardware/component/radio0/wifi-radio/> set country-code DE
admin@example:/config/hardware/component/radio0/wifi-radio/> leave
For Access Point mode:
admin@example:/> configure
admin@example:/config/> edit hardware component radio0 wifi-radio
admin@example:/config/hardware/component/radio0/wifi-radio/> set country-code DE
admin@example:/config/hardware/component/radio0/wifi-radio/> set band 5GHz
admin@example:/config/hardware/component/radio0/wifi-radio/> set channel 36
admin@example:/config/hardware/component/radio0/wifi-radio/> set channel-width 80MHz
admin@example:/config/hardware/component/radio0/wifi-radio/> leave
Key radio parameters:
country-code: Two-letter ISO 3166-1 alpha-2 code, determines allowed channels and maximum power. Examples: US, DE, GB, SE, FR, JP.
⚠ Must match your physical location for legal compliance! ⚠band: 2.4GHz, 5GHz, or 6GHz (required for AP mode). Automatically enables appropriate WiFi standards:- 2.4GHz: 802.11n/ax
- 5GHz: 802.11n/ac/ax
- 6GHz: 802.11ax
channel: Channel number (1-233) or "auto". When set to "auto", defaults to channel 6 for 2.4GHz, channel 36 for 5GHz, or channel 37 for 6GHzchannel-width: AP channel bandwidth. Supported values areauto,20MHz,40MHz,80MHz, and160MHz. Wider channels require matching hardware, regulatory approval, and are only available on 5GHz/6GHz where supported.legacy-rates: Allow legacy 802.11b rates (1, 2, 5.5, 11 Mbps) on 2.4GHz (default: disabled). Slow 802.11b clients consume excessive airtime and degrade throughput for all stations, so the rates are normally suppressed. Enable only when old 2.4GHz-only IoT devices need them to associate. No effect on 5GHz/6GHz.probe-timeout: Seconds to wait for PHY detection at boot (default: 0). Set to a non-zero value (e.g., 30) for USB WiFi dongles that are slow to initialize due to firmware loading
Note
TX power is still determined by the driver based on regulatory
constraints and hardware capabilities. Channel width can now be set
explicitly for AP mode, or left at auto to let the driver choose.
Bands and Channels¶
Each band strikes a different balance between range and capacity. The
country-code decides which channels are legal in your location; the
lists below are the common allocations, and your regulatory domain may
allow fewer.
2.4 GHz
Channels 1-13 are available in most of the world, 1-11 in the US and Canada, and 14 in Japan (802.11b only). At 20 MHz only three channels avoid overlap: 1, 6, and 11. A 40 MHz channel takes up most of the band, so it is seldom worth using here.
Drawbacks:
- This is the most crowded band. It is shared with Bluetooth, Zigbee, cordless phones, microwave ovens, and most of the neighboring Wi-Fi.
- Narrow channels and constant contention hold real throughput well below 5 and 6 GHz.
- The upside is range: 2.4 GHz reaches further and passes through walls better, which keeps it useful for distant clients and 2.4 GHz-only IoT devices.
5 GHz
UNII-1 (channels 36-48) and UNII-3 (149-165) need no radar checks. UNII-2 (channels 52-64 and 100-144) shares spectrum with radar and requires DFS. ETSI regions such as the EU do not include UNII-3, so the only non-DFS 5 GHz channels there are 36-48. This band supports 20, 40, 80, and 160 MHz, so it is the one to use for wide, fast channels.
Drawbacks:
- Shorter range than 2.4 GHz, and a weaker signal through walls and floors.
- A DFS channel must be monitored for radar for 60 seconds (up to 10 minutes near some weather radars) before the AP may transmit, which delays start-up. If radar appears later, the AP has to leave the channel within 10 seconds and avoid it for 30 minutes, dropping clients during the move.
- The widest 80 and 160 MHz channels almost always sit on DFS spectrum, so the same radar rules apply to them.
6 GHz
The FCC regions open 59 channels (1, 5, 9 ... 233) across 5925-7125 MHz.
ETSI regions, including the EU, currently open only the lower part,
5945-6425 MHz (channels 1-93), for indoor use. Clients find networks on
the 15 Preferred Scanning Channels (5, 21, 37 ... 229) spaced every
80 MHz, and auto selects channel 37. There is no DFS in 6 GHz, so
there is no radar start-up delay.
Drawbacks:
- The shortest range and the weakest wall penetration of the three bands.
- Only Wi-Fi 6E and newer clients can use it; older phones and IoT devices cannot see the band at all.
- AP operation requires WPA3-Personal (SAE) with management frame protection, so WPA2-only and open networks are rejected.
- Indoor power limits cap coverage further.
WiFi 6 Support¶
WiFi 6 (802.11ax) is always enabled in AP mode on all bands, providing improved performance through features like OFDMA, BSS Coloring, and beamforming.
WiFi 6 Features (always enabled in AP mode on supported radios):
- OFDMA: Better multi-user efficiency in dense environments
- BSS Coloring: Reduced interference from neighboring networks
- Beamforming: Improved signal quality and range
Requirements:
- Hardware must support 802.11ax
- Client devices must support WiFi 6 for full benefits
- Older WiFi 5/4 clients can still connect but won't use WiFi 6 features
Important
6 GHz AP operation requires WPA3-Personal (SAE) with mandatory management frame protection. Open networks and WPA2-only AP configurations are not valid on 6 GHz.
Discovering Available Networks¶
Before connecting to a WiFi network, you need to discover which networks are available. Infix automatically scans for networks when a WiFi interface is created with a radio reference.
Enable Background Scanning¶
To enable scanning without connecting, configure the radio and create a WiFi interface referencing it:
Step 1: Configure the radio
admin@example:/> configure
admin@example:/config/> edit hardware component radio0 wifi-radio
admin@example:/config/hardware/component/radio0/wifi-radio/> set country-code DE
admin@example:/config/hardware/component/radio0/wifi-radio/> leave
Step 2: Create WiFi interface with radio reference only
admin@example:/> configure
admin@example:/config/> edit interface wifi0
admin@example:/config/interface/wifi0/> set wifi radio radio0
admin@example:/config/interface/wifi0/> leave
The system will now start scanning in the background. The interface will operate in scan-only mode until you configure a specific mode (station or access-point).
View Available Networks¶
Use show interface to see discovered networks and their signal strength:
admin@example:/> show interface wifi0
name : wifi0
type : wifi
index : 3
mtu : 1500
operational status : up
ip forwarding : enabled
physical address : f0:09:0d:36:5f:86
ipv4 addresses : 192.168.1.100/24 (dhcp)
ipv6 addresses :
in-octets : 148388
out-octets : 24555
mode : station
ssid : MyNetwork
signal : -45 dBm (good)
rx bitrate : 72.2 Mbps
tx bitrate : 86.6 Mbps
──────────────────────────────────────────────────────────────────────
Available Networks
SSID BSSID SECURITY SIGNAL CHANNEL
MyNetwork b4:fb:e4:17:b6:a7 WPA2-Personal good 6
GuestWiFi c8:3a:35:12:34:56 WPA2-Personal fair 11
CoffeeShop 00:1a:2b:3c:4d:5e Open bad 1
In the CLI, signal strength is reported as: excellent, good, fair or bad.
For precise signal strength values in dBm, use NETCONF or RESTCONF to access
the signal-strength leaf in the operational datastore.
Passphrase Requirements¶
To ensure your connection is secure and compatible with all network hardware, your passphrase must meet the following criteria:
- Length: Between 8 and 63 characters
- Characters: Use only standard English keyboard characters
- Allowed: Letters (A-Z, a-z), numbers (0-9), and common symbols (e.g., ! @ # $ % ^ & * ( ) _ + - = [ ] { } | ; : ' " , . < > / ? ~)
- Spaces: Spaces are allowed, but not at the very beginning or very end of the passphrase
- Prohibited: Emojis, accented characters (like á or ñ), and special "control" characters
Why the limit?
Standard WiFi security (WPA2/WPA3) requires a minimum of 8 characters to
prevent "brute-force" hacking. The character limit ensures your password
works on older routers and various operating systems.
Tips for password strength, see XKCD #936.
Station Mode (Client)¶
Station mode connects to an existing Wi-Fi network. Before configuring station mode, follow the "Discovering Available Networks (Scanning)" section above to scan for available networks and identify the SSID you want to connect to.
Step 1: Configure Password¶
Create a keystore entry for your WiFi password (8-63 characters):
admin@example:/> configure
admin@example:/config/> edit keystore symmetric-key my-wifi-key
admin@example:/config/keystore/…/my-wifi-key/> set key-format passphrase-key-format
admin@example:/config/keystore/…/my-wifi-key/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/keystore/…/my-wifi-key/> leave
The change command prompts for the passphrase interactively and
handles the base64 encoding required by the keystore automatically.
Step 2: Connect to Network¶
Configure station mode with the SSID and password to connect:
admin@example:/> configure
admin@example:/config/> edit interface wifi0
admin@example:/config/interface/wifi0/> set wifi station ssid MyHomeNetwork
admin@example:/config/interface/wifi0/> set wifi station security secret my-wifi-key
admin@example:/config/interface/wifi0/> leave
The connection attempt will start immediately. You can verify the connection status:
admin@example:/> show interface wifi0
name : wifi0
type : wifi
operational status : up
physical address : f0:09:0d:36:5f:86
mode : station
ssid : MyHomeNetwork
signal : -52 dBm (good)
Station configuration parameters:
radio: Reference to the WiFi radio (mandatory) - already set during scanningstation ssid: Network name to connect to (mandatory)station security mode:auto: default, WPA2/WPA3 auto-negotiationdisabled: open network
station security secret: Reference to keystore entry, required unless mode isdisabled
Note
The auto security mode automatically selects WPA3-SAE or WPA2-PSK based on
what the access point supports, prioritizing WPA3 for better security.
Certificate-based authentication (802.1X/EAP) is not yet supported.
Access Point Mode¶
Access Point (AP) mode allows your device to create a WiFi network that other devices can connect to. APs are configured as virtual interfaces on a WiFi radio.
Basic AP Configuration¶
First, ensure the radio is configured (see Radio Configuration above). Then create a keystore entry for your WiFi password and configure the AP interface:
Step 1: Create keystore entry for the WiFi password
admin@example:/> configure
admin@example:/config/> edit keystore symmetric-key my-wifi-secret
admin@example:/config/keystore/…/my-wifi-secret/> set key-format passphrase-key-format
admin@example:/config/keystore/…/my-wifi-secret/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/keystore/…/my-wifi-secret/> end
Step 2: Create the AP interface
admin@example:/config/> edit interface wifi0
admin@example:/config/interface/wifi0/> set wifi radio radio0
admin@example:/config/interface/wifi0/> set wifi access-point ssid MyNetwork
admin@example:/config/interface/wifi0/> set wifi access-point security secret my-wifi-secret
admin@example:/config/interface/wifi0/> leave
Note
Using wifiN as the interface name automatically sets the type to WiFi.
Alternatively, you can use any name and explicitly set type wifi.
Access Point configuration parameters:
radio: Reference to the WiFi radio (mandatory)access-point ssid: Network name (SSID) to broadcastaccess-point hidden: Set totrueto hide SSID (optional, default: false)access-point security mode: Security mode (see below)access-point security secret: Reference to keystore entry (for secured networks)
Security modes:
open: No encryption (not recommended)auto: WPA2/WPA3 transitional mode on 2.4/5 GHz, WPA3-only on 6 GHzwpa2-personal: WPA2-PSK (most compatible)wpa3-personal: WPA3-SAE (more secure, requires WPA3-capable clients)wpa2-wpa3-personal: Mixed mode (maximum compatibility)
SSID Hiding¶
To create a hidden network that doesn't broadcast its SSID:
admin@example:/config/interface/wifi0/> set wifi access-point hidden true
Multi-SSID Configuration¶
Multiple AP interfaces on the same radio allow broadcasting multiple SSIDs, each with independent security settings. This is useful for guest networks, IoT devices, or segregating traffic into different VLANs.
Step 1: Configure the radio (shared by all APs)
admin@example:/> configure
admin@example:/config/> edit hardware component radio0 wifi-radio
admin@example:/config/hardware/component/radio0/wifi-radio/> set country-code DE
admin@example:/config/hardware/component/radio0/wifi-radio/> set band 5GHz
admin@example:/config/hardware/component/radio0/wifi-radio/> set channel 36
admin@example:/config/hardware/component/radio0/wifi-radio/> leave
Step 2: Configure keystore secrets
admin@example:/> configure
admin@example:/config/> edit keystore symmetric-key main-secret
admin@example:/config/keystore/…/main-secret/> set key-format passphrase-key-format
admin@example:/config/keystore/…/main-secret/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/> edit keystore symmetric-key guest-secret
admin@example:/config/keystore/…/guest-secret/> set key-format passphrase-key-format
admin@example:/config/keystore/…/guest-secret/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/> edit keystore symmetric-key iot-secret
admin@example:/config/keystore/…/iot-secret/> set key-format passphrase-key-format
admin@example:/config/keystore/…/iot-secret/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/keystore/…/iot-secret/> leave
Step 3: Create multiple AP interfaces (all on radio0)
admin@example:/> configure
# Primary AP - Main network (WPA3 for maximum security)
admin@example:/config/> edit interface wifi0
admin@example:/config/interface/wifi0/> set wifi radio radio0
admin@example:/config/interface/wifi0/> set wifi access-point ssid MainNetwork
admin@example:/config/interface/wifi0/> set wifi access-point security mode wpa3-personal
admin@example:/config/interface/wifi0/> set wifi access-point security secret main-secret
# Guest AP - Guest network (WPA2/WPA3 mixed for compatibility)
admin@example:/config/> edit interface wifi1
admin@example:/config/interface/wifi1/> set wifi radio radio0
admin@example:/config/interface/wifi1/> set wifi access-point ssid GuestNetwork
admin@example:/config/interface/wifi1/> set wifi access-point security mode wpa2-wpa3-personal
admin@example:/config/interface/wifi1/> set wifi access-point security secret guest-secret
admin@example:/config/interface/wifi1/> set custom-phys-address static 00:0c:43:26:60:01
# IoT AP - IoT devices (WPA2 for older device compatibility)
admin@example:/config/> edit interface wifi2
admin@example:/config/interface/wifi2/> set wifi radio radio0
admin@example:/config/interface/wifi2/> set wifi access-point ssid IoT-Devices
admin@example:/config/interface/wifi2/> set wifi access-point security mode wpa2-personal
admin@example:/config/interface/wifi2/> set wifi access-point security secret iot-secret
admin@example:/config/interface/wifi2/> set custom-phys-address static 00:0c:43:26:60:02
admin@example:/config/interface/wifi2/> leave
Important
MAC Address Requirement for Multi-SSID:
When creating multiple AP interfaces on the same radio, you must configure
a unique MAC address for each secondary interface (wifi1, wifi2, etc.) using
set custom-phys-address static <MAC>. All interfaces on the same radio inherit
the radio's hardware MAC address by default, which causes network conflicts. Only
the primary interface (alphabetically first, e.g., wifi0) should use the default
hardware MAC address.
Choose MAC addresses from the same locally-administered range:
- Primary (wifi0): Uses hardware MAC (e.g.,
00:0c:43:26:60:00) - Secondary (wifi1):
00:0c:43:26:60:01(increment last octet) - Tertiary (wifi2):
00:0c:43:26:60:02(increment last octet)
Result: Three SSIDs broadcasting simultaneously on radio0:
MainNetwork(WPA3, most secure)GuestNetwork(WPA2/WPA3 mixed mode)IoT-Devices(WPA2 for compatibility)
All APs on the same radio share the same channel and physical layer settings (configured at the radio level). Each AP can have its own:
- SSID (network name)
- Security mode and passphrase
- Hidden/visible SSID setting
- Bridge membership
You can verify the configuration with show hardware component radio0 to see
radio settings, and show interface to see all active AP interfaces.
Important
AP and Station modes cannot be mixed on the same radio. All virtual interfaces on a radio must be the same mode (all APs or all Stations).
Fast Roaming Between Access Points¶
Fast roaming enables seamless client handoff between access points through 802.11k/r/v standards. These features can be enabled individually based on your requirements.
802.11r - Fast BSS Transition¶
Enable 802.11r for fast handoff (<50ms) between APs with the same SSID:
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r mobility-domain 4f57
Requirements: - All APs in roaming group must have identical SSID - All APs must have identical passphrase (same keystore secret) - All APs must use the same mobility-domain identifier
Mobility Domain Options:
- Explicit 4-character hex value (e.g., 4f57) - default if not specified
- hash - Automatically derive from SSID using MD5 (OpenWrt-compatible)
Using hash allows multiple APs with the same SSID to automatically share
the same mobility domain without manual configuration:
The NAS-Identifier (Network Access Server Identifier) is a string that uniquely identifies each AP within the 802.11r mobility domain. APs exchange this identifier during fast BSS transition so they can look up the correct PMK-R1 key for the roaming client. It must be unique per AP BSS and stable across reboots.
auto derives the identifier as:
<interface-name>-<hostname>.<mobility-domain>
Or set an explicit string:
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r nas-identifier ap01.wifi0.4f57
802.11k - Radio Resource Management¶
Enable 802.11k for client neighbor discovery and better roaming decisions:
Enables neighbor reports and beacon reports, allowing clients to discover nearby APs before roaming.
802.11v - BSS Transition Management¶
Enable 802.11v for network-assisted roaming:
Allows APs to suggest better APs to clients, improving roaming decisions.
Band Steering (MBO)¶
Enabling dot11v also turns on MBO (Multi-Band Operation), advertised in
beacons and association responses. MBO lets a dual-band client see that
the same SSID exists on another band and decide for itself when to move,
while 802.11v BSS Transition Management lets the AP suggest a better
target.
On top of the client-cooperative hints, the AP applies active steering:
on a 2.4 GHz access-point it suppresses probe responses to clients that
were recently seen on the same SSID on the 5/6 GHz band, nudging
dual-band clients onto the higher band. MBO is enabled by default
whenever dot11v is enabled:
To turn it off while keeping BSS Transition Management:
Note
Band steering only matters when the same SSID is offered on two or more bands (one access-point per radio). On a single-band network there is no other band to move to, so it has no effect.
Opportunistic Key Caching (OKC)¶
OKC reduces re-authentication time for roaming clients that do not support 802.11r. The AP caches the PMK from previous associations and shares it with other APs in the same mobility group. It is enabled by default and only activates when both AP and client support it:
Recommended Configuration¶
For optimal roaming experience, enable all three features:
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11k
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11v
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r mobility-domain 4f57
Or use hash for automatic mobility domain derivation from SSID:
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11k
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11v
admin@example:/config/interface/wifi0/> set wifi access-point roaming dot11r mobility-domain hash
Repeat for all APs that should participate in the roaming group.
Note
Not all client devices support all roaming features. Modern devices typically support 802.11k/r/v, but older devices may only support basic roaming without fast transition.
802.11s Mesh Point Mode¶
IEEE 802.11s is a wireless mesh networking standard operating at Layer 2. Mesh nodes form peer links directly with each other and route traffic using HWMP (Hybrid Wireless Mesh Protocol), which is built into the Linux mac80211 subsystem. There is no central controller; nodes discover peers and find paths on their own.
The standard defines two node roles:
- Mesh Point (MP) - a basic mesh node that forwards traffic within the mesh
- Mesh Portal (MPP) - a mesh node that bridges traffic between the mesh and an external network (e.g., a wired LAN)
In practice, a node bridging the mesh interface to a LAN acts as a mesh portal.
Note
Not all WiFi hardware supports 802.11s mesh. The driver must implement
mesh point mode in mac80211. Check your adapter's capabilities with
iw phy <phy> info and look for "mesh point" under "Supported interface
modes".
802.11s vs EasyMesh¶
| 802.11s | EasyMesh | |
|---|---|---|
| Standard | IEEE (open, ratified) | Wi-Fi Alliance (certification) |
| Topology | Peer-to-peer, any-to-any | Controller-based tree |
| Single point of failure | None | Controller |
| Multi-hop | True N-hop | Limited (1-2 hops) |
| Vendor lock-in | None | Common |
| Linux support | Kernel-native (mac80211) | Requires proprietary firmware |
Infix uses 802.11s because it runs entirely in the kernel with no proprietary components.
Mesh configuration¶
A mesh point requires the radio to have band, channel, and a valid
country-code configured. Mesh and AP modes cannot coexist on the same
radio.
Step 1: Configure the radio
admin@example:/> configure
admin@example:/config/> edit hardware component radio1 wifi-radio
admin@example:/config/hardware/component/radio1/wifi-radio/> set country-code DE
admin@example:/config/hardware/component/radio1/wifi-radio/> set band 5GHz
admin@example:/config/hardware/component/radio1/wifi-radio/> set channel 36
admin@example:/config/hardware/component/radio1/wifi-radio/> leave
Step 2: Create keystore entry for mesh security
All mesh links use WPA3-SAE encryption. All nodes in the same mesh network must share the same passphrase:
admin@example:/> configure
admin@example:/config/> edit keystore symmetric-key mesh-secret
admin@example:/config/keystore/…/mesh-secret/> set key-format passphrase-key-format
admin@example:/config/keystore/…/mesh-secret/> change cleartext-symmetric-key
Passphrase: ************
Retype passphrase: ************
admin@example:/config/keystore/…/mesh-secret/> end
Step 3: Configure the mesh interface
admin@example:/config/> edit interface wifi-mesh
admin@example:/config/interface/wifi-mesh/> set type wifi
admin@example:/config/interface/wifi-mesh/> set wifi radio radio1
admin@example:/config/interface/wifi-mesh/> set wifi mesh-point mesh-id my-mesh
admin@example:/config/interface/wifi-mesh/> set wifi mesh-point security secret mesh-secret
admin@example:/config/interface/wifi-mesh/> leave
Mesh parameters:
mesh-id: Network identifier, 1-32 characters. All nodes in the mesh must use the same mesh IDforwarding: L2 mesh forwarding (default: true). When enabled, the interface can be added to a bridge as a mesh portalsecurity secret: Keystore reference for the WPA3-SAE passphrase
Mesh portal (bridge integration)¶
To connect the wireless mesh to a wired LAN, add the mesh interface to a bridge:
admin@example:/config/> edit interface wifi-mesh
admin@example:/config/interface/wifi-mesh/> set bridge-port bridge br0
admin@example:/config/interface/wifi-mesh/> leave
Mesh with roaming APs¶
You can combine 802.11s mesh backhaul with roaming-enabled access points. Each node has a mesh interface for backhaul on one radio and AP interfaces for clients on another:
With 802.11r/k/v roaming enabled on the APs (same SSID, same passphrase, same mobility domain), clients hand off between nodes while the mesh carries backhaul traffic.
Troubleshooting¶
Use show interface wifi0 to verify signal strength and connection status.
If issues arise, try the following troubleshooting steps:
- Verify signal strength: Check that the target network shows "good" or "excellent" signal in scan results
- Check credentials: Use
show keystore symmetric <name>to verify the passphrase matches the network password - Review logs: Check system logs with
show logfor Wi-Fi related errors - Regulatory compliance: Ensure the country-code on the radio matches your location
- Hardware detection: Confirm the WiFi radio appears in
show hardware
If issues persist, check the system log for specific error messages that can help identify the root cause.