APPLIED: [SRU][J][PULL] KVM: Secure Execution guest dump encryption with customer keys
Stefan Bader
stefan.bader at canonical.com
Fri Sep 6 15:36:59 UTC 2024
On 30.08.24 11:34, frank.heimes at canonical.com wrote:
> BugLink: https://bugs.launchpad.net/bugs/1959940
>
> [ Impact ]
>
> * Hypervisor-initiated dumps for Secure Execution
> (aka confidential computing) guests are not helpful,
> because memory and CPU state is encrypted by a
> transient key only available to the Ultravisor (uv).
>
> * Workload owners can still configure kdump in order to obtain kernel
> crash information, but there are situation where kdump doesn't work.
>
> * In such situations problem determination is severely impeded.
>
> * This patch set solves this by implementing dumps created in a way
> that can only be decrypted by the owner of the guest image
> and be used for problem determination.
>
> [ Test Plan ]
>
> * The setup of a Secure Execution environment is not trivial
> and requires a certain set of hardware (IBM z15 or higher)
> with FC 115).
>
> * On top of the modification of qemu that are handled in this
> LP bug, modifications of the Kernel (LP#1959940) and
> the s390-tools (LP#1959965) are required on top.
>
> * So at least a modified kernel and qemu test builds are needed
> or both should be in -proposed at the same time (which might
> be difficult).
> A modified s390-tools is not urgently needed, since for the
> verification of the kernel and qemu part a newer version
> can be used (but a modified s390-tools is also available in PPA).
>
> * A detailed description (using Ubuntu as example) on how to setup
> secure execution is available here:
> Introducing IBM Secure Execution for Linux, April 2024 update
> https://www.ibm.com/docs/en/linuxonibm/pdf/lx24se04.pdf
>
> * And information on 'Working with dumps of KVM guests in
> IBM Secure Execution mode' is available here:
> https://www.ibm.com/docs/en/linux-on-systems\
> ?topic=commands-zgetdump#czgetdump__se_dump_examples
>
> [ Where problems could occur ]
>
> * Ultravisor (uv) return codes are introduced, which is
> generally appreciated. Just the right return codes need to be set
> (and reacted upon).
>
> * Protected virtual machine dumps are newly introduced on top of
> dump of 'normal' KVM VMs.
> Since code is shared, it could have an unforeseen impact.
>
> * The doc renaming could lead to confusion,
> if people rely on old doc structure.
>
> * The new capability case (217) could cause issues,
> for example is case of issues during initialization..
>
> * CPU dump functionality was added (mainly as new s390x specific code
> under s390/kvm), but CPU dump is only one part,
> if not working correctly, it may lead to partially useless dump data.
>
> * Configuration dump functionality was also added
> (again mainly as new s390x specific code under s390/kvm),
> similar to CPU dump.
> And moving from dumping inside of a VM to dumping from outside
> (due to potential failures if done inside), might lead to a more
> complex flow (now involving the uv), hence could be more error prone.
>
> * Adding query dump information, requires user space buffers.
> Here it's crucial that buffer size is big enough.
>
> * The newly added constants and structure definitions that are
> needed for dump support could become problematic in case wrong
> data types were used (applies to all header modifications).
>
> * IOCTL for PV information retrieval got introduced
> (kvm_s390_handle_pv_info, kvm_s390_handle_pv).
> There are potential side effect (see man ioctl),
> hence all potential failure cases should be covered.
>
> * New dump feature requires to know how much memory is needed, but if
> this call for this is incorrect, it could break the dump process.
>
> * uv_cb_header struct changed to offset representation,
> but using wrong offsets will lead to a wrong struct,
> dump issues and potential crashes.
>
> [ Other Info ]
>
> * Since 22.04 is a popular LTS release, it is already in use by many
> secure execution customers.
> But in case of severe crashes or issues in the secure execution
> (KVM) guests dumps cannot be used as of today.
>
> * This enables customers, IBM and Canonical to get support in case of
> crashes/dumps on hardware that runs secure execution environments.
>
> The following changes since commit 26e0f85b437d70d39acea1321f64dffe6608319d:
>
> UBUNTU: Upstream stable to v5.15.162 (2024-07-26 11:56:43 +0200)
>
> are available in the Git repository at:
>
> https://git.launchpad.net/~fheimes/+git/lp1959940j/ 0d574dbec328ae55aea03cf010e4998b02dda47f
>
> for you to fetch changes up to 0d574dbec328ae55aea03cf010e4998b02dda47f:
>
> Documentation/virt/kvm/api.rst: Explain rc/rrc delivery (2024-08-29 08:35:21 +0200)
>
> ----------------------------------------------------------------
> Janosch Frank (12):
> s390: uv: Add offset comments to UV query struct and fix naming
> s390/uv: Add SE hdr query information
> s390/uv: Add dump fields to query
> KVM: s390: pv: Add query interface
> KVM: s390: pv: Add dump support definitions
> KVM: s390: pv: Add query dump information
> KVM: s390: Add configuration dump functionality
> KVM: s390: Add CPU dump functionality
> KVM: s390: Add KVM_CAP_S390_PROTECTED_DUMP
> Documentation: virt: Protected virtual machine dumps
> Documentation/virt/kvm/api.rst: Add protvirt dump/info api descriptions
> Documentation/virt/kvm/api.rst: Explain rc/rrc delivery
>
> Paolo Bonzini (1):
> Documentation: KVM: add separate directories for architecture-specific documentation
>
> Documentation/virt/kvm/api.rst | 161 +++++++++++-
> Documentation/virt/kvm/index.rst | 26 +-
> Documentation/virt/kvm/s390/index.rst | 13 +
> Documentation/virt/kvm/{ => s390}/s390-diag.rst | 0
> Documentation/virt/kvm/{ => s390}/s390-pv-boot.rst | 0
> Documentation/virt/kvm/s390/s390-pv-dump.rst | 64 +++++
> Documentation/virt/kvm/{ => s390}/s390-pv.rst | 0
> .../virt/kvm/{ => x86}/amd-memory-encryption.rst | 0
> Documentation/virt/kvm/{ => x86}/cpuid.rst | 0
> Documentation/virt/kvm/{ => x86}/halt-polling.rst | 0
> Documentation/virt/kvm/{ => x86}/hypercalls.rst | 0
> Documentation/virt/kvm/x86/index.rst | 18 ++
> Documentation/virt/kvm/{ => x86}/mmu.rst | 0
> Documentation/virt/kvm/{ => x86}/msr.rst | 0
> Documentation/virt/kvm/{ => x86}/nested-vmx.rst | 0
> .../virt/kvm/{ => x86}/running-nested-guests.rst | 0
> Documentation/virt/kvm/{ => x86}/timekeeping.rst | 0
> arch/s390/boot/uv.c | 4 +
> arch/s390/include/asm/kvm_host.h | 1 +
> arch/s390/include/asm/uv.h | 77 ++++--
> arch/s390/kernel/uv.c | 53 ++++
> arch/s390/kvm/kvm-s390.c | 269 +++++++++++++++++++++
> arch/s390/kvm/kvm-s390.h | 5 +
> arch/s390/kvm/pv.c | 198 +++++++++++++++
> include/uapi/linux/kvm.h | 55 +++++
> 25 files changed, 906 insertions(+), 38 deletions(-)
> create mode 100644 Documentation/virt/kvm/s390/index.rst
> rename Documentation/virt/kvm/{ => s390}/s390-diag.rst (100%)
> rename Documentation/virt/kvm/{ => s390}/s390-pv-boot.rst (100%)
> create mode 100644 Documentation/virt/kvm/s390/s390-pv-dump.rst
> rename Documentation/virt/kvm/{ => s390}/s390-pv.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/amd-memory-encryption.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/cpuid.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/halt-polling.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/hypercalls.rst (100%)
> create mode 100644 Documentation/virt/kvm/x86/index.rst
> rename Documentation/virt/kvm/{ => x86}/mmu.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/msr.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/nested-vmx.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/running-nested-guests.rst (100%)
> rename Documentation/virt/kvm/{ => x86}/timekeeping.rst (100%)
>
Applied to jammy:linux/master-next. Thanks.
-Stefan
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_0xE8675DEECBEECEA3.asc
Type: application/pgp-keys
Size: 48643 bytes
Desc: OpenPGP public key
URL: <https://lists.ubuntu.com/archives/kernel-team/attachments/20240906/26114a1b/attachment-0001.key>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: OpenPGP_signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <https://lists.ubuntu.com/archives/kernel-team/attachments/20240906/26114a1b/attachment-0001.sig>
More information about the kernel-team
mailing list