blob: fd706cdf255c61c82ce30ef9a2c44930bef34bc8 [file] [log] [blame]
Rob Herringaf6074f2017-12-27 12:55:14 -06001/* SPDX-License-Identifier: GPL-2.0 */
Jon Hunteraa3da642012-09-14 17:41:56 -05002/*
3 * OF helpers for DMA request / controller
4 *
5 * Based on of_gpio.h
6 *
7 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
Jon Hunteraa3da642012-09-14 17:41:56 -05008 */
9
10#ifndef __LINUX_OF_DMA_H
11#define __LINUX_OF_DMA_H
12
13#include <linux/of.h>
14#include <linux/dmaengine.h>
15
16struct device_node;
17
18struct of_dma {
19 struct list_head of_dma_controllers;
20 struct device_node *of_node;
Jon Hunteraa3da642012-09-14 17:41:56 -050021 struct dma_chan *(*of_dma_xlate)
22 (struct of_phandle_args *, struct of_dma *);
Peter Ujfalusi56f13c02015-04-09 12:35:47 +030023 void *(*of_dma_route_allocate)
24 (struct of_phandle_args *, struct of_dma *);
25 struct dma_router *dma_router;
Jon Hunteraa3da642012-09-14 17:41:56 -050026 void *of_dma_data;
27};
28
29struct of_dma_filter_info {
30 dma_cap_mask_t dma_cap;
31 dma_filter_fn filter_fn;
32};
33
Kuninori Morimoto9290a162015-08-21 11:48:37 +000034#ifdef CONFIG_DMA_OF
Jon Hunteraa3da642012-09-14 17:41:56 -050035extern int of_dma_controller_register(struct device_node *np,
36 struct dma_chan *(*of_dma_xlate)
37 (struct of_phandle_args *, struct of_dma *),
38 void *data);
Lars-Peter Clausende616082013-04-19 11:42:14 +020039extern void of_dma_controller_free(struct device_node *np);
Peter Ujfalusi56f13c02015-04-09 12:35:47 +030040
41extern int of_dma_router_register(struct device_node *np,
42 void *(*of_dma_route_allocate)
43 (struct of_phandle_args *, struct of_dma *),
44 struct dma_router *dma_router);
45#define of_dma_router_free of_dma_controller_free
46
Jon Hunteraa3da642012-09-14 17:41:56 -050047extern struct dma_chan *of_dma_request_slave_channel(struct device_node *np,
Markus Pargmannbef29ec2013-02-24 16:36:09 +010048 const char *name);
Jon Hunteraa3da642012-09-14 17:41:56 -050049extern struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec,
50 struct of_dma *ofdma);
Alexander Popov16369ef2014-06-25 14:52:59 +040051extern struct dma_chan *of_dma_xlate_by_chan_id(struct of_phandle_args *dma_spec,
52 struct of_dma *ofdma);
Peter Ujfalusi56f13c02015-04-09 12:35:47 +030053
Vinod Koul4c26bc62012-09-25 09:57:36 +053054#else
Vinod Koul91f8aec2012-11-29 12:17:22 +053055static inline int of_dma_controller_register(struct device_node *np,
Vinod Koul4c26bc62012-09-25 09:57:36 +053056 struct dma_chan *(*of_dma_xlate)
57 (struct of_phandle_args *, struct of_dma *),
58 void *data)
59{
60 return -ENODEV;
61}
62
Lars-Peter Clausende616082013-04-19 11:42:14 +020063static inline void of_dma_controller_free(struct device_node *np)
Vinod Koul4c26bc62012-09-25 09:57:36 +053064{
65}
66
Peter Ujfalusi56f13c02015-04-09 12:35:47 +030067static inline int of_dma_router_register(struct device_node *np,
68 void *(*of_dma_route_allocate)
69 (struct of_phandle_args *, struct of_dma *),
70 struct dma_router *dma_router)
71{
72 return -ENODEV;
73}
74
75#define of_dma_router_free of_dma_controller_free
76
Vinod Koul91f8aec2012-11-29 12:17:22 +053077static inline struct dma_chan *of_dma_request_slave_channel(struct device_node *np,
Markus Pargmannbef29ec2013-02-24 16:36:09 +010078 const char *name)
Vinod Koul4c26bc62012-09-25 09:57:36 +053079{
Peter Ujfalusi500404e2015-11-03 12:28:10 +020080 return ERR_PTR(-ENODEV);
Vinod Koul4c26bc62012-09-25 09:57:36 +053081}
82
Vinod Koul91f8aec2012-11-29 12:17:22 +053083static inline struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec,
Vinod Koul4c26bc62012-09-25 09:57:36 +053084 struct of_dma *ofdma)
85{
86 return NULL;
87}
88
Alexander Popov16369ef2014-06-25 14:52:59 +040089#define of_dma_xlate_by_chan_id NULL
90
Vinod Koul4c26bc62012-09-25 09:57:36 +053091#endif
Jon Hunteraa3da642012-09-14 17:41:56 -050092
93#endif /* __LINUX_OF_DMA_H */