blob: a2912b47102cf3a1f410726e116d060c739f44d7 [file] [log] [blame]
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00001/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef ASM_POWERPC_DMA_DIRECT_H
3#define ASM_POWERPC_DMA_DIRECT_H 1
4
5static inline bool dma_capable(struct device *dev, dma_addr_t addr, size_t size)
6{
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00007 if (!dev->dma_mask)
8 return false;
9
David Brazdil0f672f62019-12-10 10:32:29 +000010 return addr + size - 1 <=
11 min_not_zero(*dev->dma_mask, dev->bus_dma_mask);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000012}
13
14static inline dma_addr_t __phys_to_dma(struct device *dev, phys_addr_t paddr)
15{
David Brazdil0f672f62019-12-10 10:32:29 +000016 if (!dev)
17 return paddr + PCI_DRAM_OFFSET;
18 return paddr + dev->archdata.dma_offset;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000019}
20
21static inline phys_addr_t __dma_to_phys(struct device *dev, dma_addr_t daddr)
22{
David Brazdil0f672f62019-12-10 10:32:29 +000023 if (!dev)
24 return daddr - PCI_DRAM_OFFSET;
25 return daddr - dev->archdata.dma_offset;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000026}
27#endif /* ASM_POWERPC_DMA_DIRECT_H */