3 * Copyright (c) 2012 Samsung Electronics Co., Ltd.
4 * Authoer: Inki Dae <inki.dae@samsung.com>
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2 of the License, or (at your
9 * option) any later version.
12 #ifndef _EXYNOS_DRM_IOMMU_H_
13 #define _EXYNOS_DRM_IOMMU_H_
15 #define EXYNOS_DEV_ADDR_START 0x20000000
16 #define EXYNOS_DEV_ADDR_SIZE 0x40000000
18 #ifdef CONFIG_DRM_EXYNOS_IOMMU
20 #if defined(CONFIG_ARM_DMA_USE_IOMMU)
21 #include <asm/dma-iommu.h>
23 static inline int __exynos_iommu_create_mapping(struct exynos_drm_private
*priv
,
24 unsigned long start
, unsigned long size
)
26 priv
->mapping
= arm_iommu_create_mapping(&platform_bus_type
, start
,
28 return IS_ERR(priv
->mapping
);
32 __exynos_iommu_release_mapping(struct exynos_drm_private
*priv
)
34 arm_iommu_release_mapping(priv
->mapping
);
37 static inline int __exynos_iommu_attach(struct exynos_drm_private
*priv
,
40 if (dev
->archdata
.mapping
)
41 arm_iommu_detach_device(dev
);
43 return arm_iommu_attach_device(dev
, priv
->mapping
);
46 static inline void __exynos_iommu_detach(struct exynos_drm_private
*priv
,
49 arm_iommu_detach_device(dev
);
52 #elif defined(CONFIG_IOMMU_DMA)
53 #include <linux/dma-iommu.h>
55 static inline int __exynos_iommu_create_mapping(struct exynos_drm_private
*priv
,
56 unsigned long start
, unsigned long size
)
58 struct iommu_domain
*domain
;
61 domain
= iommu_domain_alloc(priv
->dma_dev
->bus
);
65 ret
= iommu_get_dma_cookie(domain
);
69 ret
= iommu_dma_init_domain(domain
, start
, size
, NULL
);
73 priv
->mapping
= domain
;
77 iommu_put_dma_cookie(domain
);
79 iommu_domain_free(domain
);
83 static inline void __exynos_iommu_release_mapping(struct exynos_drm_private
*priv
)
85 struct iommu_domain
*domain
= priv
->mapping
;
87 iommu_put_dma_cookie(domain
);
88 iommu_domain_free(domain
);
92 static inline int __exynos_iommu_attach(struct exynos_drm_private
*priv
,
95 struct iommu_domain
*domain
= priv
->mapping
;
97 return iommu_attach_device(domain
, dev
);
100 static inline void __exynos_iommu_detach(struct exynos_drm_private
*priv
,
103 struct iommu_domain
*domain
= priv
->mapping
;
105 iommu_detach_device(domain
, dev
);
108 #error Unsupported architecture and IOMMU/DMA-mapping glue code
111 int drm_create_iommu_mapping(struct drm_device
*drm_dev
);
113 void drm_release_iommu_mapping(struct drm_device
*drm_dev
);
115 int drm_iommu_attach_device(struct drm_device
*drm_dev
,
116 struct device
*subdrv_dev
);
118 void drm_iommu_detach_device(struct drm_device
*dev_dev
,
119 struct device
*subdrv_dev
);
121 static inline bool is_drm_iommu_supported(struct drm_device
*drm_dev
)
123 struct exynos_drm_private
*priv
= drm_dev
->dev_private
;
125 return priv
->mapping
? true : false;
130 static inline int drm_create_iommu_mapping(struct drm_device
*drm_dev
)
135 static inline void drm_release_iommu_mapping(struct drm_device
*drm_dev
)
139 static inline int drm_iommu_attach_device(struct drm_device
*drm_dev
,
140 struct device
*subdrv_dev
)
145 static inline void drm_iommu_detach_device(struct drm_device
*drm_dev
,
146 struct device
*subdrv_dev
)
150 static inline bool is_drm_iommu_supported(struct drm_device
*drm_dev
)