dma-mapping.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #ifndef ___ASM_SPARC_DMA_MAPPING_H
  2. #define ___ASM_SPARC_DMA_MAPPING_H
  3. #include <linux/scatterlist.h>
  4. #include <linux/mm.h>
  5. #include <linux/dma-debug.h>
  6. #define DMA_ERROR_CODE (~(dma_addr_t)0x0)
  7. extern int dma_supported(struct device *dev, u64 mask);
  8. extern int dma_set_mask(struct device *dev, u64 dma_mask);
  9. #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)
  10. #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h)
  11. #define dma_is_consistent(d, h) (1)
  12. extern struct dma_map_ops *dma_ops;
  13. static inline struct dma_map_ops *get_dma_ops(struct device *dev)
  14. {
  15. return dma_ops;
  16. }
  17. #include <asm-generic/dma-mapping-common.h>
  18. static inline void *dma_alloc_coherent(struct device *dev, size_t size,
  19. dma_addr_t *dma_handle, gfp_t flag)
  20. {
  21. struct dma_map_ops *ops = get_dma_ops(dev);
  22. return ops->alloc_coherent(dev, size, dma_handle, flag);
  23. }
  24. static inline void dma_free_coherent(struct device *dev, size_t size,
  25. void *cpu_addr, dma_addr_t dma_handle)
  26. {
  27. struct dma_map_ops *ops = get_dma_ops(dev);
  28. ops->free_coherent(dev, size, cpu_addr, dma_handle);
  29. }
  30. static inline int dma_mapping_error(struct device *dev, dma_addr_t dma_addr)
  31. {
  32. return (dma_addr == DMA_ERROR_CODE);
  33. }
  34. static inline int dma_get_cache_alignment(void)
  35. {
  36. /*
  37. * no easy way to get cache size on all processors, so return
  38. * the maximum possible, to be safe
  39. */
  40. return (1 << INTERNODE_CACHE_SHIFT);
  41. }
  42. #endif