RE: [V10 1/8] ACPI: Add support for AMD ACPI based Wifi band RFI mitigation feature

From: Quan, Evan
Date: Sun Aug 27 2023 - 22:14:35 EST


[AMD Official Use Only - General]

> -----Original Message-----
> From: Simon Horman <horms@xxxxxxxxxx>
> Sent: Sunday, August 27, 2023 11:43 PM
> To: Quan, Evan <Evan.Quan@xxxxxxx>
> Cc: lenb@xxxxxxxxxx; johannes@xxxxxxxxxxxxxxxx; davem@xxxxxxxxxxxxx;
> edumazet@xxxxxxxxxx; kuba@xxxxxxxxxx; pabeni@xxxxxxxxxx; Deucher,
> Alexander <Alexander.Deucher@xxxxxxx>; rafael@xxxxxxxxxx; Lazar, Lijo
> <Lijo.Lazar@xxxxxxx>; Limonciello, Mario <Mario.Limonciello@xxxxxxx>;
> linux-kernel@xxxxxxxxxxxxxxx; linux-acpi@xxxxxxxxxxxxxxx; amd-
> gfx@xxxxxxxxxxxxxxxxxxxxx; dri-devel@xxxxxxxxxxxxxxxxxxxxx; linux-
> wireless@xxxxxxxxxxxxxxx; netdev@xxxxxxxxxxxxxxx
> Subject: Re: [V10 1/8] ACPI: Add support for AMD ACPI based Wifi band RFI
> mitigation feature
>
> On Fri, Aug 25, 2023 at 04:38:39PM +0800, Evan Quan wrote:
> > Due to electrical and mechanical constraints in certain platform
> > designs there may be likely interference of relatively high-powered
> > harmonics of the (G-)DDR memory clocks with local radio module
> > frequency bands used by Wifi 6/6e/7.
> >
> > To mitigate this, AMD has introduced a mechanism that devices can use
> > to notify active use of particular frequencies so that other devices
> > can make relative internal adjustments as necessary to avoid this resonance.
> >
> > Signed-off-by: Evan Quan <evan.quan@xxxxxxx>
>
> ...
>
> > diff --git a/drivers/acpi/amd_wbrf.c b/drivers/acpi/amd_wbrf.c
>
> ...
>
> > +/**
> > + * acpi_amd_wbrf_add_exclusion - broadcast the frequency band the
> device
> > + * is using
> > + *
> > + * @dev: device pointer
> > + * @in: input structure containing the frequency band the device is
> > +using
> > + *
> > + * Broadcast to other consumers the frequency band the device starts
> > + * to use. Underneath the surface the information is cached into an
> > + * internal buffer first. Then a notification is sent to all those
> > + * registered consumers. So then they can retrieve that buffer to
> > + * know the latest active frequency bands. The benifit with such
> > +design
>
> nit: ./checkpatch.pl --codespell suggests benifit -> benefit.
Thanks, will fix that.

Evan
>
> > + * is for those consumers which have not been registered yet, they
> > +can
> > + * still have a chance to retrieve such information later.
> > + */
> > +int acpi_amd_wbrf_add_exclusion(struct device *dev,
> > + struct wbrf_ranges_in_out *in)
> > +{
> > + struct acpi_device *adev = ACPI_COMPANION(dev);
> > + int ret;
> > +
> > + if (!adev)
> > + return -ENODEV;
> > +
> > + ret = wbrf_record(adev, WBRF_RECORD_ADD, in);
> > + if (ret)
> > + return ret;
> > +
> > + blocking_notifier_call_chain(&wbrf_chain_head,
> > + WBRF_CHANGED,
> > + NULL);
> > +
> > + return 0;
> > +}
> > +EXPORT_SYMBOL_GPL(acpi_amd_wbrf_add_exclusion);
>
> ...