Received: by 10.223.176.5 with SMTP id f5csp3180669wra; Mon, 29 Jan 2018 09:57:26 -0800 (PST) X-Google-Smtp-Source: AH8x2268zJegnl/zKPnqrF5m+Hj1RcLzZ+LFfOAwZeXKFZZ7jJohnqQNQXlAFB2lgWQe6UvUuA5b X-Received: by 10.99.95.206 with SMTP id t197mr5071240pgb.274.1517248646603; Mon, 29 Jan 2018 09:57:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517248646; cv=none; d=google.com; s=arc-20160816; b=CqmJ/hnkr4MvvWZvqEzsghN0pneyBDlj8lKKg7+ODvyctCBWBr6AIR6nrn4MB52YUd FcdjwKX6h/8Lzbju7hTkVrK3xy850SNUzLtt4/n/EkrIBf6Xfm+hIIyD5BTIuT06JpJU MNsvAOb+iXsTiFUQQ2rxUHjEuq55Nwmgt3AJtiv0JYaIldKGjbGjHeDu5dVuYjdCmOUc 3ig3fsmh+T3a3MHScwc/TRw8hHofZC2L8J2ZRc6bfSRGcOslaMM+Q3GPgOZiYqH4QT0H D0CXmH6F7kOybTYG3uQhSKAzvxLKc2UkNSLMvrKBpaYYUBehA5kcFnXcQvRIQba7FEeL ZeuA== 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=YIewQInbRS1hciCOhuWBKPytDusK4uwWKhv1Tk5rdds=; b=pSx1Wm0bWM2aF5lX4ulisUpQLYzOcFEZXOXRtNaCuSF/qvJT1OjWqf5ldWnSSE7Dqn 1RtlFhOlM6hzrtkDLkv5Mss5ioD3ed6cG49uDBU7Bo6gqx+Fz+7RHTrX/Rwwxm2K2fBm z9p8y0r5FTCWcey7rj3orGhNG3ySiwPuunF0iC6bmP59jEyogDAoHLdorM3bTKr2grdh 4YAdSJJsSqt+Pp9UYaVO7jOSYg02W7oguuZeJPXSU9YvvOb+PhPBhdTd1AJb7NdNGV9f qRzuAIVua+HrFl0swpPFtWrO8W/hi5oaji9BOl02aHIe45dinp+Gs+zgwJNcbRGZxrkc ckFg== 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 b7si7723337pgq.275.2018.01.29.09.57.11; Mon, 29 Jan 2018 09:57:26 -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 S1751663AbeA2Rzv (ORCPT + 99 others); Mon, 29 Jan 2018 12:55:51 -0500 Received: from foss.arm.com ([217.140.101.70]:44008 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751528AbeA2Rzt (ORCPT ); Mon, 29 Jan 2018 12:55:49 -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 110571682; Mon, 29 Jan 2018 09:46:42 -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 F179C3F487; Mon, 29 Jan 2018 09:46:39 -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 , Jon Masters Subject: [PATCH v2 12/16] firmware/psci: Expose PSCI conduit Date: Mon, 29 Jan 2018 17:45:55 +0000 Message-Id: <20180129174559.1866-13-marc.zyngier@arm.com> X-Mailer: git-send-email 2.14.2 In-Reply-To: <20180129174559.1866-1-marc.zyngier@arm.com> References: <20180129174559.1866-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. 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