2021-07-19 14:21:05 +03:00
|
|
|
/*
|
|
|
|
* QEMU host SGX EPC memory backend
|
|
|
|
*
|
|
|
|
* Copyright (C) 2019 Intel Corporation
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Sean Christopherson <sean.j.christopherson@intel.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
|
|
* See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "qemu/osdep.h"
|
2023-02-02 16:38:27 +03:00
|
|
|
#include <sys/ioctl.h>
|
2021-07-19 14:21:05 +03:00
|
|
|
#include "qom/object_interfaces.h"
|
|
|
|
#include "qapi/error.h"
|
|
|
|
#include "sysemu/hostmem.h"
|
|
|
|
#include "hw/i386/hostmem-epc.h"
|
|
|
|
|
2023-11-20 15:50:52 +03:00
|
|
|
static bool
|
2021-07-19 14:21:05 +03:00
|
|
|
sgx_epc_backend_memory_alloc(HostMemoryBackend *backend, Error **errp)
|
|
|
|
{
|
2023-11-20 14:59:15 +03:00
|
|
|
g_autofree char *name = NULL;
|
2021-07-19 14:21:05 +03:00
|
|
|
uint32_t ram_flags;
|
|
|
|
int fd;
|
|
|
|
|
|
|
|
if (!backend->size) {
|
|
|
|
error_setg(errp, "can't create backend with size 0");
|
2023-11-20 15:50:52 +03:00
|
|
|
return false;
|
2021-07-19 14:21:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
fd = qemu_open_old("/dev/sgx_vepc", O_RDWR);
|
|
|
|
if (fd < 0) {
|
|
|
|
error_setg_errno(errp, errno,
|
|
|
|
"failed to open /dev/sgx_vepc to alloc SGX EPC");
|
2023-11-20 15:50:52 +03:00
|
|
|
return false;
|
2021-07-19 14:21:05 +03:00
|
|
|
}
|
|
|
|
|
2024-06-05 13:44:58 +03:00
|
|
|
backend->aligned = true;
|
2021-07-19 14:21:05 +03:00
|
|
|
name = object_get_canonical_path(OBJECT(backend));
|
|
|
|
ram_flags = (backend->share ? RAM_SHARED : 0) | RAM_PROTECTED;
|
2023-11-20 15:50:52 +03:00
|
|
|
return memory_region_init_ram_from_fd(&backend->mr, OBJECT(backend), name,
|
|
|
|
backend->size, ram_flags, fd, 0, errp);
|
2021-07-19 14:21:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static void sgx_epc_backend_instance_init(Object *obj)
|
|
|
|
{
|
|
|
|
HostMemoryBackend *m = MEMORY_BACKEND(obj);
|
|
|
|
|
|
|
|
m->share = true;
|
|
|
|
m->merge = false;
|
|
|
|
m->dump = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void sgx_epc_backend_class_init(ObjectClass *oc, void *data)
|
|
|
|
{
|
|
|
|
HostMemoryBackendClass *bc = MEMORY_BACKEND_CLASS(oc);
|
|
|
|
|
|
|
|
bc->alloc = sgx_epc_backend_memory_alloc;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const TypeInfo sgx_epc_backed_info = {
|
|
|
|
.name = TYPE_MEMORY_BACKEND_EPC,
|
|
|
|
.parent = TYPE_MEMORY_BACKEND,
|
|
|
|
.instance_init = sgx_epc_backend_instance_init,
|
|
|
|
.class_init = sgx_epc_backend_class_init,
|
|
|
|
.instance_size = sizeof(HostMemoryBackendEpc),
|
|
|
|
};
|
|
|
|
|
|
|
|
static void register_types(void)
|
|
|
|
{
|
|
|
|
int fd = qemu_open_old("/dev/sgx_vepc", O_RDWR);
|
|
|
|
if (fd >= 0) {
|
|
|
|
close(fd);
|
|
|
|
|
|
|
|
type_register_static(&sgx_epc_backed_info);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type_init(register_types);
|