Commit d2d7e9ae authored by Erik Andren's avatar Erik Andren Committed by Mauro Carvalho Chehab

V4L/DVB (9095): gspca: Moves some sensor initialization to each sensor in m5602.

Signed-off-by: default avatarErik Andren <erik.andren@gmail.com>
Signed-off-by: default avatarJean-Francois Moine <moinejf@free.fr>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 1b334599
...@@ -152,6 +152,8 @@ struct sd { ...@@ -152,6 +152,8 @@ struct sd {
/* A pointer to the currently connected sensor */ /* A pointer to the currently connected sensor */
struct m5602_sensor *sensor; struct m5602_sensor *sensor;
struct sd_desc *desc;
/* The current frame's id, used to detect frame boundaries */ /* The current frame's id, used to detect frame boundaries */
u8 frame_id; u8 frame_id;
......
...@@ -108,44 +108,28 @@ int m5602_probe_sensor(struct sd *sd) ...@@ -108,44 +108,28 @@ int m5602_probe_sensor(struct sd *sd)
{ {
/* Try the po1030 */ /* Try the po1030 */
sd->sensor = &po1030; sd->sensor = &po1030;
if (!sd->sensor->probe(sd)) { if (!sd->sensor->probe(sd))
sd_desc.ctrls = po1030.ctrls;
sd_desc.nctrls = po1030.nctrls;
return 0; return 0;
}
/* Try the mt9m111 sensor */ /* Try the mt9m111 sensor */
sd->sensor = &mt9m111; sd->sensor = &mt9m111;
if (!sd->sensor->probe(sd)) { if (!sd->sensor->probe(sd))
sd_desc.ctrls = mt9m111.ctrls;
sd_desc.nctrls = mt9m111.nctrls;
return 0; return 0;
}
/* Try the s5k4aa */ /* Try the s5k4aa */
sd->sensor = &s5k4aa; sd->sensor = &s5k4aa;
if (!sd->sensor->probe(sd)) { if (!sd->sensor->probe(sd))
sd_desc.ctrls = s5k4aa.ctrls;
sd_desc.nctrls = s5k4aa.nctrls;
return 0; return 0;
}
/* Try the ov9650 */ /* Try the ov9650 */
sd->sensor = &ov9650; sd->sensor = &ov9650;
if (!sd->sensor->probe(sd)) { if (!sd->sensor->probe(sd))
sd_desc.ctrls = ov9650.ctrls;
sd_desc.nctrls = ov9650.nctrls;
return 0; return 0;
}
/* Try the s5k83a */ /* Try the s5k83a */
sd->sensor = &s5k83a; sd->sensor = &s5k83a;
if (!sd->sensor->probe(sd)) { if (!sd->sensor->probe(sd))
sd_desc.ctrls = s5k83a.ctrls;
sd_desc.nctrls = s5k83a.nctrls;
return 0; return 0;
}
/* More sensor probe function goes here */ /* More sensor probe function goes here */
info("Failed to find a sensor"); info("Failed to find a sensor");
...@@ -246,8 +230,10 @@ int m5602_configure(struct gspca_dev *gspca_dev, ...@@ -246,8 +230,10 @@ int m5602_configure(struct gspca_dev *gspca_dev,
int err; int err;
PDEBUG(DBG_GSPCA, "m5602_configure start"); PDEBUG(DBG_GSPCA, "m5602_configure start");
cam = &gspca_dev->cam; cam = &gspca_dev->cam;
cam->epaddr = M5602_ISOC_ENDPOINT_ADDR; cam->epaddr = M5602_ISOC_ENDPOINT_ADDR;
sd->desc = &sd_desc;
if (dump_bridge) if (dump_bridge)
m5602_dump_bridge(sd); m5602_dump_bridge(sd);
......
...@@ -62,6 +62,8 @@ int mt9m111_probe(struct sd *sd) ...@@ -62,6 +62,8 @@ int mt9m111_probe(struct sd *sd)
sensor_found: sensor_found:
sd->gspca_dev.cam.cam_mode = mt9m111.modes; sd->gspca_dev.cam.cam_mode = mt9m111.modes;
sd->gspca_dev.cam.nmodes = mt9m111.nmodes; sd->gspca_dev.cam.nmodes = mt9m111.nmodes;
sd->desc->ctrls = mt9m111.ctrls;
sd->desc->nctrls = mt9m111.nctrls;
return 0; return 0;
} }
......
...@@ -132,6 +132,8 @@ int ov9650_probe(struct sd *sd) ...@@ -132,6 +132,8 @@ int ov9650_probe(struct sd *sd)
sensor_found: sensor_found:
sd->gspca_dev.cam.cam_mode = ov9650.modes; sd->gspca_dev.cam.cam_mode = ov9650.modes;
sd->gspca_dev.cam.nmodes = ov9650.nmodes; sd->gspca_dev.cam.nmodes = ov9650.nmodes;
sd->desc->ctrls = ov9650.ctrls;
sd->desc->nctrls = ov9650.nctrls;
return 0; return 0;
} }
......
...@@ -59,6 +59,8 @@ int po1030_probe(struct sd *sd) ...@@ -59,6 +59,8 @@ int po1030_probe(struct sd *sd)
sensor_found: sensor_found:
sd->gspca_dev.cam.cam_mode = po1030.modes; sd->gspca_dev.cam.cam_mode = po1030.modes;
sd->gspca_dev.cam.nmodes = po1030.nmodes; sd->gspca_dev.cam.nmodes = po1030.nmodes;
sd->desc->ctrls = po1030.ctrls;
sd->desc->nctrls = po1030.nctrls;
return 0; return 0;
} }
......
...@@ -78,6 +78,9 @@ int s5k4aa_probe(struct sd *sd) ...@@ -78,6 +78,9 @@ int s5k4aa_probe(struct sd *sd)
sensor_found: sensor_found:
sd->gspca_dev.cam.cam_mode = s5k4aa.modes; sd->gspca_dev.cam.cam_mode = s5k4aa.modes;
sd->gspca_dev.cam.nmodes = s5k4aa.nmodes; sd->gspca_dev.cam.nmodes = s5k4aa.nmodes;
sd->desc->ctrls = s5k4aa.ctrls;
sd->desc->nctrls = s5k4aa.nctrls;
return 0; return 0;
} }
......
...@@ -63,6 +63,8 @@ int s5k83a_probe(struct sd *sd) ...@@ -63,6 +63,8 @@ int s5k83a_probe(struct sd *sd)
sensor_found: sensor_found:
sd->gspca_dev.cam.cam_mode = s5k83a.modes; sd->gspca_dev.cam.cam_mode = s5k83a.modes;
sd->gspca_dev.cam.nmodes = s5k83a.nmodes; sd->gspca_dev.cam.nmodes = s5k83a.nmodes;
sd->desc->ctrls = s5k83a.ctrls;
sd->desc->nctrls = s5k83a.nctrls;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment