1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * PCI Peer 2 Peer DMA support.
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (c) 2016-2018, Logan Gunthorpe
6*4882a593Smuzhiyun * Copyright (c) 2016-2017, Microsemi Corporation
7*4882a593Smuzhiyun * Copyright (c) 2017, Christoph Hellwig
8*4882a593Smuzhiyun * Copyright (c) 2018, Eideticom Inc.
9*4882a593Smuzhiyun */
10*4882a593Smuzhiyun
11*4882a593Smuzhiyun #ifndef _LINUX_PCI_P2PDMA_H
12*4882a593Smuzhiyun #define _LINUX_PCI_P2PDMA_H
13*4882a593Smuzhiyun
14*4882a593Smuzhiyun #include <linux/pci.h>
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun struct block_device;
17*4882a593Smuzhiyun struct scatterlist;
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun #ifdef CONFIG_PCI_P2PDMA
20*4882a593Smuzhiyun int pci_p2pdma_add_resource(struct pci_dev *pdev, int bar, size_t size,
21*4882a593Smuzhiyun u64 offset);
22*4882a593Smuzhiyun int pci_p2pdma_distance_many(struct pci_dev *provider, struct device **clients,
23*4882a593Smuzhiyun int num_clients, bool verbose);
24*4882a593Smuzhiyun bool pci_has_p2pmem(struct pci_dev *pdev);
25*4882a593Smuzhiyun struct pci_dev *pci_p2pmem_find_many(struct device **clients, int num_clients);
26*4882a593Smuzhiyun void *pci_alloc_p2pmem(struct pci_dev *pdev, size_t size);
27*4882a593Smuzhiyun void pci_free_p2pmem(struct pci_dev *pdev, void *addr, size_t size);
28*4882a593Smuzhiyun pci_bus_addr_t pci_p2pmem_virt_to_bus(struct pci_dev *pdev, void *addr);
29*4882a593Smuzhiyun struct scatterlist *pci_p2pmem_alloc_sgl(struct pci_dev *pdev,
30*4882a593Smuzhiyun unsigned int *nents, u32 length);
31*4882a593Smuzhiyun void pci_p2pmem_free_sgl(struct pci_dev *pdev, struct scatterlist *sgl);
32*4882a593Smuzhiyun void pci_p2pmem_publish(struct pci_dev *pdev, bool publish);
33*4882a593Smuzhiyun int pci_p2pdma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
34*4882a593Smuzhiyun int nents, enum dma_data_direction dir, unsigned long attrs);
35*4882a593Smuzhiyun void pci_p2pdma_unmap_sg_attrs(struct device *dev, struct scatterlist *sg,
36*4882a593Smuzhiyun int nents, enum dma_data_direction dir, unsigned long attrs);
37*4882a593Smuzhiyun int pci_p2pdma_enable_store(const char *page, struct pci_dev **p2p_dev,
38*4882a593Smuzhiyun bool *use_p2pdma);
39*4882a593Smuzhiyun ssize_t pci_p2pdma_enable_show(char *page, struct pci_dev *p2p_dev,
40*4882a593Smuzhiyun bool use_p2pdma);
41*4882a593Smuzhiyun #else /* CONFIG_PCI_P2PDMA */
pci_p2pdma_add_resource(struct pci_dev * pdev,int bar,size_t size,u64 offset)42*4882a593Smuzhiyun static inline int pci_p2pdma_add_resource(struct pci_dev *pdev, int bar,
43*4882a593Smuzhiyun size_t size, u64 offset)
44*4882a593Smuzhiyun {
45*4882a593Smuzhiyun return -EOPNOTSUPP;
46*4882a593Smuzhiyun }
pci_p2pdma_distance_many(struct pci_dev * provider,struct device ** clients,int num_clients,bool verbose)47*4882a593Smuzhiyun static inline int pci_p2pdma_distance_many(struct pci_dev *provider,
48*4882a593Smuzhiyun struct device **clients, int num_clients, bool verbose)
49*4882a593Smuzhiyun {
50*4882a593Smuzhiyun return -1;
51*4882a593Smuzhiyun }
pci_has_p2pmem(struct pci_dev * pdev)52*4882a593Smuzhiyun static inline bool pci_has_p2pmem(struct pci_dev *pdev)
53*4882a593Smuzhiyun {
54*4882a593Smuzhiyun return false;
55*4882a593Smuzhiyun }
pci_p2pmem_find_many(struct device ** clients,int num_clients)56*4882a593Smuzhiyun static inline struct pci_dev *pci_p2pmem_find_many(struct device **clients,
57*4882a593Smuzhiyun int num_clients)
58*4882a593Smuzhiyun {
59*4882a593Smuzhiyun return NULL;
60*4882a593Smuzhiyun }
pci_alloc_p2pmem(struct pci_dev * pdev,size_t size)61*4882a593Smuzhiyun static inline void *pci_alloc_p2pmem(struct pci_dev *pdev, size_t size)
62*4882a593Smuzhiyun {
63*4882a593Smuzhiyun return NULL;
64*4882a593Smuzhiyun }
pci_free_p2pmem(struct pci_dev * pdev,void * addr,size_t size)65*4882a593Smuzhiyun static inline void pci_free_p2pmem(struct pci_dev *pdev, void *addr,
66*4882a593Smuzhiyun size_t size)
67*4882a593Smuzhiyun {
68*4882a593Smuzhiyun }
pci_p2pmem_virt_to_bus(struct pci_dev * pdev,void * addr)69*4882a593Smuzhiyun static inline pci_bus_addr_t pci_p2pmem_virt_to_bus(struct pci_dev *pdev,
70*4882a593Smuzhiyun void *addr)
71*4882a593Smuzhiyun {
72*4882a593Smuzhiyun return 0;
73*4882a593Smuzhiyun }
pci_p2pmem_alloc_sgl(struct pci_dev * pdev,unsigned int * nents,u32 length)74*4882a593Smuzhiyun static inline struct scatterlist *pci_p2pmem_alloc_sgl(struct pci_dev *pdev,
75*4882a593Smuzhiyun unsigned int *nents, u32 length)
76*4882a593Smuzhiyun {
77*4882a593Smuzhiyun return NULL;
78*4882a593Smuzhiyun }
pci_p2pmem_free_sgl(struct pci_dev * pdev,struct scatterlist * sgl)79*4882a593Smuzhiyun static inline void pci_p2pmem_free_sgl(struct pci_dev *pdev,
80*4882a593Smuzhiyun struct scatterlist *sgl)
81*4882a593Smuzhiyun {
82*4882a593Smuzhiyun }
pci_p2pmem_publish(struct pci_dev * pdev,bool publish)83*4882a593Smuzhiyun static inline void pci_p2pmem_publish(struct pci_dev *pdev, bool publish)
84*4882a593Smuzhiyun {
85*4882a593Smuzhiyun }
pci_p2pdma_map_sg_attrs(struct device * dev,struct scatterlist * sg,int nents,enum dma_data_direction dir,unsigned long attrs)86*4882a593Smuzhiyun static inline int pci_p2pdma_map_sg_attrs(struct device *dev,
87*4882a593Smuzhiyun struct scatterlist *sg, int nents, enum dma_data_direction dir,
88*4882a593Smuzhiyun unsigned long attrs)
89*4882a593Smuzhiyun {
90*4882a593Smuzhiyun return 0;
91*4882a593Smuzhiyun }
pci_p2pdma_unmap_sg_attrs(struct device * dev,struct scatterlist * sg,int nents,enum dma_data_direction dir,unsigned long attrs)92*4882a593Smuzhiyun static inline void pci_p2pdma_unmap_sg_attrs(struct device *dev,
93*4882a593Smuzhiyun struct scatterlist *sg, int nents, enum dma_data_direction dir,
94*4882a593Smuzhiyun unsigned long attrs)
95*4882a593Smuzhiyun {
96*4882a593Smuzhiyun }
pci_p2pdma_enable_store(const char * page,struct pci_dev ** p2p_dev,bool * use_p2pdma)97*4882a593Smuzhiyun static inline int pci_p2pdma_enable_store(const char *page,
98*4882a593Smuzhiyun struct pci_dev **p2p_dev, bool *use_p2pdma)
99*4882a593Smuzhiyun {
100*4882a593Smuzhiyun *use_p2pdma = false;
101*4882a593Smuzhiyun return 0;
102*4882a593Smuzhiyun }
pci_p2pdma_enable_show(char * page,struct pci_dev * p2p_dev,bool use_p2pdma)103*4882a593Smuzhiyun static inline ssize_t pci_p2pdma_enable_show(char *page,
104*4882a593Smuzhiyun struct pci_dev *p2p_dev, bool use_p2pdma)
105*4882a593Smuzhiyun {
106*4882a593Smuzhiyun return sprintf(page, "none\n");
107*4882a593Smuzhiyun }
108*4882a593Smuzhiyun #endif /* CONFIG_PCI_P2PDMA */
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun
pci_p2pdma_distance(struct pci_dev * provider,struct device * client,bool verbose)111*4882a593Smuzhiyun static inline int pci_p2pdma_distance(struct pci_dev *provider,
112*4882a593Smuzhiyun struct device *client, bool verbose)
113*4882a593Smuzhiyun {
114*4882a593Smuzhiyun return pci_p2pdma_distance_many(provider, &client, 1, verbose);
115*4882a593Smuzhiyun }
116*4882a593Smuzhiyun
pci_p2pmem_find(struct device * client)117*4882a593Smuzhiyun static inline struct pci_dev *pci_p2pmem_find(struct device *client)
118*4882a593Smuzhiyun {
119*4882a593Smuzhiyun return pci_p2pmem_find_many(&client, 1);
120*4882a593Smuzhiyun }
121*4882a593Smuzhiyun
pci_p2pdma_map_sg(struct device * dev,struct scatterlist * sg,int nents,enum dma_data_direction dir)122*4882a593Smuzhiyun static inline int pci_p2pdma_map_sg(struct device *dev, struct scatterlist *sg,
123*4882a593Smuzhiyun int nents, enum dma_data_direction dir)
124*4882a593Smuzhiyun {
125*4882a593Smuzhiyun return pci_p2pdma_map_sg_attrs(dev, sg, nents, dir, 0);
126*4882a593Smuzhiyun }
127*4882a593Smuzhiyun
pci_p2pdma_unmap_sg(struct device * dev,struct scatterlist * sg,int nents,enum dma_data_direction dir)128*4882a593Smuzhiyun static inline void pci_p2pdma_unmap_sg(struct device *dev,
129*4882a593Smuzhiyun struct scatterlist *sg, int nents, enum dma_data_direction dir)
130*4882a593Smuzhiyun {
131*4882a593Smuzhiyun pci_p2pdma_unmap_sg_attrs(dev, sg, nents, dir, 0);
132*4882a593Smuzhiyun }
133*4882a593Smuzhiyun
134*4882a593Smuzhiyun #endif /* _LINUX_PCI_P2P_H */
135