From nobody Fri Dec 09 13:18:58 2022 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4NTBS30k94z4kWWD; Fri, 9 Dec 2022 13:18:59 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4NTBS30D9nz424Z; Fri, 9 Dec 2022 13:18:59 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1670591939; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=YUDWb5Mw3YeRLDAoyEKss/5vl2+QPs6x2uLBrQOsl5E=; b=E8mrIPvr1b5dz2Z75tzKxTNhfHxS4QXjTVLF0R2Pmno1f2AcwJrZ1P4BB7m3+CeGAPRtDq +/KPoWC0DUEnMFsfuFNlBFuGzmRHtiqFq3AdPWNcmgsiZVXiZksNx+jqpi07ot+J14P1Xb W0zaDv/ZWK6Hzz4PCrdSZsNdl4Q2i7VHAhNw9LtJUvPmYpfIYmnIQ1aJwe4Un6PgPQX9uo S94akqkl/PRbkJ7iztjvgkxiGJ6pLGP2KonhpZDcX7FGsKer0FD6iAvJZDLQJHC2gpC8Bm +r1I0jaKbSNAkQCPZt2Mc6kEeUSE2HUerbKe6VvS/M11M6102l6s+t4bBUiQMA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1670591939; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=YUDWb5Mw3YeRLDAoyEKss/5vl2+QPs6x2uLBrQOsl5E=; b=UHI1K1JDhPxG+gEkE+NbD3iPvKl5j1R9hgw5MVno5/2FpaA9psgOgFXZhE00Ri0w4iZNWh TlYPgLodstPzr265dURw9GMsAmuW2RHLR9RK7laEI33PXusBIVympepUUUr1QCUkaJ3Slt UxEJR8+Qai0LkgKMKsQr2Qy1JZS0cQQp0DwH8aU1wsK3IeGJA8Zm2jlh+pvtkgXIpy1jjP DEvAXy+sDOabgadvooxGncXiNzEoE5TumEuR0wzEpANNH1GHQjrw4KLBD9/Oxdbs4r5TsR 4Jj7BW1htgfMoYNi/YwgVVR/PoX40xa5NBmp7Mu6MvAz2rb42tEsVqSlfczGkw== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1670591939; a=rsa-sha256; cv=none; b=S6IJHiRfVClohd9LZnQ0R2enjE3lJzExaJ8FAi6nvmwIAi+3qsu7lv2y0ZMtpP1wmegxsH qkP1dHc9qaP6FTOo92UkBDLiD8FpSOZNX2WZvc291VfD9O5NCv9c9zfax7tTMVWN1ifaPI t61BrLncs3N3tGZjHNpWDNt2zylhN49ExDf4L+wE7jlR9GS2+yUFEKnfd7ltgFr3VXEX66 GSfPVtuyl9R4R/LMLo30lkZJCZ6ru3dgSgAOv0eOvOEODuT+L1OlbPrw3sH8c5z1g1ka2A Ct+WJHhTly2WAzZ24qt/JSXVm8Rex2Hswq7saWDkfpWE3lw5CxmF+QfwKIDu0A== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4NTBS26QSlzcmn; Fri, 9 Dec 2022 13:18:58 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 2B9DIwdt072738; Fri, 9 Dec 2022 13:18:58 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 2B9DIw0V072737; Fri, 9 Dec 2022 13:18:58 GMT (envelope-from git) Date: Fri, 9 Dec 2022 13:18:58 GMT Message-Id: <202212091318.2B9DIw0V072737@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: =?utf-8?Q?Corvin=20K=C3=B6hne?= Subject: git: 5f7fc790c64f - stable/13 - bhyve: create all vcpus on startup List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: corvink X-Git-Repository: src X-Git-Refname: refs/heads/stable/13 X-Git-Reftype: branch X-Git-Commit: 5f7fc790c64fb120cd6918db84e985d40b874661 Auto-Submitted: auto-generated X-ThisMailContainsUnwantedMimeParts: N The branch stable/13 has been updated by corvink: URL: https://cgit.FreeBSD.org/src/commit/?id=5f7fc790c64fb120cd6918db84e985d40b874661 commit 5f7fc790c64fb120cd6918db84e985d40b874661 Author: Corvin Köhne AuthorDate: 2022-09-07 07:05:36 +0000 Commit: Corvin Köhne CommitDate: 2022-12-09 13:18:04 +0000 bhyve: create all vcpus on startup vcpus could be restarted by the guest by sending an INIT SIPI SIPI sequence to a vcpu. That's not supported by bhyve yet but it will be supported in a future commit. So, create the vcpu threads only once on startup to make restarting a vcpu easier. MFC after: 2 weeks Differential Revision: https://reviews.freebsd.org/D35621 Sponsored by: Beckhoff Automation GmbH & Co. KG (cherry picked from commit 9cc9abf409cc9d761f42b16b0dc8f5c0cc4f9a44) --- usr.sbin/bhyve/bhyverun.c | 41 ++++++++++++++++------------------------- usr.sbin/bhyve/bhyverun.h | 1 - usr.sbin/bhyve/spinup_ap.c | 4 ++-- usr.sbin/bhyve/spinup_ap.h | 2 +- 4 files changed, 19 insertions(+), 29 deletions(-) diff --git a/usr.sbin/bhyve/bhyverun.c b/usr.sbin/bhyve/bhyverun.c index 27166d9046e5..c1e0904d13ed 100644 --- a/usr.sbin/bhyve/bhyverun.c +++ b/usr.sbin/bhyve/bhyverun.c @@ -547,13 +547,11 @@ fbsdrun_start_thread(void *param) return (NULL); } -void -fbsdrun_addcpu(struct vmctx *ctx, int fromcpu, int newcpu, uint64_t rip) +static void +fbsdrun_addcpu(struct vmctx *ctx, int newcpu, uint64_t rip, bool suspend) { int error; - assert(fromcpu == BSP); - /* * The 'newcpu' must be activated in the context of 'fromcpu'. If * vm_activate_cpu() is delayed until newcpu's pthread starts running @@ -566,6 +564,9 @@ fbsdrun_addcpu(struct vmctx *ctx, int fromcpu, int newcpu, uint64_t rip) CPU_SET_ATOMIC(newcpu, &cpumask); + if (suspend) + vm_suspend_cpu(ctx, newcpu); + /* * Set up the vmexit struct to allow execution to start * at the given RIP @@ -688,8 +689,7 @@ static int vmexit_spinup_ap(struct vmctx *ctx, struct vm_exit *vme, int *pvcpu) { - (void)spinup_ap(ctx, *pvcpu, - vme->u.spinup_ap.vcpu, vme->u.spinup_ap.rip); + (void)spinup_ap(ctx, vme->u.spinup_ap.vcpu, vme->u.spinup_ap.rip); return (VMEXIT_CONTINUE); } @@ -1127,8 +1127,8 @@ do_open(const char *vmname) return (ctx); } -void -spinup_vcpu(struct vmctx *ctx, int vcpu) +static void +spinup_vcpu(struct vmctx *ctx, int vcpu, bool suspend) { int error; uint64_t rip; @@ -1140,7 +1140,7 @@ spinup_vcpu(struct vmctx *ctx, int vcpu) error = vm_set_capability(ctx, vcpu, VM_CAP_UNRESTRICTED_GUEST, 1); assert(error == 0); - fbsdrun_addcpu(ctx, BSP, vcpu, rip); + fbsdrun_addcpu(ctx, vcpu, rip, suspend); } static bool @@ -1569,25 +1569,16 @@ main(int argc, char *argv[]) mt_vmm_info = calloc(guest_ncpus, sizeof(*mt_vmm_info)); /* - * Add CPU 0 + * Add all vCPUs. */ - fbsdrun_addcpu(ctx, BSP, BSP, rip); - + for (int vcpu = 0; vcpu < guest_ncpus; vcpu++) { + bool suspend = (vcpu != BSP); #ifdef BHYVE_SNAPSHOT - /* - * If we restore a VM, start all vCPUs now (including APs), otherwise, - * let the guest OS to spin them up later via vmexits. - */ - if (restore_file != NULL) { - for (vcpu = 0; vcpu < guest_ncpus; vcpu++) { - if (vcpu == BSP) - continue; - - fprintf(stdout, "spinning up vcpu no %d...\r\n", vcpu); - spinup_vcpu(ctx, vcpu); - } - } + if (restore_file != NULL) + suspend = false; #endif + spinup_vcpu(ctx, vcpu, suspend); + } /* * Head off to the main event dispatch loop diff --git a/usr.sbin/bhyve/bhyverun.h b/usr.sbin/bhyve/bhyverun.h index d10604011d31..5bd7542d8533 100644 --- a/usr.sbin/bhyve/bhyverun.h +++ b/usr.sbin/bhyve/bhyverun.h @@ -44,7 +44,6 @@ uintptr_t paddr_host2guest(struct vmctx *ctx, void *addr); #endif void fbsdrun_set_capabilities(struct vmctx *ctx, int cpu); -void fbsdrun_addcpu(struct vmctx *ctx, int fromcpu, int newcpu, uint64_t rip); int fbsdrun_virtio_msix(void); #endif diff --git a/usr.sbin/bhyve/spinup_ap.c b/usr.sbin/bhyve/spinup_ap.c index 7c4186f5ed15..2b7e602f8003 100644 --- a/usr.sbin/bhyve/spinup_ap.c +++ b/usr.sbin/bhyve/spinup_ap.c @@ -77,7 +77,7 @@ spinup_ap_realmode(struct vmctx *ctx, int newcpu, uint64_t *rip) } int -spinup_ap(struct vmctx *ctx, int vcpu, int newcpu, uint64_t rip) +spinup_ap(struct vmctx *ctx, int newcpu, uint64_t rip) { int error; @@ -100,7 +100,7 @@ spinup_ap(struct vmctx *ctx, int vcpu, int newcpu, uint64_t rip) spinup_ap_realmode(ctx, newcpu, &rip); - fbsdrun_addcpu(ctx, vcpu, newcpu, rip); + vm_resume_cpu(ctx, newcpu); return (newcpu); } diff --git a/usr.sbin/bhyve/spinup_ap.h b/usr.sbin/bhyve/spinup_ap.h index 226542f6c331..e67bac42944b 100644 --- a/usr.sbin/bhyve/spinup_ap.h +++ b/usr.sbin/bhyve/spinup_ap.h @@ -31,6 +31,6 @@ #ifndef _SPINUP_AP_H_ #define _SPINUP_AP_H_ -int spinup_ap(struct vmctx *ctx, int vcpu, int newcpu, uint64_t rip); +int spinup_ap(struct vmctx *ctx, int newcpu, uint64_t rip); #endif