Linux Sound subsystem development
 help / color / mirror / Atom feed
* Re: [PATCH v5 01/35] ASoC: Intel: avs: Include CPUID header at file scope
       [not found] ` <20250905121515.192792-2-darwi@linutronix.de>
@ 2025-10-16 10:57   ` Borislav Petkov
  2025-10-16 19:21     ` Ahmed S. Darwish
  0 siblings, 1 reply; 3+ messages in thread
From: Borislav Petkov @ 2025-10-16 10:57 UTC (permalink / raw)
  To: Ahmed S. Darwish, Cezary Rojewski
  Cc: Ingo Molnar, Dave Hansen, Thomas Gleixner, Andrew Cooper,
	Sean Christopherson, David Woodhouse, H. Peter Anvin,
	Peter Zijlstra, Sohil Mehta, John Ogness, x86, x86-cpuid, LKML,
	linux-sound

On Fri, Sep 05, 2025 at 02:14:41PM +0200, Ahmed S. Darwish wrote:
> +#ifdef CONFIG_X86
> +#include <asm/cpuid/api.h>
> +static unsigned int intel_crystal_freq_hz(void)
> +{
> +	return cpuid_ecx(CPUID_LEAF_TSC);
> +}
> +#else
> +static unsigned int intel_crystal_freq_hz(void)
> +{
> +	return 0;
> +}
> +#endif /* !CONFIG_X86 */

Why are we even bothering with !CONFIG_X86?

Because this thing has || COMPILE_TEST in Kconfig.

But this thing gets enough compile testing on x86 already so why not simply
drop the whole unnecessary gunk?

---

diff --git a/sound/soc/intel/Kconfig b/sound/soc/intel/Kconfig
index 412555e626b8..63367364916a 100644
--- a/sound/soc/intel/Kconfig
+++ b/sound/soc/intel/Kconfig
@@ -95,7 +95,7 @@ config SND_SOC_INTEL_KEEMBAY
 
 config SND_SOC_INTEL_AVS
 	tristate "Intel AVS driver"
-	depends on X86 || COMPILE_TEST
+	depends on X86
 	depends on PCI
 	depends on COMMON_CLK
 	select ACPI_NHLT if ACPI
diff --git a/sound/soc/intel/avs/tgl.c b/sound/soc/intel/avs/tgl.c
index afb066516101..d920488d24b1 100644
--- a/sound/soc/intel/avs/tgl.c
+++ b/sound/soc/intel/avs/tgl.c
@@ -11,7 +11,7 @@
 #include "debug.h"
 #include "messages.h"
 
-#define CPUID_TSC_LEAF 0x15
+#include <asm/cpuid/api.h>
 
 static int avs_tgl_dsp_core_power(struct avs_dev *adev, u32 core_mask, bool power)
 {
@@ -44,18 +44,15 @@ static int avs_tgl_config_basefw(struct avs_dev *adev)
 {
 	struct pci_dev *pci = adev->base.pci;
 	struct avs_bus_hwid hwid;
+	unsigned int freq;
 	int ret;
-#ifdef CONFIG_X86
-	unsigned int ecx;
 
-#include <asm/cpuid/api.h>
-	ecx = cpuid_ecx(CPUID_TSC_LEAF);
-	if (ecx) {
-		ret = avs_ipc_set_fw_config(adev, 1, AVS_FW_CFG_XTAL_FREQ_HZ, sizeof(ecx), &ecx);
+	freq = cpuid_ecx(CPUID_LEAF_TSC);
+	if (freq) {
+		ret = avs_ipc_set_fw_config(adev, 1, AVS_FW_CFG_XTAL_FREQ_HZ, sizeof(freq), &freq);
 		if (ret)
 			return AVS_IPC_RET(ret);
 	}
-#endif
 
 	hwid.device = pci->device;
 	hwid.subsystem = pci->subsystem_vendor | (pci->subsystem_device << 16);

-- 
Regards/Gruss,
    Boris.

https://people.kernel.org/tglx/notes-about-netiquette

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH v5 01/35] ASoC: Intel: avs: Include CPUID header at file scope
  2025-10-16 10:57   ` [PATCH v5 01/35] ASoC: Intel: avs: Include CPUID header at file scope Borislav Petkov
@ 2025-10-16 19:21     ` Ahmed S. Darwish
  2026-03-20 12:39       ` Borislav Petkov
  0 siblings, 1 reply; 3+ messages in thread
From: Ahmed S. Darwish @ 2025-10-16 19:21 UTC (permalink / raw)
  To: Borislav Petkov
  Cc: Cezary Rojewski, Ingo Molnar, Dave Hansen, Thomas Gleixner,
	Andrew Cooper, Sean Christopherson, David Woodhouse,
	H. Peter Anvin, Peter Zijlstra, Sohil Mehta, John Ogness, x86,
	x86-cpuid, LKML, linux-sound

On Thu, 16 Oct 2025, Borislav Petkov wrote:
>
> Why are we even bothering with !CONFIG_X86?
>
> Because this thing has || COMPILE_TEST in Kconfig.
>
> But this thing gets enough compile testing on x86 already so why not
> simply drop the whole unnecessary gunk?
>

Makes sense; will do.

Thanks!
Ahmed

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH v5 01/35] ASoC: Intel: avs: Include CPUID header at file scope
  2025-10-16 19:21     ` Ahmed S. Darwish
@ 2026-03-20 12:39       ` Borislav Petkov
  0 siblings, 0 replies; 3+ messages in thread
From: Borislav Petkov @ 2026-03-20 12:39 UTC (permalink / raw)
  To: Ahmed S. Darwish
  Cc: Cezary Rojewski, Ingo Molnar, Dave Hansen, Thomas Gleixner,
	Andrew Cooper, Sean Christopherson, David Woodhouse,
	H. Peter Anvin, Peter Zijlstra, Sohil Mehta, John Ogness, x86,
	x86-cpuid, LKML, linux-sound

On Thu, Oct 16, 2025 at 09:21:26PM +0200, Ahmed S. Darwish wrote:
> On Thu, 16 Oct 2025, Borislav Petkov wrote:
> >
> > Why are we even bothering with !CONFIG_X86?
> >
> > Because this thing has || COMPILE_TEST in Kconfig.
> >
> > But this thing gets enough compile testing on x86 already so why not
> > simply drop the whole unnecessary gunk?
> >
> 
> Makes sense; will do.

I'll queue the below soon, if no one complains:

---

From 65453ddafe5d7cf715266f7d32356c42965f2f86 Mon Sep 17 00:00:00 2001
From: "Ahmed S. Darwish" <darwi@linutronix.de>
Date: Fri, 5 Sep 2025 14:14:41 +0200
Subject: [PATCH] ASoC: Intel: avs: Include CPUID header at file scope

Commit

    cbe37a4d2b3c ("ASoC: Intel: avs: Configure basefw on TGL-based platforms")

includes the main CPUID header from within a C function.  This works by
sheer luck and forbids further refactoring inside the CPUID header.

Include the CPUID header at file scope instead.

Note, for the CPUID(0x15) leaf number, use CPUID_LEAF_TSC instead of
defining a custom local macro for it.

  [ bp: Massage, zap the CONFIG_X86 ifdeffery and dependency on
    COMPILE_TEST because this driver gets enough compile testing on x86
    alone already. ]

Signed-off-by: Ahmed S. Darwish <darwi@linutronix.de>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Link: https://patch.msgid.link/20250905121515.192792-2-darwi@linutronix.de
---
 sound/soc/intel/Kconfig   |  2 +-
 sound/soc/intel/avs/tgl.c | 18 ++++++------------
 2 files changed, 7 insertions(+), 13 deletions(-)

diff --git a/sound/soc/intel/Kconfig b/sound/soc/intel/Kconfig
index 412555e626b8..63367364916a 100644
--- a/sound/soc/intel/Kconfig
+++ b/sound/soc/intel/Kconfig
@@ -95,7 +95,7 @@ config SND_SOC_INTEL_KEEMBAY
 
 config SND_SOC_INTEL_AVS
 	tristate "Intel AVS driver"
-	depends on X86 || COMPILE_TEST
+	depends on X86
 	depends on PCI
 	depends on COMMON_CLK
 	select ACPI_NHLT if ACPI
diff --git a/sound/soc/intel/avs/tgl.c b/sound/soc/intel/avs/tgl.c
index afb066516101..ba4831f4de5a 100644
--- a/sound/soc/intel/avs/tgl.c
+++ b/sound/soc/intel/avs/tgl.c
@@ -7,12 +7,12 @@
 //
 
 #include <linux/pci.h>
+#include <asm/cpuid/api.h>
+
 #include "avs.h"
 #include "debug.h"
 #include "messages.h"
 
-#define CPUID_TSC_LEAF 0x15
-
 static int avs_tgl_dsp_core_power(struct avs_dev *adev, u32 core_mask, bool power)
 {
 	core_mask &= AVS_MAIN_CORE_MASK;
@@ -42,20 +42,14 @@ static int avs_tgl_dsp_core_stall(struct avs_dev *adev, u32 core_mask, bool stal
 
 static int avs_tgl_config_basefw(struct avs_dev *adev)
 {
+	unsigned int freq = cpuid_ecx(CPUID_LEAF_TSC);
 	struct pci_dev *pci = adev->base.pci;
 	struct avs_bus_hwid hwid;
 	int ret;
-#ifdef CONFIG_X86
-	unsigned int ecx;
 
-#include <asm/cpuid/api.h>
-	ecx = cpuid_ecx(CPUID_TSC_LEAF);
-	if (ecx) {
-		ret = avs_ipc_set_fw_config(adev, 1, AVS_FW_CFG_XTAL_FREQ_HZ, sizeof(ecx), &ecx);
-		if (ret)
-			return AVS_IPC_RET(ret);
-	}
-#endif
+	ret = avs_ipc_set_fw_config(adev, 1, AVS_FW_CFG_XTAL_FREQ_HZ, sizeof(freq), &freq);
+	if (ret)
+		return AVS_IPC_RET(ret);
 
 	hwid.device = pci->device;
 	hwid.subsystem = pci->subsystem_vendor | (pci->subsystem_device << 16);
-- 
2.51.0

-- 
Regards/Gruss,
    Boris.

https://people.kernel.org/tglx/notes-about-netiquette

^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2026-03-20 12:40 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20250905121515.192792-1-darwi@linutronix.de>
     [not found] ` <20250905121515.192792-2-darwi@linutronix.de>
2025-10-16 10:57   ` [PATCH v5 01/35] ASoC: Intel: avs: Include CPUID header at file scope Borislav Petkov
2025-10-16 19:21     ` Ahmed S. Darwish
2026-03-20 12:39       ` Borislav Petkov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox