Re: [PATCH v2 00/21] Enable CET Virtualization

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Apr 22, 2023 at 12:54:11AM +0300, Mike Rapoport wrote:
> Hi,
> 
> On Fri, Apr 21, 2023 at 09:45:54AM -0400, Yang Weijiang wrote:
> >
> > Tests:
> > --------------------------------------------------------------------------
> > This series passed basic CET user shadow stack test and kernel IBT test in
> > L1 and L2 guest. It also passed CET KUT test which has been merged there.
> > 
> > Executed all KUT tests and KVM selftests against this series, all test cases
> > passes except the vmx test, the failure is due to CR4_CET bit testing in
> > test_vmxon_bad_cr(). After add CR4_CET bit to skip list, the test passed.
> > I'll send a patch to fix this issue later.
> > 
> > 
> > To run user shadow stack test and kernel IBT test in VM, you need an CET
> > capable platform, e.g., Sapphire Rapids server, and follow below steps to
> > build host/guest kernel properly:
> > 
> > 1. Buld host kernel. Patch this series to kernel tree and build kernel
> > with CET capable gcc version(e.g., >=8.5.0).
> > 
> > 2. Build guest kernel. Patch CET native series to kernel tree and opt-in
> > CONFIG_X86_KERNEL_IBT and CONFIG_X86_USER_SHADOW_STACK options.
> > 
> > 3. Launch a VM with QEMU built with CET enabling patches [2].
> > 
> > Check kernel selftest test_shadow_stack_64 output:
> > [INFO]  new_ssp = 7f8c82100ff8, *new_ssp = 7f8c82101001
> > [INFO]  changing ssp from 7f8c82900ff0 to 7f8c82100ff8
> > [INFO]  ssp is now 7f8c82101000
> > [OK]    Shadow stack pivot
> > [OK]    Shadow stack faults
> > [INFO]  Corrupting shadow stack
> > [INFO]  Generated shadow stack violation successfully
> > [OK]    Shadow stack violation test
> > [INFO]  Gup read -> shstk access success
> > [INFO]  Gup write -> shstk access success
> > [INFO]  Violation from normal write
> > [INFO]  Gup read -> write access success
> > [INFO]  Violation from normal write
> > [INFO]  Gup write -> write access success
> > [INFO]  Cow gup write -> write access success
> > [OK]    Shadow gup test
> > [INFO]  Violation from shstk access
> > [OK]    mprotect() test
> > [SKIP]  Userfaultfd unavailable.
> > [OK]    32 bit test
> > 
> > Check kernel IBT with dmesg | grep CET:
> > CET detected: Indirect Branch Tracking enabled
> > 
> > --------------------------------------------------------------------------
> > Changes in v2:
> > 1. Remove excessive checks on host CET Kconfig options in v1 patchset [3].
> > 2. Make CET CPUIDs, MSRs and control flags enabling independent to host CET status.
> > 3. Introduce supervisor SHSTK support to make the patch set complete.
> > 4. Refactor patches to accommodate above changes.
> > 5. Rebase on kvm-x86/next [4].
> > 
> > 
> > [1]: linux-next: https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/tree/?h=next-20230420
> > [2]: QEMU patch: https://lore.kernel.org/all/20230421041227.90915-1-weijiang.yang@xxxxxxxxx/
> > [3]: v1 patchset: https://lore.kernel.org/all/20220616084643.19564-1-weijiang.yang@xxxxxxxxx/
> > [4]: Rebase branch: https://github.com/kvm-x86/linux.git, commit: 7b632f72528d (tag: kvm-x86-next-2023.04.14)
>  
> I played a bit with KVM support for shadow stacks on AMD machines and I
> rebased v1 patches along with John's SVM series 
> 
> https://lore.kernel.org/kvm/20221012203910.204793-1-john.allen@xxxxxxx/
> 
> on top of v6.3-rc4 and Rick's series for host shadow stack support. I've
> put this at
> 
> https://git.kernel.org/pub/scm/linux/kernel/git/rppt/linux.git/log/?h=shstk/kvm
> 
> if anybody is interested. With this I could successfully run shadow stack
> self test in a guest on an AMD Zen3 machine.

That's great news! Thanks for testing!

Thanks,
John

> 
> One thing I've noticed while rebasing is that John's patches move
> cet_is_msr_accessible() from vmx/ to x86.c and I also had to make such move
> for cet_is_ssp_msr_accessible().
> 
> Would make sense to have them available for both VMX and SVM from the
> start.
> 
> > Rick Edgecombe (5):
> >   x86/shstk: Add Kconfig option for shadow stack
> >   x86/cpufeatures: Add CPU feature flags for shadow stacks
> >   x86/cpufeatures: Enable CET CR4 bit for shadow stack
> >   x86/fpu/xstate: Introduce CET MSR and XSAVES supervisor states
> >   x86/fpu: Add helper for modifying xstate
> > 
> > Sean Christopherson (2):
> >   KVM:x86: Report XSS as to-be-saved if there are supported features
> >   KVM:x86: Load guest FPU state when accessing xsaves-managed MSRs
> > 
> > Yang Weijiang (14):
> >   KVM:x86: Refresh CPUID on write to guest MSR_IA32_XSS
> >   KVM:x86: Init kvm_caps.supported_xss with supported feature bits
> >   KVM:x86: Add #CP support in guest exception classification
> >   KVM:VMX: Introduce CET VMCS fields and control bits
> >   KVM:x86: Add fault checks for guest CR4.CET setting
> >   KVM:VMX: Emulate reads and writes to CET MSRs
> >   KVM:VMX: Add a synthetic MSR to allow userspace VMM to access
> >     GUEST_SSP
> >   KVM:x86: Report CET MSRs as to-be-saved if CET is supported
> >   KVM:x86: Save/Restore GUEST_SSP to/from SMM state save area
> >   KVM:VMX: Pass through user CET MSRs to the guest
> >   KVM:x86: Enable CET virtualization for VMX and advertise to userspace
> >   KVM:nVMX: Enable user CET support for nested VMX
> >   KVM:x86: Enable supervisor IBT support for guest
> >   KVM:x86: Support CET supervisor shadow stack MSR access
> > 
> >  arch/x86/Kconfig                         |  24 ++++
> >  arch/x86/Kconfig.assembler               |   5 +
> >  arch/x86/include/asm/cpufeatures.h       |   2 +
> >  arch/x86/include/asm/disabled-features.h |   8 +-
> >  arch/x86/include/asm/fpu/api.h           |   9 ++
> >  arch/x86/include/asm/fpu/types.h         |  16 ++-
> >  arch/x86/include/asm/fpu/xstate.h        |   6 +-
> >  arch/x86/include/asm/kvm_host.h          |   3 +-
> >  arch/x86/include/asm/vmx.h               |   8 ++
> >  arch/x86/include/uapi/asm/kvm.h          |   1 +
> >  arch/x86/include/uapi/asm/kvm_para.h     |   1 +
> >  arch/x86/kernel/cpu/common.c             |  35 ++++--
> >  arch/x86/kernel/cpu/cpuid-deps.c         |   1 +
> >  arch/x86/kernel/fpu/core.c               |  19 +++
> >  arch/x86/kernel/fpu/xstate.c             |  90 +++++++-------
> >  arch/x86/kvm/cpuid.c                     |  23 +++-
> >  arch/x86/kvm/cpuid.h                     |   6 +
> >  arch/x86/kvm/smm.c                       |  20 +++
> >  arch/x86/kvm/vmx/capabilities.h          |   4 +
> >  arch/x86/kvm/vmx/nested.c                |  29 ++++-
> >  arch/x86/kvm/vmx/vmcs12.c                |   6 +
> >  arch/x86/kvm/vmx/vmcs12.h                |  14 ++-
> >  arch/x86/kvm/vmx/vmx.c                   | 150 ++++++++++++++++++++++-
> >  arch/x86/kvm/vmx/vmx.h                   |   6 +-
> >  arch/x86/kvm/x86.c                       |  79 ++++++++++--
> >  arch/x86/kvm/x86.h                       |  46 ++++++-
> >  26 files changed, 528 insertions(+), 83 deletions(-)
> > 
> > 
> > base-commit: 7b632f72528d5fa3f0265358a393f534da47d9dd
> > -- 
> > 2.27.0
> > 
> 
> -- 
> Sincerely yours,
> Mike.



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux