Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp510315pxk; Thu, 3 Sep 2020 05:57:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxyPFPZloDLwN3MJRpJcVc7MX0/NfDQx2nZsVa3QofOvd3QHGoz7GE+FvqYooL+VwMf6xm7 X-Received: by 2002:a17:906:7cc6:: with SMTP id h6mr1978852ejp.266.1599137856695; Thu, 03 Sep 2020 05:57:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599137856; cv=none; d=google.com; s=arc-20160816; b=RQlbQUiMaMu+aGOQ+U0jry0dZxoBX2VwMM1jV2LZGbvgZzs50v32xQFiUnqXqjoQSg mMqMOWnexljNJbMsHW4mrbhDJPfPBMCkphXOMIpbkg7fV5SghdFOg+j0/O1Y6yof1jHA dAq5B6GCT7H8lLJYItsYhiaDA+7jZisGqSz49e8rTi01U7mMeXDRoBTyoTIbW7rsxiQ/ STaVgWCA71yuoHcVPn0RcmtbQ9SbJaRlF+6gn72QGC7GYNB+y85ncazmKva8fhPEpJ49 CJl4e7aNhVxQDPT1g5eRdfMhT4Xrj8p9SHPneSdsOyhFzQPKATANYgC6g8tHw7Ljr4Sp ye3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=YluJ4by+iwdsCWdNsb6eL6qMK5ScJl6H5Se9eja/E/o=; b=fjkdLmZyojQfw1BN2u/5LUHUOfZwQKHbbYTHTZtQWPLGaFyv9IItYHFKE6BWbNwPxu fi+02r4Txv1H2SpcgmL9KIbeosJhRdepPv2jC4TB0YO2SBYJU9L23s6G1dT8vzxG9nQz 8wpPUmJqSTE8l4G9xY40T+p6SD7hrcVcseMdQRXvRzmteLm4HBprKISPnBMvYeqTlUyA LKG/8gcjqfOviYqaPihXOtwUbNKF00PK3dT+ziXpOnKn3j+QzoskGczbt/38i0kfSFaQ nVw98vKQ2eeugajsbJdpU+58LJjnoI/J+Of8UrWOXSV/Dih30osFBbuz6E4qNIjGFrN3 /TYg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z5si1662245ejj.403.2020.09.03.05.57.13; Thu, 03 Sep 2020 05:57:36 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728812AbgICMxx (ORCPT + 99 others); Thu, 3 Sep 2020 08:53:53 -0400 Received: from mga11.intel.com ([192.55.52.93]:9284 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728935AbgICMnx (ORCPT ); Thu, 3 Sep 2020 08:43:53 -0400 IronPort-SDR: JoXCq2D41Iovz6b30fvTgDX8Tw7JiVhHIU6MUcOOiobfQYfo/Np/O2TiLauZi9dh+TO71sbYz3 c+JqDcMi2fNw== X-IronPort-AV: E=McAfee;i="6000,8403,9732"; a="155069681" X-IronPort-AV: E=Sophos;i="5.76,386,1592895600"; d="scan'208";a="155069681" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Sep 2020 05:42:56 -0700 IronPort-SDR: EkGNmBh/XFePzsVO8AXBaYHRwPefSiCmfGWe5Iuo7W6VWG0GuwKSMG5fBdNQXIhv4gO/7vL/1t eBV90r5JMgNw== X-IronPort-AV: E=Sophos;i="5.76,386,1592895600"; d="scan'208";a="339270774" Received: from shsi6026.sh.intel.com (HELO localhost) ([10.239.147.135]) by fmsmga003-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Sep 2020 05:42:53 -0700 From: shuo.a.liu@intel.com To: linux-kernel@vger.kernel.org, x86@kernel.org Cc: Greg Kroah-Hartman , "H . Peter Anvin" , Thomas Gleixner , Ingo Molnar , Borislav Petkov , Sean Christopherson , Yu Wang , Reinette Chatre , Shuo Liu , Zhi Wang , Zhenyu Wang Subject: [PATCH v2 07/17] virt: acrn: Introduce an ioctl to set vCPU registers state Date: Thu, 3 Sep 2020 20:41:51 +0800 Message-Id: <20200903124201.17275-8-shuo.a.liu@intel.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200903124201.17275-1-shuo.a.liu@intel.com> References: <20200903124201.17275-1-shuo.a.liu@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Shuo Liu A virtual CPU of User VM has different context due to the different registers state. ACRN userspace needs to set the virtual CPU registers state (e.g. giving a initial registers state to a virtual BSP of a User VM). HSM provides an ioctl ACRN_IOCTL_SET_VCPU_REGS to do the virtual CPU registers state setting. The ioctl passes the registers state from ACRN userspace to the hypervisor directly. Signed-off-by: Shuo Liu Reviewed-by: Zhi Wang Reviewed-by: Reinette Chatre Cc: Zhi Wang Cc: Zhenyu Wang Cc: Yu Wang Cc: Reinette Chatre Cc: Greg Kroah-Hartman --- drivers/virt/acrn/hsm.c | 14 +++++++ drivers/virt/acrn/hypercall.h | 13 +++++++ include/uapi/linux/acrn.h | 71 +++++++++++++++++++++++++++++++++++ 3 files changed, 98 insertions(+) diff --git a/drivers/virt/acrn/hsm.c b/drivers/virt/acrn/hsm.c index 6ec6aa9053d3..13df76d0206e 100644 --- a/drivers/virt/acrn/hsm.c +++ b/drivers/virt/acrn/hsm.c @@ -12,6 +12,7 @@ #define pr_fmt(fmt) "acrn: " fmt #define dev_fmt(fmt) "acrn: " fmt +#include #include #include #include @@ -49,6 +50,7 @@ static long acrn_dev_ioctl(struct file *filp, unsigned int cmd, { struct acrn_vm *vm = filp->private_data; struct acrn_vm_creation *vm_param; + struct acrn_vcpu_regs *cpu_regs; int ret = 0; if (vm->vmid == ACRN_INVALID_VMID && cmd != ACRN_IOCTL_CREATE_VM) { @@ -96,6 +98,18 @@ static long acrn_dev_ioctl(struct file *filp, unsigned int cmd, case ACRN_IOCTL_DESTROY_VM: ret = acrn_vm_destroy(vm); break; + case ACRN_IOCTL_SET_VCPU_REGS: + cpu_regs = memdup_user((void __user *)ioctl_param, + sizeof(struct acrn_vcpu_regs)); + if (IS_ERR(cpu_regs)) + return PTR_ERR(cpu_regs); + + ret = hcall_set_vcpu_regs(vm->vmid, virt_to_phys(cpu_regs)); + if (ret < 0) + dev_err(dev, "Failed to set regs state of VM%u!\n", + vm->vmid); + kfree(cpu_regs); + break; default: dev_warn(dev, "Unknown IOCTL 0x%x!\n", cmd); ret = -ENOTTY; diff --git a/drivers/virt/acrn/hypercall.h b/drivers/virt/acrn/hypercall.h index 426b66cadb1f..f29cfae08862 100644 --- a/drivers/virt/acrn/hypercall.h +++ b/drivers/virt/acrn/hypercall.h @@ -19,6 +19,7 @@ #define HC_START_VM _HC_ID(HC_ID, HC_ID_VM_BASE + 0x02) #define HC_PAUSE_VM _HC_ID(HC_ID, HC_ID_VM_BASE + 0x03) #define HC_RESET_VM _HC_ID(HC_ID, HC_ID_VM_BASE + 0x05) +#define HC_SET_VCPU_REGS _HC_ID(HC_ID, HC_ID_VM_BASE + 0x06) /** * hcall_create_vm() - Create a User VM @@ -75,4 +76,16 @@ static inline long hcall_reset_vm(u64 vmid) return acrn_hypercall1(HC_RESET_VM, vmid); } +/** + * hcall_set_vcpu_regs() - Set up registers of virtual CPU of a User VM + * @vmid: User VM ID + * @regs_state: Service VM GPA of registers state + * + * Return: 0 on success, <0 on failure + */ +static inline long hcall_set_vcpu_regs(u64 vmid, u64 regs_state) +{ + return acrn_hypercall2(HC_SET_VCPU_REGS, vmid, regs_state); +} + #endif /* __ACRN_HSM_HYPERCALL_H */ diff --git a/include/uapi/linux/acrn.h b/include/uapi/linux/acrn.h index 364b1a783074..1d5b82e154fb 100644 --- a/include/uapi/linux/acrn.h +++ b/include/uapi/linux/acrn.h @@ -36,6 +36,75 @@ struct acrn_vm_creation { __u8 reserved2[8]; } __attribute__((aligned(8))); +struct acrn_gp_regs { + __u64 rax; + __u64 rcx; + __u64 rdx; + __u64 rbx; + __u64 rsp; + __u64 rbp; + __u64 rsi; + __u64 rdi; + __u64 r8; + __u64 r9; + __u64 r10; + __u64 r11; + __u64 r12; + __u64 r13; + __u64 r14; + __u64 r15; +}; + +struct acrn_descriptor_ptr { + __u16 limit; + __u64 base; + __u16 reserved[3]; +} __attribute__ ((__packed__)); + +struct acrn_regs { + struct acrn_gp_regs gprs; + struct acrn_descriptor_ptr gdt; + struct acrn_descriptor_ptr idt; + + __u64 rip; + __u64 cs_base; + __u64 cr0; + __u64 cr4; + __u64 cr3; + __u64 ia32_efer; + __u64 rflags; + __u64 reserved_64[4]; + + __u32 cs_ar; + __u32 cs_limit; + __u32 reserved_32[3]; + + __u16 cs_sel; + __u16 ss_sel; + __u16 ds_sel; + __u16 es_sel; + __u16 fs_sel; + __u16 gs_sel; + __u16 ldt_sel; + __u16 tr_sel; + + __u16 reserved_16[4]; +}; + +/** + * struct acrn_vcpu_regs - Info of vCPU registers state + * @vcpu_id: vCPU ID + * @reserved0: Reserved + * @vcpu_regs: vCPU registers state + * + * This structure will be passed to hypervisor directly. + */ +struct acrn_vcpu_regs { + __u16 vcpu_id; + __u16 reserved0[3]; + struct acrn_regs vcpu_regs; +} __attribute__((aligned(8))); + /* The ioctl type, documented in ioctl-number.rst */ #define ACRN_IOCTL_TYPE 0xA2 @@ -52,5 +121,7 @@ struct acrn_vm_creation { _IO(ACRN_IOCTL_TYPE, 0x13) #define ACRN_IOCTL_RESET_VM \ _IO(ACRN_IOCTL_TYPE, 0x15) +#define ACRN_IOCTL_SET_VCPU_REGS \ + _IOW(ACRN_IOCTL_TYPE, 0x16, struct acrn_vcpu_regs) #endif /* _UAPI_ACRN_H */ -- 2.28.0