[media] exynos4-is: Remove dependency on SYSCON for non-dt platforms
authorSylwester Nawrocki <s.nawrocki@samsung.com>
Sun, 31 Mar 2013 23:31:02 +0000 (20:31 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Thu, 4 Apr 2013 22:53:56 +0000 (19:53 -0300)
Currently the whole driver depends on MFD_SYSCON, which in turn
depends on OF. To allow to use the driver on non-dt platforms
(S5PV210) the SYSREG support is made conditional (it is needed
only for dt enabled platforms) and MFD_SYSCON is selected if
OF is enabled, instead of depending on OF.

Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/platform/exynos4-is/Kconfig
drivers/media/platform/exynos4-is/fimc-core.c
drivers/media/platform/exynos4-is/fimc-core.h
drivers/media/platform/exynos4-is/fimc-reg.c

index 91dbd4b223620a96bd7f70a47b369103de6706c7..ae579208565b16d49d6f96da61073feb0eda796c 100644 (file)
@@ -2,7 +2,6 @@
 config VIDEO_SAMSUNG_EXYNOS4_IS
        bool "Samsung S5P/EXYNOS4 SoC series Camera Subsystem driver"
        depends on VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API && PLAT_S5P && PM_RUNTIME
-       depends on MFD_SYSCON
        help
          Say Y here to enable camera host interface devices for
          Samsung S5P and EXYNOS SoC series.
@@ -14,6 +13,7 @@ config VIDEO_S5P_FIMC
        depends on I2C
        select VIDEOBUF2_DMA_CONTIG
        select V4L2_MEM2MEM_DEV
+       select MFD_SYSCON if OF
        help
          This is a V4L2 driver for Samsung S5P and EXYNOS4 SoC camera host
          interface and video postprocessor (FIMC) devices.
index 44239e5b3a47254600ed7827894459879fbe0806..6b4a244132fb1ee33ebfb1a5099af91a211f60f3 100644 (file)
@@ -966,8 +966,7 @@ static int fimc_probe(struct platform_device *pdev)
        spin_lock_init(&fimc->slock);
        mutex_init(&fimc->lock);
 
-       fimc->sysreg = syscon_regmap_lookup_by_phandle(dev->of_node,
-                                               "samsung,sysreg");
+       fimc->sysreg = fimc_get_sysreg_regmap(dev->of_node);
        if (IS_ERR(fimc->sysreg))
                return PTR_ERR(fimc->sysreg);
 
index 793333a33b240f0a7c8b4d3d797941fafe814a48..7d361b24dfd7fe3a23ce0ad70e69a23e6975dc01 100644 (file)
@@ -15,6 +15,7 @@
 #include <linux/regmap.h>
 #include <linux/sched.h>
 #include <linux/spinlock.h>
+#include <linux/mfd/syscon.h>
 #include <linux/types.h>
 #include <linux/videodev2.h>
 #include <linux/io.h>
@@ -645,6 +646,15 @@ void fimc_unregister_m2m_device(struct fimc_dev *fimc);
 int fimc_register_driver(void);
 void fimc_unregister_driver(void);
 
+#ifdef CONFIG_MFD_SYSCON
+static inline struct regmap * fimc_get_sysreg_regmap(struct device_node *node)
+{
+       return syscon_regmap_lookup_by_phandle(node, "samsung,sysreg");
+}
+#else
+#define fimc_get_sysreg_regmap(node) (NULL)
+#endif
+
 /* -----------------------------------------------------*/
 /* fimc-m2m.c */
 void fimc_m2m_job_finish(struct fimc_ctx *ctx, int vb_state);
index c276eb8e97110acca87b777b6ac3291fe1c20def..c82e9bdaae94dcf4a3c3292a73bca447225fe66e 100644 (file)
@@ -805,6 +805,9 @@ int fimc_hw_camblk_cfg_writeback(struct fimc_dev *fimc)
        unsigned int mask, val, camblk_cfg;
        int ret;
 
+       if (map == NULL)
+               return 0;
+
        ret = regmap_read(map, SYSREG_CAMBLK, &camblk_cfg);
        if (ret < 0 || ((camblk_cfg & 0x00700000) >> 20 != 0x3))
                return ret;