From: James Prestwood <prestwoj@gmail.com>
To: Denis Kenzior <denkenz@gmail.com>,
Alexander Ganslandt <alexanga@axis.com>,
iwd@lists.linux.dev
Subject: Re: Roaming questions
Date: Thu, 13 Feb 2025 07:42:41 -0800 [thread overview]
Message-ID: <7ddbf418-e8c2-4d2a-9495-3a1cce2ddb3e@gmail.com> (raw)
In-Reply-To: <9eb9d215-8a21-4d82-9da7-50077dd63e13@gmail.com>
On 2/13/25 7:24 AM, Denis Kenzior wrote:
> Hi Alexander,
>
> On 2/13/25 9:01 AM, Alexander Ganslandt wrote:
>> Hello,
>>
>> I'm looking into different roaming solutions and currently evaluating
>> iwd, which seems promising so far! My use-case is a device live
>> streaming video while moving around large areas, and the goal is to
>> do so without hiccups in the live stream. I have a few questions:
>>
>> Looking at station_roam_failed(), it will schedule a full scan if the
>> previous limited scan failed to find a better BSS to roam to. A full
>> scan on our chip takes about 7 seconds, which is often enough time
>> for the signal to get low enough to deauthenticate the station when
>> you're moving. It seems to me that a better approach would be to
>> schedule a scan for either the "known frequencies",
>
> The idea is to use neighbor reports when possible. If neighbor
> reports are supported, iwd scans the frequencies in the neighbor
> report. Otherwise the limited scan uses the frequencies that iwd
> knows the network operates on. If the limited scan fails, then iwd
> falls back to the catch-all full scan. The hope is that falling back
> to the full scan should never happen in practice.
>
>> or all non-DFS frequencies (since passive scanning takes extra time)
>> or some other popular group of frequencies that won't take long to
>> scan. If we're lucky there is a good BSS in that scan, otherwise we
>> schedule a scan for the rest of the frequencies. In the worst case,
>> this should be identical to a full scan with minor extra overhead. Do
>> you have any thoughts about this from your side? Is it something that
>> could be accepted into iwd or could it cause issues for other use-cases?
>
> If you find that full scans do indeed happen when roaming, then
> introducing intermediate limited / non-DFS scan(s) prior to the
> catch-all scan would be just fine.
This is an area I want to improve since we do see full scans routinely.
Not because we didn't see any acceptable BSS's via neighbor reports, but
because the current one was simply better. Likely another limited scan
using the very same neighbor reports, just done later, would result in a
successful roam. But its tough because you can't always the APs are
sending accurate neighbor reports.
>
>>
>> Another question is about the "CriticalRoamThreshold". There seems to
>> be a config for this and some functions for lowering and raising the
>> roam threshold, but I can't see that they're called from anywhere? It
>> seems to me that only "RoamThreshold" is used, or am I missing
>> something? There's also a hardcoded delay of 5 seconds from the point
>> where the roam threshold is passed before a scan is started, is that
>> just a "hysteresis" to not immediately start a scan if the signal
>> temporarily drops, or does it have some other function?
>
> This is currently used with the Affinities property on the Station
> interface. For now it is only useful to lock the station to the
> currently connected BSS to prevent roaming. For example, for the
> duration of firmware upgrade or similar scenarios.
>
>>
>> Thanks in advance!
>>
>> Best regards,
>> Alexander
>>
>
> Regards,
> -Denis
>
next prev parent reply other threads:[~2025-02-13 15:42 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-13 15:01 Roaming questions Alexander Ganslandt
2025-02-13 15:24 ` Denis Kenzior
2025-02-13 15:42 ` James Prestwood [this message]
2025-02-17 10:15 ` Alexander Ganslandt
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7ddbf418-e8c2-4d2a-9495-3a1cce2ddb3e@gmail.com \
--to=prestwoj@gmail.com \
--cc=alexanga@axis.com \
--cc=denkenz@gmail.com \
--cc=iwd@lists.linux.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox