if (ret)
                gc2235_remove(client);
 
-       return atomisp_register_i2c_module(&dev->sd, gcpdev, RAW_CAMERA);
+       return atomisp_register_i2c_module(&dev->sd, gcpdev);
 
 out_free:
        v4l2_device_unregister_subdev(&dev->sd);
 
                return ret;
        }
 
-       ret = atomisp_register_i2c_module(&dev->sd, pdata, RAW_CAMERA);
+       ret = atomisp_register_i2c_module(&dev->sd, pdata);
        if (ret) {
                v4l2_device_unregister_subdev(&dev->sd);
                kfree(dev);
 
        if (ret)
                ov2722_remove(client);
 
-       return atomisp_register_i2c_module(&dev->sd, ovpdev, RAW_CAMERA);
+       return atomisp_register_i2c_module(&dev->sd, ovpdev);
 
 out_ctrl_handler_free:
        v4l2_ctrl_handler_free(&dev->ctrl_handler);
 
 #include "atomisp_platform.h"
 
 int atomisp_register_i2c_module(struct v4l2_subdev *subdev,
-                               struct camera_sensor_platform_data *plat_data,
-                               enum intel_v4l2_subdev_type type);
+                               struct camera_sensor_platform_data *plat_data);
 int atomisp_gmin_remove_subdev(struct v4l2_subdev *sd);
 int gmin_get_var_int(struct device *dev, bool is_gmin,
                     const char *var, int def);
 
 
 #define N_ATOMISP_INPUT_FORMAT (ATOMISP_INPUT_FORMAT_USER_DEF8 + 1)
 
-enum intel_v4l2_subdev_type {
-       RAW_CAMERA = 1,
-};
-
-struct intel_v4l2_subdev_id {
-       char name[17];
-       enum intel_v4l2_subdev_type type;
-       enum atomisp_camera_port    port;
-};
-
 struct intel_v4l2_subdev_table {
-       enum intel_v4l2_subdev_type type;
        enum atomisp_camera_port port;
        unsigned int lanes;
        struct v4l2_subdev *subdev;
 
 static int gmin_v1p8_enable_count;
 static int gmin_v2p8_enable_count;
 
-/* The atomisp uses type==0 for the end-of-list marker, so leave space. */
+/* The atomisp uses subdev==NULL for the end-of-list marker, so leave space. */
 static struct intel_v4l2_subdev_table pdata_subdevs[MAX_SUBDEVS + 1];
 
 static const struct atomisp_platform_data pdata = {
 EXPORT_SYMBOL_GPL(atomisp_get_platform_data);
 
 int atomisp_register_i2c_module(struct v4l2_subdev *subdev,
-                               struct camera_sensor_platform_data *plat_data,
-                               enum intel_v4l2_subdev_type type)
+                               struct camera_sensor_platform_data *plat_data)
 {
        int i;
        struct gmin_subdev *gs;
        struct i2c_client *client = v4l2_get_subdevdata(subdev);
        struct acpi_device *adev = ACPI_COMPANION(&client->dev);
 
-       dev_info(&client->dev, "register atomisp i2c module type %d\n", type);
-
        /* The windows driver model (and thus most BIOSes by default)
         * uses ACPI runtime power management for camera devices, but
         * we don't.  Disable it, or else the rails will be needlessly
        adev->power.flags.power_resources = 0;
 
        for (i = 0; i < MAX_SUBDEVS; i++)
-               if (!pdata.subdevs[i].type)
+               if (!pdata.subdevs[i].subdev)
                        break;
 
-       if (pdata.subdevs[i].type)
+       if (i == MAX_SUBDEVS)
                return -ENOMEM;
 
        /* Note subtlety of initialization order: at the point where
        if (!gs)
                return -ENODEV;
 
-       pdata.subdevs[i].type = type;
        pdata.subdevs[i].port = gs->csi_port;
        pdata.subdevs[i].lanes = gs->csi_lanes;
        pdata.subdevs[i].subdev = subdev;
        }
 
        for (i = 0; i < MAX_SUBDEVS; i++)
-               if (!pdata.subdevs[i].type)
+               if (!pdata.subdevs[i].subdev)
                        break;
 
        if (i >= MAX_SUBDEVS) {
        if (ret)
                return ret;
 
-       pdata.subdevs[i].type = RAW_CAMERA;
        pdata.subdevs[i].port = port;
        pdata.subdevs[i].lanes = lanes;
        pdata.subdevs[i].subdev = subdev;
 
                camera_sensor_csi_free(subdev);
                pdata.subdevs[i].subdev = NULL;
-               pdata.subdevs[i].type = 0;
                pdata.subdevs[i].port = 0;
                break;
        }
 
        round_down((2 * (n) + (d) * (step)) / (2 * (d)), (step))
 
 struct atomisp_input_subdev {
-       unsigned int type;
        enum atomisp_camera_port port;
        u32 code; /* MEDIA_BUS_FMT_* */
        bool binning_support;
 
 
        input->type = V4L2_INPUT_TYPE_CAMERA;
        input->index = index;
-       input->reserved[0] = isp->inputs[index].type;
        input->reserved[1] = isp->inputs[index].port;
 
        return 0;
 
         * converting them to standard v4l2 sensor drivers using runtime-pm +
         * ACPI for pm and v4l2_async_register_subdev_sensor() registration.
         */
-       for (subdevs = pdata->subdevs; subdevs->type; ++subdevs) {
+       for (subdevs = pdata->subdevs; subdevs->subdev; subdevs++) {
                ret = v4l2_device_register_subdev(&isp->v4l2_dev, subdevs->subdev);
                if (ret)
                        continue;
 
-               switch (subdevs->type) {
-               case RAW_CAMERA:
-                       if (subdevs->port >= ATOMISP_CAMERA_NR_PORTS) {
-                               dev_err(isp->dev, "port %d not supported\n", subdevs->port);
-                               break;
-                       }
-
-                       if (isp->sensor_subdevs[subdevs->port]) {
-                               dev_err(isp->dev, "port %d already has a sensor attached\n",
-                                       subdevs->port);
-                               break;
-                       }
+               if (subdevs->port >= ATOMISP_CAMERA_NR_PORTS) {
+                       dev_err(isp->dev, "port %d not supported\n", subdevs->port);
+                       continue;
+               }
 
-                       mipi_port = atomisp_port_to_mipi_port(isp, subdevs->port);
-                       isp->sensor_lanes[mipi_port] = subdevs->lanes;
-                       isp->sensor_subdevs[subdevs->port] = subdevs->subdev;
-                       break;
-               default:
-                       dev_dbg(isp->dev, "unknown subdev probed\n");
-                       break;
+               if (isp->sensor_subdevs[subdevs->port]) {
+                       dev_err(isp->dev, "port %d already has a sensor attached\n",
+                               subdevs->port);
+                       continue;
                }
+
+               mipi_port = atomisp_port_to_mipi_port(isp, subdevs->port);
+               isp->sensor_lanes[mipi_port] = subdevs->lanes;
+               isp->sensor_subdevs[subdevs->port] = subdevs->subdev;
        }
 
        return atomisp_csi_lane_config(isp);
 
                input = &isp->inputs[isp->input_cnt];
 
-               input->type = RAW_CAMERA;
                input->port = i;
                input->camera = isp->sensor_subdevs[i];
                input->csi_port = &isp->csi2_port[i].subdev;