1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Copyright (C) 2014-2015 ARM Ltd.
4 */
5 #ifndef __DMA_IOMMU_H
6 #define __DMA_IOMMU_H
7
8 #include <linux/errno.h>
9 #include <linux/types.h>
10
11 #ifdef CONFIG_IOMMU_DMA
12 #include <linux/dma-mapping.h>
13 #include <linux/iommu.h>
14 #include <linux/msi.h>
15
16 /* Domain management interface for IOMMU drivers */
17 int iommu_get_dma_cookie(struct iommu_domain *domain);
18 int iommu_get_msi_cookie(struct iommu_domain *domain, dma_addr_t base);
19 void iommu_put_dma_cookie(struct iommu_domain *domain);
20
21 /* Setup call for arch DMA mapping code */
22 void iommu_setup_dma_ops(struct device *dev, u64 dma_base, u64 dma_limit);
23 int iommu_dma_init_fq(struct iommu_domain *domain);
24
25 /* The DMA API isn't _quite_ the whole story, though... */
26 /*
27 * iommu_dma_prepare_msi() - Map the MSI page in the IOMMU device
28 *
29 * The MSI page will be stored in @desc.
30 *
31 * Return: 0 on success otherwise an error describing the failure.
32 */
33 int iommu_dma_prepare_msi(struct msi_desc *desc, phys_addr_t msi_addr);
34
35 /* Update the MSI message if required. */
36 void iommu_dma_compose_msi_msg(struct msi_desc *desc,
37 struct msi_msg *msg);
38
39 void iommu_dma_get_resv_regions(struct device *dev, struct list_head *list);
40
41 void iommu_dma_free_cpu_cached_iovas(unsigned int cpu,
42 struct iommu_domain *domain);
43
44 extern bool iommu_dma_forcedac;
45
46 int iommu_dma_enable_best_fit_algo(struct device *dev);
47
48 #else /* CONFIG_IOMMU_DMA */
49
50 struct iommu_domain;
51 struct msi_desc;
52 struct msi_msg;
53 struct device;
54
iommu_setup_dma_ops(struct device * dev,u64 dma_base,u64 dma_limit)55 static inline void iommu_setup_dma_ops(struct device *dev, u64 dma_base,
56 u64 dma_limit)
57 {
58 }
59
iommu_dma_init_fq(struct iommu_domain * domain)60 static inline int iommu_dma_init_fq(struct iommu_domain *domain)
61 {
62 return -EINVAL;
63 }
64
iommu_get_dma_cookie(struct iommu_domain * domain)65 static inline int iommu_get_dma_cookie(struct iommu_domain *domain)
66 {
67 return -ENODEV;
68 }
69
iommu_get_msi_cookie(struct iommu_domain * domain,dma_addr_t base)70 static inline int iommu_get_msi_cookie(struct iommu_domain *domain, dma_addr_t base)
71 {
72 return -ENODEV;
73 }
74
iommu_put_dma_cookie(struct iommu_domain * domain)75 static inline void iommu_put_dma_cookie(struct iommu_domain *domain)
76 {
77 }
78
iommu_dma_prepare_msi(struct msi_desc * desc,phys_addr_t msi_addr)79 static inline int iommu_dma_prepare_msi(struct msi_desc *desc,
80 phys_addr_t msi_addr)
81 {
82 return 0;
83 }
84
iommu_dma_compose_msi_msg(struct msi_desc * desc,struct msi_msg * msg)85 static inline void iommu_dma_compose_msi_msg(struct msi_desc *desc,
86 struct msi_msg *msg)
87 {
88 }
89
iommu_dma_get_resv_regions(struct device * dev,struct list_head * list)90 static inline void iommu_dma_get_resv_regions(struct device *dev, struct list_head *list)
91 {
92 }
93
iommu_dma_enable_best_fit_algo(struct device * dev)94 static inline int iommu_dma_enable_best_fit_algo(struct device *dev)
95 {
96 return -ENODEV;
97 }
98
99 #endif /* CONFIG_IOMMU_DMA */
100 #endif /* __DMA_IOMMU_H */
101