Received: by 10.223.176.5 with SMTP id f5csp2640903wra; Thu, 1 Feb 2018 03:49:26 -0800 (PST) X-Google-Smtp-Source: AH8x2252wnTi6BUTZpKIsIPgsnijobef/WJS/arAieXZZcX869jee8Wydj6tuzCkZKLUuHnfnhAi X-Received: by 2002:a17:902:a588:: with SMTP id az8-v6mr7312626plb.10.1517485766113; Thu, 01 Feb 2018 03:49:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517485765; cv=none; d=google.com; s=arc-20160816; b=MC7Dj30YcbgSWe4fzyWbmEYdDpRGU9r/8qXcqnKjaQS7ynK10tpRm945YklpeUKu3u Wo8ddmUE15p1ioggyhBOvZiBgXw8zRUlgeVwxER2MwjJEZ0DElWgZpiPAY81te2Q8gFR uPN5RuS/Wv5H9cOtKrpH4gw8okjMp4n5yy6WvkYBbcislmZflgsLnGGwzcTJgMgaraHA RL0Cg+y97gE4vNuQDpVNCibVAcn2x4EQd6EgaN0mC03V30Cwft0K0iXn4qix3CMdecwk 3hFEul1jMqfuQQAhtF+buXIixq3MuExZHsGJfUybtewz4cNJ5JNoeshTOjCGwqLjImSv gXsA== 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=xazjuGnjBWZuU5y48412kW8dhwTSVIyJ0zXGh/G2il8=; b=QSZgJ51nohS4SkZu7MaVbAjEqmpACiNy0taC07uWVqVEeGuCDrnk+Ojc1CS1SYK2gu G4EHzeKtS98xgMfShhHgI3SZU4MXa+Jq+gOgunPsYXxYmZng5B2eenQwc+3uQu9rZRcY eXMWu3hPw3s/GtSOgrn8l/pvZridGkv2goRVxQzFvhHICPlOgX/gHvfRf3EQZcU8Jxkg /FMFfmVnleiFIxA/msJEhw3F0QPSVeuUYONyuoRRx/YrYyazTdlZeoqXWav6Yq4J0gev hgxgAAFMPh3XDV6xB/bBuhFhb2BVSFgaBKTmV3Gds90cJVbImn1yzDGwIjmG62krT3re VhFQ== 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 h3si990310pgc.179.2018.02.01.03.49.11; Thu, 01 Feb 2018 03:49:25 -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 S1752546AbeBALsU (ORCPT + 99 others); Thu, 1 Feb 2018 06:48:20 -0500 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:48540 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752531AbeBALsQ (ORCPT ); Thu, 1 Feb 2018 06:48:16 -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 588A81529; Thu, 1 Feb 2018 03:48:16 -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 8F7F43F25C; Thu, 1 Feb 2018 03:48:13 -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 v3 13/18] firmware/psci: Expose PSCI conduit Date: Thu, 1 Feb 2018 11:46:52 +0000 Message-Id: <20180201114657.7323-14-marc.zyngier@arm.com> X-Mailer: git-send-email 2.14.2 In-Reply-To: <20180201114657.7323-1-marc.zyngier@arm.com> References: <20180201114657.7323-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 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