From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-9.8 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH, MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 24E72C4363A for ; Thu, 8 Oct 2020 13:01:40 +0000 (UTC) Received: from merlin.infradead.org (merlin.infradead.org [205.233.59.134]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 9C6142083B for ; Thu, 8 Oct 2020 13:01:39 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="juHjbN7E"; dkim=temperror (0-bit key) header.d=cerno.tech header.i=@cerno.tech header.b="Fqk1S9k2"; dkim=temperror (0-bit key) header.d=messagingengine.com header.i=@messagingengine.com header.b="pSmspXEC" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 9C6142083B Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=cerno.tech Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=merlin.20170209; h=Sender:Content-Type:Cc: List-Subscribe:List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id: In-Reply-To:MIME-Version:References:Message-ID:Subject:To:From:Date:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=Ye/cZrUZ3l5dJsrcy6BylshsCIOpIqwurw879PgL9Vg=; b=juHjbN7Ed8cibL9KVRBym3DqM YrcSJYpE4M4sJp3krYuVqgRF6F9s/cTgFryGR59ztl7Iq7ViAbNKuj808rFlGA1bQNtH5gxNmEv3O 9rl27N27zXIhkGfX8S6VhNMpgtHe6ePeuvwTDuTqrzrjz++b5ZkNSa3zRPh46uvKZFAG5lGTNcKjV WRe9Sb2rXtvfXaM20iqchYIXMdYQOpXVlQXtCkiNOt82N3JtYkXmT6F0NOcPO0qjVCHW/OSkOeF/G JRdyiJZ08RxmaC+QPv8MoymIt/Wd8Co5uM6BYMTpIY77TD94TKupaO6xRb6cEb1501VFCWkXx8AKz dkuWvLo4Q==; Received: from localhost ([::1] helo=merlin.infradead.org) by merlin.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1kQVWY-0006oX-Nd; Thu, 08 Oct 2020 12:59:58 +0000 Received: from wout2-smtp.messagingengine.com ([64.147.123.25]) by merlin.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1kQVWU-0006nL-DF for linux-arm-kernel@lists.infradead.org; Thu, 08 Oct 2020 12:59:55 +0000 Received: from compute6.internal (compute6.nyi.internal [10.202.2.46]) by mailout.west.internal (Postfix) with ESMTP id 6FD17C6B; Thu, 8 Oct 2020 08:59:51 -0400 (EDT) Received: from mailfrontend1 ([10.202.2.162]) by compute6.internal (MEProxy); Thu, 08 Oct 2020 08:59:52 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cerno.tech; h= date:from:to:cc:subject:message-id:references:mime-version :content-type:in-reply-to; s=fm1; bh=3SsMPKFcJD/Vgq1ZIeICUGAqHY3 QhttTAnqlfP7RyEo=; b=Fqk1S9k2s/l/sajXunRqgPJIKUvzM0+fKl4azWAOeB9 8n/4FA3T8/kNQlhLVVMFqhSXkyn0keR3OM9wGTOHukNRg5Equ6M/lp7UsvzRRPmW Hx+NhM+uy4CXQ/7GkjRdDswZLoSaLRHsYP2nAnRUGyJ4Qk6zeAZIZapyzzwcyQar lWYb28TRmpN5qxa6aCoPhcqe0eXs4PVfDrzzmA1gh94/gYak9W2gYf/0FsKaWJRW ytEbpLyBurxebTJjivP3crTFqO32bGYjiDMrT+dh0On7Is5qwgwbHu+blw1bSRwI CBhdr1/iasPbh5IArLhqcqNwrrFkxkcvFOlDOu35E/w== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to:x-me-proxy :x-me-proxy:x-me-sender:x-me-sender:x-sasl-enc; s=fm1; bh=3SsMPK FcJD/Vgq1ZIeICUGAqHY3QhttTAnqlfP7RyEo=; b=pSmspXECnR05lOEEzdcgiE XOWReweTlSOz2/mwzrnPtV4YY8BzDmvPfINh5weULgChuMjPt/EusfXRwmzqqBag mrBq+PDU/w5WCNbc9+YsQ7SkZqjSAEBXLlNky+5YB+a7A3PJDrqAtSan6mdWz6bI tQx7ZhyUKGTPssf8djnleqULbv/WxWnRUJWD1aaejmxudl0BItFKGe5ef/wBYZhw XAujH3m9n7Sa1ioL1rC+OTh1VwXEA6Y9t6mm8mNqbgwZW0f2vibTiX0jUjOTQ572 N+ohHoBuS1jEXWXKgCTbHZ3z8FdUHuNkXXgqq7et3R8lCnroVD3RkugzXZ/G9f2Q == X-ME-Sender: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedujedrgeelgdefvdcutefuodetggdotefrodftvf curfhrohhfihhlvgemucfhrghsthforghilhdpqfgfvfdpuffrtefokffrpgfnqfghnecu uegrihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenuc fjughrpeffhffvuffkfhggtggujgesghdtreertddtvdenucfhrhhomhepofgrgihimhgv ucftihhprghrugcuoehmrgigihhmvgestggvrhhnohdrthgvtghhqeenucggtffrrghtth gvrhhnpeelkeeghefhuddtleejgfeljeffheffgfeijefhgfeufefhtdevteegheeiheeg udenucfkphepledtrdekledrieekrdejieenucevlhhushhtvghrufhiiigvpedtnecurf grrhgrmhepmhgrihhlfhhrohhmpehmrgigihhmvgestggvrhhnohdrthgvtghh X-ME-Proxy: Received: from localhost (lfbn-tou-1-1502-76.w90-89.abo.wanadoo.fr [90.89.68.76]) by mail.messagingengine.com (Postfix) with ESMTPA id B7BE63280060; Thu, 8 Oct 2020 08:59:47 -0400 (EDT) Date: Thu, 8 Oct 2020 14:59:46 +0200 From: Maxime Ripard To: Samuel Holland Subject: Re: [PATCH 11/25] ASoC: sun8i-codec: Enable all supported clock inversions Message-ID: <20201008125946.ialsolxkdgdje3sy@gilmour.lan> References: <20201001021148.15852-1-samuel@sholland.org> <20201001021148.15852-12-samuel@sholland.org> <20201005113015.acp2gascxkytl7z4@gilmour.lan> <7b8206b6-ccd8-6d70-6210-fb7d79a330a3@sholland.org> MIME-Version: 1.0 In-Reply-To: <7b8206b6-ccd8-6d70-6210-fb7d79a330a3@sholland.org> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20201008_085954_587651_71237EAA X-CRM114-Status: GOOD ( 31.80 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Ondrej Jirman , alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, Takashi Iwai , Liam Girdwood , Chen-Yu Tsai , Mark Brown , Jaroslav Kysela , linux-arm-kernel@lists.infradead.org Content-Type: multipart/mixed; boundary="===============2378090183653018733==" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org --===============2378090183653018733== Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="2nok6hajuhde5mnx" Content-Disposition: inline --2nok6hajuhde5mnx Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, Oct 05, 2020 at 11:29:51PM -0500, Samuel Holland wrote: >=20 > On 10/5/20 6:30 AM, Maxime Ripard wrote: > > On Wed, Sep 30, 2020 at 09:11:34PM -0500, Samuel Holland wrote: > > > When using the I2S, LEFT_J, or RIGHT_J format, the hardware supports > > > independent BCLK and LRCK inversion control. When using DSP_A or DSP_= B, > > > LRCK inversion is not supported. The register bit is repurposed to > > > select between DSP_A and DSP_B. Extend the driver to support this. > > >=20 > > > Signed-off-by: Samuel Holland > > > --- > > > sound/soc/sunxi/sun8i-codec.c | 57 +++++++++++++++++++++++---------= --- > > > 1 file changed, 37 insertions(+), 20 deletions(-) > > >=20 > > > diff --git a/sound/soc/sunxi/sun8i-codec.c b/sound/soc/sunxi/sun8i-co= dec.c > > > index 0b713b2a2028..506420fb355c 100644 > > > --- a/sound/soc/sunxi/sun8i-codec.c > > > +++ b/sound/soc/sunxi/sun8i-codec.c > > > @@ -39,18 +39,17 @@ > > > #define SUN8I_MOD_RST_CTL_AIF1 15 > > > #define SUN8I_MOD_RST_CTL_ADC 3 > > > #define SUN8I_MOD_RST_CTL_DAC 2 > > > #define SUN8I_SYS_SR_CTRL 0x018 > > > #define SUN8I_SYS_SR_CTRL_AIF1_FS 12 > > > #define SUN8I_SYS_SR_CTRL_AIF2_FS 8 > > > #define SUN8I_AIF1CLK_CTRL 0x040 > > > #define SUN8I_AIF1CLK_CTRL_AIF1_MSTR_MOD 15 > > > -#define SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV 14 > > > -#define SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV 13 > > > +#define SUN8I_AIF1CLK_CTRL_AIF1_CLK_INV 13 > > > #define SUN8I_AIF1CLK_CTRL_AIF1_BCLK_DIV 9 > > > #define SUN8I_AIF1CLK_CTRL_AIF1_LRCK_DIV 6 > > > #define SUN8I_AIF1CLK_CTRL_AIF1_WORD_SIZ 4 > > > #define SUN8I_AIF1CLK_CTRL_AIF1_WORD_SIZ_16 (1 << 4) > > > #define SUN8I_AIF1CLK_CTRL_AIF1_DATA_FMT 2 > > > #define SUN8I_AIF1_ADCDAT_CTRL 0x044 > > > #define SUN8I_AIF1_ADCDAT_CTRL_AIF1_AD0L_ENA 15 > > > #define SUN8I_AIF1_ADCDAT_CTRL_AIF1_AD0R_ENA 14 > > > @@ -85,16 +84,17 @@ > > > #define SUN8I_DAC_MXR_SRC_DACR_MXR_SRC_AIF1DA1R 10 > > > #define SUN8I_DAC_MXR_SRC_DACR_MXR_SRC_AIF2DACR 9 > > > #define SUN8I_DAC_MXR_SRC_DACR_MXR_SRC_ADCR 8 > > > #define SUN8I_SYSCLK_CTL_AIF1CLK_SRC_MASK GENMASK(9, 8) > > > #define SUN8I_SYSCLK_CTL_AIF2CLK_SRC_MASK GENMASK(5, 4) > > > #define SUN8I_SYS_SR_CTRL_AIF1_FS_MASK GENMASK(15, 12) > > > #define SUN8I_SYS_SR_CTRL_AIF2_FS_MASK GENMASK(11, 8) > > > +#define SUN8I_AIF1CLK_CTRL_AIF1_CLK_INV_MASK GENMASK(14, 13) > > > #define SUN8I_AIF1CLK_CTRL_AIF1_BCLK_DIV_MASK GENMASK(12, 9) > > > #define SUN8I_AIF1CLK_CTRL_AIF1_LRCK_DIV_MASK GENMASK(8, 6) > > > #define SUN8I_AIF1CLK_CTRL_AIF1_WORD_SIZ_MASK GENMASK(5, 4) > > > #define SUN8I_AIF1CLK_CTRL_AIF1_DATA_FMT_MASK GENMASK(3, 2) > > > enum { > > > AIF1, > > > NAIFS > > > @@ -168,17 +168,17 @@ static int sun8i_codec_get_hw_rate(struct snd_p= cm_hw_params *params) > > > default: > > > return -EINVAL; > > > } > > > } > > > static int sun8i_codec_set_fmt(struct snd_soc_dai *dai, unsigned in= t fmt) > > > { > > > struct sun8i_codec *scodec =3D snd_soc_dai_get_drvdata(dai); > > > - u32 format, value; > > > + u32 format, invert, value; > > > /* clock masters */ > > > switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { > > > case SND_SOC_DAIFMT_CBS_CFS: /* Codec slave, DAI master */ > > > value =3D 0x1; > > > break; > > > case SND_SOC_DAIFMT_CBM_CFM: /* Codec Master, DAI slave */ > > > value =3D 0x0; > > > @@ -197,55 +197,72 @@ static int sun8i_codec_set_fmt(struct snd_soc_d= ai *dai, unsigned int fmt) > > > break; > > > case SND_SOC_DAIFMT_LEFT_J: > > > format =3D 0x1; > > > break; > > > case SND_SOC_DAIFMT_RIGHT_J: > > > format =3D 0x2; > > > break; > > > case SND_SOC_DAIFMT_DSP_A: > > > + format =3D 0x3; > > > + invert =3D 0x0; /* Set LRCK_INV to 0 */ > > > + break; > > > case SND_SOC_DAIFMT_DSP_B: > > > format =3D 0x3; > > > + invert =3D 0x1; /* Set LRCK_INV to 1 */ > > > break; > > > default: > > > return -EINVAL; > > > } > > > regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL, > > > SUN8I_AIF1CLK_CTRL_AIF1_DATA_FMT_MASK, > > > format << SUN8I_AIF1CLK_CTRL_AIF1_DATA_FMT); > > > /* clock inversion */ > > > switch (fmt & SND_SOC_DAIFMT_INV_MASK) { > > > case SND_SOC_DAIFMT_NB_NF: /* Normal */ > > > value =3D 0x0; > > > break; > > > - case SND_SOC_DAIFMT_IB_IF: /* Inversion */ > > > + case SND_SOC_DAIFMT_NB_IF: /* Inverted LRCK */ > > > value =3D 0x1; > > > break; > > > + case SND_SOC_DAIFMT_IB_NF: /* Inverted BCLK */ > > > + value =3D 0x2; > > > + break; > > > + case SND_SOC_DAIFMT_IB_IF: /* Both inverted */ > > > + value =3D 0x3; > > > + break; > > > default: > > > return -EINVAL; > > > } > > > - regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL, > > > - BIT(SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV), > > > - value << SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV); > > > - /* > > > - * It appears that the DAI and the codec in the A33 SoC don't > > > - * share the same polarity for the LRCK signal when they mean > > > - * 'normal' and 'inverted' in the datasheet. > > > - * > > > - * Since the DAI here is our regular i2s driver that have been > > > - * tested with way more codecs than just this one, it means > > > - * that the codec probably gets it backward, and we have to > > > - * invert the value here. > > > - */ > > > - value ^=3D scodec->quirks->lrck_inversion; > > > + if (format =3D=3D 0x3) { > >=20 > > Could we use a define here? That would be more readable >=20 > Yes, I can do that. >=20 > > > + /* Inverted LRCK is not available in DSP mode. */ > > > + if (value & BIT(0)) > > > + return -EINVAL; > >=20 > > And same thing here, explicitly testing both for DSP_A and DSP_B would > > be more readable. >=20 > Here, `value & BIT(0)` means SND_SOC_DAIFMT_NB_IF || > SND_SOC_DAIFMT_IB_IF, not selecting the DSP format. >=20 > > (And I guess value isn't such a great variable name anymore either) >=20 > If I rename `invert` to `dsp_format`, and replace `value` here with > `invert`, I think that would be more clear. Yep, definitely :) Maxime --2nok6hajuhde5mnx Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iHUEABYIAB0WIQRcEzekXsqa64kGDp7j7w1vZxhRxQUCX38NQgAKCRDj7w1vZxhR xcW0AQDhGpbhsKRaELaFSYsyNwEgCac4EG/NPUpOB5iPA3IWWwEAwPdnukIky0b5 YlV38uib2dEXsYTVQ8yvgoYMuIKSRAk= =ebxQ -----END PGP SIGNATURE----- --2nok6hajuhde5mnx-- --===============2378090183653018733== Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Disposition: inline _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel --===============2378090183653018733==--