Received: by 10.223.176.5 with SMTP id f5csp949928wra; Tue, 6 Feb 2018 09:59:29 -0800 (PST) X-Google-Smtp-Source: AH8x227nordq3/DGtQLk/b8vGNL3/qNAQTj+WM/LKqC1kbpbXwg9Vnydl3YJnBMPjGtODXjOASJg X-Received: by 2002:a17:902:9895:: with SMTP id s21-v6mr3139723plp.297.1517939968998; Tue, 06 Feb 2018 09:59:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517939968; cv=none; d=google.com; s=arc-20160816; b=TZk0R4PAbxvWTI3SqzsLnrx4DVrrjcgDPlFvuYTUwkVha5eLGPYKyhayHow6ky/svF PCkyVzN/YuKr8q87ezJ1dkBdO6Len1Ik14DTUdSAMIwY44+PFl4kOd+m2FqLdpefmacb FiDCM1kE3geD8HAuZWo11XrW3Csm9C+6zmBCG43Rs7GIzATkhlBjP1NaR3al5mj7e5R6 WQWqYTHtSLZYopJCLWSQjOqMsR2zvMXi89do4xQhee7DYMPpZyrXfLxSkIlfpfPkSM66 5aLWfg8aRB1nUlEgC1x3hj3f52Px5OIj7bDCvCwwZmoXoE5nZWmJ8bmGG6wGc9JLYv/k 7ejQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=Ic+kuVC1qoVsujEeqPKodg3BnV/kLLOUlPBV0495pQ4=; b=ZhCZdITXNnYFenpdBchRDIGDDxG4M9/UPfbs0asEAIMr6+AUVnFPO/GEUjiL2nxoTl sjGTQbs9j0lrJLUIsw2+Thfo8lhBbd9c1Se0DiYkbECpqY3VEnin2ohnF6cqMUUAcSWs vkI3KUdMGu7Jansgl2goJOa5GWZLNxXmKSOKsZPXWvnjVZ8zMlJ1ngBK7qe4ELtkDHv/ 7gWKcoyjIzHbHmhyA7BK6+ygRWoYufWom+3E5iGUAOTEvGSa+BDWB7Bdk/lXerlLUSVz KITWUXBx+oUMpVzhJs4vqfc9GdaA0Crgj4CBJ72CqfepaW3UJGN7bCN80xr9ReY2TUPT 68kQ== 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 h20si6768852pfh.395.2018.02.06.09.59.15; Tue, 06 Feb 2018 09:59:28 -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; 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 S1753003AbeBFR6Q (ORCPT + 99 others); Tue, 6 Feb 2018 12:58:16 -0500 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:41152 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752834AbeBFR5W (ORCPT ); Tue, 6 Feb 2018 12:57:22 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B06321435; Tue, 6 Feb 2018 09:57:21 -0800 (PST) Received: from approximate.cambridge.arm.com (approximate.cambridge.arm.com [10.1.207.62]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 0F5F63F25C; Tue, 6 Feb 2018 09:57:18 -0800 (PST) From: Marc Zyngier To: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu Cc: Catalin Marinas , Will Deacon , Peter Maydell , Christoffer Dall , Lorenzo Pieralisi , Mark Rutland , Robin Murphy , Ard Biesheuvel , Andrew Jones , Hanjun Guo , Jayachandran C , Jon Masters , Russell King - ARM Linux Subject: [PATCH v4 12/17] firmware/psci: Expose PSCI conduit Date: Tue, 6 Feb 2018 17:56:16 +0000 Message-Id: <20180206175621.929-13-marc.zyngier@arm.com> X-Mailer: git-send-email 2.14.2 In-Reply-To: <20180206175621.929-1-marc.zyngier@arm.com> References: <20180206175621.929-1-marc.zyngier@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In order to call into the firmware to apply workarounds, it is useful to find out whether we're using HVC or SMC. Let's expose this through the psci_ops. Acked-by: Lorenzo Pieralisi Reviewed-by: Robin Murphy Tested-by: Ard Biesheuvel Signed-off-by: Marc Zyngier --- drivers/firmware/psci.c | 28 +++++++++++++++++++++++----- include/linux/psci.h | 7 +++++++ 2 files changed, 30 insertions(+), 5 deletions(-) diff --git a/drivers/firmware/psci.c b/drivers/firmware/psci.c index 8b25d31e8401..e9493da2b111 100644 --- a/drivers/firmware/psci.c +++ b/drivers/firmware/psci.c @@ -59,7 +59,9 @@ bool psci_tos_resident_on(int cpu) return cpu == resident_cpu; } -struct psci_operations psci_ops; +struct psci_operations psci_ops = { + .conduit = PSCI_CONDUIT_NONE, +}; typedef unsigned long (psci_fn)(unsigned long, unsigned long, unsigned long, unsigned long); @@ -210,6 +212,22 @@ static unsigned long psci_migrate_info_up_cpu(void) 0, 0, 0); } +static void set_conduit(enum psci_conduit conduit) +{ + switch (conduit) { + case PSCI_CONDUIT_HVC: + invoke_psci_fn = __invoke_psci_fn_hvc; + break; + case PSCI_CONDUIT_SMC: + invoke_psci_fn = __invoke_psci_fn_smc; + break; + default: + WARN(1, "Unexpected PSCI conduit %d\n", conduit); + } + + psci_ops.conduit = conduit; +} + static int get_set_conduit_method(struct device_node *np) { const char *method; @@ -222,9 +240,9 @@ static int get_set_conduit_method(struct device_node *np) } if (!strcmp("hvc", method)) { - invoke_psci_fn = __invoke_psci_fn_hvc; + set_conduit(PSCI_CONDUIT_HVC); } else if (!strcmp("smc", method)) { - invoke_psci_fn = __invoke_psci_fn_smc; + set_conduit(PSCI_CONDUIT_SMC); } else { pr_warn("invalid \"method\" property: %s\n", method); return -EINVAL; @@ -654,9 +672,9 @@ int __init psci_acpi_init(void) pr_info("probing for conduit method from ACPI.\n"); if (acpi_psci_use_hvc()) - invoke_psci_fn = __invoke_psci_fn_hvc; + set_conduit(PSCI_CONDUIT_HVC); else - invoke_psci_fn = __invoke_psci_fn_smc; + set_conduit(PSCI_CONDUIT_SMC); return psci_probe(); } diff --git a/include/linux/psci.h b/include/linux/psci.h index f724fd8c78e8..f2679e5faa4f 100644 --- a/include/linux/psci.h +++ b/include/linux/psci.h @@ -25,6 +25,12 @@ bool psci_tos_resident_on(int cpu); int psci_cpu_init_idle(unsigned int cpu); int psci_cpu_suspend_enter(unsigned long index); +enum psci_conduit { + PSCI_CONDUIT_NONE, + PSCI_CONDUIT_SMC, + PSCI_CONDUIT_HVC, +}; + struct psci_operations { u32 (*get_version)(void); int (*cpu_suspend)(u32 state, unsigned long entry_point); @@ -34,6 +40,7 @@ struct psci_operations { int (*affinity_info)(unsigned long target_affinity, unsigned long lowest_affinity_level); int (*migrate_info_type)(void); + enum psci_conduit conduit; }; extern struct psci_operations psci_ops; -- 2.14.2