diff options
author | Guennadi Liakhovetski <g.liakhovetski@gmx.de> | 2009-08-25 10:46:59 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-09-18 23:19:07 -0400 |
commit | c9c1f1c0dbe90b82939917fdc3e4c9ccad42342d (patch) | |
tree | 0a6605999055710b88c71c546f6b2507e675e845 /drivers/media/video | |
parent | 08590b9613f7f624fe3a052586eea2dbb3584b38 (diff) |
V4L/DVB (12530): soc-camera: switch to using v4l2_subdev_call()
Use v4l2_subdev_call() instead of v4l2_device_call_until_err() in all host
drivers and in soc-camera core.
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/mx1_camera.c | 12 | ||||
-rw-r--r-- | drivers/media/video/mx3_camera.c | 10 | ||||
-rw-r--r-- | drivers/media/video/pxa_camera.c | 9 | ||||
-rw-r--r-- | drivers/media/video/sh_mobile_ceu_camera.c | 17 | ||||
-rw-r--r-- | drivers/media/video/soc_camera.c | 30 |
5 files changed, 38 insertions, 40 deletions
diff --git a/drivers/media/video/mx1_camera.c b/drivers/media/video/mx1_camera.c index add496fca4d..ed7856bdad4 100644 --- a/drivers/media/video/mx1_camera.c +++ b/drivers/media/video/mx1_camera.c | |||
@@ -465,9 +465,7 @@ static void mx1_camera_remove_device(struct soc_camera_device *icd) | |||
465 | static int mx1_camera_set_crop(struct soc_camera_device *icd, | 465 | static int mx1_camera_set_crop(struct soc_camera_device *icd, |
466 | struct v4l2_crop *a) | 466 | struct v4l2_crop *a) |
467 | { | 467 | { |
468 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 468 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
469 | struct device *control = to_soc_camera_control(icd); | ||
470 | struct v4l2_subdev *sd = dev_get_drvdata(control); | ||
471 | 469 | ||
472 | return v4l2_subdev_call(sd, video, s_crop, a); | 470 | return v4l2_subdev_call(sd, video, s_crop, a); |
473 | } | 471 | } |
@@ -539,7 +537,7 @@ static int mx1_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt) | |||
539 | static int mx1_camera_set_fmt(struct soc_camera_device *icd, | 537 | static int mx1_camera_set_fmt(struct soc_camera_device *icd, |
540 | struct v4l2_format *f) | 538 | struct v4l2_format *f) |
541 | { | 539 | { |
542 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 540 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
543 | const struct soc_camera_format_xlate *xlate; | 541 | const struct soc_camera_format_xlate *xlate; |
544 | struct v4l2_pix_format *pix = &f->fmt.pix; | 542 | struct v4l2_pix_format *pix = &f->fmt.pix; |
545 | int ret; | 543 | int ret; |
@@ -550,7 +548,7 @@ static int mx1_camera_set_fmt(struct soc_camera_device *icd, | |||
550 | return -EINVAL; | 548 | return -EINVAL; |
551 | } | 549 | } |
552 | 550 | ||
553 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, s_fmt, f); | 551 | ret = v4l2_subdev_call(sd, video, s_fmt, f); |
554 | if (!ret) { | 552 | if (!ret) { |
555 | icd->buswidth = xlate->buswidth; | 553 | icd->buswidth = xlate->buswidth; |
556 | icd->current_fmt = xlate->host_fmt; | 554 | icd->current_fmt = xlate->host_fmt; |
@@ -562,11 +560,11 @@ static int mx1_camera_set_fmt(struct soc_camera_device *icd, | |||
562 | static int mx1_camera_try_fmt(struct soc_camera_device *icd, | 560 | static int mx1_camera_try_fmt(struct soc_camera_device *icd, |
563 | struct v4l2_format *f) | 561 | struct v4l2_format *f) |
564 | { | 562 | { |
565 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 563 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
566 | /* TODO: limit to mx1 hardware capabilities */ | 564 | /* TODO: limit to mx1 hardware capabilities */ |
567 | 565 | ||
568 | /* limit to sensor capabilities */ | 566 | /* limit to sensor capabilities */ |
569 | return v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, try_fmt, f); | 567 | return v4l2_subdev_call(sd, video, try_fmt, f); |
570 | } | 568 | } |
571 | 569 | ||
572 | static int mx1_camera_reqbufs(struct soc_camera_file *icf, | 570 | static int mx1_camera_reqbufs(struct soc_camera_file *icf, |
diff --git a/drivers/media/video/mx3_camera.c b/drivers/media/video/mx3_camera.c index de7ebfbf039..f7888f30da5 100644 --- a/drivers/media/video/mx3_camera.c +++ b/drivers/media/video/mx3_camera.c | |||
@@ -786,8 +786,7 @@ static int mx3_camera_set_crop(struct soc_camera_device *icd, | |||
786 | struct v4l2_rect *rect = &a->c; | 786 | struct v4l2_rect *rect = &a->c; |
787 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 787 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
788 | struct mx3_camera_dev *mx3_cam = ici->priv; | 788 | struct mx3_camera_dev *mx3_cam = ici->priv; |
789 | struct device *control = to_soc_camera_control(icd); | 789 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
790 | struct v4l2_subdev *sd = dev_get_drvdata(control); | ||
791 | 790 | ||
792 | /* | 791 | /* |
793 | * We now know pixel formats and can decide upon DMA-channel(s) | 792 | * We now know pixel formats and can decide upon DMA-channel(s) |
@@ -809,6 +808,7 @@ static int mx3_camera_set_fmt(struct soc_camera_device *icd, | |||
809 | { | 808 | { |
810 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 809 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
811 | struct mx3_camera_dev *mx3_cam = ici->priv; | 810 | struct mx3_camera_dev *mx3_cam = ici->priv; |
811 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
812 | const struct soc_camera_format_xlate *xlate; | 812 | const struct soc_camera_format_xlate *xlate; |
813 | struct v4l2_pix_format *pix = &f->fmt.pix; | 813 | struct v4l2_pix_format *pix = &f->fmt.pix; |
814 | struct v4l2_rect rect = { | 814 | struct v4l2_rect rect = { |
@@ -837,7 +837,7 @@ static int mx3_camera_set_fmt(struct soc_camera_device *icd, | |||
837 | 837 | ||
838 | configure_geometry(mx3_cam, &rect); | 838 | configure_geometry(mx3_cam, &rect); |
839 | 839 | ||
840 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, s_fmt, f); | 840 | ret = v4l2_subdev_call(sd, video, s_fmt, f); |
841 | if (!ret) { | 841 | if (!ret) { |
842 | icd->buswidth = xlate->buswidth; | 842 | icd->buswidth = xlate->buswidth; |
843 | icd->current_fmt = xlate->host_fmt; | 843 | icd->current_fmt = xlate->host_fmt; |
@@ -849,7 +849,7 @@ static int mx3_camera_set_fmt(struct soc_camera_device *icd, | |||
849 | static int mx3_camera_try_fmt(struct soc_camera_device *icd, | 849 | static int mx3_camera_try_fmt(struct soc_camera_device *icd, |
850 | struct v4l2_format *f) | 850 | struct v4l2_format *f) |
851 | { | 851 | { |
852 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 852 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
853 | const struct soc_camera_format_xlate *xlate; | 853 | const struct soc_camera_format_xlate *xlate; |
854 | struct v4l2_pix_format *pix = &f->fmt.pix; | 854 | struct v4l2_pix_format *pix = &f->fmt.pix; |
855 | __u32 pixfmt = pix->pixelformat; | 855 | __u32 pixfmt = pix->pixelformat; |
@@ -875,7 +875,7 @@ static int mx3_camera_try_fmt(struct soc_camera_device *icd, | |||
875 | /* camera has to see its format, but the user the original one */ | 875 | /* camera has to see its format, but the user the original one */ |
876 | pix->pixelformat = xlate->cam_fmt->fourcc; | 876 | pix->pixelformat = xlate->cam_fmt->fourcc; |
877 | /* limit to sensor capabilities */ | 877 | /* limit to sensor capabilities */ |
878 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, try_fmt, f); | 878 | ret = v4l2_subdev_call(sd, video, try_fmt, f); |
879 | pix->pixelformat = xlate->host_fmt->fourcc; | 879 | pix->pixelformat = xlate->host_fmt->fourcc; |
880 | 880 | ||
881 | field = pix->field; | 881 | field = pix->field; |
diff --git a/drivers/media/video/pxa_camera.c b/drivers/media/video/pxa_camera.c index c38ce84b944..4bc2a4f81f7 100644 --- a/drivers/media/video/pxa_camera.c +++ b/drivers/media/video/pxa_camera.c | |||
@@ -1286,8 +1286,7 @@ static int pxa_camera_set_crop(struct soc_camera_device *icd, | |||
1286 | struct v4l2_rect *rect = &a->c; | 1286 | struct v4l2_rect *rect = &a->c; |
1287 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 1287 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
1288 | struct pxa_camera_dev *pcdev = ici->priv; | 1288 | struct pxa_camera_dev *pcdev = ici->priv; |
1289 | struct device *control = to_soc_camera_control(icd); | 1289 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
1290 | struct v4l2_subdev *sd = dev_get_drvdata(control); | ||
1291 | struct soc_camera_sense sense = { | 1290 | struct soc_camera_sense sense = { |
1292 | .master_clock = pcdev->mclk, | 1291 | .master_clock = pcdev->mclk, |
1293 | .pixel_clock_max = pcdev->ciclk / 4, | 1292 | .pixel_clock_max = pcdev->ciclk / 4, |
@@ -1323,6 +1322,7 @@ static int pxa_camera_set_fmt(struct soc_camera_device *icd, | |||
1323 | { | 1322 | { |
1324 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 1323 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
1325 | struct pxa_camera_dev *pcdev = ici->priv; | 1324 | struct pxa_camera_dev *pcdev = ici->priv; |
1325 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
1326 | const struct soc_camera_data_format *cam_fmt = NULL; | 1326 | const struct soc_camera_data_format *cam_fmt = NULL; |
1327 | const struct soc_camera_format_xlate *xlate = NULL; | 1327 | const struct soc_camera_format_xlate *xlate = NULL; |
1328 | struct soc_camera_sense sense = { | 1328 | struct soc_camera_sense sense = { |
@@ -1346,7 +1346,7 @@ static int pxa_camera_set_fmt(struct soc_camera_device *icd, | |||
1346 | icd->sense = &sense; | 1346 | icd->sense = &sense; |
1347 | 1347 | ||
1348 | cam_f.fmt.pix.pixelformat = cam_fmt->fourcc; | 1348 | cam_f.fmt.pix.pixelformat = cam_fmt->fourcc; |
1349 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, s_fmt, f); | 1349 | ret = v4l2_subdev_call(sd, video, s_fmt, f); |
1350 | 1350 | ||
1351 | icd->sense = NULL; | 1351 | icd->sense = NULL; |
1352 | 1352 | ||
@@ -1375,6 +1375,7 @@ static int pxa_camera_try_fmt(struct soc_camera_device *icd, | |||
1375 | struct v4l2_format *f) | 1375 | struct v4l2_format *f) |
1376 | { | 1376 | { |
1377 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 1377 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
1378 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
1378 | const struct soc_camera_format_xlate *xlate; | 1379 | const struct soc_camera_format_xlate *xlate; |
1379 | struct v4l2_pix_format *pix = &f->fmt.pix; | 1380 | struct v4l2_pix_format *pix = &f->fmt.pix; |
1380 | __u32 pixfmt = pix->pixelformat; | 1381 | __u32 pixfmt = pix->pixelformat; |
@@ -1404,7 +1405,7 @@ static int pxa_camera_try_fmt(struct soc_camera_device *icd, | |||
1404 | /* camera has to see its format, but the user the original one */ | 1405 | /* camera has to see its format, but the user the original one */ |
1405 | pix->pixelformat = xlate->cam_fmt->fourcc; | 1406 | pix->pixelformat = xlate->cam_fmt->fourcc; |
1406 | /* limit to sensor capabilities */ | 1407 | /* limit to sensor capabilities */ |
1407 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, 0, video, try_fmt, f); | 1408 | ret = v4l2_subdev_call(sd, video, try_fmt, f); |
1408 | pix->pixelformat = xlate->host_fmt->fourcc; | 1409 | pix->pixelformat = xlate->host_fmt->fourcc; |
1409 | 1410 | ||
1410 | field = pix->field; | 1411 | field = pix->field; |
diff --git a/drivers/media/video/sh_mobile_ceu_camera.c b/drivers/media/video/sh_mobile_ceu_camera.c index 726cf0e4dc2..28c3affe882 100644 --- a/drivers/media/video/sh_mobile_ceu_camera.c +++ b/drivers/media/video/sh_mobile_ceu_camera.c | |||
@@ -854,8 +854,7 @@ static int sh_mobile_ceu_set_crop(struct soc_camera_device *icd, | |||
854 | struct v4l2_crop cam_crop; | 854 | struct v4l2_crop cam_crop; |
855 | struct v4l2_rect *cam_rect = &cam_crop.c, target, cam_max; | 855 | struct v4l2_rect *cam_rect = &cam_crop.c, target, cam_max; |
856 | struct sh_mobile_ceu_cam *cam = icd->host_priv; | 856 | struct sh_mobile_ceu_cam *cam = icd->host_priv; |
857 | struct device *control = to_soc_camera_control(icd); | 857 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
858 | struct v4l2_subdev *sd = dev_get_drvdata(control); | ||
859 | unsigned int hscale = pcdev->cflcr & 0xffff; | 858 | unsigned int hscale = pcdev->cflcr & 0xffff; |
860 | unsigned int vscale = (pcdev->cflcr >> 16) & 0xffff; | 859 | unsigned int vscale = (pcdev->cflcr >> 16) & 0xffff; |
861 | unsigned short width, height; | 860 | unsigned short width, height; |
@@ -1016,6 +1015,7 @@ static int sh_mobile_ceu_set_fmt(struct soc_camera_device *icd, | |||
1016 | struct sh_mobile_ceu_dev *pcdev = ici->priv; | 1015 | struct sh_mobile_ceu_dev *pcdev = ici->priv; |
1017 | struct sh_mobile_ceu_cam *cam = icd->host_priv; | 1016 | struct sh_mobile_ceu_cam *cam = icd->host_priv; |
1018 | struct v4l2_pix_format *pix = &f->fmt.pix; | 1017 | struct v4l2_pix_format *pix = &f->fmt.pix; |
1018 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
1019 | __u32 pixfmt = pix->pixelformat; | 1019 | __u32 pixfmt = pix->pixelformat; |
1020 | const struct soc_camera_format_xlate *xlate; | 1020 | const struct soc_camera_format_xlate *xlate; |
1021 | unsigned int width = pix->width, height = pix->height, tmp_w, tmp_h; | 1021 | unsigned int width = pix->width, height = pix->height, tmp_w, tmp_h; |
@@ -1042,7 +1042,7 @@ static int sh_mobile_ceu_set_fmt(struct soc_camera_device *icd, | |||
1042 | } | 1042 | } |
1043 | 1043 | ||
1044 | pix->pixelformat = xlate->cam_fmt->fourcc; | 1044 | pix->pixelformat = xlate->cam_fmt->fourcc; |
1045 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, video, s_fmt, f); | 1045 | ret = v4l2_subdev_call(sd, video, s_fmt, f); |
1046 | pix->pixelformat = pixfmt; | 1046 | pix->pixelformat = pixfmt; |
1047 | dev_dbg(&icd->dev, "Camera %d fmt %ux%u, requested %ux%u, max %ux%u\n", | 1047 | dev_dbg(&icd->dev, "Camera %d fmt %ux%u, requested %ux%u, max %ux%u\n", |
1048 | ret, pix->width, pix->height, width, height, | 1048 | ret, pix->width, pix->height, width, height, |
@@ -1082,8 +1082,7 @@ static int sh_mobile_ceu_set_fmt(struct soc_camera_device *icd, | |||
1082 | pix->width = tmp_w; | 1082 | pix->width = tmp_w; |
1083 | pix->height = tmp_h; | 1083 | pix->height = tmp_h; |
1084 | pix->pixelformat = xlate->cam_fmt->fourcc; | 1084 | pix->pixelformat = xlate->cam_fmt->fourcc; |
1085 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, | 1085 | ret = v4l2_subdev_call(sd, video, s_fmt, f); |
1086 | video, s_fmt, f); | ||
1087 | pix->pixelformat = pixfmt; | 1086 | pix->pixelformat = pixfmt; |
1088 | dev_dbg(&icd->dev, "Camera scaled to %ux%u\n", | 1087 | dev_dbg(&icd->dev, "Camera scaled to %ux%u\n", |
1089 | pix->width, pix->height); | 1088 | pix->width, pix->height); |
@@ -1140,6 +1139,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd, | |||
1140 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 1139 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
1141 | const struct soc_camera_format_xlate *xlate; | 1140 | const struct soc_camera_format_xlate *xlate; |
1142 | struct v4l2_pix_format *pix = &f->fmt.pix; | 1141 | struct v4l2_pix_format *pix = &f->fmt.pix; |
1142 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
1143 | __u32 pixfmt = pix->pixelformat; | 1143 | __u32 pixfmt = pix->pixelformat; |
1144 | int width, height; | 1144 | int width, height; |
1145 | int ret; | 1145 | int ret; |
@@ -1165,8 +1165,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd, | |||
1165 | pix->pixelformat = xlate->cam_fmt->fourcc; | 1165 | pix->pixelformat = xlate->cam_fmt->fourcc; |
1166 | 1166 | ||
1167 | /* limit to sensor capabilities */ | 1167 | /* limit to sensor capabilities */ |
1168 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, video, | 1168 | ret = v4l2_subdev_call(sd, video, try_fmt, f); |
1169 | try_fmt, f); | ||
1170 | pix->pixelformat = pixfmt; | 1169 | pix->pixelformat = pixfmt; |
1171 | if (ret < 0) | 1170 | if (ret < 0) |
1172 | return ret; | 1171 | return ret; |
@@ -1182,9 +1181,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd, | |||
1182 | int tmp_w = pix->width, tmp_h = pix->height; | 1181 | int tmp_w = pix->width, tmp_h = pix->height; |
1183 | pix->width = 2560; | 1182 | pix->width = 2560; |
1184 | pix->height = 1920; | 1183 | pix->height = 1920; |
1185 | ret = v4l2_device_call_until_err(&ici->v4l2_dev, | 1184 | ret = v4l2_subdev_call(sd, video, try_fmt, f); |
1186 | (__u32)icd, video, | ||
1187 | try_fmt, f); | ||
1188 | if (ret < 0) { | 1185 | if (ret < 0) { |
1189 | /* Shouldn't actually happen... */ | 1186 | /* Shouldn't actually happen... */ |
1190 | dev_err(&icd->dev, | 1187 | dev_err(&icd->dev, |
diff --git a/drivers/media/video/soc_camera.c b/drivers/media/video/soc_camera.c index d9ccc286659..dd023bdb189 100644 --- a/drivers/media/video/soc_camera.c +++ b/drivers/media/video/soc_camera.c | |||
@@ -152,9 +152,9 @@ static int soc_camera_s_std(struct file *file, void *priv, v4l2_std_id *a) | |||
152 | { | 152 | { |
153 | struct soc_camera_file *icf = file->private_data; | 153 | struct soc_camera_file *icf = file->private_data; |
154 | struct soc_camera_device *icd = icf->icd; | 154 | struct soc_camera_device *icd = icf->icd; |
155 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 155 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
156 | 156 | ||
157 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, s_std, *a); | 157 | return v4l2_subdev_call(sd, core, s_std, *a); |
158 | } | 158 | } |
159 | 159 | ||
160 | static int soc_camera_reqbufs(struct file *file, void *priv, | 160 | static int soc_camera_reqbufs(struct file *file, void *priv, |
@@ -589,7 +589,7 @@ static int soc_camera_streamon(struct file *file, void *priv, | |||
589 | { | 589 | { |
590 | struct soc_camera_file *icf = file->private_data; | 590 | struct soc_camera_file *icf = file->private_data; |
591 | struct soc_camera_device *icd = icf->icd; | 591 | struct soc_camera_device *icd = icf->icd; |
592 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 592 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
593 | int ret; | 593 | int ret; |
594 | 594 | ||
595 | WARN_ON(priv != file->private_data); | 595 | WARN_ON(priv != file->private_data); |
@@ -599,7 +599,7 @@ static int soc_camera_streamon(struct file *file, void *priv, | |||
599 | 599 | ||
600 | mutex_lock(&icd->video_lock); | 600 | mutex_lock(&icd->video_lock); |
601 | 601 | ||
602 | v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, video, s_stream, 1); | 602 | v4l2_subdev_call(sd, video, s_stream, 1); |
603 | 603 | ||
604 | /* This calls buf_queue from host driver's videobuf_queue_ops */ | 604 | /* This calls buf_queue from host driver's videobuf_queue_ops */ |
605 | ret = videobuf_streamon(&icf->vb_vidq); | 605 | ret = videobuf_streamon(&icf->vb_vidq); |
@@ -614,7 +614,7 @@ static int soc_camera_streamoff(struct file *file, void *priv, | |||
614 | { | 614 | { |
615 | struct soc_camera_file *icf = file->private_data; | 615 | struct soc_camera_file *icf = file->private_data; |
616 | struct soc_camera_device *icd = icf->icd; | 616 | struct soc_camera_device *icd = icf->icd; |
617 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 617 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
618 | 618 | ||
619 | WARN_ON(priv != file->private_data); | 619 | WARN_ON(priv != file->private_data); |
620 | 620 | ||
@@ -627,7 +627,7 @@ static int soc_camera_streamoff(struct file *file, void *priv, | |||
627 | * remaining buffers. When the last buffer is freed, stop capture */ | 627 | * remaining buffers. When the last buffer is freed, stop capture */ |
628 | videobuf_streamoff(&icf->vb_vidq); | 628 | videobuf_streamoff(&icf->vb_vidq); |
629 | 629 | ||
630 | v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, video, s_stream, 0); | 630 | v4l2_subdev_call(sd, video, s_stream, 0); |
631 | 631 | ||
632 | mutex_unlock(&icd->video_lock); | 632 | mutex_unlock(&icd->video_lock); |
633 | 633 | ||
@@ -672,6 +672,7 @@ static int soc_camera_g_ctrl(struct file *file, void *priv, | |||
672 | struct soc_camera_file *icf = file->private_data; | 672 | struct soc_camera_file *icf = file->private_data; |
673 | struct soc_camera_device *icd = icf->icd; | 673 | struct soc_camera_device *icd = icf->icd; |
674 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 674 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
675 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
675 | int ret; | 676 | int ret; |
676 | 677 | ||
677 | WARN_ON(priv != file->private_data); | 678 | WARN_ON(priv != file->private_data); |
@@ -695,7 +696,7 @@ static int soc_camera_g_ctrl(struct file *file, void *priv, | |||
695 | return ret; | 696 | return ret; |
696 | } | 697 | } |
697 | 698 | ||
698 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, g_ctrl, ctrl); | 699 | return v4l2_subdev_call(sd, core, g_ctrl, ctrl); |
699 | } | 700 | } |
700 | 701 | ||
701 | static int soc_camera_s_ctrl(struct file *file, void *priv, | 702 | static int soc_camera_s_ctrl(struct file *file, void *priv, |
@@ -704,6 +705,7 @@ static int soc_camera_s_ctrl(struct file *file, void *priv, | |||
704 | struct soc_camera_file *icf = file->private_data; | 705 | struct soc_camera_file *icf = file->private_data; |
705 | struct soc_camera_device *icd = icf->icd; | 706 | struct soc_camera_device *icd = icf->icd; |
706 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 707 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); |
708 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); | ||
707 | int ret; | 709 | int ret; |
708 | 710 | ||
709 | WARN_ON(priv != file->private_data); | 711 | WARN_ON(priv != file->private_data); |
@@ -714,7 +716,7 @@ static int soc_camera_s_ctrl(struct file *file, void *priv, | |||
714 | return ret; | 716 | return ret; |
715 | } | 717 | } |
716 | 718 | ||
717 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, s_ctrl, ctrl); | 719 | return v4l2_subdev_call(sd, core, s_ctrl, ctrl); |
718 | } | 720 | } |
719 | 721 | ||
720 | static int soc_camera_cropcap(struct file *file, void *fh, | 722 | static int soc_camera_cropcap(struct file *file, void *fh, |
@@ -812,9 +814,9 @@ static int soc_camera_g_chip_ident(struct file *file, void *fh, | |||
812 | { | 814 | { |
813 | struct soc_camera_file *icf = file->private_data; | 815 | struct soc_camera_file *icf = file->private_data; |
814 | struct soc_camera_device *icd = icf->icd; | 816 | struct soc_camera_device *icd = icf->icd; |
815 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 817 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
816 | 818 | ||
817 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, g_chip_ident, id); | 819 | return v4l2_subdev_call(sd, core, g_chip_ident, id); |
818 | } | 820 | } |
819 | 821 | ||
820 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 822 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
@@ -823,9 +825,9 @@ static int soc_camera_g_register(struct file *file, void *fh, | |||
823 | { | 825 | { |
824 | struct soc_camera_file *icf = file->private_data; | 826 | struct soc_camera_file *icf = file->private_data; |
825 | struct soc_camera_device *icd = icf->icd; | 827 | struct soc_camera_device *icd = icf->icd; |
826 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 828 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
827 | 829 | ||
828 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, g_register, reg); | 830 | return v4l2_subdev_call(sd, core, g_register, reg); |
829 | } | 831 | } |
830 | 832 | ||
831 | static int soc_camera_s_register(struct file *file, void *fh, | 833 | static int soc_camera_s_register(struct file *file, void *fh, |
@@ -833,9 +835,9 @@ static int soc_camera_s_register(struct file *file, void *fh, | |||
833 | { | 835 | { |
834 | struct soc_camera_file *icf = file->private_data; | 836 | struct soc_camera_file *icf = file->private_data; |
835 | struct soc_camera_device *icd = icf->icd; | 837 | struct soc_camera_device *icd = icf->icd; |
836 | struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); | 838 | struct v4l2_subdev *sd = soc_camera_to_subdev(icd); |
837 | 839 | ||
838 | return v4l2_device_call_until_err(&ici->v4l2_dev, (__u32)icd, core, s_register, reg); | 840 | return v4l2_subdev_call(sd, core, s_register, reg); |
839 | } | 841 | } |
840 | #endif | 842 | #endif |
841 | 843 | ||