Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1364911imm; Tue, 2 Oct 2018 07:08:40 -0700 (PDT) X-Google-Smtp-Source: ACcGV61cWErh4VbfbURNIpNI9ntC0z/UPBa47rugExrFFfsCbplbQXxEjDxYPEAN99UwehCBOc3H X-Received: by 2002:a17:902:a58a:: with SMTP id az10-v6mr17021842plb.204.1538489320124; Tue, 02 Oct 2018 07:08:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538489320; cv=none; d=google.com; s=arc-20160816; b=CxTHSf3nL2nslEvDEYcMubmZxREqRjmaf1aRDFq4jBjKYRDD022y5pKu7lzUK0PAGp VIL0naqrgETapl15h8RBcsaTjLLRMwmQBUEWwKuaOtsL4Ygnf6xYJBl+FLLHT1AxvINB K1B4fSP6fRejcXm+vPRFPGAKDe6IqGrrqtkx1IuKBwJwP3X1mtnisGTEAZKPEUDO6n0n FLOwPEg8L0n0MQYNgp209l+CnX+cgr9wdSbvz/ge+eBx4MNWS5lsZqcowaiQM6CKbqSj lsAp1uZJr86GIYyAUEE5ZY+xSRoSeVUEilBa650wxlchc7Zl99nlcAsWbjwcfrmpOV2l CL0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from; bh=0Y+KQgAaQV5FDMEfXsKdCCxjL1nnpL8BpEPXBZz8YoY=; b=TFlnyEdwUuHXZnWMfL20om8OYsNYrxKqR7h2Th9CD08tjSHNbOtBZtDDuDgZTsoORg 1MT0Qf1Y4KLjioOv5xxNe1o97eBQy3goygU3BIu9Nprtbac+UObNncduDNDpG9OeaC2m bd8zZEn+wVDAg9fi7Bv4IXh+XtWyeYyTVOk02bCPlr9GwX9kt0E4N91yz8eMXC1Z+YOc OR90wC9vlDhAn0yKb9QHnj8wSoeTAYNeMXvr6/nk8N7MPAyD5DUZjP7m0faa6lI9RVEz e6n8S0M+RMvzA4PW5VvgRaJ+9vka99RiFIJR87wVrVeWwcrQD9l61Ods1PthjLqk1KZQ hZBg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b20-v6si15527219pfo.60.2018.10.02.07.08.25; Tue, 02 Oct 2018 07:08:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729421AbeJBULx (ORCPT + 99 others); Tue, 2 Oct 2018 16:11:53 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:32774 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728632AbeJBULx (ORCPT ); Tue, 2 Oct 2018 16:11:53 -0400 Received: from localhost (24-104-73-23-ip-static.hfc.comcastbusiness.net [24.104.73.23]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 6DED1266; Tue, 2 Oct 2018 13:28:30 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hiroyuki Yokoyama , Kuninori Morimoto , Mark Brown , Sasha Levin Subject: [PATCH 4.18 112/228] ASoC: rsnd: SSI parent cares SWSP bit Date: Tue, 2 Oct 2018 06:23:29 -0700 Message-Id: <20181002132506.966345961@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20181002132459.032960735@linuxfoundation.org> References: <20181002132459.032960735@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Kuninori Morimoto [ Upstream commit 203cdf51f28820bee7893b4be392847418e6f4ec ] SSICR has SWSP bit (= Serial WS Polarity) which decides WS pin 1st channel polarity (low or hi). This bit shouldn't exchange after running. Current SSI "parent" doesn't care SSICR, just controls clock only. Because of this behavior, if platform uses SSI0 as playback, SSI1 as capture, and if user starts capture -> playback order, SSI0 SSICR::SWSP bit exchanged 0 -> 1 during captureing, and it makes capture noise. This patch cares SSICR on SSI parent, too. Special thanks to Yokoyama-san Reported-by: Hiroyuki Yokoyama Signed-off-by: Kuninori Morimoto Tested-by: Hiroyuki Yokoyama Signed-off-by: Mark Brown Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- sound/soc/sh/rcar/ssi.c | 32 +++++++++++++++++++++----------- 1 file changed, 21 insertions(+), 11 deletions(-) --- a/sound/soc/sh/rcar/ssi.c +++ b/sound/soc/sh/rcar/ssi.c @@ -37,6 +37,7 @@ #define CHNL_4 (1 << 22) /* Channels */ #define CHNL_6 (2 << 22) /* Channels */ #define CHNL_8 (3 << 22) /* Channels */ +#define DWL_MASK (7 << 19) /* Data Word Length mask */ #define DWL_8 (0 << 19) /* Data Word Length */ #define DWL_16 (1 << 19) /* Data Word Length */ #define DWL_18 (2 << 19) /* Data Word Length */ @@ -353,21 +354,18 @@ static void rsnd_ssi_config_init(struct struct rsnd_dai *rdai = rsnd_io_to_rdai(io); struct snd_pcm_runtime *runtime = rsnd_io_to_runtime(io); struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod); - u32 cr_own; - u32 cr_mode; - u32 wsr; + u32 cr_own = ssi->cr_own; + u32 cr_mode = ssi->cr_mode; + u32 wsr = ssi->wsr; int is_tdm; - if (rsnd_ssi_is_parent(mod, io)) - return; - is_tdm = rsnd_runtime_is_ssi_tdm(io); /* * always use 32bit system word. * see also rsnd_ssi_master_clk_enable() */ - cr_own = FORCE | SWL_32; + cr_own |= FORCE | SWL_32; if (rdai->bit_clk_inv) cr_own |= SCKP; @@ -377,9 +375,18 @@ static void rsnd_ssi_config_init(struct cr_own |= SDTA; if (rdai->sys_delay) cr_own |= DEL; + + /* + * We shouldn't exchange SWSP after running. + * This means, parent needs to care it. + */ + if (rsnd_ssi_is_parent(mod, io)) + goto init_end; + if (rsnd_io_is_play(io)) cr_own |= TRMD; + cr_own &= ~DWL_MASK; switch (snd_pcm_format_width(runtime->format)) { case 16: cr_own |= DWL_16; @@ -406,7 +413,7 @@ static void rsnd_ssi_config_init(struct wsr |= WS_MODE; cr_own |= CHNL_8; } - +init_end: ssi->cr_own = cr_own; ssi->cr_mode = cr_mode; ssi->wsr = wsr; @@ -465,15 +472,18 @@ static int rsnd_ssi_quit(struct rsnd_mod return -EIO; } - if (!rsnd_ssi_is_parent(mod, io)) - ssi->cr_own = 0; - rsnd_ssi_master_clk_stop(mod, io); rsnd_mod_power_off(mod); ssi->usrcnt--; + if (!ssi->usrcnt) { + ssi->cr_own = 0; + ssi->cr_mode = 0; + ssi->wsr = 0; + } + return 0; }