Commit 4ce1cf7b authored by Pierre Morel's avatar Pierre Morel Committed by Michael S. Tsirkin

s390: virtio: PV needs VIRTIO I/O device protection

If protected virtualization is active on s390, VIRTIO has only retricted
access to the guest memory.
Define CONFIG_ARCH_HAS_RESTRICTED_VIRTIO_MEMORY_ACCESS and export
arch_has_restricted_virtio_memory_access to advertize VIRTIO if that's
the case.
Signed-off-by: default avatarPierre Morel <pmorel@linux.ibm.com>
Reviewed-by: default avatarCornelia Huck <cohuck@redhat.com>
Reviewed-by: default avatarHalil Pasic <pasic@linux.ibm.com>
Link: https://lore.kernel.org/r/1599728030-17085-3-git-send-email-pmorel@linux.ibm.comSigned-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
Acked-by: default avatarChristian Borntraeger <borntraeger@de.ibm.com>
parent 0afa15e1
...@@ -820,6 +820,7 @@ menu "Virtualization" ...@@ -820,6 +820,7 @@ menu "Virtualization"
config PROTECTED_VIRTUALIZATION_GUEST config PROTECTED_VIRTUALIZATION_GUEST
def_bool n def_bool n
prompt "Protected virtualization guest support" prompt "Protected virtualization guest support"
select ARCH_HAS_RESTRICTED_VIRTIO_MEMORY_ACCESS
help help
Select this option, if you want to be able to run this Select this option, if you want to be able to run this
kernel as a protected virtualization KVM guest. kernel as a protected virtualization KVM guest.
......
...@@ -45,6 +45,7 @@ ...@@ -45,6 +45,7 @@
#include <asm/kasan.h> #include <asm/kasan.h>
#include <asm/dma-mapping.h> #include <asm/dma-mapping.h>
#include <asm/uv.h> #include <asm/uv.h>
#include <linux/virtio_config.h>
pgd_t swapper_pg_dir[PTRS_PER_PGD] __section(.bss..swapper_pg_dir); pgd_t swapper_pg_dir[PTRS_PER_PGD] __section(.bss..swapper_pg_dir);
...@@ -160,6 +161,16 @@ bool force_dma_unencrypted(struct device *dev) ...@@ -160,6 +161,16 @@ bool force_dma_unencrypted(struct device *dev)
return is_prot_virt_guest(); return is_prot_virt_guest();
} }
#ifdef CONFIG_ARCH_HAS_RESTRICTED_VIRTIO_MEMORY_ACCESS
int arch_has_restricted_virtio_memory_access(void)
{
return is_prot_virt_guest();
}
EXPORT_SYMBOL(arch_has_restricted_virtio_memory_access);
#endif
/* protected virtualization */ /* protected virtualization */
static void pv_init(void) static void pv_init(void)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment