From nobody Sat Nov 30 10:41:21 2024 Received: from inva021.nxp.com (inva021.nxp.com [92.121.34.21]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4D4A3181B8D; Tue, 10 Sep 2024 07:41:15 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=92.121.34.21 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954077; cv=none; b=DCIwbJw3nEHKSJeKxPAkOAkGSJo48Ms34T0jEqVcouuAgyMm6F+J8v6/5qTNdcB2E5Bgj1reJ+MvYXxGA578xllNs9tWg+YQwOVNtFiSqd9wglG6JbjsDq533I1JkejVtEL67egzftl3+AH42LYr6Qp6zI2zTh073o6C8QDV86Q= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954077; c=relaxed/simple; bh=VNbk77Jl2DJV3hPeoRb+VZz9WjfY9QgerFt2bTeBD+c=; h=From:To:Subject:Date:Message-Id:In-Reply-To:References; b=YjZUpReXvZGPtCJEL9ZWdwqh3joSM0bh3MFt6Ub3mkyIje53D+5BOm38aI6Y/DAGvQDQzU2yLFmWen093c55Z8MaxS/H3lPtcf3k3jdKTPBaDypsyIITtFBF1PYeT0iKF/5vhI392zJhso+LETMYS90uHFIeik0LcdFYgC9xAfE= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com; spf=pass smtp.mailfrom=nxp.com; arc=none smtp.client-ip=92.121.34.21 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=nxp.com Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 232D3200D45; Tue, 10 Sep 2024 09:41:08 +0200 (CEST) Received: from aprdc01srsp001v.ap-rdc01.nxp.com (aprdc01srsp001v.ap-rdc01.nxp.com [165.114.16.16]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id DD4FC201765; Tue, 10 Sep 2024 09:41:07 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by aprdc01srsp001v.ap-rdc01.nxp.com (Postfix) with ESMTP id 475B51834898; Tue, 10 Sep 2024 15:41:06 +0800 (+08) From: Shengjiu Wang To: robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, devicetree@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, shengjiu.wang@gmail.com Subject: [PATCH 1/3] arm64: dts: imx93-9x9-qsb: Enable sound-wm8962 sound card Date: Tue, 10 Sep 2024 15:19:30 +0800 Message-Id: <1725952772-30357-2-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> References: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Add wm8962 sound card which connects to sai3. The connection of SAI3 and wm8962 is controlled by PCAL6524HEAZ module, add gpio-hog for it. Signed-off-by: Shengjiu Wang --- .../boot/dts/freescale/imx93-9x9-qsb.dts | 74 +++++++++++++++++++ 1 file changed, 74 insertions(+) diff --git a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts b/arch/arm64/b= oot/dts/freescale/imx93-9x9-qsb.dts index f8a73612fa05..336333919a74 100644 --- a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts +++ b/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts @@ -61,6 +61,15 @@ vdevbuffer: vdevbuffer@a4020000 { =20 }; =20 + reg_audio_pwr: regulator-audio-pwr { + compatible =3D "regulator-fixed"; + regulator-name =3D "audio-pwr"; + regulator-min-microvolt =3D <3300000>; + regulator-max-microvolt =3D <3300000>; + gpio =3D <&pcal6524 16 GPIO_ACTIVE_HIGH>; + enable-active-high; + }; + reg_vref_1v8: regulator-adc-vref { compatible =3D "regulator-fixed"; regulator-name =3D "VREF_1V8"; @@ -88,6 +97,22 @@ reg_usdhc2_vmmc: regulator-usdhc2 { enable-active-high; off-on-delay-us =3D <12000>; }; + + sound-wm8962 { + compatible =3D "fsl,imx-audio-wm8962"; + model =3D "wm8962-audio"; + audio-cpu =3D <&sai3>; + audio-codec =3D <&wm8962>; + hp-det-gpio =3D <&pcal6524 4 GPIO_ACTIVE_HIGH>; + audio-routing =3D + "Headphone Jack", "HPOUTL", + "Headphone Jack", "HPOUTR", + "Ext Spk", "SPKOUTL", + "Ext Spk", "SPKOUTR", + "AMIC", "MICBIAS", + "IN3R", "AMIC", + "IN1R", "AMIC"; + }; }; =20 &adc1 { @@ -136,6 +161,28 @@ &lpi2c1 { pinctrl-0 =3D <&pinctrl_lpi2c1>; status =3D "okay"; =20 + wm8962: codec@1a { + compatible =3D "wlf,wm8962"; + reg =3D <0x1a>; + clocks =3D <&clk IMX93_CLK_SAI3_GATE>; + DCVDD-supply =3D <®_audio_pwr>; + DBVDD-supply =3D <®_audio_pwr>; + AVDD-supply =3D <®_audio_pwr>; + CPVDD-supply =3D <®_audio_pwr>; + MICVDD-supply =3D <®_audio_pwr>; + PLLVDD-supply =3D <®_audio_pwr>; + SPKVDD1-supply =3D <®_audio_pwr>; + SPKVDD2-supply =3D <®_audio_pwr>; + gpio-cfg =3D < + 0x0000 /* 0:Default */ + 0x0000 /* 1:Default */ + 0x0000 /* 2:FN_DMICCLK */ + 0x0000 /* 3:Default */ + 0x0000 /* 4:FN_DMICCDAT */ + 0x0000 /* 5:Default */ + >; + }; + ptn5110: tcpc@50 { compatible =3D "nxp,ptn5110", "tcpci"; reg =3D <0x50>; @@ -194,6 +241,12 @@ pcal6524: gpio@22 { interrupts =3D <26 IRQ_TYPE_LEVEL_LOW>; pinctrl-names =3D "default"; pinctrl-0 =3D <&pinctrl_pcal6524>; + + exp-sel-hog { + gpio-hog; + gpios =3D <22 GPIO_ACTIVE_HIGH>; + output-low; + }; }; =20 pmic@25 { @@ -286,6 +339,17 @@ &mu2 { status =3D "okay"; }; =20 +&sai3 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pinctrl_sai3>; + assigned-clocks =3D <&clk IMX93_CLK_SAI3>; + assigned-clock-parents =3D <&clk IMX93_CLK_AUDIO_PLL>; + assigned-clock-rates =3D <12288000>; + fsl,sai-mclk-direction-output; + fsl,sai-synchronous-rx; + status =3D "okay"; +}; + &usbotg1 { dr_mode =3D "otg"; hnp-disable; @@ -443,6 +507,16 @@ MX93_PAD_SD2_RESET_B__GPIO3_IO07 0x31e >; }; =20 + pinctrl_sai3: sai3grp { + fsl,pins =3D < + MX93_PAD_GPIO_IO12__SAI3_RX_SYNC 0x31e + MX93_PAD_GPIO_IO18__SAI3_RX_BCLK 0x31e + MX93_PAD_GPIO_IO17__SAI3_MCLK 0x31e + MX93_PAD_GPIO_IO19__SAI3_TX_DATA00 0x31e + MX93_PAD_GPIO_IO20__SAI3_RX_DATA00 0x31e + >; + }; + pinctrl_usdhc2_gpio: usdhc2gpiogrp { fsl,pins =3D < MX93_PAD_SD2_CD_B__GPIO3_IO00 0x31e --=20 2.34.1 From nobody Sat Nov 30 10:41:21 2024 Received: from inva021.nxp.com (inva021.nxp.com [92.121.34.21]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 24164183CB4; Tue, 10 Sep 2024 07:41:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=92.121.34.21 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954077; cv=none; b=hH9ckODX/sU6KwIpRuyc8D1zfVFkObiNEM9EgY5aTdP9RXbobXHZ8UJTlG/Wv+5LfCKPI9Bg3cQN2TKGjZZXo5gmUp6RSM1BAJHXHVTUyHHJunsVViAz9Jqnl9BIqj42Oyh1XHqWXorc40rtVbaV+OxKOsgsoVvce/AmuQ9Nz/k= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954077; c=relaxed/simple; bh=Et+UfQRgT99VcIYLJ72g03+QVLpFGHXwdlZAl6ZKtqE=; h=From:To:Subject:Date:Message-Id:In-Reply-To:References; b=RydT7Zo/TWyZTokM7t6tHNJ7tns9wh1RnKZKnfOmBOAOpNZ67u6YeGB7nl8gYgwG6vno1qRRU/S2gwuGaJfMnfgwf3zO9sJNX3PaeBqyMpKndFA2Df7DXYhTx8WQvdWEMO2pAl8ibsYRD3NhpTIwzP7CBkXpsrdu6TSRwHHXh3M= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com; spf=pass smtp.mailfrom=nxp.com; arc=none smtp.client-ip=92.121.34.21 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=nxp.com Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id D90C6200D62; Tue, 10 Sep 2024 09:41:08 +0200 (CEST) Received: from aprdc01srsp001v.ap-rdc01.nxp.com (aprdc01srsp001v.ap-rdc01.nxp.com [165.114.16.16]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 9FA85200D4D; Tue, 10 Sep 2024 09:41:08 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by aprdc01srsp001v.ap-rdc01.nxp.com (Postfix) with ESMTP id 633F91834890; Tue, 10 Sep 2024 15:41:07 +0800 (+08) From: Shengjiu Wang To: robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, devicetree@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, shengjiu.wang@gmail.com Subject: [PATCH 2/3] arm64: dts: imx93-9x9-qsb: add bt-sco sound card support Date: Tue, 10 Sep 2024 15:19:31 +0800 Message-Id: <1725952772-30357-3-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> References: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Add bt-sco sound card, which is used by BT HFP case. It supports wb profile as default Signed-off-by: Shengjiu Wang --- .../boot/dts/freescale/imx93-9x9-qsb.dts | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts b/arch/arm64/b= oot/dts/freescale/imx93-9x9-qsb.dts index 336333919a74..d213a5343803 100644 --- a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts +++ b/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts @@ -98,6 +98,30 @@ reg_usdhc2_vmmc: regulator-usdhc2 { off-on-delay-us =3D <12000>; }; =20 + bt_sco_codec: bt_sco_codec { + #sound-dai-cells =3D <1>; + compatible =3D "linux,bt-sco"; + }; + + sound-bt-sco { + compatible =3D "simple-audio-card"; + simple-audio-card,name =3D "bt-sco-audio"; + simple-audio-card,format =3D "dsp_a"; + simple-audio-card,bitclock-inversion; + simple-audio-card,frame-master =3D <&btcpu>; + simple-audio-card,bitclock-master =3D <&btcpu>; + + btcpu: simple-audio-card,cpu { + sound-dai =3D <&sai1>; + dai-tdm-slot-num =3D <2>; + dai-tdm-slot-width =3D <16>; + }; + + simple-audio-card,codec { + sound-dai =3D <&bt_sco_codec 1>; + }; + }; + sound-wm8962 { compatible =3D "fsl,imx-audio-wm8962"; model =3D "wm8962-audio"; @@ -339,6 +363,16 @@ &mu2 { status =3D "okay"; }; =20 +&sai1 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pinctrl_sai1>; + assigned-clocks =3D <&clk IMX93_CLK_SAI1>; + assigned-clock-parents =3D <&clk IMX93_CLK_AUDIO_PLL>; + assigned-clock-rates =3D <12288000>; + fsl,sai-mclk-direction-output; + status =3D "okay"; +}; + &sai3 { pinctrl-names =3D "default"; pinctrl-0 =3D <&pinctrl_sai3>; @@ -507,6 +541,15 @@ MX93_PAD_SD2_RESET_B__GPIO3_IO07 0x31e >; }; =20 + pinctrl_sai1: sai1grp { + fsl,pins =3D < + MX93_PAD_SAI1_TXC__SAI1_TX_BCLK 0x31e + MX93_PAD_SAI1_TXFS__SAI1_TX_SYNC 0x31e + MX93_PAD_SAI1_TXD0__SAI1_TX_DATA00 0x31e + MX93_PAD_SAI1_RXD0__SAI1_RX_DATA00 0x31e + >; + }; + pinctrl_sai3: sai3grp { fsl,pins =3D < MX93_PAD_GPIO_IO12__SAI3_RX_SYNC 0x31e --=20 2.34.1 From nobody Sat Nov 30 10:41:21 2024 Received: from inva021.nxp.com (inva021.nxp.com [92.121.34.21]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 38754184545; Tue, 10 Sep 2024 07:41:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=92.121.34.21 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954078; cv=none; b=QBW7KP2JzdhPs20wInaK/IX8x5Bewun//X6t1hd+zy1j0IQ/5s51l6/edHXB0tiF3FvwGhBYyTX4PjYfjL1boNh2f3rB+Y55zlJfQmL3ym79v1Enh9sR1n8naQkOWGuGvYyLNI0HABPhhEGLDewJMiNf2l0fLJU/tkhOPyNXzvY= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725954078; c=relaxed/simple; bh=8uO+euh4dZ2JsdT0ibbqmLE0P4Hx3ZTvP4vIhWtm14Y=; h=From:To:Subject:Date:Message-Id:In-Reply-To:References; b=WYtLeeghPuzCXgHOkL0OyB7BjC3oBLlIpIEdwvsg8cCP1GISwwQf3XUgpOuu1k9pZ6wGe8f+PLxiDa3WybGiLU56fBXKbL5AH3Eds/T0NAPd5JlDfWb8hXxHMjIhg41lOo7/bK2FMCe+t08Am081DqMukQouWhVVmLzFen1GHgg= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com; spf=pass smtp.mailfrom=nxp.com; arc=none smtp.client-ip=92.121.34.21 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=nxp.com Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 5A90F200633; Tue, 10 Sep 2024 09:41:10 +0200 (CEST) Received: from aprdc01srsp001v.ap-rdc01.nxp.com (aprdc01srsp001v.ap-rdc01.nxp.com [165.114.16.16]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 202E7200649; Tue, 10 Sep 2024 09:41:10 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by aprdc01srsp001v.ap-rdc01.nxp.com (Postfix) with ESMTP id 7F089180031E; Tue, 10 Sep 2024 15:41:08 +0800 (+08) From: Shengjiu Wang To: robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, devicetree@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, shengjiu.wang@gmail.com Subject: [PATCH 3/3] arm64: dts: imx93-9x9-qsb: Add PDM microphone sound card support Date: Tue, 10 Sep 2024 15:19:32 +0800 Message-Id: <1725952772-30357-4-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> References: <1725952772-30357-1-git-send-email-shengjiu.wang@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Add PDM micphone sound card support, configure the pinmux. This sound card supports recording sound from PDM microphone and convert the PDM format data to PCM data. Signed-off-by: Shengjiu Wang --- .../boot/dts/freescale/imx93-9x9-qsb.dts | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts b/arch/arm64/b= oot/dts/freescale/imx93-9x9-qsb.dts index d213a5343803..1340f5462d11 100644 --- a/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts +++ b/arch/arm64/boot/dts/freescale/imx93-9x9-qsb.dts @@ -122,6 +122,18 @@ simple-audio-card,codec { }; }; =20 + sound-micfil { + compatible =3D "fsl,imx-audio-card"; + model =3D "micfil-audio"; + pri-dai-link { + link-name =3D "micfil hifi"; + format =3D "i2s"; + cpu { + sound-dai =3D <&micfil>; + }; + }; + }; + sound-wm8962 { compatible =3D "fsl,imx-audio-wm8962"; model =3D "wm8962-audio"; @@ -266,6 +278,12 @@ pcal6524: gpio@22 { pinctrl-names =3D "default"; pinctrl-0 =3D <&pinctrl_pcal6524>; =20 + mic-can-sel-hog { + gpio-hog; + gpios =3D <17 GPIO_ACTIVE_HIGH>; + output-low; + }; + exp-sel-hog { gpio-hog; gpios =3D <22 GPIO_ACTIVE_HIGH>; @@ -355,6 +373,15 @@ &lpuart1 { /* console */ status =3D "okay"; }; =20 +&micfil { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pinctrl_pdm>; + assigned-clocks =3D <&clk IMX93_CLK_PDM>; + assigned-clock-parents =3D <&clk IMX93_CLK_AUDIO_PLL>; + assigned-clock-rates =3D <49152000>; + status =3D "okay"; +}; + &mu1 { status =3D "okay"; }; @@ -535,6 +562,14 @@ MX93_PAD_SD1_STROBE__USDHC1_STROBE 0x15fe >; }; =20 + pinctrl_pdm: pdmgrp { + fsl,pins =3D < + MX93_PAD_PDM_CLK__PDM_CLK 0x31e + MX93_PAD_PDM_BIT_STREAM0__PDM_BIT_STREAM00 0x31e + MX93_PAD_PDM_BIT_STREAM1__PDM_BIT_STREAM01 0x31e + >; + }; + pinctrl_reg_usdhc2_vmmc: regusdhc2vmmcgrp { fsl,pins =3D < MX93_PAD_SD2_RESET_B__GPIO3_IO07 0x31e --=20 2.34.1