Received: by 10.192.165.148 with SMTP id m20csp406316imm; Fri, 4 May 2018 12:09:45 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpwl//UGEXN4qwh/hMBfjX7sOrXw256301whNV2DX1q8hRkzNyhYHmPr+d+xNfFgjkoDQv0 X-Received: by 10.98.236.24 with SMTP id k24mr28035956pfh.204.1525460985535; Fri, 04 May 2018 12:09:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525460985; cv=none; d=google.com; s=arc-20160816; b=JaOVqeNr/H90/q4P+/Vrtay2bAdHXTqU3NSKiXmVt5HT0m5graVXyW0MJ3fmfeFKQY jaFrpLQalvcq+nTgEUhzdPTHNeIuSUtZNJ2NScUbvci6NGhnYfnE6sIY04GJ//o0Aose jPWVobXC1qumCAKIzZihG6r88RBVwRsP3VtQb1eCX9DF2Vi54IuTrfCWwllmYL5lYRzJ 7ZsSMip3kMpHqzYj/SbIbC4sBn6e5vf1Nxn6NDfRX8epjVh2NjxhOTzPTiNsG3zlMUam l1a/xoY/qXeeTbmhBAUrJ4ghZXEHnGdSUqsEEz0Lkdd7cQmyV7kMQyZk8+3BRe+jFfyd Ol0Q== 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=Srn1QZupRh7I2vv0wMkNl6+nAAmwgWu7o8FM3ThtZ7s=; b=M2rjqOMjQ3FHlmGZt9yO1Nw/b6aPJ3q8O9AlXwY+I/euOu4mkZo/AmBkMDHOMWZu1D IH8dbeJihC6PIg7zFMyCheXKuJH28nDxVZrg2iC49SkPLkE8qw8EmNJeGC2VOCk39dPQ 6aGWL2u3Lthb0nAYsZHijlUUgaDwXR2ePwugQGDseo8omFsM4LxhPgYsG9m2VrJR4zMo ky+FaD0PA2XS5ReebB4gpSpQD8p640eETQyyl0tq1tue27ds+x2a9CwPD0ALbQhG5v1d 5j+jq9euq1vK9oLc5+jk/qSyNWR/DQMc21Ze3NKJ7vSkkpAprblFunNPpCqzxAok/Iin usZQ== 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 e9-v6si16559527pln.72.2018.05.04.12.09.30; Fri, 04 May 2018 12:09:45 -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 S1751982AbeEDTIr (ORCPT + 99 others); Fri, 4 May 2018 15:08:47 -0400 Received: from mail.bootlin.com ([62.4.15.54]:42993 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751651AbeEDTHB (ORCPT ); Fri, 4 May 2018 15:07:01 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id 9F90820723; Fri, 4 May 2018 21:06:59 +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 A3BE020650; Fri, 4 May 2018 21:06:58 +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: f.fainelli@gmail.com, opendmb@gmail.com, 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 v9 07/12] ARM: sunxi: Add initialization of CNTVOFF Date: Fri, 4 May 2018 21:05:40 +0200 Message-Id: <20180504190545.5114-8-mylene.josserand@bootlin.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20180504190545.5114-1-mylene.josserand@bootlin.com> References: <20180504190545.5114-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 Acked-by: Maxime Ripard --- 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..752e0748b0c8 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_a83t_cntvoff_init(void) +{ +#ifdef CONFIG_SMP + secure_cntvoff_init(); +#endif +} + +static const char * const sun8i_a83t_cntvoff_board_dt_compat[] = { + "allwinner,sun8i-a83t", + NULL, +}; + +DT_MACHINE_START(SUN8I_A83T_CNTVOFF_DT, "Allwinner sun8i-a83t board") + .init_early = sun8i_a83t_cntvoff_init, + .init_time = sun6i_timer_init, + .dt_compat = sun8i_a83t_cntvoff_board_dt_compat, +MACHINE_END + static const char * const sun9i_board_dt_compat[] = { "allwinner,sun9i-a80", NULL, -- 2.11.0