8b356aa11f
Replaces the 13 broken DKMS-path -danctnix mirrors from PR #17 + adds 9 new series-dirs for the c-stack patches that were never split (Patches A/B/C-v3/F/D/E/C2/G/H) + retires the cumulative-c5x-danctnix single-file interim from fleet/ohm.yaml. Mechanism: cd marfrit/bes2600-dkms-mobian git format-patch fe73571..cleanups --no-merges -o /tmp/cleanups/ git format-patch cleanups..bes2600/bh-c-fossil-cleanup --no-merges -o /tmp/h/ for each commit: route to series-dir, sed-rewrite a/bes2600/foo.c -> a/drivers/staging/bes2600/foo.c The 29 cleanups commits + 1 Patch H commit map to 25 series-dirs (a few series-dirs get multiple commits: lmac-recover gets c5.2 + c5.2.1 as 0001+0002; cw1200-fix-backports gets F3+F2+F1 as 0001-0003; factory-series gets request_firmware + STANDARD_FACTORY_EFUSE_FLAG as 0001+0002). fleet/ohm.yaml apply order matches cleanups commit chronology, which is what produced the working c5x interim. cumulative.patch from ka-promote ohm now has 32 resolved patches (29 cleanups + 1 Patch H + scan-filter-5ghz + xor-neon SCS + besser#18-fix), 276 079 bytes, b2sum 7418db5ddf8fe938b130bc9d0e9f7dc9060f3a13703cd50757835ac43140a13... Apply order in cleanups + bh-c-fossil-cleanup: 1 factory-series (c1 + factory-no-efuse-flag) 3 factory-thread-dev 4 pm-gate-on-handshake 5 remove-chardev-user-interface 6 enable-testmode 7 tx-sdio-dma-oob-danctnix (was 'staging-prep-series') 8 factory-drop-kernel-write-danctnix 9 drop-dpd-file-paths-danctnix 10 drop-orphan-file-io-danctnix 11 pm-timeout-silence-danctnix 12 scan-defer-on-reject-danctnix (c5.1) 13 scan-defer-backoff-tune-danctnix (c5.1.1) 14 lmac-recover-via-mmc-hw-reset-danctnix (c5.2 + c5.2.1) 16 pm-state-resync-danctnix (c6.1) 17 pm-wake-consume-state-danctnix (c6.2) 18 pm-detect-firmware-unsupported-danctnix (c7) 19 decrypt-storm-fast-recover-danctnix (Patch A) 20 connection-loss-fast-recover-danctnix (Patch B) 21 cw1200-fix-backports-danctnix (Patches F3 + F2 + F1) 24 sdio-rx-no-relay-danctnix (Patch C v3) 25 license-spdx-restore-attribution-danctnix (Patch G) 26 ba-lock-atomic-danctnix (Patch D) 27 ps-state-lock-skip-pm-disabled-danctnix (Patch E) 28 rx-list-batch-delivery-danctnix (Patch C2) 29 bh-c-fossil-cleanup-danctnix (Patch H) 30 scan-filter-5ghz-danctnix (besser#1) 31 arch/arm64/xor-neon-... (GCC 15 SCS) 32 queue-pending-record-lock-bh-danctnix (besser#18) Verification: pkgrel=6 build from this manifest in progress; if srcversion == 26B0003FE9F2B05DCE838C4 (pkgrel=5's), source-tree is byte-equivalent to the c5x interim + scan-filter + besser#18 stack that's currently running on ohm. Refs: #17 (the broken mirror), #28 (the interim PR that landed cumulative-c5x), #31 (ka-promote trailer normalisation followup).
110 lines
4.8 KiB
Diff
110 lines
4.8 KiB
Diff
From 8fc1bacdeda64feb751433ee827dc9647e23bee4 Mon Sep 17 00:00:00 2001
|
|
From: Markus Fritsche <fritsche.markus@gmail.com>
|
|
Date: Tue, 28 Apr 2026 14:32:18 +0200
|
|
Subject: [PATCH 14/29] bes2600: widen scan-defer backoff to 30s and decay
|
|
count on quiet
|
|
|
|
The scan-defer logic added in the previous patch ("bes2600: defer
|
|
scan and soften WARN on firmware reject") used a 10-second backoff
|
|
window and never cleared reject_count outside of a successful scan.
|
|
Field testing on a PineTab2 (linux-pinetab2 6.19.10-danctnix1) shows
|
|
two distinct mac80211 scan-retry cadences in practice:
|
|
|
|
* Idle background scans every ~5 minutes when associated -- well
|
|
outside any plausible backoff, the defer guard correctly falls
|
|
through to a real WSM scan attempt.
|
|
|
|
* Roam-evaluation bursts triggered when mac80211 wants to find a
|
|
candidate AP for handover (signal degradation, beacon loss,
|
|
locally-generated DEAUTH_LEAVING reason=3). Cadence is ~12 s, and
|
|
one boot reproduced 14 such rejected scans in 3 minutes during a
|
|
single burst, none of which engaged the defer guard because every
|
|
retry landed just outside the 10 s window.
|
|
|
|
Two-line behaviour change to fix that:
|
|
|
|
1. BES2600_SCAN_BACKOFF_JIFFIES grows from 10*HZ to 30*HZ, so a
|
|
12 s-cadence burst stays inside the window across consecutive
|
|
rejects and the third reject in the burst trips the threshold
|
|
guard. The 5 min idle case is still naturally past the window
|
|
and is unaffected.
|
|
|
|
2. bes2600_scan_should_defer() resets reject_count to 0 when
|
|
time_after(jiffies, backoff_until). Without this, reject_count
|
|
accumulated indefinitely across the slow-cadence rejects, so an
|
|
isolated reject after long quiet would have tripped the
|
|
threshold the moment it arrived. After the change, count is
|
|
latched only inside an active burst and decays cleanly when the
|
|
burst ends.
|
|
|
|
Net effect on a roam burst:
|
|
|
|
* t=0 reject #1 (count 1, backoff_until = t0 + 30s)
|
|
* t=12 reject #2 (count 2, backoff_until = t1 + 30s)
|
|
* t=24 reject #3 (count 3, threshold met, next scan deferred)
|
|
* t=36 defer fires, no WSM round-trip, reject not sent
|
|
* ... defers continue until the firmware-policy state clears
|
|
* scan succeeds -> reject_count = 0, normal cadence resumes
|
|
|
|
WSM 0x0007 confirm rejections in a burst drop from ~14 to ~3 (just
|
|
the scans needed to reach the threshold). wpa_supplicant's reason=3
|
|
locally-generated disconnects driven by exhausted roam candidates
|
|
during the same burst window also drop.
|
|
|
|
No new state, no new symbols, no change to mac80211-facing semantics:
|
|
the deferred scan still completes via the existing fail: path with
|
|
status=-EBUSY, the same response a real firmware-busy would produce.
|
|
|
|
Signed-off-by: Markus Fritsche <fritsche.markus@gmail.com>
|
|
---
|
|
bes2600/scan.c | 17 +++++++++++++++--
|
|
1 file changed, 15 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/drivers/staging/bes2600/scan.c b/drivers/staging/bes2600/scan.c
|
|
index faa1c90..ad5033b 100644
|
|
--- a/drivers/staging/bes2600/scan.c
|
|
+++ b/drivers/staging/bes2600/scan.c
|
|
@@ -22,9 +22,17 @@
|
|
* After this many consecutive WSM scan rejections from firmware, stop
|
|
* issuing new scans for BES2600_SCAN_BACKOFF_JIFFIES and let the state
|
|
* that's rejecting them (coex window, firmware-internal busy) clear.
|
|
+ *
|
|
+ * The backoff has to be at least as long as the natural mac80211 scan-
|
|
+ * retry cadence, otherwise the next attempt lands outside the window
|
|
+ * and bypasses the defer guard. Observed in the wild on PineTab2:
|
|
+ * roam-evaluation bursts at ~12 s cadence, idle background scans at
|
|
+ * ~5 min cadence. 30 s catches the burst and leaves the slow case
|
|
+ * alone (the firmware-policy state has had minutes to clear by then
|
|
+ * anyway).
|
|
*/
|
|
#define BES2600_SCAN_REJECT_THRESHOLD 3
|
|
-#define BES2600_SCAN_BACKOFF_JIFFIES (10 * HZ)
|
|
+#define BES2600_SCAN_BACKOFF_JIFFIES (30 * HZ)
|
|
|
|
static void bes2600_scan_restart_delayed(struct bes2600_vif *priv);
|
|
|
|
@@ -40,7 +48,9 @@ static void bes2600_scan_restart_delayed(struct bes2600_vif *priv);
|
|
* 2. We already saw >= BES2600_SCAN_REJECT_THRESHOLD consecutive
|
|
* rejections on recent scan attempts and the backoff window has
|
|
* not yet elapsed. Whatever was rejecting them is likely still
|
|
- * rejecting them; give it time.
|
|
+ * rejecting them; give it time. If the backoff has elapsed without
|
|
+ * a fresh reject refreshing it, the burst is over and we reset the
|
|
+ * count so an isolated reject doesn't immediately re-trip.
|
|
*
|
|
* Returns true if the caller should abandon the scan iteration.
|
|
*/
|
|
@@ -51,6 +61,9 @@ static bool bes2600_scan_should_defer(struct bes2600_common *hw_priv)
|
|
return true;
|
|
#endif
|
|
|
|
+ if (time_after(jiffies, hw_priv->scan.backoff_until))
|
|
+ hw_priv->scan.reject_count = 0;
|
|
+
|
|
if (hw_priv->scan.reject_count >= BES2600_SCAN_REJECT_THRESHOLD &&
|
|
time_before(jiffies, hw_priv->scan.backoff_until))
|
|
return true;
|
|
--
|
|
2.54.0
|
|
|