Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1999171imu; Fri, 14 Dec 2018 04:17:06 -0800 (PST) X-Google-Smtp-Source: AFSGD/XkWiqQdbwF8CgqRJW+OwfSylvW1b1w0DOUd9hjCTW64Z9gORkOwaZIvJGFTo6NHMlCy32h X-Received: by 2002:a17:902:9006:: with SMTP id a6mr2639611plp.334.1544789826388; Fri, 14 Dec 2018 04:17:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544789826; cv=none; d=google.com; s=arc-20160816; b=H2H++34TeK02oTrldSgVfJS3Wa4jBSIN0A1F86Bk+4vW4TVMYC0fQ/wDWZnkdtsN+N HRC3b+hfBV+f8tJ447RUyKmq071xkxnSk/lqY837V0p+JibSTt645OlU+ebHAk+ojRl7 Hji51jIdc9px9oll98DrMIaOLrypQZsYAbrh7mXA0Rdb8b2vftEJn3xy7/3blGkeoZzt /V7eXc94nfk3OM2oVuedY5Yu3NKnj/WStupQpfYQz1jdGLHSmjBz19GCsfnIXKqZwYid B35ZBn5czekUnJrfM9xDCFPmWUhc22bsnlTWnrHv+lpr+gPMLDcObGaPG0GJE4EQIWOX m3Mg== 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:dkim-signature; bh=qywsmcXYgJWPa9hJB0w6Jk2BzwD3BqFvWZ1mDDjNonM=; b=w5lNcwT9Oh3VIY+4FjTM+Wk1W+38qsdE7rskTPO+nww0ngN+aeXAcD4US0G+i3RvIy DKp+1pWg/9uF1QSPzBFMs5u+r4Rkwuh3mX7jZTrg6KNkfFHZcEmRQ7PnKyoZeQh1JMcX vlV6mf4itVRdkxy/Z4zTT3887rump0KHJAZxtAAGihd1uNT0WcnHNagkUBQnBc23IILt glcGrGWJyZERNLKOtSbiikh+LcOY9haRM7l139XYXNuPCaNeViqDIZLd4ySs3Z3U2pv+ BB3ZsiIUqYl/M0cgDXP02HCvmfldxH2GzDS5pQFFikDLPpo2N0i0WuQTrptrPcFqaUPF uJJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=sQ5jXzGr; 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 h5si3805340pgc.237.2018.12.14.04.16.51; Fri, 14 Dec 2018 04:17:06 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=default header.b=sQ5jXzGr; 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 S1732435AbeLNMOu (ORCPT + 99 others); Fri, 14 Dec 2018 07:14:50 -0500 Received: from mail.kernel.org ([198.145.29.99]:34548 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732422AbeLNMOr (ORCPT ); Fri, 14 Dec 2018 07:14:47 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9F8F52133F; Fri, 14 Dec 2018 12:14:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1544789687; bh=8gSfu1FfUKe2hW003MlIabwGJdFCeMZY7mrsns3IM+U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sQ5jXzGrzIVdJHrca3mIYRHAGGyZbPx0tuZ1QpTLSlGL3epXBpK2hZpiR/tDe8saQ CTcZzA7zihjK6pU3nujFZOAHSuY50H3WOZip/vLiYZ9UIFuAMsS6NGl1Vu/otJNY5J 4YT7n9VVIv8yk7g8EjALmQBcP4Gzau5KkYPcCLGI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tzung-Bi Shih , Mark Brown , Sasha Levin Subject: [PATCH 4.4 15/88] ASoC: dapm: Recalculate audio map forcely when card instantiated Date: Fri, 14 Dec 2018 12:59:49 +0100 Message-Id: <20181214115703.411783905@linuxfoundation.org> X-Mailer: git-send-email 2.20.0 In-Reply-To: <20181214115702.151309521@linuxfoundation.org> References: <20181214115702.151309521@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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.4-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 882eab6c28d23a970ae73b7eb831b169a672d456 ] Audio map are possible in wrong state before card->instantiated has been set to true. Imaging the following examples: time 1: at the beginning in:-1 in:-1 in:-1 in:-1 out:-1 out:-1 out:-1 out:-1 SIGGEN A B Spk time 2: after someone called snd_soc_dapm_new_widgets() (e.g. create_fill_widget_route_map() in sound/soc/codecs/hdac_hdmi.c) in:1 in:0 in:0 in:0 out:0 out:0 out:0 out:1 SIGGEN A B Spk time 3: routes added in:1 in:0 in:0 in:0 out:0 out:0 out:0 out:1 SIGGEN -----> A -----> B ---> Spk In the end, the path should be powered on but it did not. At time 3, "in" of SIGGEN and "out" of Spk did not propagate to their neighbors because snd_soc_dapm_add_path() will not invalidate the paths if the card has not instantiated (i.e. card->instantiated is false). To correct the state of audio map, recalculate the whole map forcely. Signed-off-by: Tzung-Bi Shih Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- sound/soc/soc-core.c | 1 + 1 file changed, 1 insertion(+) diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c index fa6b74a304a7..b927f9c81d92 100644 --- a/sound/soc/soc-core.c +++ b/sound/soc/soc-core.c @@ -1711,6 +1711,7 @@ static int snd_soc_instantiate_card(struct snd_soc_card *card) } card->instantiated = 1; + dapm_mark_endpoints_dirty(card); snd_soc_dapm_sync(&card->dapm); mutex_unlock(&card->mutex); mutex_unlock(&client_mutex); -- 2.19.1