|  | /* | 
|  | * SGX EPC device | 
|  | * | 
|  | * 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. | 
|  | */ | 
|  | #ifndef QEMU_SGX_EPC_H | 
|  | #define QEMU_SGX_EPC_H | 
|  |  | 
|  | #include "hw/qdev-core.h" | 
|  | #include "hw/i386/hostmem-epc.h" | 
|  |  | 
|  | #define TYPE_SGX_EPC "sgx-epc" | 
|  | #define SGX_EPC(obj) \ | 
|  | OBJECT_CHECK(SGXEPCDevice, (obj), TYPE_SGX_EPC) | 
|  | #define SGX_EPC_CLASS(oc) \ | 
|  | OBJECT_CLASS_CHECK(SGXEPCDeviceClass, (oc), TYPE_SGX_EPC) | 
|  | #define SGX_EPC_GET_CLASS(obj) \ | 
|  | OBJECT_GET_CLASS(SGXEPCDeviceClass, (obj), TYPE_SGX_EPC) | 
|  |  | 
|  | #define SGX_EPC_ADDR_PROP "addr" | 
|  | #define SGX_EPC_SIZE_PROP "size" | 
|  | #define SGX_EPC_MEMDEV_PROP "memdev" | 
|  | #define SGX_EPC_NUMA_NODE_PROP "node" | 
|  |  | 
|  | /** | 
|  | * SGXEPCDevice: | 
|  | * @addr: starting guest physical address, where @SGXEPCDevice is mapped. | 
|  | *         Default value: 0, means that address is auto-allocated. | 
|  | * @hostmem: host memory backend providing memory for @SGXEPCDevice | 
|  | */ | 
|  | typedef struct SGXEPCDevice { | 
|  | /* private */ | 
|  | DeviceState parent_obj; | 
|  |  | 
|  | /* public */ | 
|  | uint64_t addr; | 
|  | uint32_t node; | 
|  | HostMemoryBackendEpc *hostmem; | 
|  | } SGXEPCDevice; | 
|  |  | 
|  | /* | 
|  | * @base: address in guest physical address space where EPC regions start | 
|  | * @mr: address space container for memory devices | 
|  | */ | 
|  | typedef struct SGXEPCState { | 
|  | uint64_t base; | 
|  | uint64_t size; | 
|  |  | 
|  | MemoryRegion mr; | 
|  |  | 
|  | struct SGXEPCDevice **sections; | 
|  | int nr_sections; | 
|  | } SGXEPCState; | 
|  |  | 
|  | bool sgx_epc_get_section(int section_nr, uint64_t *addr, uint64_t *size); | 
|  | void sgx_epc_build_srat(GArray *table_data); | 
|  |  | 
|  | static inline uint64_t sgx_epc_above_4g_end(SGXEPCState *sgx_epc) | 
|  | { | 
|  | assert(sgx_epc != NULL && sgx_epc->base >= 0x100000000ULL); | 
|  |  | 
|  | return sgx_epc->base + sgx_epc->size; | 
|  | } | 
|  |  | 
|  | #endif |