Received: by 10.223.185.116 with SMTP id b49csp4745993wrg; Tue, 6 Mar 2018 23:41:48 -0800 (PST) X-Google-Smtp-Source: AG47ELu2+aaxaElvJ9I7ZDHrrHs6xlrFesgpwtsWIgkHG+lt81xku7fNYNsg+s0bY0qD6bfkhEBf X-Received: by 10.99.38.135 with SMTP id m129mr9987537pgm.2.1520408508757; Tue, 06 Mar 2018 23:41:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520408508; cv=none; d=google.com; s=arc-20160816; b=1IAKHDPyRcOzJYTFHdfZOqzJtGQ7G4PYzfq7nsyOpM/6N6ENke5/mbwNwZCIl1CyeQ pB+uEG6jz8SL9Q/kj/cPBqqw2q+Ls8+oMgyabHJdm3dRZK848j63jBXKvlU/9ngClknT HKME9VuAuxV5OSCgNdIucrvhKX7NfNvd9c/qpeKLYYEz3Qn1ZH8eBGBY/+3Yf/+S+4Jg 65/VvBPKz6eSOIxEVZUoohwNHZLfylzRiV1mB4zrMC662uZrWjFOcVACelS7F0eqljR5 94kCYb3EutriVbCI2cDrS0n8eq7iz01OcjnXUpY9TtnSyDT0903tBq99yLud9ScfbR7M +SdQ== 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:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=iYnfQYagbWE6WcEnuKcM7gQdfFF7/dYKYxh4X3Uw9xQ=; b=BjQ7IxtOhWrgdB72rjknjp3oQl53L/qN91lzf7GgHN9ciO65ZjMVYKN1ed1RnCXmkd QmrR1V4q6IGnf7zXCwTYU5f6P5+oG7wBZNiSaLaFxiu/+k1hjJ+rBiuzfK9hFkBQZ8p0 p+00h5MKcw90VhvKL/v8vdMYmDTx3JfLj3vUKPRawf9f8SD04BKPErmrphSdGjo+Yh5Q LzNpNRu4eYUjcsLy+nZHDE6xv7mhPZqdtWlAFpivmWcxVK6o3mR0Pigm2+wa0e9P2MXi xdIXVJb/jXY572W1xiwnElMioWChP7V+7V52VNP1ghHatbAzm7wsjRpGkQy4PeZN6wyC TZ9Q== 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 t6-v6si12728427plj.126.2018.03.06.23.41.21; Tue, 06 Mar 2018 23:41:48 -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 S1751246AbeCGHjn (ORCPT + 99 others); Wed, 7 Mar 2018 02:39:43 -0500 Received: from goliath.siemens.de ([192.35.17.28]:50321 "EHLO goliath.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751196AbeCGHjl (ORCPT ); Wed, 7 Mar 2018 02:39:41 -0500 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by goliath.siemens.de (8.15.2/8.15.2) with ESMTPS id w277dLUL032098 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Wed, 7 Mar 2018 08:39:21 +0100 Received: from md1f2u6c.ww002.siemens.net ([167.87.11.133]) by mail3.siemens.de (8.15.2/8.15.2) with ESMTP id w277dIAh004697; Wed, 7 Mar 2018 08:39:20 +0100 From: Jan Kiszka To: Thomas Gleixner , Ingo Molnar , "H . Peter Anvin" , Bjorn Helgaas Cc: x86@kernel.org, Linux Kernel Mailing List , jailhouse-dev@googlegroups.com, linux-pci@vger.kernel.org, virtualization@lists.linux-foundation.org, Andy Shevchenko , Rob Herring , Mark Rutland , Juergen Gross Subject: [PATCH v5 1/7] jailhouse: Provide detection for non-x86 systems Date: Wed, 7 Mar 2018 08:39:12 +0100 Message-Id: X-Mailer: git-send-email 2.13.6 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jan Kiszka Implement jailhouse_paravirt() via device tree probing on architectures != x86. Will be used by the PCI core. CC: Rob Herring CC: Mark Rutland CC: Juergen Gross Signed-off-by: Jan Kiszka Reviewed-by: Juergen Gross --- Documentation/devicetree/bindings/jailhouse.txt | 8 ++++++++ arch/x86/include/asm/jailhouse_para.h | 2 +- include/linux/hypervisor.h | 17 +++++++++++++++-- 3 files changed, 24 insertions(+), 3 deletions(-) create mode 100644 Documentation/devicetree/bindings/jailhouse.txt diff --git a/Documentation/devicetree/bindings/jailhouse.txt b/Documentation/devicetree/bindings/jailhouse.txt new file mode 100644 index 000000000000..2901c25ff340 --- /dev/null +++ b/Documentation/devicetree/bindings/jailhouse.txt @@ -0,0 +1,8 @@ +Jailhouse non-root cell device tree bindings +-------------------------------------------- + +When running in a non-root Jailhouse cell (partition), the device tree of this +platform shall have a top-level "hypervisor" node with the following +properties: + +- compatible = "jailhouse,cell" diff --git a/arch/x86/include/asm/jailhouse_para.h b/arch/x86/include/asm/jailhouse_para.h index 875b54376689..b885a961a150 100644 --- a/arch/x86/include/asm/jailhouse_para.h +++ b/arch/x86/include/asm/jailhouse_para.h @@ -1,7 +1,7 @@ /* SPDX-License-Identifier: GPL2.0 */ /* - * Jailhouse paravirt_ops implementation + * Jailhouse paravirt detection * * Copyright (c) Siemens AG, 2015-2017 * diff --git a/include/linux/hypervisor.h b/include/linux/hypervisor.h index b19563f9a8eb..fc08b433c856 100644 --- a/include/linux/hypervisor.h +++ b/include/linux/hypervisor.h @@ -8,15 +8,28 @@ */ #ifdef CONFIG_X86 + +#include #include + static inline void hypervisor_pin_vcpu(int cpu) { x86_platform.hyper.pin_vcpu(cpu); } -#else + +#else /* !CONFIG_X86 */ + +#include + static inline void hypervisor_pin_vcpu(int cpu) { } -#endif + +static inline bool jailhouse_paravirt(void) +{ + return of_find_compatible_node(NULL, NULL, "jailhouse,cell"); +} + +#endif /* !CONFIG_X86 */ #endif /* __LINUX_HYPEVISOR_H */ -- 2.13.6