From patchwork Thu Apr 2 15:46:04 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: =?utf-8?b?SsO8cmdlbiBHcm/Dnw==?= X-Patchwork-Id: 11471045 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id A422F1668 for ; Thu, 2 Apr 2020 15:46:53 +0000 (UTC) Received: from lists.xenproject.org (lists.xenproject.org [192.237.175.120]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 8982A20737 for ; Thu, 2 Apr 2020 15:46:53 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 8982A20737 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=suse.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=xen-devel-bounces@lists.xenproject.org Received: from localhost ([127.0.0.1] helo=lists.xenproject.org) by lists.xenproject.org with esmtp (Exim 4.89) (envelope-from ) id 1jK238-0003lt-7t; Thu, 02 Apr 2020 15:46:34 +0000 Received: from us1-rack-iad1.inumbo.com ([172.99.69.81]) by lists.xenproject.org with esmtp (Exim 4.89) (envelope-from ) id 1jK236-0003lB-Gu for xen-devel@lists.xenproject.org; Thu, 02 Apr 2020 15:46:32 +0000 X-Inumbo-ID: 19c5fed6-74f9-11ea-b58d-bc764e2007e4 Received: from mx2.suse.de (unknown [195.135.220.15]) by us1-rack-iad1.inumbo.com (Halon) with ESMTPS id 19c5fed6-74f9-11ea-b58d-bc764e2007e4; Thu, 02 Apr 2020 15:46:22 +0000 (UTC) X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id D482AAE38; Thu, 2 Apr 2020 15:46:19 +0000 (UTC) From: Juergen Gross To: xen-devel@lists.xenproject.org Subject: [PATCH v7 00/12] Add hypervisor sysfs-like support Date: Thu, 2 Apr 2020 17:46:04 +0200 Message-Id: <20200402154616.16927-1-jgross@suse.com> X-Mailer: git-send-email 2.16.4 X-BeenThere: xen-devel@lists.xenproject.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Xen developer discussion List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Cc: Juergen Gross , Kevin Tian , Stefano Stabellini , Julien Grall , Jun Nakajima , Wei Liu , Andrew Cooper , Ian Jackson , George Dunlap , Jan Beulich , Anthony PERARD , Daniel De Graaf , Volodymyr Babchuk , =?utf-8?q?Roger_Pau_Monn?= =?utf-8?q?=C3=A9?= Errors-To: xen-devel-bounces@lists.xenproject.org Sender: "Xen-devel" On the 2019 Xen developer summit there was agreement that the Xen hypervisor should gain support for a hierarchical name-value store similar to the Linux kernel's sysfs. This is a first implementation of that idea adding the basic functionality to hypervisor and tools side. The interface to any user program making use of that "xen-hypfs" is a new library "libxenhypfs" with a stable interface. The series adds read-only nodes with buildinfo data and writable nodes with runtime parameters. xl is switched to use the new file system for modifying the runtime parameters and the old sysctl interface for that purpose is dropped. Changes in V7: - old patch 1 already applied - add new patch 1 (carved out and modified from patch 9) - addressed review comments - modified public interface to have a max write size instead of a writable flag only Changes in V6: - added new patches 1, 10, 11, 12 - addressed review comments - modified interface for creating nodes for runtime parameters Changes in V5: - switched to xsm for privilege check Changes in V4: - former patch 2 removed as already committed - addressed review comments Changes in V3: - major rework, especially by supporting binary contents of entries - added several new patches (1, 2, 7) - full support of all runtime parameters - support of writing entries (especially runtime parameters) Changes in V2: - all comments to V1 addressed - added man-page for xenhypfs tool - added runtime parameter read access for string parameters Changes in V1: - renamed xenfs ->xenhypfs - added writable entries support at the interface level and in the xenhypfs tool - added runtime parameter read access (integer type only for now) - added docs/misc/hypfs-paths.pandoc for path descriptions Juergen Gross (12): xen/vmx: let opt_ept_ad always reflect the current setting xen: add a generic way to include binary files as variables docs: add feature document for Xen hypervisor sysfs-like support xen: add basic hypervisor filesystem support libs: add libxenhypfs tools: add xenfs tool xen: provide version information in hypfs xen: add /buildinfo/config entry to hypervisor filesystem xen: add runtime parameter access support to hypfs tools/libxl: use libxenhypfs for setting xen runtime parameters tools/libxc: remove xc_set_parameters() xen: remove XEN_SYSCTL_set_parameter support .gitignore | 6 + docs/features/hypervisorfs.pandoc | 92 +++++++ docs/man/xenhypfs.1.pod | 61 ++++ docs/misc/hypfs-paths.pandoc | 163 +++++++++++ tools/Rules.mk | 8 +- tools/flask/policy/modules/dom0.te | 4 +- tools/libs/Makefile | 1 + tools/libs/hypfs/Makefile | 16 ++ tools/libs/hypfs/core.c | 536 ++++++++++++++++++++++++++++++++++++ tools/libs/hypfs/include/xenhypfs.h | 75 +++++ tools/libs/hypfs/libxenhypfs.map | 10 + tools/libs/hypfs/xenhypfs.pc.in | 10 + tools/libxc/include/xenctrl.h | 1 - tools/libxc/xc_misc.c | 21 -- tools/libxl/Makefile | 3 +- tools/libxl/libxl.c | 53 +++- tools/libxl/libxl_internal.h | 1 + tools/libxl/xenlight.pc.in | 2 +- tools/misc/Makefile | 6 + tools/misc/xenhypfs.c | 192 +++++++++++++ tools/xl/xl_misc.c | 1 - xen/arch/arm/traps.c | 1 + xen/arch/arm/xen.lds.S | 10 +- xen/arch/x86/hvm/hypercall.c | 1 + xen/arch/x86/hvm/vmx/vmcs.c | 54 +++- xen/arch/x86/hvm/vmx/vmx.c | 4 +- xen/arch/x86/hypercall.c | 1 + xen/arch/x86/pv/domain.c | 21 +- xen/arch/x86/pv/hypercall.c | 1 + xen/arch/x86/xen.lds.S | 10 +- xen/common/Kconfig | 10 + xen/common/Makefile | 13 + xen/common/grant_table.c | 49 +++- xen/common/hypfs.c | 381 +++++++++++++++++++++++++ xen/common/kernel.c | 84 +++++- xen/common/sysctl.c | 36 --- xen/drivers/char/console.c | 61 +++- xen/include/Makefile | 1 + xen/include/asm-x86/hvm/vmx/vmcs.h | 3 +- xen/include/public/hypfs.h | 127 +++++++++ xen/include/public/sysctl.h | 19 +- xen/include/public/xen.h | 1 + xen/include/xen/hypercall.h | 8 + xen/include/xen/hypfs.h | 118 ++++++++ xen/include/xen/kernel.h | 3 + xen/include/xen/lib.h | 1 - xen/include/xen/param.h | 101 ++++--- xen/include/xlat.lst | 2 + xen/include/xsm/dummy.h | 6 + xen/include/xsm/xsm.h | 6 + xen/tools/binfile | 41 +++ xen/xsm/dummy.c | 1 + xen/xsm/flask/Makefile | 5 +- xen/xsm/flask/flask-policy.S | 16 -- xen/xsm/flask/hooks.c | 9 +- xen/xsm/flask/policy/access_vectors | 4 +- 56 files changed, 2284 insertions(+), 187 deletions(-) create mode 100644 docs/features/hypervisorfs.pandoc create mode 100644 docs/man/xenhypfs.1.pod create mode 100644 docs/misc/hypfs-paths.pandoc create mode 100644 tools/libs/hypfs/Makefile create mode 100644 tools/libs/hypfs/core.c create mode 100644 tools/libs/hypfs/include/xenhypfs.h create mode 100644 tools/libs/hypfs/libxenhypfs.map create mode 100644 tools/libs/hypfs/xenhypfs.pc.in create mode 100644 tools/misc/xenhypfs.c create mode 100644 xen/common/hypfs.c create mode 100644 xen/include/public/hypfs.h create mode 100644 xen/include/xen/hypfs.h create mode 100755 xen/tools/binfile delete mode 100644 xen/xsm/flask/flask-policy.S