Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp657121iog; Mon, 13 Jun 2022 10:01:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwMO1NNKas9RVqm2p1wnGSK3bHWfux6E0oFZr+evLNET+ymZlvPR3v9o2zeUc3KW6mNmCH5 X-Received: by 2002:aa7:88cb:0:b0:51c:2627:2c03 with SMTP id k11-20020aa788cb000000b0051c26272c03mr146281pff.63.1655139674954; Mon, 13 Jun 2022 10:01:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655139674; cv=none; d=google.com; s=arc-20160816; b=QH0XzM+/Uimwyj43YjUwqBChNK9Ki0o8LRhRBY3Bi+8ZGMJ+xEsnFLRqybjb64Pq75 eGFIZiKmrWGtevid2ZDdJdAcb2CSfofHlEjyiy6zxFdF7WxUkqIbyC8A3nVC4BmsYFV1 nFVPCXZLYGpiNCp91RW+TzX+B2j1W5d19JcuqpGklUeQbGiVN7Lct7rUxGbiC/X/s2SS MWAbWRTMfIAqof5tl22SUOwMwau8wkeYTCQKpj74vv66Uo164JdYNNUYzefEemyufON6 7LN4Od9DMsNMNmk2a/fk1hslCTrxRopfbAw0O/LUY08HlNiQY/ygDYqKnFSHkvyayH7a W51g== 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=BblCRHqMvy/hekoU+/UnKEN3r7SGox31OQTdKRHap+A=; b=qGccn6XJrXi4/+hAtuj6z0Y8aMJwjXufgXxYiS/tT1CwsHtJvyy6jW33MdXynQVgVT 85XI6r0PGAdFOrApvy5TqOXfHLD8KmERyTuarotgd/rQ9c5PRqMis5z4ALtKEiF5UyeA Kp66SBBN+vdrlcZVsP28xMUJuiQEDYjcrWSlUA948Som8sbxogSTNij3bAP6tOkpyJ3K GQ0fKaOOJf0Ohse/PadRxcmi9+Q8yDXDOv0F1GFWPQ8Lr4dj3yC8XxgtvO6AHguJxifk 0k4zTN40HTGMjfefKmYIizcpXdoSvFVAm8ZgZIIAkEYuDVEWBsEGZbtELqaI+Ks4IsKM 8MfA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=plhwczOr; 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 u11-20020a170902e80b00b0016511ed9294si11832006plg.86.2022.06.13.10.00.58; Mon, 13 Jun 2022 10:01:14 -0700 (PDT) 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=plhwczOr; 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 S1380516AbiFMOAk (ORCPT + 99 others); Mon, 13 Jun 2022 10:00:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35868 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1380338AbiFMNyH (ORCPT ); Mon, 13 Jun 2022 09:54:07 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 237C642EFC; Mon, 13 Jun 2022 04:34:56 -0700 (PDT) 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 8E1E1B80EC7; Mon, 13 Jun 2022 11:34:54 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 09B1CC3411F; Mon, 13 Jun 2022 11:34:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1655120093; bh=wH7/90BcNZzwB2bJOgzMEcaResWqJwE5uqhLmPT9ENA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=plhwczOrxv8KhMOrOQypvl5Pyv9UJDyZNZBZS6JsLXjCW72DapxDc6OIm/4u5a7L4 X+UbwbBKaaiWjgSsqOCf9o9oB48HmtzEw0BiaIDnvX4Qob9OK44ykFxM08ZSkl/J1D I9ly82FEGO9OJagxQraWmqYElCGLFQFm4XGCcNHs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andre Przywara , Robin Murphy , Daniel Lezcano , Sasha Levin Subject: [PATCH 5.18 248/339] clocksource/drivers/sp804: Avoid error on multiple instances Date: Mon, 13 Jun 2022 12:11:13 +0200 Message-Id: <20220613094934.176246058@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220613094926.497929857@linuxfoundation.org> References: <20220613094926.497929857@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=-8.3 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: Andre Przywara [ Upstream commit a98399cbc1e05f7b977419f03905501d566cf54e ] When a machine sports more than one SP804 timer instance, we only bring up the first one, since multiple timers of the same kind are not useful to Linux. As this is intentional behaviour, we should not return an error message, as we do today: =============== [ 0.000800] Failed to initialize '/bus@8000000/motherboard-bus@8000000/iofpga-bus@300000000/timer@120000': -22 =============== Replace the -EINVAL return with a debug message and return 0 instead. Also we do not reach the init function anymore if the DT node is disabled (as this is now handled by OF_DECLARE), so remove the explicit check for that case. This fixes a long standing bogus error when booting ARM's fastmodels. Signed-off-by: Andre Przywara Reviewed-by: Robin Murphy Link: https://lore.kernel.org/r/20220506162522.3675399-1-andre.przywara@arm.com Signed-off-by: Daniel Lezcano Signed-off-by: Sasha Levin --- drivers/clocksource/timer-sp804.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/clocksource/timer-sp804.c b/drivers/clocksource/timer-sp804.c index 401d592e85f5..e6a87f4af2b5 100644 --- a/drivers/clocksource/timer-sp804.c +++ b/drivers/clocksource/timer-sp804.c @@ -259,6 +259,11 @@ static int __init sp804_of_init(struct device_node *np, struct sp804_timer *time struct clk *clk1, *clk2; const char *name = of_get_property(np, "compatible", NULL); + if (initialized) { + pr_debug("%pOF: skipping further SP804 timer device\n", np); + return 0; + } + base = of_iomap(np, 0); if (!base) return -ENXIO; @@ -270,11 +275,6 @@ static int __init sp804_of_init(struct device_node *np, struct sp804_timer *time writel(0, timer1_base + timer->ctrl); writel(0, timer2_base + timer->ctrl); - if (initialized || !of_device_is_available(np)) { - ret = -EINVAL; - goto err; - } - clk1 = of_clk_get(np, 0); if (IS_ERR(clk1)) clk1 = NULL; -- 2.35.1