Received: by 10.223.185.116 with SMTP id b49csp7040475wrg; Wed, 28 Feb 2018 21:42:46 -0800 (PST) X-Google-Smtp-Source: AG47ELsw3PbxexzILrbVg8bxJHMjSLVy/gJXkEkr6chCs2Lnb7XOBgI/dfxVSUoAzK7rBG824ViZ X-Received: by 10.101.72.198 with SMTP id o6mr584163pgs.279.1519882966283; Wed, 28 Feb 2018 21:42:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519882966; cv=none; d=google.com; s=arc-20160816; b=jr8nv1B505Z3M2K/flnj4nzSZTERmRyw8l4hutBRQMFNXYcLu6vxEqakljD+lITAKO cWvPp5rRETIy1SAIcJpuxWSEbR+4nhkJL64/qujFKpyfBdoPlD/+WHhOBHiizk/7KBBu h+wzRXs2Dy2XbhFCkfqU/uiiK+J95F3OzwX7czDMZP6+INpwH1ID4nTLBrnT84A5xgSM 06a1DsbKD8mc5JOmd3g5FCKiHRnc9vFSN8Axcj1odUN1vd60Px/e8REM/iso538SCdwZ lmSd8rKPXU3XwtK7x5k9v5IxADl/i6DumYqJyGUidv7OC3nrrI7b3MJ642PPwhvNB0FS f06g== 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=e2yXQHYHFrtQQJuCOCXMY6GU7gbIbbLdHMD+UHREL9E=; b=hgW99Zzeg5PbZddo5TnaGywYyGrS686UHC7Le/0bnE5peloiS+1yNiE1hXNE0x3MKj RJeVqxYWy0c9YnMdg33A7z82wBUXd4bNm/RnkvS0RSnmUTeeGTzredh+JOXkceHHvFCK MOPN1wtrItkQK6664OSeIcwMyJjQkBgZu6vaS38sExWPize7+Dn1/5pMI0L35tmGrJzS pZO/sfy795iQLJFYxp+NWC8Pgw/BuvkVdjBXXP62EgfaZ5ASveXLizwd2su+FxToHjl6 Ve6dIq1O3otHGD7TL6nlTtyG9Kg5vacbYCx6DYVbNqW698ulcHPCWsx6l3njELZCQcWV oPNQ== 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 q9-v6si2485702plr.110.2018.02.28.21.42.32; Wed, 28 Feb 2018 21:42:46 -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 S966093AbeCAFlM (ORCPT + 99 others); Thu, 1 Mar 2018 00:41:12 -0500 Received: from david.siemens.de ([192.35.17.14]:59740 "EHLO david.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966050AbeCAFlK (ORCPT ); Thu, 1 Mar 2018 00:41:10 -0500 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by david.siemens.de (8.15.2/8.15.2) with ESMTPS id w215epPI028963 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Mar 2018 06:40:51 +0100 Received: from md1f2u6c.ww002.siemens.net ([167.87.33.50]) by mail3.siemens.de (8.15.2/8.15.2) with ESMTP id w215eo90000453; Thu, 1 Mar 2018 06:40:51 +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 Subject: [PATCH v3 1/6] jailhouse: Provide detection for non-x86 systems Date: Thu, 1 Mar 2018 06:40:44 +0100 Message-Id: <558f5cbae432ae029e2d8ee9b0ef44d837318625.1519882849.git.jan.kiszka@siemens.com> 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 Signed-off-by: Jan Kiszka --- 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