Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp1058769pxb; Tue, 8 Feb 2022 08:22:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJwz0nuQ4EoeeBlTi/0LyJvJB5+x1RHnvTVIQKEEFOQPoHcII5brGc9uSIF1lnT+a8wFhLwG X-Received: by 2002:a63:ff0a:: with SMTP id k10mr1450388pgi.179.1644337325956; Tue, 08 Feb 2022 08:22:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644337325; cv=none; d=google.com; s=arc-20160816; b=xRmIumdlRTzg4YEGcmnMyRFGBYztKdoFj4x+JNUV0RR6ALJHzW5Ap0ma5ZM47XnNF2 fGb305CgbLZ6QymTKIBJ3EctvRR5700yqTYoHMb/w5bhBghDSrPRHwhQcyFnOGvR4ns+ /MGZmvCTME3ey/2CyzhvxREdn2loALC0adLdpFtef0IdrLMRc4jHDQLHT6yRPXyfD8w8 V8+iQyB7rA0gyeA7qXVm5Uuj6qeuKjBQ57x9TCvLamN0jRTxEF+VKE+Nn8X3T0LFkY3I +Ba137UHbckx/Ek0Bh2ZOxvQ9Pn++rYjtPAkWdKeXJ4NEkeys+LTdxgKkQYxXpv2MoPq Nqow== 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=OjFxmc6T7/qfcVDNAsPAZomtNG5KzSP46OAFs7vf72o=; b=nIXxQkHFE9m98WG6s5BiYA+3Es/5PBG6+km/bcG/ocQoT4Mt19AS8zMhg/TjS+Q3UN vfc654NRlTIjg9YQFrsruRbZeDDybTZuySSHUxqCmT4+8PWtksMaCU4DHXnuZ4Z8OERh zYTaQ5K1AoZNvuYk2tjfRT3N1TtrXNAqgCcpelXHqzTO2iSKtnxA5saFqChHfCMQU8+L cn+rukhiY/GUJXMH84FMuhtfu7KBjLQ5+fsnzsicN0993XzycRP3Y0ihj0oL1Jtztx1K wxbUXgCQKt4Flms9YYOjZuhYKsJp+2XWyiDtwKbY2vvWYrNObboTar+xtbaZxz/xNKgx IaVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=TJl7+4hu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x18si12317618pll.165.2022.02.08.08.21.51; Tue, 08 Feb 2022 08:22:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=TJl7+4hu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-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 S1384919AbiBGLal (ORCPT + 99 others); Mon, 7 Feb 2022 06:30:41 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34776 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1357487AbiBGLXL (ORCPT ); Mon, 7 Feb 2022 06:23:11 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1C5C6C043181; Mon, 7 Feb 2022 03:23:10 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id C2496B81028; Mon, 7 Feb 2022 11:23:08 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D9594C004E1; Mon, 7 Feb 2022 11:23:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1644232987; bh=YT8gsCAg7F7T3vjACjvYf0OXzG7CD0BJNhqoexsczrg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TJl7+4huupDfTjFMXEC15HFeQGYIb9E9yNdlJUQa+tvMQMQRDfCiatPM6eWNiGbwd 7lxnJ1nqkrrVn2P3wD6H4CYBMCbeQQaQ8/P96hFJ9Q02lXY/pRoaMCYhsSvRYIEFfT rv1ty4LwXaqikOVil87ayX8+XTKc9rtFI2ezLXrc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jiasheng Jiang , Mark Brown , James Liao , Kevin Hilman , Frank Wunderlich , Daniel Golle , Guenter Roeck Subject: [PATCH 5.10 23/74] Revert "ASoC: mediatek: Check for error clk pointer" Date: Mon, 7 Feb 2022 12:06:21 +0100 Message-Id: <20220207103757.999234038@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220207103757.232676988@linuxfoundation.org> References: <20220207103757.232676988@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Guenter Roeck This reverts commit d491a2c2cf96f9f3d855cf0bcd807d48ccb98e81 which is commit 9de2b9286a6dd16966959b3cb34fc2ddfd39213e upstream With this patch in the tree, Chromebooks running the affected hardware no longer boot. Bisect points to this patch, and reverting it fixes the problem. An analysis of the code with this patch applied shows: ret = init_clks(pdev, clk); if (ret) return ERR_PTR(ret); ... for (j = 0; j < MAX_CLKS && data->clk_id[j]; j++) { struct clk *c = clk[data->clk_id[j]]; if (IS_ERR(c)) { dev_err(&pdev->dev, "%s: clk unavailable\n", data->name); return ERR_CAST(c); } scpd->clk[j] = c; } Not all clocks in the clk_names array have to be present. Only the clocks in the data->clk_id array are actually needed. The code already checks if the required clocks are available and bails out if not. The assumption that all clocks have to be present is wrong, and commit 9de2b9286a6d needs to be reverted. Fixes: 9de2b9286a6d ("ASoC: mediatek: Check for error clk pointer") Cc: Jiasheng Jiang Cc: Mark Brown Cc: James Liao Cc: Kevin Hilman Cc: Matthias Brugger Cc: Daniel Golle Link: https://lore.kernel.org/lkml/20220205014755.699603-1-linux@roeck-us.net/ Signed-off-by: Guenter Roeck Signed-off-by: Greg Kroah-Hartman --- drivers/soc/mediatek/mtk-scpsys.c | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) --- a/drivers/soc/mediatek/mtk-scpsys.c +++ b/drivers/soc/mediatek/mtk-scpsys.c @@ -411,17 +411,12 @@ out: return ret; } -static int init_clks(struct platform_device *pdev, struct clk **clk) +static void init_clks(struct platform_device *pdev, struct clk **clk) { int i; - for (i = CLK_NONE + 1; i < CLK_MAX; i++) { + for (i = CLK_NONE + 1; i < CLK_MAX; i++) clk[i] = devm_clk_get(&pdev->dev, clk_names[i]); - if (IS_ERR(clk[i])) - return PTR_ERR(clk[i]); - } - - return 0; } static struct scp *init_scp(struct platform_device *pdev, @@ -431,7 +426,7 @@ static struct scp *init_scp(struct platf { struct genpd_onecell_data *pd_data; struct resource *res; - int i, j, ret; + int i, j; struct scp *scp; struct clk *clk[CLK_MAX]; @@ -486,9 +481,7 @@ static struct scp *init_scp(struct platf pd_data->num_domains = num; - ret = init_clks(pdev, clk); - if (ret) - return ERR_PTR(ret); + init_clks(pdev, clk); for (i = 0; i < num; i++) { struct scp_domain *scpd = &scp->domains[i];