On Wed, 2023-06-21 at 13:45 +0800, Evan Quan wrote:Since it's all gated by CONFIG_ACPI_WBRF for each subsystem that it touches,
To support AMD's WBRF interference mitigation mechanism, Wifi adaptersI was going to say this looks good ... but still have a few nits, sorry.
utilized in the system must register the frequencies in use(or unregister
those frequencies no longer used) via the dedicated APCI calls. So that,
other drivers responding to the frequencies can take proper actions to
mitigate possible interference.
To make WBRF feature functional, the kernel needs to be configured with
CONFIG_ACPI_WBRF and the platform is equipped with WBRF support(from
BIOS and drivers).
Signed-off-by: Mario Limonciello <mario.limonciello@xxxxxxx>
Co-developed-by: Evan Quan <evan.quan@xxxxxxx>
Signed-off-by: Evan Quan <evan.quan@xxxxxxx>
But then the next question anyway is how we merge this? The wifi parts
sort of depend on the first patch, although technically I guess I could
merge them since it's all hidden behind the CONFIG_ symbol, assuming you
get that in via some other tree it can combine upstream.
I'd also say you can merge those parts elsewhere but I'm planning to
also land some locking rework that I've been working on, so it will
probably conflict somewhere.
+++ b/net/mac80211/chan.cYou ignore the return value here.
@@ -506,11 +506,16 @@ static void _ieee80211_change_chanctx(struct ieee80211_local *local,
WARN_ON(!cfg80211_chandef_compatible(&ctx->conf.def, chandef));
+ ieee80211_remove_wbrf(local, &ctx->conf.def);
+
ctx->conf.def = *chandef;
/* check if min chanctx also changed */
changed = IEEE80211_CHANCTX_CHANGE_WIDTH |
_ieee80211_recalc_chanctx_min_def(local, ctx, rsvd_for);
+
+ ieee80211_add_wbrf(local, &ctx->conf.def);
@@ -668,6 +673,10 @@ static int ieee80211_add_chanctx(struct ieee80211_local *local,But not here.
lockdep_assert_held(&local->mtx);
lockdep_assert_held(&local->chanctx_mtx);
+ err = ieee80211_add_wbrf(local, &ctx->conf.def);
+ if (err)
+ return err;
In the code, there are basically two error paths:
+int ieee80211_add_wbrf(struct ieee80211_local *local,This really won't fail, just if the bandwidth calculation was bad, but
+ struct cfg80211_chan_def *chandef)
+{
+ struct device *dev = local->hw.wiphy->dev.parent;
+ struct wbrf_ranges_in ranges_in = {0};
+ int ret;
+
+ if (!local->wbrf_supported)
+ return 0;
+
+ ret = wbrf_get_ranges_from_chandef(chandef, &ranges_in);
+ if (ret)
+ return ret;
that's an internal error that WARNs anyway and we can ignore it.
+ return wbrf_add_exclusion(ACPI_COMPANION(dev), &ranges_in);This I find a bit confusing, why do we even propagate the error? If the
platform has some issue with it, should we really fail the connection?
I think it seems better to me to just make this void, and have it be
only a notification interface?
johannes