34 lines
1012 B
C
34 lines
1012 B
C
|
/* 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 <linux/dma-mapping.h>
|
||
|
|
||
|
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 */
|