aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/gspca/zc3xx.c
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2012-05-09 10:19:00 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2012-05-14 08:42:34 -0400
commita8a478601ac1d8877e23cb832fe4b44042ce6f20 (patch)
treec2a0074e12c85ba852f340bbf83ec5fbd0ec348c /drivers/media/video/gspca/zc3xx.c
parent98684298f9ed89554cdaa4afe2554fca8276d1e9 (diff)
[media] gscpa: Move ctrl_handler to gspca_dev
We intend to eventually port all sub-drivers to the control-framework. At which point it will make more sense to have the ctrl_handler in gspca_dev then to have it in the subdrivers. Lets move it there now, to avoid a lot of work to move it later. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/gspca/zc3xx.c')
-rw-r--r--drivers/media/video/gspca/zc3xx.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/media/video/gspca/zc3xx.c b/drivers/media/video/gspca/zc3xx.c
index a8839fb3c1d6..0d504a7c512c 100644
--- a/drivers/media/video/gspca/zc3xx.c
+++ b/drivers/media/video/gspca/zc3xx.c
@@ -39,7 +39,6 @@ static int force_sensor = -1;
39struct sd { 39struct sd {
40 struct gspca_dev gspca_dev; /* !! must be the first item */ 40 struct gspca_dev gspca_dev; /* !! must be the first item */
41 41
42 struct v4l2_ctrl_handler ctrl_handler;
43 struct { /* gamma/brightness/contrast control cluster */ 42 struct { /* gamma/brightness/contrast control cluster */
44 struct v4l2_ctrl *gamma; 43 struct v4l2_ctrl *gamma;
45 struct v4l2_ctrl *brightness; 44 struct v4l2_ctrl *brightness;
@@ -6328,8 +6327,9 @@ static int sd_config(struct gspca_dev *gspca_dev,
6328 6327
6329static int zcxx_g_volatile_ctrl(struct v4l2_ctrl *ctrl) 6328static int zcxx_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
6330{ 6329{
6331 struct sd *sd = container_of(ctrl->handler, struct sd, ctrl_handler); 6330 struct gspca_dev *gspca_dev =
6332 struct gspca_dev *gspca_dev = &sd->gspca_dev; 6331 container_of(ctrl->handler, struct gspca_dev, ctrl_handler);
6332 struct sd *sd = (struct sd *)gspca_dev;
6333 6333
6334 switch (ctrl->id) { 6334 switch (ctrl->id) {
6335 case V4L2_CID_AUTOGAIN: 6335 case V4L2_CID_AUTOGAIN:
@@ -6343,8 +6343,9 @@ static int zcxx_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
6343 6343
6344static int zcxx_s_ctrl(struct v4l2_ctrl *ctrl) 6344static int zcxx_s_ctrl(struct v4l2_ctrl *ctrl)
6345{ 6345{
6346 struct sd *sd = container_of(ctrl->handler, struct sd, ctrl_handler); 6346 struct gspca_dev *gspca_dev =
6347 struct gspca_dev *gspca_dev = &sd->gspca_dev; 6347 container_of(ctrl->handler, struct gspca_dev, ctrl_handler);
6348 struct sd *sd = (struct sd *)gspca_dev;
6348 int i, qual; 6349 int i, qual;
6349 6350
6350 gspca_dev->usb_err = 0; 6351 gspca_dev->usb_err = 0;
@@ -6404,7 +6405,7 @@ static const struct v4l2_ctrl_ops zcxx_ctrl_ops = {
6404static int sd_init_controls(struct gspca_dev *gspca_dev) 6405static int sd_init_controls(struct gspca_dev *gspca_dev)
6405{ 6406{
6406 struct sd *sd = (struct sd *)gspca_dev; 6407 struct sd *sd = (struct sd *)gspca_dev;
6407 struct v4l2_ctrl_handler *hdl = &sd->ctrl_handler; 6408 struct v4l2_ctrl_handler *hdl = &gspca_dev->ctrl_handler;
6408 static const u8 gamma[SENSOR_MAX] = { 6409 static const u8 gamma[SENSOR_MAX] = {
6409 [SENSOR_ADCM2700] = 4, 6410 [SENSOR_ADCM2700] = 4,
6410 [SENSOR_CS2102] = 4, 6411 [SENSOR_CS2102] = 4,