Received: by 10.192.165.148 with SMTP id m20csp713383imm; Fri, 20 Apr 2018 14:17:41 -0700 (PDT) X-Google-Smtp-Source: AIpwx48ruJShcsWGmPKQUAPQv3Bn8jkCiKQbDt69pve8GQUPYnzKtTQzMmo0D4h8+I2tPSPoLedm X-Received: by 2002:a17:902:9a0c:: with SMTP id v12-v6mr11350016plp.162.1524259061224; Fri, 20 Apr 2018 14:17:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524259061; cv=none; d=google.com; s=arc-20160816; b=pYt1TyTlrrwVn5XDZECIoIAmwewG4mUCaUeytDXyaX0dygB7MUW7o0233bt7/OiZmC eDqP8v5koj9z3xydHquifucFaZopLQKk5TFgFSpV6VrclLiPnrFu81jX766KcdUGWdl9 6Bg53gAimCoHt28kgrKDEf0P64FQWbGnozhDF2OVV7NxVxsoiZicavkUHjrSRgI0cgP+ SRosveiLMK8KRDlrL1GVjmq5I5aDmrkG5vLpHmLeLV9YQe7Fb2Fi69u7Ld768ua1s+4F qxetXzZ/F8YcrVThEIbuDkaKDyJ88XnbCkCr/6ybLHMp77XECkBs+Z6Gr1O9m0ofmrcH 8Izw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=HYOZCg//7sSpE28NzyKJ/jmv6F2xELiiOWTDGNHytTI=; b=tcxYb9hyAoT65Tv6xIGKvVjPIeou08jIIV+Q61f1qnBMIHsxp7FGG1G4+nsIqewXDd 39KnHkoblBrUouU3BrzpIi6R+M1lizPDNGe0emx1FaBnCecq8eLH7Xd97r8bQLmC90xN mUfa/DJrMvXhzkpMGbvCPLSpB0EjUUKcLaBujBb3CWgFgoY0KXexJe8pku0qt+32Qyy1 QDaMbwXhMleA5DufNN+Cn3kBKQ3XTSutfao9z5IZJuWfY/xjPx5j2yA1NCRc32a80Nue +2IqpeyBZlZuJNJ3XJALaSXgdzpX34qyvScHKVZN5Uq6Uebmos2k5gcpaoYJcJwdSmU4 3gKg== 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 k28si769953pgn.129.2018.04.20.14.17.04; Fri, 20 Apr 2018 14:17:41 -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 S1753164AbeDTVLm (ORCPT + 99 others); Fri, 20 Apr 2018 17:11:42 -0400 Received: from mail.bootlin.com ([62.4.15.54]:51427 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753077AbeDTVLk (ORCPT ); Fri, 20 Apr 2018 17:11:40 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id CD0BD207A8; Fri, 20 Apr 2018 23:11:38 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from dell-desktop.home (176-137-37-244.abo.bbox.fr [176.137.37.244]) by mail.bootlin.com (Postfix) with ESMTPSA id E179220713; Fri, 20 Apr 2018 23:11:37 +0200 (CEST) From: =?UTF-8?q?Myl=C3=A8ne=20Josserand?= To: linux@armlinux.org.uk, maxime.ripard@bootlin.com, wens@csie.org, marc.zyngier@arm.com, mark.rutland@arm.com, robh+dt@kernel.org, horms@verge.net.au, geert@linux-m68k.org, magnus.damm@gmail.com Cc: linux-renesas-soc@vger.kernel.org, devicetree@vger.kernel.org, clabbe.montjoie@gmail.com, quentin.schulz@bootlin.com, thomas.petazzoni@bootlin.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, mylene.josserand@bootlin.com Subject: [PATCH v7 06/11] ARM: sunxi: Add initialization of CNTVOFF Date: Fri, 20 Apr 2018 23:10:17 +0200 Message-Id: <20180420211022.11759-7-mylene.josserand@bootlin.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20180420211022.11759-1-mylene.josserand@bootlin.com> References: <20180420211022.11759-1-mylene.josserand@bootlin.com> 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 Add the initialization of CNTVOFF for sun8i-a83t. For boot CPU, create a new machine that handles this function's call in an "init_early" callback. We need to initialize CNTVOFF before the arch timer's initialization otherwise, it will not be taken into account and fails to boot correctly. Because of that, this function can't be called in SMP's early_initcall function which is called after timer's init. For secondary CPUs, add this function into secondary_startup assembly entry. Signed-off-by: Mylène Josserand --- arch/arm/mach-sunxi/headsmp.S | 1 + arch/arm/mach-sunxi/sunxi.c | 20 +++++++++++++++++++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/arch/arm/mach-sunxi/headsmp.S b/arch/arm/mach-sunxi/headsmp.S index 37dc772701f3..32d76be98541 100644 --- a/arch/arm/mach-sunxi/headsmp.S +++ b/arch/arm/mach-sunxi/headsmp.S @@ -71,6 +71,7 @@ ENDPROC(sunxi_mc_smp_cluster_cache_enable) ENTRY(sunxi_mc_smp_secondary_startup) bl sunxi_mc_smp_cluster_cache_enable + bl secure_cntvoff_init b secondary_startup ENDPROC(sunxi_mc_smp_secondary_startup) diff --git a/arch/arm/mach-sunxi/sunxi.c b/arch/arm/mach-sunxi/sunxi.c index 5e9602ce1573..ddc439f6269b 100644 --- a/arch/arm/mach-sunxi/sunxi.c +++ b/arch/arm/mach-sunxi/sunxi.c @@ -16,6 +16,7 @@ #include #include +#include static const char * const sunxi_board_dt_compat[] = { "allwinner,sun4i-a10", @@ -62,7 +63,6 @@ MACHINE_END static const char * const sun8i_board_dt_compat[] = { "allwinner,sun8i-a23", "allwinner,sun8i-a33", - "allwinner,sun8i-a83t", "allwinner,sun8i-h2-plus", "allwinner,sun8i-h3", "allwinner,sun8i-r40", @@ -75,6 +75,24 @@ DT_MACHINE_START(SUN8I_DT, "Allwinner sun8i Family") .dt_compat = sun8i_board_dt_compat, MACHINE_END +void __init sun8i_cntvoff_init(void) +{ +#ifdef CONFIG_SMP + secure_cntvoff_init(); +#endif +} + +static const char * const sun8i_cntvoff_board_dt_compat[] = { + "allwinner,sun8i-a83t", + NULL, +}; + +DT_MACHINE_START(SUN8I_CNTVOFF_DT, "Allwinner sun8i-a83t board") + .init_early = sun8i_cntvoff_init, + .init_time = sun6i_timer_init, + .dt_compat = sun8i_cntvoff_board_dt_compat, +MACHINE_END + static const char * const sun9i_board_dt_compat[] = { "allwinner,sun9i-a80", NULL, -- 2.11.0