blob: 33b68a8f4bf0506f76da62779ab2646192849d7e (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
/**
* Copyright © 2022 Oracle and/or its affiliates.
*
* 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 REMOTE_IOMMU_H
#define REMOTE_IOMMU_H
#include "hw/pci/pci_bus.h"
#include "hw/pci/pci.h"
#ifndef INT2VOIDP
#define INT2VOIDP(i) (void *)(uintptr_t)(i)
#endif
typedef struct RemoteIommuElem {
MemoryRegion *mr;
AddressSpace as;
} RemoteIommuElem;
#define TYPE_REMOTE_IOMMU "x-remote-iommu"
OBJECT_DECLARE_SIMPLE_TYPE(RemoteIommu, REMOTE_IOMMU)
struct RemoteIommu {
Object parent;
GHashTable *elem_by_devfn;
QemuMutex lock;
};
void remote_iommu_setup(PCIBus *pci_bus);
void remote_iommu_unplug_dev(PCIDevice *pci_dev);
#endif
|