[media] exynos4-is: Remove support for non-dt platforms
authorSylwester Nawrocki <s.nawrocki@samsung.com>
Tue, 15 Apr 2014 11:35:25 +0000 (08:35 -0300)
committerMauro Carvalho Chehab <m.chehab@samsung.com>
Fri, 23 May 2014 21:52:54 +0000 (18:52 -0300)
All platforms supported by this driver are going to get device tree
support in this kernel release so remove code that would have been
actually not used any more.

Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
17 files changed:
Documentation/video4linux/fimc.txt
MAINTAINERS
drivers/media/platform/exynos4-is/Kconfig
drivers/media/platform/exynos4-is/common.c
drivers/media/platform/exynos4-is/fimc-core.h
drivers/media/platform/exynos4-is/fimc-isp-video.c
drivers/media/platform/exynos4-is/fimc-isp.h
drivers/media/platform/exynos4-is/fimc-lite-reg.c
drivers/media/platform/exynos4-is/fimc-lite.c
drivers/media/platform/exynos4-is/fimc-lite.h
drivers/media/platform/exynos4-is/fimc-reg.c
drivers/media/platform/exynos4-is/media-dev.c
drivers/media/platform/exynos4-is/media-dev.h
drivers/media/platform/exynos4-is/mipi-csis.c
include/linux/platform_data/mipi-csis.h [deleted file]
include/media/exynos-fimc.h [new file with mode: 0644]
include/media/s5p_fimc.h [deleted file]

index 7d6e160724bd4b15547d579556dbb3d5399d98d0..e0c6b8bc4743736c2f98dce83238d24bf86aa8af 100644 (file)
@@ -140,39 +140,9 @@ You can either grep through the kernel log to find relevant information, i.e.
 or retrieve the information from /dev/media? with help of the media-ctl tool:
 # media-ctl -p
 
-6. Platform support
-===================
-
-The machine code (arch/arm/plat-samsung and arch/arm/mach-*) must select
-following options:
-
-CONFIG_S5P_DEV_FIMC0       mandatory
-CONFIG_S5P_DEV_FIMC1  \
-CONFIG_S5P_DEV_FIMC2  |    optional
-CONFIG_S5P_DEV_FIMC3  |
-CONFIG_S5P_SETUP_FIMC /
-CONFIG_S5P_DEV_CSIS0  \    optional for MIPI-CSI interface
-CONFIG_S5P_DEV_CSIS1  /
-
-Except that, relevant s5p_device_fimc? should be registered in the machine code
-in addition to a "s5p-fimc-md" platform device to which the media device driver
-is bound.  The "s5p-fimc-md" device instance is required even if only mem-to-mem
-operation is used.
-
-The description of sensor(s) attached to FIMC/MIPI-CSIS camera inputs should be
-passed as the "s5p-fimc-md" device platform_data.  The platform data structure
-is defined in file include/media/s5p_fimc.h.
-
 7. Build
 ========
 
-This driver depends on following config options:
-PLAT_S5P,
-PM_RUNTIME,
-I2C,
-REGULATOR,
-VIDEO_V4L2_SUBDEV_API,
-
 If the driver is built as a loadable kernel module (CONFIG_VIDEO_SAMSUNG_S5P_FIMC=m)
 two modules are created (in addition to the core v4l2 modules): s5p-fimc.ko and
 optional s5p-csis.ko (MIPI-CSI receiver subdev).
index 129621ed165f1d2dc9a8af8d6cddbddd1b46619e..6b7c633a2e98c495c71ed626283004cf74174e00 100644 (file)
@@ -7654,7 +7654,6 @@ L:        linux-media@vger.kernel.org
 Q:     https://patchwork.linuxtv.org/project/linux-media/list/
 S:     Supported
 F:     drivers/media/platform/exynos4-is/
-F:     include/media/s5p_fimc.h
 
 SAMSUNG S3C24XX/S3C64XX SOC SERIES CAMIF DRIVER
 M:     Sylwester Nawrocki <sylvester.nawrocki@gmail.com>
index e1b2ceba00c13e2136e548693ff3038df5c89cae..5dcaa0a805403c5e23372ee12bf3af06e49d35b7 100644 (file)
@@ -3,6 +3,7 @@ config VIDEO_SAMSUNG_EXYNOS4_IS
        bool "Samsung S5P/EXYNOS4 SoC series Camera Subsystem driver"
        depends on VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API
        depends on (PLAT_S5P || ARCH_EXYNOS)
+       depends on OF && COMMON_CLK
        help
          Say Y here to enable camera host interface devices for
          Samsung S5P and EXYNOS SoC series.
@@ -17,7 +18,7 @@ config VIDEO_S5P_FIMC
        depends on I2C
        select VIDEOBUF2_DMA_CONTIG
        select V4L2_MEM2MEM_DEV
-       select MFD_SYSCON if OF
+       select MFD_SYSCON
        select VIDEO_EXYNOS4_IS_COMMON
        help
          This is a V4L2 driver for Samsung S5P and EXYNOS4 SoC camera host
index 0ec210b4da1da053ae3e17b101b137d614d2ff14..0eb34ecb8ee442159c5e02bc116c535bf1d7dc44 100644 (file)
@@ -10,7 +10,7 @@
  */
 
 #include <linux/module.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 #include "common.h"
 
 /* Called with the media graph mutex held or entity->stream_count > 0. */
index 1790fb4e32eabfc8af8084d452e6483827a3852f..6c75c6ced1f70419d17088377fc1ff8dc1cfd5c4 100644 (file)
@@ -27,7 +27,7 @@
 #include <media/v4l2-device.h>
 #include <media/v4l2-mem2mem.h>
 #include <media/v4l2-mediabus.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #define dbg(fmt, args...) \
        pr_debug("%s:%d: " fmt "\n", __func__, __LINE__, ##args)
index ced46600e3436d33b4d85f9414e33faaf8e1788c..93f9cf2ebcd67293d5565c9900b37f949e86c4be 100644 (file)
@@ -30,7 +30,7 @@
 #include <media/v4l2-ioctl.h>
 #include <media/videobuf2-core.h>
 #include <media/videobuf2-dma-contig.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #include "common.h"
 #include "media-dev.h"
index 4dc55a18d9786d1d479cb5e7cfb9b96433e1c556..b99be09b49fc7bae8cfdb0038fe3232f6f328013 100644 (file)
@@ -24,7 +24,7 @@
 #include <media/videobuf2-core.h>
 #include <media/v4l2-device.h>
 #include <media/v4l2-mediabus.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 extern int fimc_isp_debug;
 
index d0dc7ee0445272eb9d3111b88a33460626f49a6a..bc3ec7d25a32fa79ebb4dd4d829d403887aeb148 100644 (file)
@@ -12,7 +12,7 @@
 #include <linux/bitops.h>
 #include <linux/delay.h>
 #include <linux/io.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #include "fimc-lite-reg.h"
 #include "fimc-lite.h"
index 630aef52dbb81df1c58100a3c81c4a7c3c0cf12e..a97d2352f1d7a4a83b1b957f1d23ff1bb5e05f47 100644 (file)
@@ -30,7 +30,7 @@
 #include <media/v4l2-mem2mem.h>
 #include <media/videobuf2-core.h>
 #include <media/videobuf2-dma-contig.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #include "common.h"
 #include "fimc-core.h"
index 7428b2d22b529f97720fd7fbc0922ac4e80c6b22..ea19dc7be63e34af7d212755c87dc095fcfa7a68 100644 (file)
@@ -23,7 +23,7 @@
 #include <media/v4l2-ctrls.h>
 #include <media/v4l2-device.h>
 #include <media/v4l2-mediabus.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #define FIMC_LITE_DRV_NAME     "exynos-fimc-lite"
 #define FLITE_CLK_NAME         "flite"
index 1db8cb4c46ef0a2c67e6525f4cfbaea2d3b13d7b..2d77fd8f440ab96f1de7e2e7783814bbd7880ebe 100644 (file)
@@ -13,7 +13,7 @@
 #include <linux/io.h>
 #include <linux/regmap.h>
 
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 #include "media-dev.h"
 
 #include "fimc-reg.h"
index 6e2d6042ade6098d3facc19bc0abda2013b1aee5..344718df5c62885866d8c6ec0953163c7d99c60a 100644 (file)
@@ -31,7 +31,7 @@
 #include <media/v4l2-ctrls.h>
 #include <media/v4l2-of.h>
 #include <media/media-device.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #include "media-dev.h"
 #include "fimc-core.h"
 #include "fimc-lite.h"
 #include "mipi-csis.h"
 
-static int __fimc_md_set_camclk(struct fimc_md *fmd,
-                               struct fimc_source_info *si,
-                               bool on);
-
 /* Set up image sensor subdev -> FIMC capture node notifications. */
 static void __setup_sensor_notification(struct fimc_md *fmd,
                                        struct v4l2_subdev *sensor,
@@ -223,17 +219,10 @@ static int __fimc_pipeline_open(struct exynos_media_pipeline *ep,
                        return ret;
        }
 
-       ret = fimc_md_set_camclk(sd, true);
-       if (ret < 0)
-               goto err_wbclk;
-
        ret = fimc_pipeline_s_power(p, 1);
        if (!ret)
                return 0;
 
-       fimc_md_set_camclk(sd, false);
-
-err_wbclk:
        if (!IS_ERR(fmd->wbclk[CLK_IDX_WB_B]) && p->subdevs[IDX_IS_ISP])
                clk_disable_unprepare(fmd->wbclk[CLK_IDX_WB_B]);
 
@@ -259,7 +248,6 @@ static int __fimc_pipeline_close(struct exynos_media_pipeline *ep)
        }
 
        ret = fimc_pipeline_s_power(p, 0);
-       fimc_md_set_camclk(sd, false);
 
        fmd = entity_to_fimc_mdev(&sd->entity);
 
@@ -337,75 +325,14 @@ static void fimc_md_pipelines_free(struct fimc_md *fmd)
        }
 }
 
-/*
- * Sensor subdevice helper functions
- */
-static struct v4l2_subdev *fimc_md_register_sensor(struct fimc_md *fmd,
-                                               struct fimc_source_info *si)
-{
-       struct i2c_adapter *adapter;
-       struct v4l2_subdev *sd = NULL;
-
-       if (!si || !fmd)
-               return NULL;
-       /*
-        * If FIMC bus type is not Writeback FIFO assume it is same
-        * as sensor_bus_type.
-        */
-       si->fimc_bus_type = si->sensor_bus_type;
-
-       adapter = i2c_get_adapter(si->i2c_bus_num);
-       if (!adapter) {
-               v4l2_warn(&fmd->v4l2_dev,
-                         "Failed to get I2C adapter %d, deferring probe\n",
-                         si->i2c_bus_num);
-               return ERR_PTR(-EPROBE_DEFER);
-       }
-       sd = v4l2_i2c_new_subdev_board(&fmd->v4l2_dev, adapter,
-                                               si->board_info, NULL);
-       if (IS_ERR_OR_NULL(sd)) {
-               i2c_put_adapter(adapter);
-               v4l2_warn(&fmd->v4l2_dev,
-                         "Failed to acquire subdev %s, deferring probe\n",
-                         si->board_info->type);
-               return ERR_PTR(-EPROBE_DEFER);
-       }
-       v4l2_set_subdev_hostdata(sd, si);
-       sd->grp_id = GRP_ID_SENSOR;
-
-       v4l2_info(&fmd->v4l2_dev, "Registered sensor subdevice %s\n",
-                 sd->name);
-       return sd;
-}
-
-static void fimc_md_unregister_sensor(struct v4l2_subdev *sd)
-{
-       struct i2c_client *client = v4l2_get_subdevdata(sd);
-       struct i2c_adapter *adapter;
-
-       if (!client || client->dev.of_node)
-               return;
-
-       v4l2_device_unregister_subdev(sd);
-
-       adapter = client->adapter;
-       i2c_unregister_device(client);
-       if (adapter)
-               i2c_put_adapter(adapter);
-}
-
-#ifdef CONFIG_OF
 /* Parse port node and register as a sub-device any sensor specified there. */
 static int fimc_md_parse_port_node(struct fimc_md *fmd,
                                   struct device_node *port,
                                   unsigned int index)
 {
+       struct fimc_source_info *pd = &fmd->sensor[index].pdata;
        struct device_node *rem, *ep, *np;
-       struct fimc_source_info *pd;
        struct v4l2_of_endpoint endpoint;
-       u32 val;
-
-       pd = &fmd->sensor[index].pdata;
 
        /* Assume here a port node can have only one endpoint node. */
        ep = of_get_next_child(port, NULL);
@@ -425,20 +352,6 @@ static int fimc_md_parse_port_node(struct fimc_md *fmd,
                                                        ep->full_name);
                return 0;
        }
-       if (!of_property_read_u32(rem, "samsung,camclk-out", &val))
-               pd->clk_id = val;
-
-       if (!of_property_read_u32(rem, "clock-frequency", &val))
-               pd->clk_frequency = val;
-       else
-               pd->clk_frequency = DEFAULT_SENSOR_CLK_FREQ;
-
-       if (pd->clk_frequency == 0) {
-               v4l2_err(&fmd->v4l2_dev, "Wrong clock frequency at node %s\n",
-                        rem->full_name);
-               of_node_put(rem);
-               return -EINVAL;
-       }
 
        if (fimc_input_is_parallel(endpoint.base.port)) {
                if (endpoint.bus_type == V4L2_MBUS_PARALLEL)
@@ -485,14 +398,26 @@ static int fimc_md_parse_port_node(struct fimc_md *fmd,
 }
 
 /* Register all SoC external sub-devices */
-static int fimc_md_of_sensors_register(struct fimc_md *fmd,
-                                      struct device_node *np)
+static int fimc_md_register_sensor_entities(struct fimc_md *fmd)
 {
        struct device_node *parent = fmd->pdev->dev.of_node;
        struct device_node *node, *ports;
        int index = 0;
        int ret;
 
+       /*
+        * Runtime resume one of the FIMC entities to make sure
+        * the sclk_cam clocks are not globally disabled.
+        */
+       if (!fmd->pmf)
+               return -ENXIO;
+
+       ret = pm_runtime_get_sync(fmd->pmf);
+       if (ret < 0)
+               return ret;
+
+       fmd->num_sensors = 0;
+
        /* Attach sensors linked to MIPI CSI-2 receivers */
        for_each_available_child_of_node(parent, node) {
                struct device_node *port;
@@ -506,14 +431,14 @@ static int fimc_md_of_sensors_register(struct fimc_md *fmd,
 
                ret = fimc_md_parse_port_node(fmd, port, index);
                if (ret < 0)
-                       return ret;
+                       goto rpm_put;
                index++;
        }
 
        /* Attach sensors listed in the parallel-ports node */
        ports = of_get_child_by_name(parent, "parallel-ports");
        if (!ports)
-               return 0;
+               goto rpm_put;
 
        for_each_child_of_node(ports, node) {
                ret = fimc_md_parse_port_node(fmd, node, index);
@@ -521,8 +446,9 @@ static int fimc_md_of_sensors_register(struct fimc_md *fmd,
                        break;
                index++;
        }
-
-       return 0;
+rpm_put:
+       pm_runtime_put(fmd->pmf);
+       return ret;
 }
 
 static int __of_get_csis_id(struct device_node *np)
@@ -535,68 +461,10 @@ static int __of_get_csis_id(struct device_node *np)
        of_property_read_u32(np, "reg", &reg);
        return reg - FIMC_INPUT_MIPI_CSI2_0;
 }
-#else
-#define fimc_md_of_sensors_register(fmd, np) (-ENOSYS)
-#define __of_get_csis_id(np) (-ENOSYS)
-#endif
-
-static int fimc_md_register_sensor_entities(struct fimc_md *fmd)
-{
-       struct s5p_platform_fimc *pdata = fmd->pdev->dev.platform_data;
-       struct device_node *of_node = fmd->pdev->dev.of_node;
-       int num_clients = 0;
-       int ret, i;
-
-       /*
-        * Runtime resume one of the FIMC entities to make sure
-        * the sclk_cam clocks are not globally disabled.
-        */
-       if (!fmd->pmf)
-               return -ENXIO;
-
-       ret = pm_runtime_get_sync(fmd->pmf);
-       if (ret < 0)
-               return ret;
-
-       if (of_node) {
-               fmd->num_sensors = 0;
-               ret = fimc_md_of_sensors_register(fmd, of_node);
-       } else if (pdata) {
-               WARN_ON(pdata->num_clients > ARRAY_SIZE(fmd->sensor));
-               num_clients = min_t(u32, pdata->num_clients,
-                                   ARRAY_SIZE(fmd->sensor));
-               fmd->num_sensors = num_clients;
-
-               for (i = 0; i < num_clients; i++) {
-                       struct fimc_sensor_info *si = &fmd->sensor[i];
-                       struct v4l2_subdev *sd;
-
-                       si->pdata = pdata->source_info[i];
-                       ret = __fimc_md_set_camclk(fmd, &si->pdata, true);
-                       if (ret)
-                               break;
-                       sd = fimc_md_register_sensor(fmd, &si->pdata);
-                       ret = __fimc_md_set_camclk(fmd, &si->pdata, false);
-
-                       if (IS_ERR(sd)) {
-                               si->subdev = NULL;
-                               ret = PTR_ERR(sd);
-                               break;
-                       }
-                       si->subdev = sd;
-                       if (ret)
-                               break;
-               }
-       }
-
-       pm_runtime_put(fmd->pmf);
-       return ret;
-}
 
 /*
  * MIPI-CSIS, FIMC and FIMC-LITE platform devices registration.
  */
-
 static int register_fimc_lite_entity(struct fimc_md *fmd,
                                     struct fimc_lite *fimc_lite)
 {
@@ -753,35 +621,9 @@ dev_unlock:
        return ret;
 }
 
-static int fimc_md_pdev_match(struct device *dev, void *data)
-{
-       struct platform_device *pdev = to_platform_device(dev);
-       int plat_entity = -1;
-       int ret;
-       char *p;
-
-       if (!get_device(dev))
-               return -ENODEV;
-
-       if (!strcmp(pdev->name, CSIS_DRIVER_NAME)) {
-               plat_entity = IDX_CSIS;
-       } else {
-               p = strstr(pdev->name, "fimc");
-               if (p && *(p + 4) == 0)
-                       plat_entity = IDX_FIMC;
-       }
-
-       if (plat_entity >= 0)
-               ret = fimc_md_register_platform_entity(data, pdev,
-                                                      plat_entity);
-       put_device(dev);
-       return 0;
-}
-
 /* Register FIMC, FIMC-LITE and CSIS media entities */
-#ifdef CONFIG_OF
-static int fimc_md_register_of_platform_entities(struct fimc_md *fmd,
-                                                struct device_node *parent)
+static int fimc_md_register_platform_entities(struct fimc_md *fmd,
+                                             struct device_node *parent)
 {
        struct device_node *node;
        int ret = 0;
@@ -815,9 +657,6 @@ static int fimc_md_register_of_platform_entities(struct fimc_md *fmd,
 
        return ret;
 }
-#else
-#define fimc_md_register_of_platform_entities(fmd, node) (-ENOSYS)
-#endif
 
 static void fimc_md_unregister_entities(struct fimc_md *fmd)
 {
@@ -845,14 +684,6 @@ static void fimc_md_unregister_entities(struct fimc_md *fmd)
                v4l2_device_unregister_subdev(fmd->csis[i].sd);
                fmd->csis[i].sd = NULL;
        }
-       if (fmd->pdev->dev.of_node == NULL) {
-               for (i = 0; i < fmd->num_sensors; i++) {
-                       if (fmd->sensor[i].subdev == NULL)
-                               continue;
-                       fimc_md_unregister_sensor(fmd->sensor[i].subdev);
-                       fmd->sensor[i].subdev = NULL;
-               }
-       }
 
        if (fmd->fimc_is)
                v4l2_device_unregister_subdev(&fmd->fimc_is->isp.subdev);
@@ -1137,7 +968,7 @@ static void fimc_md_put_clocks(struct fimc_md *fmd)
 
 static int fimc_md_get_clocks(struct fimc_md *fmd)
 {
-       struct device *dev = NULL;
+       struct device *dev = &fmd->pdev->dev;
        char clk_name[32];
        struct clk *clock;
        int i, ret = 0;
@@ -1145,16 +976,12 @@ static int fimc_md_get_clocks(struct fimc_md *fmd)
        for (i = 0; i < FIMC_MAX_CAMCLKS; i++)
                fmd->camclk[i].clock = ERR_PTR(-EINVAL);
 
-       if (fmd->pdev->dev.of_node)
-               dev = &fmd->pdev->dev;
-
        for (i = 0; i < FIMC_MAX_CAMCLKS; i++) {
                snprintf(clk_name, sizeof(clk_name), "sclk_cam%u", i);
                clock = clk_get(dev, clk_name);
 
                if (IS_ERR(clock)) {
-                       dev_err(&fmd->pdev->dev, "Failed to get clock: %s\n",
-                                                               clk_name);
+                       dev_err(dev, "Failed to get clock: %s\n", clk_name);
                        ret = PTR_ERR(clock);
                        break;
                }
@@ -1188,86 +1015,6 @@ static int fimc_md_get_clocks(struct fimc_md *fmd)
        return ret;
 }
 
-static int __fimc_md_set_camclk(struct fimc_md *fmd,
-                               struct fimc_source_info *si,
-                               bool on)
-{
-       struct fimc_camclk_info *camclk;
-       int ret = 0;
-
-       /*
-        * When device tree is used the sensor drivers are supposed to
-        * control the clock themselves. This whole function will be
-        * removed once S5PV210 platform is converted to the device tree.
-        */
-       if (fmd->pdev->dev.of_node)
-               return 0;
-
-       if (WARN_ON(si->clk_id >= FIMC_MAX_CAMCLKS) || !fmd || !fmd->pmf)
-               return -EINVAL;
-
-       camclk = &fmd->camclk[si->clk_id];
-
-       dbg("camclk %d, f: %lu, use_count: %d, on: %d",
-           si->clk_id, si->clk_frequency, camclk->use_count, on);
-
-       if (on) {
-               if (camclk->use_count > 0 &&
-                   camclk->frequency != si->clk_frequency)
-                       return -EINVAL;
-
-               if (camclk->use_count++ == 0) {
-                       clk_set_rate(camclk->clock, si->clk_frequency);
-                       camclk->frequency = si->clk_frequency;
-                       ret = pm_runtime_get_sync(fmd->pmf);
-                       if (ret < 0)
-                               return ret;
-                       ret = clk_prepare_enable(camclk->clock);
-                       dbg("Enabled camclk %d: f: %lu", si->clk_id,
-                           clk_get_rate(camclk->clock));
-               }
-               return ret;
-       }
-
-       if (WARN_ON(camclk->use_count == 0))
-               return 0;
-
-       if (--camclk->use_count == 0) {
-               clk_disable_unprepare(camclk->clock);
-               pm_runtime_put(fmd->pmf);
-               dbg("Disabled camclk %d", si->clk_id);
-       }
-       return ret;
-}
-
-/**
- * fimc_md_set_camclk - peripheral sensor clock setup
- * @sd: sensor subdev to configure sclk_cam clock for
- * @on: 1 to enable or 0 to disable the clock
- *
- * There are 2 separate clock outputs available in the SoC for external
- * image processors. These clocks are shared between all registered FIMC
- * devices to which sensors can be attached, either directly or through
- * the MIPI CSI receiver. The clock is allowed here to be used by
- * multiple sensors concurrently if they use same frequency.
- * This function should only be called when the graph mutex is held.
- */
-int fimc_md_set_camclk(struct v4l2_subdev *sd, bool on)
-{
-       struct fimc_source_info *si = v4l2_get_subdev_hostdata(sd);
-       struct fimc_md *fmd = entity_to_fimc_mdev(&sd->entity);
-
-       /*
-        * If there is a clock provider registered the sensors will
-        * handle their clock themselves, no need to control it on
-        * the host interface side.
-        */
-       if (fmd->clk_provider.num_clocks > 0)
-               return 0;
-
-       return __fimc_md_set_camclk(fmd, si, on);
-}
-
 static int __fimc_md_modify_pipeline(struct media_entity *entity, bool enable)
 {
        struct exynos_video_entity *ve;
@@ -1426,7 +1173,6 @@ static int fimc_md_get_pinctrl(struct fimc_md *fmd)
        return 0;
 }
 
-#ifdef CONFIG_OF
 static int cam_clk_prepare(struct clk_hw *hw)
 {
        struct cam_clk *camclk = to_cam_clk(hw);
@@ -1518,10 +1264,6 @@ err:
        fimc_md_unregister_clk_provider(fmd);
        return ret;
 }
-#else
-#define fimc_md_register_clk_provider(fmd) (0)
-#define fimc_md_unregister_clk_provider(fmd)
-#endif
 
 static int subdev_notifier_bound(struct v4l2_async_notifier *notifier,
                                 struct v4l2_subdev *subdev,
@@ -1585,8 +1327,8 @@ static int fimc_md_probe(struct platform_device *pdev)
                return -ENOMEM;
 
        spin_lock_init(&fmd->slock);
-       fmd->pdev = pdev;
        INIT_LIST_HEAD(&fmd->pipelines);
+       fmd->pdev = pdev;
 
        strlcpy(fmd->media_dev.model, "SAMSUNG S5P FIMC",
                sizeof(fmd->media_dev.model));
@@ -1599,6 +1341,7 @@ static int fimc_md_probe(struct platform_device *pdev)
        strlcpy(v4l2_dev->name, "s5p-fimc-md", sizeof(v4l2_dev->name));
 
        fmd->use_isp = fimc_md_is_isp_available(dev->of_node);
+       fmd->user_subdev_api = true;
 
        ret = v4l2_device_register(dev, &fmd->v4l2_dev);
        if (ret < 0) {
@@ -1616,8 +1359,6 @@ static int fimc_md_probe(struct platform_device *pdev)
        if (ret)
                goto err_md;
 
-       fmd->user_subdev_api = (dev->of_node != NULL);
-
        ret = fimc_md_get_pinctrl(fmd);
        if (ret < 0) {
                if (ret != EPROBE_DEFER)
@@ -1630,22 +1371,16 @@ static int fimc_md_probe(struct platform_device *pdev)
        /* Protect the media graph while we're registering entities */
        mutex_lock(&fmd->media_dev.graph_mutex);
 
-       if (dev->of_node)
-               ret = fimc_md_register_of_platform_entities(fmd, dev->of_node);
-       else
-               ret = bus_for_each_dev(&platform_bus_type, NULL, fmd,
-                                               fimc_md_pdev_match);
+       ret = fimc_md_register_platform_entities(fmd, dev->of_node);
        if (ret) {
                mutex_unlock(&fmd->media_dev.graph_mutex);
                goto err_clk;
        }
 
-       if (dev->platform_data || dev->of_node) {
-               ret = fimc_md_register_sensor_entities(fmd);
-               if (ret) {
-                       mutex_unlock(&fmd->media_dev.graph_mutex);
-                       goto err_m_ent;
-               }
+       ret = fimc_md_register_sensor_entities(fmd);
+       if (ret) {
+               mutex_unlock(&fmd->media_dev.graph_mutex);
+               goto err_m_ent;
        }
 
        mutex_unlock(&fmd->media_dev.graph_mutex);
index 58c49456b13fd0af60518f2575f7a09d9a4571a0..03214541f1493422e57749dbf6e62af138d74c41 100644 (file)
@@ -19,7 +19,7 @@
 #include <media/media-entity.h>
 #include <media/v4l2-device.h>
 #include <media/v4l2-subdev.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 
 #include "fimc-core.h"
 #include "fimc-lite.h"
@@ -94,9 +94,7 @@ struct fimc_sensor_info {
 };
 
 struct cam_clk {
-#ifdef CONFIG_COMMON_CLK
        struct clk_hw hw;
-#endif
        struct fimc_md *fmd;
 };
 #define to_cam_clk(_hw) container_of(_hw, struct cam_clk, hw)
@@ -144,9 +142,7 @@ struct fimc_md {
 
        struct cam_clk_provider {
                struct clk *clks[FIMC_MAX_CAMCLKS];
-#ifdef CONFIG_COMMON_CLK
                struct clk_onecell_data clk_data;
-#endif
                struct device_node *of_node;
                struct cam_clk camclk[FIMC_MAX_CAMCLKS];
                int num_clocks;
index 3678ba59725cf807cec7fa63527f0dd4ce3d3f1f..ae54ef5f535d9c105f643d76e3f78c72ee341095 100644 (file)
 #include <linux/of.h>
 #include <linux/of_graph.h>
 #include <linux/phy/phy.h>
-#include <linux/platform_data/mipi-csis.h>
 #include <linux/platform_device.h>
 #include <linux/pm_runtime.h>
 #include <linux/regulator/consumer.h>
 #include <linux/slab.h>
 #include <linux/spinlock.h>
 #include <linux/videodev2.h>
-#include <media/s5p_fimc.h>
+#include <media/exynos-fimc.h>
 #include <media/v4l2-of.h>
 #include <media/v4l2-subdev.h>
 
@@ -730,26 +729,6 @@ static irqreturn_t s5pcsis_irq_handler(int irq, void *dev_id)
        return IRQ_HANDLED;
 }
 
-static int s5pcsis_get_platform_data(struct platform_device *pdev,
-                                    struct csis_state *state)
-{
-       struct s5p_platform_mipi_csis *pdata = pdev->dev.platform_data;
-
-       if (pdata == NULL) {
-               dev_err(&pdev->dev, "Platform data not specified\n");
-               return -EINVAL;
-       }
-
-       state->clk_frequency = pdata->clk_rate;
-       state->num_lanes = pdata->lanes;
-       state->hs_settle = pdata->hs_settle;
-       state->index = max(0, pdev->id);
-       state->max_num_lanes = state->index ? CSIS1_MAX_LANES :
-                                             CSIS0_MAX_LANES;
-       return 0;
-}
-
-#ifdef CONFIG_OF
 static int s5pcsis_parse_dt(struct platform_device *pdev,
                            struct csis_state *state)
 {
@@ -787,9 +766,6 @@ static int s5pcsis_parse_dt(struct platform_device *pdev,
 
        return 0;
 }
-#else
-#define s5pcsis_parse_dt(pdev, state) (-ENOSYS)
-#endif
 
 static int s5pcsis_pm_resume(struct device *dev, bool runtime);
 static const struct of_device_id s5pcsis_of_match[];
@@ -812,19 +788,14 @@ static int s5pcsis_probe(struct platform_device *pdev)
        spin_lock_init(&state->slock);
        state->pdev = pdev;
 
-       if (dev->of_node) {
-               of_id = of_match_node(s5pcsis_of_match, dev->of_node);
-               if (WARN_ON(of_id == NULL))
-                       return -EINVAL;
-
-               drv_data = of_id->data;
-               state->interrupt_mask = drv_data->interrupt_mask;
+       of_id = of_match_node(s5pcsis_of_match, dev->of_node);
+       if (WARN_ON(of_id == NULL))
+               return -EINVAL;
 
-               ret = s5pcsis_parse_dt(pdev, state);
-       } else {
-               ret = s5pcsis_get_platform_data(pdev, state);
-       }
+       drv_data = of_id->data;
+       state->interrupt_mask = drv_data->interrupt_mask;
 
+       ret = s5pcsis_parse_dt(pdev, state);
        if (ret < 0)
                return ret;
 
diff --git a/include/linux/platform_data/mipi-csis.h b/include/linux/platform_data/mipi-csis.h
deleted file mode 100644 (file)
index c2fd902..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (C) 2010 - 2012 Samsung Electronics Co., Ltd.
- *
- * Samsung S5P/Exynos SoC series MIPI CSIS device support
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
-
-#ifndef __PLAT_SAMSUNG_MIPI_CSIS_H_
-#define __PLAT_SAMSUNG_MIPI_CSIS_H_ __FILE__
-
-/**
- * struct s5p_platform_mipi_csis - platform data for S5P MIPI-CSIS driver
- * @clk_rate:    bus clock frequency
- * @wclk_source: CSI wrapper clock selection: 0 - bus clock, 1 - ext. SCLK_CAM
- * @lanes:       number of data lanes used
- * @hs_settle:   HS-RX settle time
- */
-struct s5p_platform_mipi_csis {
-       unsigned long clk_rate;
-       u8 wclk_source;
-       u8 lanes;
-       u8 hs_settle;
-};
-
-#endif /* __PLAT_SAMSUNG_MIPI_CSIS_H_ */
diff --git a/include/media/exynos-fimc.h b/include/media/exynos-fimc.h
new file mode 100644 (file)
index 0000000..aa44660
--- /dev/null
@@ -0,0 +1,161 @@
+/*
+ * Samsung S5P/Exynos4 SoC series camera interface driver header
+ *
+ * Copyright (C) 2010 - 2013 Samsung Electronics Co., Ltd.
+ * Sylwester Nawrocki <s.nawrocki@samsung.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#ifndef S5P_FIMC_H_
+#define S5P_FIMC_H_
+
+#include <media/media-entity.h>
+#include <media/v4l2-dev.h>
+#include <media/v4l2-mediabus.h>
+
+/*
+ * Enumeration of data inputs to the camera subsystem.
+ */
+enum fimc_input {
+       FIMC_INPUT_PARALLEL_0   = 1,
+       FIMC_INPUT_PARALLEL_1,
+       FIMC_INPUT_MIPI_CSI2_0  = 3,
+       FIMC_INPUT_MIPI_CSI2_1,
+       FIMC_INPUT_WRITEBACK_A  = 5,
+       FIMC_INPUT_WRITEBACK_B,
+       FIMC_INPUT_WRITEBACK_ISP = 5,
+};
+
+/*
+ * Enumeration of the FIMC data bus types.
+ */
+enum fimc_bus_type {
+       /* Camera parallel bus */
+       FIMC_BUS_TYPE_ITU_601 = 1,
+       /* Camera parallel bus with embedded synchronization */
+       FIMC_BUS_TYPE_ITU_656,
+       /* Camera MIPI-CSI2 serial bus */
+       FIMC_BUS_TYPE_MIPI_CSI2,
+       /* FIFO link from LCD controller (WriteBack A) */
+       FIMC_BUS_TYPE_LCD_WRITEBACK_A,
+       /* FIFO link from LCD controller (WriteBack B) */
+       FIMC_BUS_TYPE_LCD_WRITEBACK_B,
+       /* FIFO link from FIMC-IS */
+       FIMC_BUS_TYPE_ISP_WRITEBACK = FIMC_BUS_TYPE_LCD_WRITEBACK_B,
+};
+
+#define fimc_input_is_parallel(x) ((x) == 1 || (x) == 2)
+#define fimc_input_is_mipi_csi(x) ((x) == 3 || (x) == 4)
+
+/*
+ * The subdevices' group IDs.
+ */
+#define GRP_ID_SENSOR          (1 << 8)
+#define GRP_ID_FIMC_IS_SENSOR  (1 << 9)
+#define GRP_ID_WRITEBACK       (1 << 10)
+#define GRP_ID_CSIS            (1 << 11)
+#define GRP_ID_FIMC            (1 << 12)
+#define GRP_ID_FLITE           (1 << 13)
+#define GRP_ID_FIMC_IS         (1 << 14)
+
+/**
+ * struct fimc_source_info - video source description required for the host
+ *                          interface configuration
+ *
+ * @fimc_bus_type: FIMC camera input type
+ * @sensor_bus_type: image sensor bus type, MIPI, ITU-R BT.601 etc.
+ * @flags: the parallel sensor bus flags defining signals polarity (V4L2_MBUS_*)
+ * @mux_id: FIMC camera interface multiplexer index (separate for MIPI and ITU)
+ */
+struct fimc_source_info {
+       enum fimc_bus_type fimc_bus_type;
+       enum fimc_bus_type sensor_bus_type;
+       u16 flags;
+       u16 mux_id;
+};
+
+/*
+ * v4l2_device notification id. This is only for internal use in the kernel.
+ * Sensor subdevs should issue S5P_FIMC_TX_END_NOTIFY notification in single
+ * frame capture mode when there is only one VSYNC pulse issued by the sensor
+ * at begining of the frame transmission.
+ */
+#define S5P_FIMC_TX_END_NOTIFY _IO('e', 0)
+
+#define FIMC_MAX_PLANES        3
+
+/**
+ * struct fimc_fmt - color format data structure
+ * @mbus_code: media bus pixel code, -1 if not applicable
+ * @name: format description
+ * @fourcc: fourcc code for this format, 0 if not applicable
+ * @color: the driver's private color format id
+ * @memplanes: number of physically non-contiguous data planes
+ * @colplanes: number of physically contiguous data planes
+ * @colorspace: v4l2 colorspace (V4L2_COLORSPACE_*)
+ * @depth: per plane driver's private 'number of bits per pixel'
+ * @mdataplanes: bitmask indicating meta data plane(s), (1 << plane_no)
+ * @flags: flags indicating which operation mode format applies to
+ */
+struct fimc_fmt {
+       enum v4l2_mbus_pixelcode mbus_code;
+       char    *name;
+       u32     fourcc;
+       u32     color;
+       u16     memplanes;
+       u16     colplanes;
+       u8      colorspace;
+       u8      depth[FIMC_MAX_PLANES];
+       u16     mdataplanes;
+       u16     flags;
+#define FMT_FLAGS_CAM          (1 << 0)
+#define FMT_FLAGS_M2M_IN       (1 << 1)
+#define FMT_FLAGS_M2M_OUT      (1 << 2)
+#define FMT_FLAGS_M2M          (1 << 1 | 1 << 2)
+#define FMT_HAS_ALPHA          (1 << 3)
+#define FMT_FLAGS_COMPRESSED   (1 << 4)
+#define FMT_FLAGS_WRITEBACK    (1 << 5)
+#define FMT_FLAGS_RAW_BAYER    (1 << 6)
+#define FMT_FLAGS_YUV          (1 << 7)
+};
+
+struct exynos_media_pipeline;
+
+/*
+ * Media pipeline operations to be called from within a video node,  i.e. the
+ * last entity within the pipeline. Implemented by related media device driver.
+ */
+struct exynos_media_pipeline_ops {
+       int (*prepare)(struct exynos_media_pipeline *p,
+                                               struct media_entity *me);
+       int (*unprepare)(struct exynos_media_pipeline *p);
+       int (*open)(struct exynos_media_pipeline *p, struct media_entity *me,
+                                                       bool resume);
+       int (*close)(struct exynos_media_pipeline *p);
+       int (*set_stream)(struct exynos_media_pipeline *p, bool state);
+};
+
+struct exynos_video_entity {
+       struct video_device vdev;
+       struct exynos_media_pipeline *pipe;
+};
+
+struct exynos_media_pipeline {
+       struct media_pipeline mp;
+       const struct exynos_media_pipeline_ops *ops;
+};
+
+static inline struct exynos_video_entity *vdev_to_exynos_video_entity(
+                                       struct video_device *vdev)
+{
+       return container_of(vdev, struct exynos_video_entity, vdev);
+}
+
+#define fimc_pipeline_call(ent, op, args...)                             \
+       (!(ent) ? -ENOENT : (((ent)->pipe->ops && (ent)->pipe->ops->op) ? \
+       (ent)->pipe->ops->op(((ent)->pipe), ##args) : -ENOIOCTLCMD))      \
+
+#endif /* S5P_FIMC_H_ */
diff --git a/include/media/s5p_fimc.h b/include/media/s5p_fimc.h
deleted file mode 100644 (file)
index b975c28..0000000
+++ /dev/null
@@ -1,182 +0,0 @@
-/*
- * Samsung S5P/Exynos4 SoC series camera interface driver header
- *
- * Copyright (C) 2010 - 2013 Samsung Electronics Co., Ltd.
- * Sylwester Nawrocki <s.nawrocki@samsung.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
-
-#ifndef S5P_FIMC_H_
-#define S5P_FIMC_H_
-
-#include <media/media-entity.h>
-#include <media/v4l2-dev.h>
-#include <media/v4l2-mediabus.h>
-
-/*
- * Enumeration of data inputs to the camera subsystem.
- */
-enum fimc_input {
-       FIMC_INPUT_PARALLEL_0   = 1,
-       FIMC_INPUT_PARALLEL_1,
-       FIMC_INPUT_MIPI_CSI2_0  = 3,
-       FIMC_INPUT_MIPI_CSI2_1,
-       FIMC_INPUT_WRITEBACK_A  = 5,
-       FIMC_INPUT_WRITEBACK_B,
-       FIMC_INPUT_WRITEBACK_ISP = 5,
-};
-
-/*
- * Enumeration of the FIMC data bus types.
- */
-enum fimc_bus_type {
-       /* Camera parallel bus */
-       FIMC_BUS_TYPE_ITU_601 = 1,
-       /* Camera parallel bus with embedded synchronization */
-       FIMC_BUS_TYPE_ITU_656,
-       /* Camera MIPI-CSI2 serial bus */
-       FIMC_BUS_TYPE_MIPI_CSI2,
-       /* FIFO link from LCD controller (WriteBack A) */
-       FIMC_BUS_TYPE_LCD_WRITEBACK_A,
-       /* FIFO link from LCD controller (WriteBack B) */
-       FIMC_BUS_TYPE_LCD_WRITEBACK_B,
-       /* FIFO link from FIMC-IS */
-       FIMC_BUS_TYPE_ISP_WRITEBACK = FIMC_BUS_TYPE_LCD_WRITEBACK_B,
-};
-
-#define fimc_input_is_parallel(x) ((x) == 1 || (x) == 2)
-#define fimc_input_is_mipi_csi(x) ((x) == 3 || (x) == 4)
-
-/*
- * The subdevices' group IDs.
- */
-#define GRP_ID_SENSOR          (1 << 8)
-#define GRP_ID_FIMC_IS_SENSOR  (1 << 9)
-#define GRP_ID_WRITEBACK       (1 << 10)
-#define GRP_ID_CSIS            (1 << 11)
-#define GRP_ID_FIMC            (1 << 12)
-#define GRP_ID_FLITE           (1 << 13)
-#define GRP_ID_FIMC_IS         (1 << 14)
-
-struct i2c_board_info;
-
-/**
- * struct fimc_source_info - video source description required for the host
- *                          interface configuration
- *
- * @board_info: pointer to I2C subdevice's board info
- * @clk_frequency: frequency of the clock the host interface provides to sensor
- * @fimc_bus_type: FIMC camera input type
- * @sensor_bus_type: image sensor bus type, MIPI, ITU-R BT.601 etc.
- * @flags: the parallel sensor bus flags defining signals polarity (V4L2_MBUS_*)
- * @i2c_bus_num: i2c control bus id the sensor is attached to
- * @mux_id: FIMC camera interface multiplexer index (separate for MIPI and ITU)
- * @clk_id: index of the SoC peripheral clock for sensors
- */
-struct fimc_source_info {
-       struct i2c_board_info *board_info;
-       unsigned long clk_frequency;
-       enum fimc_bus_type fimc_bus_type;
-       enum fimc_bus_type sensor_bus_type;
-       u16 flags;
-       u16 i2c_bus_num;
-       u16 mux_id;
-       u8 clk_id;
-};
-
-/**
- * struct s5p_platform_fimc - camera host interface platform data
- *
- * @source_info: properties of an image source for the host interface setup
- * @num_clients: the number of attached image sources
- */
-struct s5p_platform_fimc {
-       struct fimc_source_info *source_info;
-       int num_clients;
-};
-
-/*
- * v4l2_device notification id. This is only for internal use in the kernel.
- * Sensor subdevs should issue S5P_FIMC_TX_END_NOTIFY notification in single
- * frame capture mode when there is only one VSYNC pulse issued by the sensor
- * at begining of the frame transmission.
- */
-#define S5P_FIMC_TX_END_NOTIFY _IO('e', 0)
-
-#define FIMC_MAX_PLANES        3
-
-/**
- * struct fimc_fmt - color format data structure
- * @mbus_code: media bus pixel code, -1 if not applicable
- * @name: format description
- * @fourcc: fourcc code for this format, 0 if not applicable
- * @color: the driver's private color format id
- * @memplanes: number of physically non-contiguous data planes
- * @colplanes: number of physically contiguous data planes
- * @colorspace: v4l2 colorspace (V4L2_COLORSPACE_*)
- * @depth: per plane driver's private 'number of bits per pixel'
- * @mdataplanes: bitmask indicating meta data plane(s), (1 << plane_no)
- * @flags: flags indicating which operation mode format applies to
- */
-struct fimc_fmt {
-       enum v4l2_mbus_pixelcode mbus_code;
-       char    *name;
-       u32     fourcc;
-       u32     color;
-       u16     memplanes;
-       u16     colplanes;
-       u8      colorspace;
-       u8      depth[FIMC_MAX_PLANES];
-       u16     mdataplanes;
-       u16     flags;
-#define FMT_FLAGS_CAM          (1 << 0)
-#define FMT_FLAGS_M2M_IN       (1 << 1)
-#define FMT_FLAGS_M2M_OUT      (1 << 2)
-#define FMT_FLAGS_M2M          (1 << 1 | 1 << 2)
-#define FMT_HAS_ALPHA          (1 << 3)
-#define FMT_FLAGS_COMPRESSED   (1 << 4)
-#define FMT_FLAGS_WRITEBACK    (1 << 5)
-#define FMT_FLAGS_RAW_BAYER    (1 << 6)
-#define FMT_FLAGS_YUV          (1 << 7)
-};
-
-struct exynos_media_pipeline;
-
-/*
- * Media pipeline operations to be called from within a video node,  i.e. the
- * last entity within the pipeline. Implemented by related media device driver.
- */
-struct exynos_media_pipeline_ops {
-       int (*prepare)(struct exynos_media_pipeline *p,
-                                               struct media_entity *me);
-       int (*unprepare)(struct exynos_media_pipeline *p);
-       int (*open)(struct exynos_media_pipeline *p, struct media_entity *me,
-                                                       bool resume);
-       int (*close)(struct exynos_media_pipeline *p);
-       int (*set_stream)(struct exynos_media_pipeline *p, bool state);
-};
-
-struct exynos_video_entity {
-       struct video_device vdev;
-       struct exynos_media_pipeline *pipe;
-};
-
-struct exynos_media_pipeline {
-       struct media_pipeline mp;
-       const struct exynos_media_pipeline_ops *ops;
-};
-
-static inline struct exynos_video_entity *vdev_to_exynos_video_entity(
-                                       struct video_device *vdev)
-{
-       return container_of(vdev, struct exynos_video_entity, vdev);
-}
-
-#define fimc_pipeline_call(ent, op, args...)                             \
-       (!(ent) ? -ENOENT : (((ent)->pipe->ops && (ent)->pipe->ops->op) ? \
-       (ent)->pipe->ops->op(((ent)->pipe), ##args) : -ENOIOCTLCMD))      \
-
-#endif /* S5P_FIMC_H_ */