| /* |
| * OF helpers for DMA request / controller |
| * |
| * Based on of_gpio.h |
| * |
| * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/ |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation. |
| */ |
| |
| #ifndef __LINUX_OF_DMA_H |
| #define __LINUX_OF_DMA_H |
| |
| #include <linux/of.h> |
| #include <linux/dmaengine.h> |
| |
| struct device_node; |
| |
| struct of_dma { |
| struct list_head of_dma_controllers; |
| struct device_node *of_node; |
| struct dma_chan *(*of_dma_xlate) |
| (struct of_phandle_args *, struct of_dma *); |
| void *(*of_dma_route_allocate) |
| (struct of_phandle_args *, struct of_dma *); |
| struct dma_router *dma_router; |
| void *of_dma_data; |
| }; |
| |
| struct of_dma_filter_info { |
| dma_cap_mask_t dma_cap; |
| dma_filter_fn filter_fn; |
| }; |
| |
| #ifdef CONFIG_DMA_OF |
| extern int of_dma_controller_register(struct device_node *np, |
| struct dma_chan *(*of_dma_xlate) |
| (struct of_phandle_args *, struct of_dma *), |
| void *data); |
| extern void of_dma_controller_free(struct device_node *np); |
| |
| extern int of_dma_router_register(struct device_node *np, |
| void *(*of_dma_route_allocate) |
| (struct of_phandle_args *, struct of_dma *), |
| struct dma_router *dma_router); |
| #define of_dma_router_free of_dma_controller_free |
| |
| extern struct dma_chan *of_dma_request_slave_channel(struct device_node *np, |
| const char *name); |
| extern struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, |
| struct of_dma *ofdma); |
| extern struct dma_chan *of_dma_xlate_by_chan_id(struct of_phandle_args *dma_spec, |
| struct of_dma *ofdma); |
| extern unsigned int of_dma_get_mcode_addr(struct device_node *np); |
| extern bool of_dma_secure_mode(struct device_node *np); |
| #ifdef CONFIG_SOC_EXYNOS8895 |
| extern void __iomem *of_dma_get_sel_chan_address(struct device_node *np); |
| #endif |
| extern void __iomem *of_dma_get_arwrapper_address(struct device_node *np, unsigned int num); |
| extern void __iomem *of_dma_get_awwrapper_address(struct device_node *np, unsigned int num); |
| extern void __iomem *of_dma_get_instwrapper_address(struct device_node *np); |
| extern bool of_dma_get_wrapper_available(struct device_node *np); |
| extern u64 of_dma_get_mask(struct device_node *np, char *name); |
| extern bool of_dma_multi_irq(struct device_node *np); |
| #else |
| static inline unsigned int of_dma_get_mcode_addr(struct device_node *np) |
| { |
| return -ENODEV; |
| } |
| static inline int of_dma_controller_register(struct device_node *np, |
| struct dma_chan *(*of_dma_xlate) |
| (struct of_phandle_args *, struct of_dma *), |
| void *data) |
| { |
| return -ENODEV; |
| } |
| |
| static inline void of_dma_controller_free(struct device_node *np) |
| { |
| } |
| |
| static inline int of_dma_router_register(struct device_node *np, |
| void *(*of_dma_route_allocate) |
| (struct of_phandle_args *, struct of_dma *), |
| struct dma_router *dma_router) |
| { |
| return -ENODEV; |
| } |
| |
| #define of_dma_router_free of_dma_controller_free |
| |
| static inline struct dma_chan *of_dma_request_slave_channel(struct device_node *np, |
| const char *name) |
| { |
| return ERR_PTR(-ENODEV); |
| } |
| |
| static inline struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, |
| struct of_dma *ofdma) |
| { |
| return NULL; |
| } |
| |
| static inline void __iomem *of_dma_get_wrapper_address(struct device_node *np, unsigned int num) |
| { |
| return NULL; |
| } |
| |
| static inline void __iomem *of_dma_get_arwrapper_address(struct device_node *np, unsigned int num) |
| { |
| return NULL; |
| } |
| |
| static inline void __iomem *of_dma_get_awwrapper_address(struct device_node *np, unsigned int num) |
| { |
| return NULL; |
| } |
| |
| static inline void __iomem *of_dma_get_instwrapper_address(struct device_node *np) |
| { |
| return NULL; |
| } |
| |
| static inline bool of_dma_get_wrapper_available(struct device_node *np) |
| { |
| return NULL; |
| } |
| |
| static u64 of_dma_get_mask(struct device_node *np, char *name) |
| { |
| return NULL; |
| } |
| #define of_dma_xlate_by_chan_id NULL |
| |
| static inline bool of_dma_multi_irq(struct device_node *np) |
| { |
| return NULL; |
| } |
| |
| #endif |
| |
| #endif /* __LINUX_OF_DMA_H */ |