/* SPDX-License-Identifier: GPL-2.0-or-later */ /* Copyright (c) 2024 NVIDIA Corporation & Affiliates */ #ifndef LINUX_HMM_DMA_H #define LINUX_HMM_DMA_H #include struct dma_iova_state; struct pci_p2pdma_map_state; /* * struct hmm_dma_map - array of PFNs and DMA addresses * * @state: DMA IOVA state * @pfns: array of PFNs * @dma_list: array of DMA addresses * @dma_entry_size: size of each DMA entry in the array */ struct hmm_dma_map { struct dma_iova_state state; unsigned long *pfn_list; dma_addr_t *dma_list; size_t dma_entry_size; }; int hmm_dma_map_alloc(struct device *dev, struct hmm_dma_map *map, size_t nr_entries, size_t dma_entry_size); void hmm_dma_map_free(struct device *dev, struct hmm_dma_map *map); dma_addr_t hmm_dma_map_pfn(struct device *dev, struct hmm_dma_map *map, size_t idx, struct pci_p2pdma_map_state *p2pdma_state); bool hmm_dma_unmap_pfn(struct device *dev, struct hmm_dma_map *map, size_t idx); #endif /* LINUX_HMM_DMA_H */