From patchwork Mon Jan 18 11:34:50 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Greg KH X-Patchwork-Id: 365494 Delivered-To: patch@linaro.org Received: by 2002:a17:906:fb05:0:0:0:0 with SMTP id lz5csp2676347ejb; Mon, 18 Jan 2021 03:39:09 -0800 (PST) X-Google-Smtp-Source: ABdhPJwp29AosHh8MEk3HnCl/lZXob98dMTlsmxHhOluqZRRBZb690NxBWujriVlemn8Ibb399gH X-Received: by 2002:a17:906:858f:: with SMTP id v15mr38992ejx.238.1610969949677; Mon, 18 Jan 2021 03:39:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610969949; cv=none; d=google.com; s=arc-20160816; b=K5/VOuLKVc42H27n8ziCGNUm+b8FQNv7iPm3nlAiKdh1j+Fy4t4mRkue2GiURXURhg 5vajToV2MdCOYnFYFbWOaAviLnlbuq2OCjfEyKmXgPdgqOQQTtI9tIvmdXgyzE709rqp 8bAmeNz1oB4QKMeBFz4T3c9ZXJIx0RqNGjtuML+DxMyK6u26SuVtDz12wcohuIuPzp3g P8lAb8HK1M27vq2JkfUrtAeocPV3YGDBsSLKd3oCsafvj/XGfnU9nYgpAwCztMadS2+j I6lavgsgduL54OrqgqnCDaoCU8jUFGWqzHuPAeQNrZ7ll/jlQzHbn3P4QcoVENTkxdNo y/6w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=i18D7fDVBf2yaeACd0vt4dcM+NZ0iHogZBvte/vq4Dc=; b=KzHVpq4kUdZGY6nDeGwZwOTMP8Eqav25+5jdgIPSvdVBQaUekZrsjsAIx0Jpte01e3 hw/CaK7tYlxdwyHhYLY2x4R5OwQSlAdqi7UdIoQG0MZBYHJ7YsGB/9fmCOZ4DRhhknfE YdaoegZuLNTKGrux/MPPu+ntqIPRuckJsklFMHljMm4lu8PDp9CgSeaX8X17/a2m85W1 DmE6nTZ9Rrn808xTaUZsIx+S62uvaGcjyeoFficu1ioWwjFPmILVrOJu0DLPJ4JzY1Wi fmUQUQeNFZoPVQnJyRClV4JGPXY4aXIkqYaalGlAJtPt06/WHeAsQjhc+dvSZH/UhbVm 8qcA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=cDK7kmM4; spf=pass (google.com: domain of stable-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m15si2928107ejx.309.2021.01.18.03.39.09; Mon, 18 Jan 2021 03:39:09 -0800 (PST) Received-SPF: pass (google.com: domain of stable-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=cDK7kmM4; spf=pass (google.com: domain of stable-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390455AbhARLiY (ORCPT + 13 others); Mon, 18 Jan 2021 06:38:24 -0500 Received: from mail.kernel.org ([198.145.29.99]:34046 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390380AbhARLiH (ORCPT ); Mon, 18 Jan 2021 06:38:07 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 9926F22227; Mon, 18 Jan 2021 11:36:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1610969791; bh=/djjC3kDdBNhUec3GnLY8X9oe6C7uFIRz0TdZsvwRRE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cDK7kmM4u77A/Qju8+Uc4/qvmbeXJpx1gilNtn7hZN8WcGa0Bg/Jr7UL26XBZKNZz wXhc1e9/HvoZM4x8tcvfatcjG/jvjIJAiBdkoRx5c6nFUobRYPZmySX03ec3TA61b/ 2ccC4hZneGpcE3Dxn0A1wYGAkhXK+R+BxNWyY1MA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Charles Keepax , Jerome Brunet , Mark Brown Subject: [PATCH 4.19 27/43] ASoC: meson: axg-tdm-interface: fix loopback Date: Mon, 18 Jan 2021 12:34:50 +0100 Message-Id: <20210118113336.258258504@linuxfoundation.org> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210118113334.966227881@linuxfoundation.org> References: <20210118113334.966227881@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org From: Jerome Brunet commit 671ee4db952449acde126965bf76817a3159040d upstream. When the axg-tdm-interface was introduced, the backend DAI was marked as an endpoint when DPCM was walking the DAPM graph to find a its BE. It is no longer the case since this commit 8dd26dff00c0 ("ASoC: dapm: Fix handling of custom_stop_condition on DAPM graph walks") Because of this, when DPCM finds a BE it does everything it needs on the DAIs but it won't power up the widgets between the FE and the BE if there is no actual endpoint after the BE. On meson-axg HWs, the loopback is a special DAI of the tdm-interface BE. It is only linked to the dummy codec since there no actual HW after it. >From the DAPM perspective, the DAI has no endpoint. Because of this, the TDM decoder, which is a widget between the FE and BE is not powered up. >From the user perspective, everything seems fine but no data is produced. Connecting the Loopback DAI to a dummy DAPM endpoint solves the problem. Fixes: 8dd26dff00c0 ("ASoC: dapm: Fix handling of custom_stop_condition on DAPM graph walks") Cc: Charles Keepax Signed-off-by: Jerome Brunet Link: https://lore.kernel.org/r/20201217150812.3247405-1-jbrunet@baylibre.com Signed-off-by: Mark Brown Signed-off-by: Greg Kroah-Hartman --- sound/soc/meson/axg-tdm-interface.c | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) --- a/sound/soc/meson/axg-tdm-interface.c +++ b/sound/soc/meson/axg-tdm-interface.c @@ -459,8 +459,20 @@ static int axg_tdm_iface_set_bias_level( return ret; } +static const struct snd_soc_dapm_widget axg_tdm_iface_dapm_widgets[] = { + SND_SOC_DAPM_SIGGEN("Playback Signal"), +}; + +static const struct snd_soc_dapm_route axg_tdm_iface_dapm_routes[] = { + { "Loopback", NULL, "Playback Signal" }, +}; + static const struct snd_soc_component_driver axg_tdm_iface_component_drv = { - .set_bias_level = axg_tdm_iface_set_bias_level, + .dapm_widgets = axg_tdm_iface_dapm_widgets, + .num_dapm_widgets = ARRAY_SIZE(axg_tdm_iface_dapm_widgets), + .dapm_routes = axg_tdm_iface_dapm_routes, + .num_dapm_routes = ARRAY_SIZE(axg_tdm_iface_dapm_routes), + .set_bias_level = axg_tdm_iface_set_bias_level, }; static const struct of_device_id axg_tdm_iface_of_match[] = {