Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2384825imm; Sat, 28 Jul 2018 16:11:20 -0700 (PDT) X-Google-Smtp-Source: AAOMgpe619sYXS5lYLxyY9XXEredAYXC4jYBADjd/4j/z0uG2DAbrsuVrv0Z6XSd/M7Xez+72ljB X-Received: by 2002:a62:dc1d:: with SMTP id t29-v6mr12296148pfg.244.1532819480354; Sat, 28 Jul 2018 16:11:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532819480; cv=none; d=google.com; s=arc-20160816; b=lNPsgzPJNtQWZ/TF2eZewqElC6+20vsqWaVhEg2oz6o49Rj/7l107dPvTCVg+Vd7Ub wssfv+5tO8NjEQmlo4O5TJjZP+rh6ZXm1FKmt6IKYnXbxQgZ8OWz6aTeo32otRhO5rDh K72rCPUxLTVQ3soFxGJEaUjGRUWLwVxKvdF0amxeR3xDQVvcWbGS+UbadY5BvqbgqLp5 lZcApGHkBsXg422Bumw0ZSuC8POkCQLkBHpWGaHOBEbuWXijkfBKVkstEvf0yhvR6iWu uOdzYIhLVVsRCgCDBj3wybxdffeVvqQt2n4oY7ibygfOnHQ6+G7rgzHeCmhQvJ0bWXkW j8IA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=WGX8jRFu+0DafYkuN8ixelyiU0xos9Kit4DLHmelkfQ=; b=AexNAwwRK6GkgHqh3LT/h6gqjdXfWdPR5C3BtyK4Fj0bcSEjrL/0EC9kpvqCRv05ZA YZoGS9Za1oLgOfcSkGUPh2O+qaK0S4/F6DUKq2jPklGmB0xiv73SErhI6GmIsZYFCk3A siedHZlpozXmQLCUHqy0nrScnDjWfDO5aANo4LsIWKRBlHJ8Q55dvV3nSl4eQO+iOwV7 aH3jAdC4QuIYfHahK9hBmQVXqpj563PyBhEnvGHeJqJPPfDqrLlKvV4mdKeNtGl4YfcS UYKd0tdTftRuhgixeFlTGuM/Fluh8wbm/YMJ3bhZtDYaTr2hfvqOYVecK1yBUDaP2pzC m7iw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=SeU2rkI1; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t128-v6si7960447pfc.194.2018.07.28.16.11.05; Sat, 28 Jul 2018 16:11:20 -0700 (PDT) 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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=SeU2rkI1; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731529AbeG2Ai1 (ORCPT + 99 others); Sat, 28 Jul 2018 20:38:27 -0400 Received: from mail-wm0-f66.google.com ([74.125.82.66]:51485 "EHLO mail-wm0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731435AbeG2Ai1 (ORCPT ); Sat, 28 Jul 2018 20:38:27 -0400 Received: by mail-wm0-f66.google.com with SMTP id y2-v6so9103295wma.1; Sat, 28 Jul 2018 16:10:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id; bh=WGX8jRFu+0DafYkuN8ixelyiU0xos9Kit4DLHmelkfQ=; b=SeU2rkI1UWOWIYbpDYSl07cCkVkJTxXXcZ5xgE+danCu4EkVSQI25gDzC/mm5JcwK0 T9tM2M7e3w3adwO4cF/3x4Iaz+o3262L7T2e4nOetMB90UIBGx621FoH3oPvkHu+/UWg Pyzyokoqgg3EW4QyA4mEUMmExXdF2BZFa2twLMh+GTLUh/RjU2Og36Bq4bjEEEkMpEco 7rZF8YG4R2F+GzzfCJ7C7HUzWdUJa6CRKyQAJZNBMjxaTuDLvRaTT7IUEutKRrcKRU9O 20bx1/UTlx+8vY21Lx+M/A6biWrBA6PtMjA2mh+3+HtnEF8ga9a9Bu2CLAQxErhWy6XS yfZA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id; bh=WGX8jRFu+0DafYkuN8ixelyiU0xos9Kit4DLHmelkfQ=; b=Cw0DJHLzSYiwBS6omSIFvvEv33tegrHFfKxihDjeLlsWQ5T8ZgOBfvXdwjRok48XNm O7z9+RnRMe1X2gDxKdXrckfJVhXX2TxGfVYM3+zXAj2nx78neKfzEOQSzN+nQ7Cq0zGp N1+UUTrbbI3MiVvq7aQCE15xFlTdnRQDDY/vZWqnl5+k+J7ZIQNElSjQqWfQ5IX02epL 2IEXyLk37jds3K0oxCqA1eqvM8gwxzcqmES6HJwQyBBiUFmibn02a8XTaEKdk4bwocml brvf1qRJLnNDAXyHTybrB/794rTsKnm0O5SUcqaqNhPMMeydOHBGEc+OPTzzdf0oZ+4s 1gfA== X-Gm-Message-State: AOUpUlE6QVu/8PybuuzoJHculvDaAMYDbTG84hcBFudkppeVFaw/qKrH twHvLJlcMcbFGqwebitXrQYFKK2e X-Received: by 2002:a1c:c60a:: with SMTP id w10-v6mr9447964wmf.26.1532819415522; Sat, 28 Jul 2018 16:10:15 -0700 (PDT) Received: from 640k.lan (94-36-184-250.adsl-ull.clienti.tiscali.it. [94.36.184.250]) by smtp.gmail.com with ESMTPSA id j6-v6sm6190725wro.13.2018.07.28.16.10.14 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sat, 28 Jul 2018 16:10:14 -0700 (PDT) From: Paolo Bonzini To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Liran Alon , KarimAllah Ahmed , Jim Mattson , rkrcmar@redhat.com Subject: [PATCH v6 00/10] kvm: x86: migration of nested virtualization state Date: Sun, 29 Jul 2018 01:10:02 +0200 Message-Id: <1532819412-51357-1-git-send-email-pbonzini@redhat.com> X-Mailer: git-send-email 1.8.3.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is the next version of the nested virtualization migration series, now with unit tests too. Patches 6, 7, and 9 replace the (broken) WIP patches in the kvm/queue branch, while the other seven are new and related to the tests. In particular, patch 1 is an independent bugfix, which makes it much simpler to use KVM_GET_MSR/KVM_SET_MSR in a simple userspace client such as the new test. Patches 2-4 are also improvements and bugfixes to the unit test infrastructure. Please review (especially the non-test patches of course!). Thanks, Paolo Jim Mattson (1): kvm: nVMX: Introduce KVM_CAP_NESTED_STATE Paolo Bonzini (9): KVM: x86: ensure all MSRs can always be KVM_GET/SET_MSR'd kvm: selftests: create a GDT and TSS kvm: selftests: actually use all of lib/vmx.c kvm: selftests: ensure vcpu file is released kvm: selftests: add basic test for state save and restore KVM: x86: do not load vmcs12 pages while still in SMM kvm: selftests: add test for nested state save/restore KVM: nVMX: include shadow vmcs12 in nested state KVM: selftests: add tests for shadow VMCS save/restore Documentation/virtual/kvm/api.txt | 56 ++++ arch/x86/include/asm/kvm_host.h | 9 arch/x86/include/uapi/asm/kvm.h | 37 ++ arch/x86/kvm/hyperv.c | 27 +- arch/x86/kvm/hyperv.h | 2 arch/x86/kvm/vmx.c | 255 ++++++++++++++++++- arch/x86/kvm/x86.c | 71 +++++ include/uapi/linux/kvm.h | 4 tools/testing/selftests/kvm/Makefile | 1 tools/testing/selftests/kvm/cr4_cpuid_sync_test.c | 2 tools/testing/selftests/kvm/include/kvm_util.h | 4 tools/testing/selftests/kvm/include/vmx.h | 66 ++++- tools/testing/selftests/kvm/include/x86.h | 8 tools/testing/selftests/kvm/lib/kvm_util.c | 102 ++++++- tools/testing/selftests/kvm/lib/kvm_util_internal.h | 7 tools/testing/selftests/kvm/lib/vmx.c | 104 +++++--- tools/testing/selftests/kvm/lib/x86.c | 256 ++++++++++++++++---- tools/testing/selftests/kvm/state_test.c | 224 +++++++++++++++++ tools/testing/selftests/kvm/vmx_tsc_adjust_test.c | 69 +---- 19 files changed, 1105 insertions(+), 199 deletions(-)