vt: vt_ioctl: fix VT_DISALLOCATE freeing in-use virtual console
[linux/fpc-iii.git] / drivers / gpu / drm / exynos / exynos_drm_iommu.h
blob797d9ee5f15a75c5aee52966d0145b7023e94574
1 /* exynos_drm_iommu.h
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,
27 size);
28 return IS_ERR(priv->mapping);
31 static inline void
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,
38 struct device *dev)
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,
47 struct device *dev)
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 priv->mapping = iommu_get_domain_for_dev(priv->dma_dev);
59 return 0;
62 static inline void __exynos_iommu_release_mapping(struct exynos_drm_private *priv)
64 priv->mapping = NULL;
67 static inline int __exynos_iommu_attach(struct exynos_drm_private *priv,
68 struct device *dev)
70 struct iommu_domain *domain = priv->mapping;
72 if (dev != priv->dma_dev)
73 return iommu_attach_device(domain, dev);
74 return 0;
77 static inline void __exynos_iommu_detach(struct exynos_drm_private *priv,
78 struct device *dev)
80 struct iommu_domain *domain = priv->mapping;
82 if (dev != priv->dma_dev)
83 iommu_detach_device(domain, dev);
85 #else
86 #error Unsupported architecture and IOMMU/DMA-mapping glue code
87 #endif
89 int drm_create_iommu_mapping(struct drm_device *drm_dev);
91 void drm_release_iommu_mapping(struct drm_device *drm_dev);
93 int drm_iommu_attach_device(struct drm_device *drm_dev,
94 struct device *subdrv_dev);
96 void drm_iommu_detach_device(struct drm_device *dev_dev,
97 struct device *subdrv_dev);
99 static inline bool is_drm_iommu_supported(struct drm_device *drm_dev)
101 struct exynos_drm_private *priv = drm_dev->dev_private;
103 return priv->mapping ? true : false;
106 #else
108 static inline int drm_create_iommu_mapping(struct drm_device *drm_dev)
110 return 0;
113 static inline void drm_release_iommu_mapping(struct drm_device *drm_dev)
117 static inline int drm_iommu_attach_device(struct drm_device *drm_dev,
118 struct device *subdrv_dev)
120 return 0;
123 static inline void drm_iommu_detach_device(struct drm_device *drm_dev,
124 struct device *subdrv_dev)
128 static inline bool is_drm_iommu_supported(struct drm_device *drm_dev)
130 return false;
133 #endif
134 #endif