13ed34463SSteve Sistare /* 23ed34463SSteve Sistare * VFIO CPR 33ed34463SSteve Sistare * 43ed34463SSteve Sistare * Copyright (c) 2025 Oracle and/or its affiliates. 53ed34463SSteve Sistare * 63ed34463SSteve Sistare * SPDX-License-Identifier: GPL-2.0-or-later 73ed34463SSteve Sistare */ 83ed34463SSteve Sistare 93ed34463SSteve Sistare #ifndef HW_VFIO_VFIO_CPR_H 103ed34463SSteve Sistare #define HW_VFIO_VFIO_CPR_H 113ed34463SSteve Sistare 1254857b08SSteve Sistare #include "migration/misc.h" 13eba1f657SSteve Sistare #include "system/memory.h" 1454857b08SSteve Sistare 1554857b08SSteve Sistare struct VFIOContainer; 163ed34463SSteve Sistare struct VFIOContainerBase; 17c29a65edSSteve Sistare struct VFIOGroup; 183ed34463SSteve Sistare 19*924c3ccbSZhenzhong Duan typedef int (*dma_map_fn)(const struct VFIOContainerBase *bcontainer, 20*924c3ccbSZhenzhong Duan hwaddr iova, ram_addr_t size, void *vaddr, 21*924c3ccbSZhenzhong Duan bool readonly, MemoryRegion *mr); 22*924c3ccbSZhenzhong Duan 2354857b08SSteve Sistare typedef struct VFIOContainerCPR { 2454857b08SSteve Sistare Error *blocker; 25eba1f657SSteve Sistare bool vaddr_unmapped; 26eba1f657SSteve Sistare NotifierWithReturn transfer_notifier; 27eba1f657SSteve Sistare MemoryListener remap_listener; 2854857b08SSteve Sistare } VFIOContainerCPR; 2954857b08SSteve Sistare 30dac0dd68SSteve Sistare typedef struct VFIODeviceCPR { 31dac0dd68SSteve Sistare Error *mdev_blocker; 32dac0dd68SSteve Sistare } VFIODeviceCPR; 3354857b08SSteve Sistare 3454857b08SSteve Sistare bool vfio_legacy_cpr_register_container(struct VFIOContainer *container, 3554857b08SSteve Sistare Error **errp); 3654857b08SSteve Sistare void vfio_legacy_cpr_unregister_container(struct VFIOContainer *container); 3754857b08SSteve Sistare 3854857b08SSteve Sistare int vfio_cpr_reboot_notifier(NotifierWithReturn *notifier, MigrationEvent *e, 3954857b08SSteve Sistare Error **errp); 4054857b08SSteve Sistare 413ed34463SSteve Sistare bool vfio_cpr_register_container(struct VFIOContainerBase *bcontainer, 423ed34463SSteve Sistare Error **errp); 433ed34463SSteve Sistare void vfio_cpr_unregister_container(struct VFIOContainerBase *bcontainer); 443ed34463SSteve Sistare 45c29a65edSSteve Sistare int vfio_cpr_group_get_device_fd(int d, const char *name); 46c29a65edSSteve Sistare 47c29a65edSSteve Sistare bool vfio_cpr_container_match(struct VFIOContainer *container, 48c29a65edSSteve Sistare struct VFIOGroup *group, int fd); 49c29a65edSSteve Sistare 50eba1f657SSteve Sistare void vfio_cpr_giommu_remap(struct VFIOContainerBase *bcontainer, 51eba1f657SSteve Sistare MemoryRegionSection *section); 52eba1f657SSteve Sistare 53eba1f657SSteve Sistare bool vfio_cpr_ram_discard_register_listener( 54eba1f657SSteve Sistare struct VFIOContainerBase *bcontainer, MemoryRegionSection *section); 55eba1f657SSteve Sistare 56031fbb71SSteve Sistare extern const VMStateDescription vfio_cpr_pci_vmstate; 57031fbb71SSteve Sistare 583ed34463SSteve Sistare #endif /* HW_VFIO_VFIO_CPR_H */ 59