From nobody Thu Apr 2 22:07:12 2026 Received: from mail-pg1-f174.google.com (mail-pg1-f174.google.com [209.85.215.174]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 65838285C8E for ; Fri, 13 Feb 2026 05:59:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.215.174 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770962372; cv=none; b=k2htOijr6CPvveNc56/wNkKkMCk1FKYV8PHFr43Kzyq+W9MXKkQBjvZ1YO+C0cioqP+O8D5zTsIITB3fKarBKCCjtUF7HeY78rNlxV2Qp45Q9Zmslao4nscRgOb8+KqNfreq8nCI2h7ZczACgaZ6aTGwSNBn40DhntJPqjvzENs= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1770962372; c=relaxed/simple; bh=Grm7vlf6RQceqExtGTxxpWioQmU+kkTizKOoVLFHwzc=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=c1E226q41RbKPwUlgII3c1vhKpsro5jj76bpcHvSX4ymWMBATcJAyYOe6Ikp0VWkAJH/wChuXFsWrkYUz2hksBPwo5wcizVY1UDpKbWPzYvSF8Wu2hCGlDcpLjGnr/nhKWTn47LnnIRm+4D0dxmxLOqTCGAX3wOsZcaQTmjCBQ8= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=ZGx540V1; arc=none smtp.client-ip=209.85.215.174 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="ZGx540V1" Received: by mail-pg1-f174.google.com with SMTP id 41be03b00d2f7-c54f700b5b1so354012a12.0 for ; Thu, 12 Feb 2026 21:59:31 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1770962371; x=1771567171; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=F4+SY/jOs4NZzW456dpFyxP/ymAMo96jsmXjl89V8YI=; b=ZGx540V1tjpm6Lm1TwBbrG6VMYcx+3dwQ+Nen8pM1ROT8hSkCz1QnkwD8uOqYnxXaM fdQ0zFdqpWUYL8SVb5V1m7MFN6+ayFp2jBc/RH4RinTDdTuJ6KRw8tvxZdJ/vZiMQj7i o+lraSKm680JW/uF0RWTxuMRcds61Xezan4kOOzrDRXhhT2zru5IjkY8xnZrStAc/hmS j1VLYOEsfWX4U+/i7dvFcMsOG6WXvoe42cm4dSGQrXPqwkkHHoEAxUK7cBsKYbZHOHgG wuv7qB2btnXcKV3StmHUklMpbfU0ENnFrNAToMXJXp7p8j1xsbAUtBTRK0Yb4/zOnuzc jeIQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1770962371; x=1771567171; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=F4+SY/jOs4NZzW456dpFyxP/ymAMo96jsmXjl89V8YI=; b=xIhiAmRyKgQfTWQ+ZSRAfKYNKhfA0y4Dilej3YfDIS7wj3wkygwlprRTTDCLVI2X6u D7KxWV1GFVU82/3qUvWfh17F3YNCplsx5VZpkrOTOHqpXxMXk+y1oxm3kMgk7cLaJxNf sPeJct/u0bvJys/ZsYsYKw5uin3dOzgl1VFINobWX8dqVD6mqfvV+z/pBiaAtDjQvUbk Ggw3eMFWyBXarWLAeKQEMtgkqeLPBDlpaVuCDod2HI8ilrJdlutpFusTCRPwdvzOzajB 7sdiEhDkUCQAV75mtIhZdgpmEPLaH6fHuFAsLI8Itx6+p66NdjCdhl4oUUqRSAmRgS+N QQPw== X-Forwarded-Encrypted: i=1; AJvYcCUoSbJERxdqsmPAHTk2HnXjiJeegoS12Te3DXQvZAMmwSMGYpgIBYBXYIGSAVnYLCB0k7JtMroErjYK7vM=@vger.kernel.org X-Gm-Message-State: AOJu0Yxl8Ii/d80cR9Dfr3ud8v1tqTqZ9oDNkz5K8touh1ruAJEwg8qr Xx6LFyQGJVT94gHik7CE2hrBXAttpScUbei22gWH7Xexd1RPaDtkpYvP X-Gm-Gg: AZuq6aIgSycc5wd61UWoqOwyZZWOOsTlLNPynhnLZ3TSLHzFQtT585/95+SJtBbM67N o6lptLyoe7NmpUPVO16wjFableHZD65uNa0T3GGdYJbnWjd/NP3/0HnAndwl7pWXWvs6+s1RkMk 0bFrwU3Now1vOxj5xNTqhhwziCqkt/LTvc6sfN22HvPv4p2dMyL3PHQOLIT7U92xf5Ci0ZyMHAP Fgb2QU2WcPHDM2uKb7+lToiSHQSyIgaLxDh2M3iZqG5/3bo95mytIBnCvM0xUpPS4lwTfo12AnB Z35NipKVMG+QCjTkzrjM9MQpHIq6n0x412i0V3ucwwpvWRiErvCnOLaFEMkFMrGp1SntTk/oZ3u oKT0fdjQeN19ek5/YKXwDAdBGrdEKQNdF/HhCF/R4VdWKnLzih/ORvO4x6EK9kl1B/kYv5koW/A == X-Received: by 2002:a05:6300:8049:b0:394:75f8:a01 with SMTP id adf61e73a8af0-39475f80ae2mr19965637.16.1770962370810; Thu, 12 Feb 2026 21:59:30 -0800 (PST) Received: from qby-laptop ([2a13:edc0:18:16f::a]) by smtp.gmail.com with ESMTPSA id 41be03b00d2f7-c6e1ac0e004sm6274588a12.6.2026.02.12.21.59.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Feb 2026 21:59:30 -0800 (PST) From: Mingyou Chen To: vijendar.mukunda@amd.com Cc: broonie@kernel.org, lgirdwood@gmail.com, perex@perex.cz, tiwai@suse.com, mario.limonciello@amd.com, venkataprasad.potturu@amd.com, Sunil-kumar.Dommati@amd.com, linux-sound@vger.kernel.org, linux-kernel@vger.kernel.org, Mingyou Chen Subject: [PATCH v6 2/3] ASoC: Drop RPL driver Date: Fri, 13 Feb 2026 13:59:03 +0800 Message-ID: <20260213055904.110256-3-qby140326@gmail.com> X-Mailer: git-send-email 2.51.2 In-Reply-To: <20260213055904.110256-1-qby140326@gmail.com> References: <20260213055904.110256-1-qby140326@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" The RPL driver is no longer needed because its functionality has been superseded by the YC driver Signed-off-by: Mingyou Chen --- sound/soc/amd/Kconfig | 10 - sound/soc/amd/Makefile | 1 - sound/soc/amd/rpl/Makefile | 5 - sound/soc/amd/rpl/rpl-pci-acp6x.c | 227 ------------------ sound/soc/amd/rpl/rpl_acp6x.h | 36 --- .../soc/amd/rpl/rpl_acp6x_chip_offset_byte.h | 30 --- 6 files changed, 309 deletions(-) delete mode 100644 sound/soc/amd/rpl/Makefile delete mode 100644 sound/soc/amd/rpl/rpl-pci-acp6x.c delete mode 100644 sound/soc/amd/rpl/rpl_acp6x.h delete mode 100644 sound/soc/amd/rpl/rpl_acp6x_chip_offset_byte.h diff --git a/sound/soc/amd/Kconfig b/sound/soc/amd/Kconfig index fd35a03aadcb..a6eecbe12e84 100644 --- a/sound/soc/amd/Kconfig +++ b/sound/soc/amd/Kconfig @@ -124,16 +124,6 @@ config SND_AMD_ACP_CONFIG =20 source "sound/soc/amd/acp/Kconfig" =20 -config SND_SOC_AMD_RPL_ACP6x - tristate "AMD Audio Coprocessor-v6.2 RPL support" - depends on X86 && PCI - help - This option enables Audio Coprocessor i.e. ACP v6.2 support on - AMD RPL platform. By enabling this flag build will be - triggered for ACP PCI driver. - Say m if you have such a device. - If unsure select "N". - config SND_SOC_AMD_ACP63_TOPLEVEL tristate "support for AMD platforms with ACP version >=3D 6.3" default SND_AMD_ACP_CONFIG diff --git a/sound/soc/amd/Makefile b/sound/soc/amd/Makefile index 4f89d962cce2..23b25ff0d800 100644 --- a/sound/soc/amd/Makefile +++ b/sound/soc/amd/Makefile @@ -17,5 +17,4 @@ obj-$(CONFIG_SND_SOC_AMD_ACP5x) +=3D vangogh/ obj-$(CONFIG_SND_SOC_AMD_ACP6x) +=3D yc/ obj-$(CONFIG_SND_AMD_ACP_CONFIG) +=3D acp/ obj-$(CONFIG_SND_AMD_ACP_CONFIG) +=3D snd-acp-config.o -obj-$(CONFIG_SND_SOC_AMD_RPL_ACP6x) +=3D rpl/ obj-$(CONFIG_SND_SOC_AMD_PS) +=3D ps/ diff --git a/sound/soc/amd/rpl/Makefile b/sound/soc/amd/rpl/Makefile deleted file mode 100644 index a3825c5be4e7..000000000000 --- a/sound/soc/amd/rpl/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -# SPDX-License-Identifier: GPL-2.0+ -# RPL platform Support -snd-rpl-pci-acp6x-y :=3D rpl-pci-acp6x.o - -obj-$(CONFIG_SND_SOC_AMD_RPL_ACP6x) +=3D snd-rpl-pci-acp6x.o diff --git a/sound/soc/amd/rpl/rpl-pci-acp6x.c b/sound/soc/amd/rpl/rpl-pci-= acp6x.c deleted file mode 100644 index e3afe9172bdf..000000000000 --- a/sound/soc/amd/rpl/rpl-pci-acp6x.c +++ /dev/null @@ -1,227 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0+ -/* - * AMD RPL ACP PCI Driver - * - * Copyright 2022 Advanced Micro Devices, Inc. - */ - -#include -#include -#include -#include -#include -#include - -#include "rpl_acp6x.h" - -struct rpl_dev_data { - void __iomem *acp6x_base; -}; - -static int rpl_power_on(void __iomem *acp_base) -{ - u32 val; - int timeout; - - val =3D rpl_acp_readl(acp_base + ACP_PGFSM_STATUS); - - if (!val) - return val; - - if ((val & ACP_PGFSM_STATUS_MASK) !=3D ACP_POWER_ON_IN_PROGRESS) - rpl_acp_writel(ACP_PGFSM_CNTL_POWER_ON_MASK, acp_base + ACP_PGFSM_CONTRO= L); - timeout =3D 0; - while (++timeout < 500) { - val =3D rpl_acp_readl(acp_base + ACP_PGFSM_STATUS); - if (!val) - return 0; - udelay(1); - } - return -ETIMEDOUT; -} - -static int rpl_reset(void __iomem *acp_base) -{ - u32 val; - int timeout; - - rpl_acp_writel(1, acp_base + ACP_SOFT_RESET); - timeout =3D 0; - while (++timeout < 500) { - val =3D rpl_acp_readl(acp_base + ACP_SOFT_RESET); - if (val & ACP_SOFT_RESET_SOFTRESET_AUDDONE_MASK) - break; - cpu_relax(); - } - rpl_acp_writel(0, acp_base + ACP_SOFT_RESET); - timeout =3D 0; - while (++timeout < 500) { - val =3D rpl_acp_readl(acp_base + ACP_SOFT_RESET); - if (!val) - return 0; - cpu_relax(); - } - return -ETIMEDOUT; -} - -static int rpl_init(void __iomem *acp_base) -{ - int ret; - - /* power on */ - ret =3D rpl_power_on(acp_base); - if (ret) { - pr_err("ACP power on failed\n"); - return ret; - } - rpl_acp_writel(0x01, acp_base + ACP_CONTROL); - /* Reset */ - ret =3D rpl_reset(acp_base); - if (ret) { - pr_err("ACP reset failed\n"); - return ret; - } - rpl_acp_writel(0x03, acp_base + ACP_CLKMUX_SEL); - return 0; -} - -static int rpl_deinit(void __iomem *acp_base) -{ - int ret; - - /* Reset */ - ret =3D rpl_reset(acp_base); - if (ret) { - pr_err("ACP reset failed\n"); - return ret; - } - rpl_acp_writel(0x00, acp_base + ACP_CLKMUX_SEL); - rpl_acp_writel(0x00, acp_base + ACP_CONTROL); - return 0; -} - -static int snd_rpl_probe(struct pci_dev *pci, - const struct pci_device_id *pci_id) -{ - struct rpl_dev_data *adata; - u32 addr; - int ret; - - /* RPL device check */ - switch (pci->revision) { - case 0x62: - break; - default: - dev_dbg(&pci->dev, "acp6x pci device not found\n"); - return -ENODEV; - } - if (pci_enable_device(pci)) { - dev_err(&pci->dev, "pci_enable_device failed\n"); - return -ENODEV; - } - - ret =3D pci_request_regions(pci, "AMD ACP6x audio"); - if (ret < 0) { - dev_err(&pci->dev, "pci_request_regions failed\n"); - goto disable_pci; - } - - adata =3D devm_kzalloc(&pci->dev, sizeof(struct rpl_dev_data), - GFP_KERNEL); - if (!adata) { - ret =3D -ENOMEM; - goto release_regions; - } - - addr =3D pci_resource_start(pci, 0); - adata->acp6x_base =3D devm_ioremap(&pci->dev, addr, - pci_resource_len(pci, 0)); - if (!adata->acp6x_base) { - ret =3D -ENOMEM; - goto release_regions; - } - pci_set_master(pci); - pci_set_drvdata(pci, adata); - ret =3D rpl_init(adata->acp6x_base); - if (ret) - goto release_regions; - pm_runtime_set_autosuspend_delay(&pci->dev, ACP_SUSPEND_DELAY_MS); - pm_runtime_use_autosuspend(&pci->dev); - pm_runtime_put_noidle(&pci->dev); - pm_runtime_allow(&pci->dev); - - return 0; -release_regions: - pci_release_regions(pci); -disable_pci: - pci_disable_device(pci); - - return ret; -} - -static int snd_rpl_suspend(struct device *dev) -{ - struct rpl_dev_data *adata; - int ret; - - adata =3D dev_get_drvdata(dev); - ret =3D rpl_deinit(adata->acp6x_base); - if (ret) - dev_err(dev, "ACP de-init failed\n"); - return ret; -} - -static int snd_rpl_resume(struct device *dev) -{ - struct rpl_dev_data *adata; - int ret; - - adata =3D dev_get_drvdata(dev); - ret =3D rpl_init(adata->acp6x_base); - if (ret) - dev_err(dev, "ACP init failed\n"); - return ret; -} - -static const struct dev_pm_ops rpl_pm =3D { - RUNTIME_PM_OPS(snd_rpl_suspend, snd_rpl_resume, NULL) - SYSTEM_SLEEP_PM_OPS(snd_rpl_suspend, snd_rpl_resume) -}; - -static void snd_rpl_remove(struct pci_dev *pci) -{ - struct rpl_dev_data *adata; - int ret; - - adata =3D pci_get_drvdata(pci); - ret =3D rpl_deinit(adata->acp6x_base); - if (ret) - dev_err(&pci->dev, "ACP de-init failed\n"); - pm_runtime_forbid(&pci->dev); - pm_runtime_get_noresume(&pci->dev); - pci_release_regions(pci); - pci_disable_device(pci); -} - -static const struct pci_device_id snd_rpl_ids[] =3D { - { PCI_DEVICE(PCI_VENDOR_ID_AMD, ACP_DEVICE_ID), - .class =3D PCI_CLASS_MULTIMEDIA_OTHER << 8, - .class_mask =3D 0xffffff }, - { 0, }, -}; -MODULE_DEVICE_TABLE(pci, snd_rpl_ids); - -static struct pci_driver rpl_acp6x_driver =3D { - .name =3D KBUILD_MODNAME, - .id_table =3D snd_rpl_ids, - .probe =3D snd_rpl_probe, - .remove =3D snd_rpl_remove, - .driver =3D { - .pm =3D pm_ptr(&rpl_pm), - } -}; - -module_pci_driver(rpl_acp6x_driver); - -MODULE_DESCRIPTION("AMD ACP RPL PCI driver"); -MODULE_LICENSE("GPL v2"); diff --git a/sound/soc/amd/rpl/rpl_acp6x.h b/sound/soc/amd/rpl/rpl_acp6x.h deleted file mode 100644 index f5816a33632e..000000000000 --- a/sound/soc/amd/rpl/rpl_acp6x.h +++ /dev/null @@ -1,36 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0+ */ -/* - * AMD ACP Driver - * - * Copyright (C) 2021 Advanced Micro Devices, Inc. All rights reserved. - */ - -#include "rpl_acp6x_chip_offset_byte.h" - -#define ACP_DEVICE_ID 0x15E2 -#define ACP6x_PHY_BASE_ADDRESS 0x1240000 - -#define ACP_SOFT_RESET_SOFTRESET_AUDDONE_MASK 0x00010001 -#define ACP_PGFSM_CNTL_POWER_ON_MASK 1 -#define ACP_PGFSM_CNTL_POWER_OFF_MASK 0 -#define ACP_PGFSM_STATUS_MASK 3 -#define ACP_POWERED_ON 0 -#define ACP_POWER_ON_IN_PROGRESS 1 -#define ACP_POWERED_OFF 2 -#define ACP_POWER_OFF_IN_PROGRESS 3 - -#define DELAY_US 5 -#define ACP_COUNTER 20000 - -/* time in ms for runtime suspend delay */ -#define ACP_SUSPEND_DELAY_MS 2000 - -static inline u32 rpl_acp_readl(void __iomem *base_addr) -{ - return readl(base_addr - ACP6x_PHY_BASE_ADDRESS); -} - -static inline void rpl_acp_writel(u32 val, void __iomem *base_addr) -{ - writel(val, base_addr - ACP6x_PHY_BASE_ADDRESS); -} diff --git a/sound/soc/amd/rpl/rpl_acp6x_chip_offset_byte.h b/sound/soc/amd= /rpl/rpl_acp6x_chip_offset_byte.h deleted file mode 100644 index 456498f5396d..000000000000 --- a/sound/soc/amd/rpl/rpl_acp6x_chip_offset_byte.h +++ /dev/null @@ -1,30 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0+ */ -/* - * AMD ACP 6.2 Register Documentation - * - * Copyright 2022 Advanced Micro Devices, Inc. - */ - -#ifndef _rpl_acp6x_OFFSET_HEADER -#define _rpl_acp6x_OFFSET_HEADER - -/* Registers from ACP_CLKRST block */ -#define ACP_SOFT_RESET 0x1241000 -#define ACP_CONTROL 0x1241004 -#define ACP_STATUS 0x1241008 -#define ACP_DYNAMIC_CG_MASTER_CONTROL 0x1241010 -#define ACP_PGFSM_CONTROL 0x124101C -#define ACP_PGFSM_STATUS 0x1241020 -#define ACP_CLKMUX_SEL 0x1241024 - -/* Registers from ACP_AON block */ -#define ACP_PME_EN 0x1241400 -#define ACP_DEVICE_STATE 0x1241404 -#define AZ_DEVICE_STATE 0x1241408 -#define ACP_PIN_CONFIG 0x1241440 -#define ACP_PAD_PULLUP_CTRL 0x1241444 -#define ACP_PAD_PULLDOWN_CTRL 0x1241448 -#define ACP_PAD_DRIVE_STRENGTH_CTRL 0x124144C -#define ACP_PAD_SCHMEN_CTRL 0x1241450 - -#endif --=20 2.51.2