aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuennadi Liakhovetski <g.liakhovetski@gmx.de>2011-07-15 19:03:38 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2011-07-27 16:56:08 -0400
commit7dfff95366f48bf66f77c17cdc9ebd8be696ac5d (patch)
treec4cb975f5b8b8c3008921d38fa6e4deed9c8dbc9
parentd33b290a149dafe2e3cc2901ec726bea09a2c0f4 (diff)
[media] V4L: soc-camera: remove soc-camera bus and devices on it
Now that v4l2 subdevices have got their own device objects, having one more device in soc-camera clients became redundant and confusing. This patch removes those devices and the soc-camera bus, they used to reside on. Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de> Acked-by: Paul Mundt <lethal@linux-sh.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--arch/arm/mach-shmobile/board-mackerel.c13
-rw-r--r--arch/sh/boards/mach-ap325rxa/setup.c15
-rw-r--r--drivers/media/video/atmel-isi.c64
-rw-r--r--drivers/media/video/mt9m001.c14
-rw-r--r--drivers/media/video/mt9m111.c10
-rw-r--r--drivers/media/video/mt9t031.c3
-rw-r--r--drivers/media/video/mt9t112.c10
-rw-r--r--drivers/media/video/mt9v022.c10
-rw-r--r--drivers/media/video/mx1_camera.c42
-rw-r--r--drivers/media/video/mx2_camera.c46
-rw-r--r--drivers/media/video/mx3_camera.c56
-rw-r--r--drivers/media/video/omap1_camera.c52
-rw-r--r--drivers/media/video/ov2640.c13
-rw-r--r--drivers/media/video/ov772x.c10
-rw-r--r--drivers/media/video/ov9640.c13
-rw-r--r--drivers/media/video/ov9740.c13
-rw-r--r--drivers/media/video/pxa_camera.c46
-rw-r--r--drivers/media/video/rj54n1cb0c.c7
-rw-r--r--drivers/media/video/sh_mobile_ceu_camera.c74
-rw-r--r--drivers/media/video/soc_camera.c234
-rw-r--r--drivers/media/video/soc_camera_platform.c10
-rw-r--r--drivers/media/video/tw9910.c10
-rw-r--r--include/media/soc_camera.h19
-rw-r--r--include/media/soc_camera_platform.h15
24 files changed, 337 insertions, 462 deletions
diff --git a/arch/arm/mach-shmobile/board-mackerel.c b/arch/arm/mach-shmobile/board-mackerel.c
index 3802f2afabef..1610fbf1a764 100644
--- a/arch/arm/mach-shmobile/board-mackerel.c
+++ b/arch/arm/mach-shmobile/board-mackerel.c
@@ -1192,8 +1192,8 @@ static struct platform_device sh_mmcif_device = {
1192}; 1192};
1193 1193
1194 1194
1195static int mackerel_camera_add(struct soc_camera_link *icl, struct device *dev); 1195static int mackerel_camera_add(struct soc_camera_device *icd);
1196static void mackerel_camera_del(struct soc_camera_link *icl); 1196static void mackerel_camera_del(struct soc_camera_device *icd);
1197 1197
1198static int camera_set_capture(struct soc_camera_platform_info *info, 1198static int camera_set_capture(struct soc_camera_platform_info *info,
1199 int enable) 1199 int enable)
@@ -1232,16 +1232,15 @@ static void mackerel_camera_release(struct device *dev)
1232 soc_camera_platform_release(&camera_device); 1232 soc_camera_platform_release(&camera_device);
1233} 1233}
1234 1234
1235static int mackerel_camera_add(struct soc_camera_link *icl, 1235static int mackerel_camera_add(struct soc_camera_device *icd)
1236 struct device *dev)
1237{ 1236{
1238 return soc_camera_platform_add(icl, dev, &camera_device, &camera_link, 1237 return soc_camera_platform_add(icd, &camera_device, &camera_link,
1239 mackerel_camera_release, 0); 1238 mackerel_camera_release, 0);
1240} 1239}
1241 1240
1242static void mackerel_camera_del(struct soc_camera_link *icl) 1241static void mackerel_camera_del(struct soc_camera_device *icd)
1243{ 1242{
1244 soc_camera_platform_del(icl, camera_device, &camera_link); 1243 soc_camera_platform_del(icd, camera_device, &camera_link);
1245} 1244}
1246 1245
1247static struct sh_mobile_ceu_info sh_mobile_ceu_info = { 1246static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
diff --git a/arch/sh/boards/mach-ap325rxa/setup.c b/arch/sh/boards/mach-ap325rxa/setup.c
index 969421f64a15..e57b1df6da6a 100644
--- a/arch/sh/boards/mach-ap325rxa/setup.c
+++ b/arch/sh/boards/mach-ap325rxa/setup.c
@@ -332,8 +332,8 @@ static int camera_set_capture(struct soc_camera_platform_info *info,
332 return ret; 332 return ret;
333} 333}
334 334
335static int ap325rxa_camera_add(struct soc_camera_link *icl, struct device *dev); 335static int ap325rxa_camera_add(struct soc_camera_device *icd);
336static void ap325rxa_camera_del(struct soc_camera_link *icl); 336static void ap325rxa_camera_del(struct soc_camera_device *icd);
337 337
338static struct soc_camera_platform_info camera_info = { 338static struct soc_camera_platform_info camera_info = {
339 .format_name = "UYVY", 339 .format_name = "UYVY",
@@ -366,24 +366,23 @@ static void ap325rxa_camera_release(struct device *dev)
366 soc_camera_platform_release(&camera_device); 366 soc_camera_platform_release(&camera_device);
367} 367}
368 368
369static int ap325rxa_camera_add(struct soc_camera_link *icl, 369static int ap325rxa_camera_add(struct soc_camera_device *icd)
370 struct device *dev)
371{ 370{
372 int ret = soc_camera_platform_add(icl, dev, &camera_device, &camera_link, 371 int ret = soc_camera_platform_add(icd, &camera_device, &camera_link,
373 ap325rxa_camera_release, 0); 372 ap325rxa_camera_release, 0);
374 if (ret < 0) 373 if (ret < 0)
375 return ret; 374 return ret;
376 375
377 ret = camera_probe(); 376 ret = camera_probe();
378 if (ret < 0) 377 if (ret < 0)
379 soc_camera_platform_del(icl, camera_device, &camera_link); 378 soc_camera_platform_del(icd, camera_device, &camera_link);
380 379
381 return ret; 380 return ret;
382} 381}
383 382
384static void ap325rxa_camera_del(struct soc_camera_link *icl) 383static void ap325rxa_camera_del(struct soc_camera_device *icd)
385{ 384{
386 soc_camera_platform_del(icl, camera_device, &camera_link); 385 soc_camera_platform_del(icd, camera_device, &camera_link);
387} 386}
388#endif /* CONFIG_I2C */ 387#endif /* CONFIG_I2C */
389 388
diff --git a/drivers/media/video/atmel-isi.c b/drivers/media/video/atmel-isi.c
index 4742c2837eb4..7b89f00501b8 100644
--- a/drivers/media/video/atmel-isi.c
+++ b/drivers/media/video/atmel-isi.c
@@ -253,7 +253,7 @@ static int queue_setup(struct vb2_queue *vq, unsigned int *nbuffers,
253 void *alloc_ctxs[]) 253 void *alloc_ctxs[])
254{ 254{
255 struct soc_camera_device *icd = soc_camera_from_vb2q(vq); 255 struct soc_camera_device *icd = soc_camera_from_vb2q(vq);
256 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 256 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
257 struct atmel_isi *isi = ici->priv; 257 struct atmel_isi *isi = ici->priv;
258 unsigned long size; 258 unsigned long size;
259 int ret, bytes_per_line; 259 int ret, bytes_per_line;
@@ -261,7 +261,7 @@ static int queue_setup(struct vb2_queue *vq, unsigned int *nbuffers,
261 /* Reset ISI */ 261 /* Reset ISI */
262 ret = atmel_isi_wait_status(isi, WAIT_ISI_RESET); 262 ret = atmel_isi_wait_status(isi, WAIT_ISI_RESET);
263 if (ret < 0) { 263 if (ret < 0) {
264 dev_err(icd->dev.parent, "Reset ISI timed out\n"); 264 dev_err(icd->parent, "Reset ISI timed out\n");
265 return ret; 265 return ret;
266 } 266 }
267 /* Disable all interrupts */ 267 /* Disable all interrupts */
@@ -288,7 +288,7 @@ static int queue_setup(struct vb2_queue *vq, unsigned int *nbuffers,
288 isi->sequence = 0; 288 isi->sequence = 0;
289 isi->active = NULL; 289 isi->active = NULL;
290 290
291 dev_dbg(icd->dev.parent, "%s, count=%d, size=%ld\n", __func__, 291 dev_dbg(icd->parent, "%s, count=%d, size=%ld\n", __func__,
292 *nbuffers, size); 292 *nbuffers, size);
293 293
294 return 0; 294 return 0;
@@ -308,7 +308,7 @@ static int buffer_prepare(struct vb2_buffer *vb)
308{ 308{
309 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 309 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
310 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb); 310 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb);
311 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 311 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
312 struct atmel_isi *isi = ici->priv; 312 struct atmel_isi *isi = ici->priv;
313 unsigned long size; 313 unsigned long size;
314 struct isi_dma_desc *desc; 314 struct isi_dma_desc *desc;
@@ -321,7 +321,7 @@ static int buffer_prepare(struct vb2_buffer *vb)
321 size = bytes_per_line * icd->user_height; 321 size = bytes_per_line * icd->user_height;
322 322
323 if (vb2_plane_size(vb, 0) < size) { 323 if (vb2_plane_size(vb, 0) < size) {
324 dev_err(icd->dev.parent, "%s data will not fit into plane (%lu < %lu)\n", 324 dev_err(icd->parent, "%s data will not fit into plane (%lu < %lu)\n",
325 __func__, vb2_plane_size(vb, 0), size); 325 __func__, vb2_plane_size(vb, 0), size);
326 return -EINVAL; 326 return -EINVAL;
327 } 327 }
@@ -330,7 +330,7 @@ static int buffer_prepare(struct vb2_buffer *vb)
330 330
331 if (!buf->p_dma_desc) { 331 if (!buf->p_dma_desc) {
332 if (list_empty(&isi->dma_desc_head)) { 332 if (list_empty(&isi->dma_desc_head)) {
333 dev_err(icd->dev.parent, "Not enough dma descriptors.\n"); 333 dev_err(icd->parent, "Not enough dma descriptors.\n");
334 return -EINVAL; 334 return -EINVAL;
335 } else { 335 } else {
336 /* Get an available descriptor */ 336 /* Get an available descriptor */
@@ -354,7 +354,7 @@ static int buffer_prepare(struct vb2_buffer *vb)
354static void buffer_cleanup(struct vb2_buffer *vb) 354static void buffer_cleanup(struct vb2_buffer *vb)
355{ 355{
356 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 356 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
357 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 357 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
358 struct atmel_isi *isi = ici->priv; 358 struct atmel_isi *isi = ici->priv;
359 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb); 359 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb);
360 360
@@ -374,7 +374,7 @@ static void start_dma(struct atmel_isi *isi, struct frame_buffer *buffer)
374 374
375 /* Check if already in a frame */ 375 /* Check if already in a frame */
376 if (isi_readl(isi, ISI_STATUS) & ISI_CTRL_CDC) { 376 if (isi_readl(isi, ISI_STATUS) & ISI_CTRL_CDC) {
377 dev_err(isi->icd->dev.parent, "Already in frame handling.\n"); 377 dev_err(isi->icd->parent, "Already in frame handling.\n");
378 return; 378 return;
379 } 379 }
380 380
@@ -394,7 +394,7 @@ static void start_dma(struct atmel_isi *isi, struct frame_buffer *buffer)
394static void buffer_queue(struct vb2_buffer *vb) 394static void buffer_queue(struct vb2_buffer *vb)
395{ 395{
396 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 396 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
397 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 397 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
398 struct atmel_isi *isi = ici->priv; 398 struct atmel_isi *isi = ici->priv;
399 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb); 399 struct frame_buffer *buf = container_of(vb, struct frame_buffer, vb);
400 unsigned long flags = 0; 400 unsigned long flags = 0;
@@ -412,7 +412,7 @@ static void buffer_queue(struct vb2_buffer *vb)
412static int start_streaming(struct vb2_queue *vq) 412static int start_streaming(struct vb2_queue *vq)
413{ 413{
414 struct soc_camera_device *icd = soc_camera_from_vb2q(vq); 414 struct soc_camera_device *icd = soc_camera_from_vb2q(vq);
415 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 415 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
416 struct atmel_isi *isi = ici->priv; 416 struct atmel_isi *isi = ici->priv;
417 417
418 u32 sr = 0; 418 u32 sr = 0;
@@ -427,7 +427,7 @@ static int start_streaming(struct vb2_queue *vq)
427 isi_writel(isi, ISI_CTRL, ISI_CTRL_EN); 427 isi_writel(isi, ISI_CTRL, ISI_CTRL_EN);
428 spin_unlock_irq(&isi->lock); 428 spin_unlock_irq(&isi->lock);
429 429
430 dev_dbg(icd->dev.parent, "Waiting for SOF\n"); 430 dev_dbg(icd->parent, "Waiting for SOF\n");
431 ret = wait_event_interruptible(isi->vsync_wq, 431 ret = wait_event_interruptible(isi->vsync_wq,
432 isi->state != ISI_STATE_IDLE); 432 isi->state != ISI_STATE_IDLE);
433 if (ret) 433 if (ret)
@@ -448,7 +448,7 @@ static int start_streaming(struct vb2_queue *vq)
448static int stop_streaming(struct vb2_queue *vq) 448static int stop_streaming(struct vb2_queue *vq)
449{ 449{
450 struct soc_camera_device *icd = soc_camera_from_vb2q(vq); 450 struct soc_camera_device *icd = soc_camera_from_vb2q(vq);
451 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 451 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
452 struct atmel_isi *isi = ici->priv; 452 struct atmel_isi *isi = ici->priv;
453 struct frame_buffer *buf, *node; 453 struct frame_buffer *buf, *node;
454 int ret = 0; 454 int ret = 0;
@@ -470,7 +470,7 @@ static int stop_streaming(struct vb2_queue *vq)
470 msleep(1); 470 msleep(1);
471 471
472 if (time_after(jiffies, timeout)) { 472 if (time_after(jiffies, timeout)) {
473 dev_err(icd->dev.parent, 473 dev_err(icd->parent,
474 "Timeout waiting for finishing codec request\n"); 474 "Timeout waiting for finishing codec request\n");
475 return -ETIMEDOUT; 475 return -ETIMEDOUT;
476 } 476 }
@@ -482,7 +482,7 @@ static int stop_streaming(struct vb2_queue *vq)
482 /* Disable ISI and wait for it is done */ 482 /* Disable ISI and wait for it is done */
483 ret = atmel_isi_wait_status(isi, WAIT_ISI_DISABLE); 483 ret = atmel_isi_wait_status(isi, WAIT_ISI_DISABLE);
484 if (ret < 0) 484 if (ret < 0)
485 dev_err(icd->dev.parent, "Disable ISI timed out\n"); 485 dev_err(icd->parent, "Disable ISI timed out\n");
486 486
487 return ret; 487 return ret;
488} 488}
@@ -518,7 +518,7 @@ static int isi_camera_init_videobuf(struct vb2_queue *q,
518static int isi_camera_set_fmt(struct soc_camera_device *icd, 518static int isi_camera_set_fmt(struct soc_camera_device *icd,
519 struct v4l2_format *f) 519 struct v4l2_format *f)
520{ 520{
521 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 521 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
522 struct atmel_isi *isi = ici->priv; 522 struct atmel_isi *isi = ici->priv;
523 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 523 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
524 const struct soc_camera_format_xlate *xlate; 524 const struct soc_camera_format_xlate *xlate;
@@ -528,12 +528,12 @@ static int isi_camera_set_fmt(struct soc_camera_device *icd,
528 528
529 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 529 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
530 if (!xlate) { 530 if (!xlate) {
531 dev_warn(icd->dev.parent, "Format %x not found\n", 531 dev_warn(icd->parent, "Format %x not found\n",
532 pix->pixelformat); 532 pix->pixelformat);
533 return -EINVAL; 533 return -EINVAL;
534 } 534 }
535 535
536 dev_dbg(icd->dev.parent, "Plan to set format %dx%d\n", 536 dev_dbg(icd->parent, "Plan to set format %dx%d\n",
537 pix->width, pix->height); 537 pix->width, pix->height);
538 538
539 mf.width = pix->width; 539 mf.width = pix->width;
@@ -559,7 +559,7 @@ static int isi_camera_set_fmt(struct soc_camera_device *icd,
559 pix->colorspace = mf.colorspace; 559 pix->colorspace = mf.colorspace;
560 icd->current_fmt = xlate; 560 icd->current_fmt = xlate;
561 561
562 dev_dbg(icd->dev.parent, "Finally set format %dx%d\n", 562 dev_dbg(icd->parent, "Finally set format %dx%d\n",
563 pix->width, pix->height); 563 pix->width, pix->height);
564 564
565 return ret; 565 return ret;
@@ -577,7 +577,7 @@ static int isi_camera_try_fmt(struct soc_camera_device *icd,
577 577
578 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); 578 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt);
579 if (pixfmt && !xlate) { 579 if (pixfmt && !xlate) {
580 dev_warn(icd->dev.parent, "Format %x not found\n", pixfmt); 580 dev_warn(icd->parent, "Format %x not found\n", pixfmt);
581 return -EINVAL; 581 return -EINVAL;
582 } 582 }
583 583
@@ -609,7 +609,7 @@ static int isi_camera_try_fmt(struct soc_camera_device *icd,
609 case V4L2_FIELD_NONE: 609 case V4L2_FIELD_NONE:
610 break; 610 break;
611 default: 611 default:
612 dev_err(icd->dev.parent, "Field type %d unsupported.\n", 612 dev_err(icd->parent, "Field type %d unsupported.\n",
613 mf.field); 613 mf.field);
614 ret = -EINVAL; 614 ret = -EINVAL;
615 } 615 }
@@ -670,7 +670,7 @@ static unsigned long make_bus_param(struct atmel_isi *isi)
670static int isi_camera_try_bus_param(struct soc_camera_device *icd, 670static int isi_camera_try_bus_param(struct soc_camera_device *icd,
671 unsigned char buswidth) 671 unsigned char buswidth)
672{ 672{
673 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 673 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
674 struct atmel_isi *isi = ici->priv; 674 struct atmel_isi *isi = ici->priv;
675 unsigned long camera_flags; 675 unsigned long camera_flags;
676 int ret; 676 int ret;
@@ -702,7 +702,7 @@ static int isi_camera_get_formats(struct soc_camera_device *icd,
702 702
703 fmt = soc_mbus_get_fmtdesc(code); 703 fmt = soc_mbus_get_fmtdesc(code);
704 if (!fmt) { 704 if (!fmt) {
705 dev_err(icd->dev.parent, 705 dev_err(icd->parent,
706 "Invalid format code #%u: %d\n", idx, code); 706 "Invalid format code #%u: %d\n", idx, code);
707 return 0; 707 return 0;
708 } 708 }
@@ -710,7 +710,7 @@ static int isi_camera_get_formats(struct soc_camera_device *icd,
710 /* This also checks support for the requested bits-per-sample */ 710 /* This also checks support for the requested bits-per-sample */
711 ret = isi_camera_try_bus_param(icd, fmt->bits_per_sample); 711 ret = isi_camera_try_bus_param(icd, fmt->bits_per_sample);
712 if (ret < 0) { 712 if (ret < 0) {
713 dev_err(icd->dev.parent, 713 dev_err(icd->parent,
714 "Fail to try the bus parameters.\n"); 714 "Fail to try the bus parameters.\n");
715 return 0; 715 return 0;
716 } 716 }
@@ -725,7 +725,7 @@ static int isi_camera_get_formats(struct soc_camera_device *icd,
725 xlate->host_fmt = &isi_camera_formats[0]; 725 xlate->host_fmt = &isi_camera_formats[0];
726 xlate->code = code; 726 xlate->code = code;
727 xlate++; 727 xlate++;
728 dev_dbg(icd->dev.parent, "Providing format %s using code %d\n", 728 dev_dbg(icd->parent, "Providing format %s using code %d\n",
729 isi_camera_formats[0].name, code); 729 isi_camera_formats[0].name, code);
730 } 730 }
731 break; 731 break;
@@ -733,7 +733,7 @@ static int isi_camera_get_formats(struct soc_camera_device *icd,
733 if (!isi_camera_packing_supported(fmt)) 733 if (!isi_camera_packing_supported(fmt))
734 return 0; 734 return 0;
735 if (xlate) 735 if (xlate)
736 dev_dbg(icd->dev.parent, 736 dev_dbg(icd->parent,
737 "Providing format %s in pass-through mode\n", 737 "Providing format %s in pass-through mode\n",
738 fmt->name); 738 fmt->name);
739 } 739 }
@@ -752,7 +752,7 @@ static int isi_camera_get_formats(struct soc_camera_device *icd,
752/* Called with .video_lock held */ 752/* Called with .video_lock held */
753static int isi_camera_add_device(struct soc_camera_device *icd) 753static int isi_camera_add_device(struct soc_camera_device *icd)
754{ 754{
755 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 755 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
756 struct atmel_isi *isi = ici->priv; 756 struct atmel_isi *isi = ici->priv;
757 int ret; 757 int ret;
758 758
@@ -764,14 +764,14 @@ static int isi_camera_add_device(struct soc_camera_device *icd)
764 return ret; 764 return ret;
765 765
766 isi->icd = icd; 766 isi->icd = icd;
767 dev_dbg(icd->dev.parent, "Atmel ISI Camera driver attached to camera %d\n", 767 dev_dbg(icd->parent, "Atmel ISI Camera driver attached to camera %d\n",
768 icd->devnum); 768 icd->devnum);
769 return 0; 769 return 0;
770} 770}
771/* Called with .video_lock held */ 771/* Called with .video_lock held */
772static void isi_camera_remove_device(struct soc_camera_device *icd) 772static void isi_camera_remove_device(struct soc_camera_device *icd)
773{ 773{
774 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 774 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
775 struct atmel_isi *isi = ici->priv; 775 struct atmel_isi *isi = ici->priv;
776 776
777 BUG_ON(icd != isi->icd); 777 BUG_ON(icd != isi->icd);
@@ -779,7 +779,7 @@ static void isi_camera_remove_device(struct soc_camera_device *icd)
779 clk_disable(isi->pclk); 779 clk_disable(isi->pclk);
780 isi->icd = NULL; 780 isi->icd = NULL;
781 781
782 dev_dbg(icd->dev.parent, "Atmel ISI Camera driver detached from camera %d\n", 782 dev_dbg(icd->parent, "Atmel ISI Camera driver detached from camera %d\n",
783 icd->devnum); 783 icd->devnum);
784} 784}
785 785
@@ -802,7 +802,7 @@ static int isi_camera_querycap(struct soc_camera_host *ici,
802 802
803static int isi_camera_set_bus_param(struct soc_camera_device *icd, u32 pixfmt) 803static int isi_camera_set_bus_param(struct soc_camera_device *icd, u32 pixfmt)
804{ 804{
805 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 805 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
806 struct atmel_isi *isi = ici->priv; 806 struct atmel_isi *isi = ici->priv;
807 unsigned long bus_flags, camera_flags, common_flags; 807 unsigned long bus_flags, camera_flags, common_flags;
808 int ret; 808 int ret;
@@ -812,7 +812,7 @@ static int isi_camera_set_bus_param(struct soc_camera_device *icd, u32 pixfmt)
812 812
813 bus_flags = make_bus_param(isi); 813 bus_flags = make_bus_param(isi);
814 common_flags = soc_camera_bus_param_compatible(camera_flags, bus_flags); 814 common_flags = soc_camera_bus_param_compatible(camera_flags, bus_flags);
815 dev_dbg(icd->dev.parent, "Flags cam: 0x%lx host: 0x%lx common: 0x%lx\n", 815 dev_dbg(icd->parent, "Flags cam: 0x%lx host: 0x%lx common: 0x%lx\n",
816 camera_flags, bus_flags, common_flags); 816 camera_flags, bus_flags, common_flags);
817 if (!common_flags) 817 if (!common_flags)
818 return -EINVAL; 818 return -EINVAL;
@@ -844,7 +844,7 @@ static int isi_camera_set_bus_param(struct soc_camera_device *icd, u32 pixfmt)
844 844
845 ret = icd->ops->set_bus_param(icd, common_flags); 845 ret = icd->ops->set_bus_param(icd, common_flags);
846 if (ret < 0) { 846 if (ret < 0) {
847 dev_dbg(icd->dev.parent, "Camera set_bus_param(%lx) returned %d\n", 847 dev_dbg(icd->parent, "Camera set_bus_param(%lx) returned %d\n",
848 common_flags, ret); 848 common_flags, ret);
849 return ret; 849 return ret;
850 } 850 }
diff --git a/drivers/media/video/mt9m001.c b/drivers/media/video/mt9m001.c
index e2bbd8c35c98..4da9cca939c1 100644
--- a/drivers/media/video/mt9m001.c
+++ b/drivers/media/video/mt9m001.c
@@ -603,13 +603,9 @@ static int mt9m001_video_probe(struct soc_camera_device *icd,
603 unsigned long flags; 603 unsigned long flags;
604 int ret; 604 int ret;
605 605
606 /* 606 /* We must have a parent by now. And it cannot be a wrong one. */
607 * We must have a parent by now. And it cannot be a wrong one. 607 BUG_ON(!icd->parent ||
608 * So this entire test is completely redundant. 608 to_soc_camera_host(icd->parent)->nr != icd->iface);
609 */
610 if (!icd->dev.parent ||
611 to_soc_camera_host(icd->dev.parent)->nr != icd->iface)
612 return -ENODEV;
613 609
614 /* Enable the chip */ 610 /* Enable the chip */
615 data = reg_write(client, MT9M001_CHIP_ENABLE, 1); 611 data = reg_write(client, MT9M001_CHIP_ENABLE, 1);
@@ -675,8 +671,8 @@ static void mt9m001_video_remove(struct soc_camera_device *icd)
675{ 671{
676 struct soc_camera_link *icl = to_soc_camera_link(icd); 672 struct soc_camera_link *icl = to_soc_camera_link(icd);
677 673
678 dev_dbg(&icd->dev, "Video removed: %p, %p\n", 674 dev_dbg(icd->pdev, "Video removed: %p, %p\n",
679 icd->dev.parent, icd->vdev); 675 icd->parent, icd->vdev);
680 if (icl->free_bus) 676 if (icl->free_bus)
681 icl->free_bus(icl); 677 icl->free_bus(icl);
682} 678}
diff --git a/drivers/media/video/mt9m111.c b/drivers/media/video/mt9m111.c
index 7962334a386b..cbccc869c7e1 100644
--- a/drivers/media/video/mt9m111.c
+++ b/drivers/media/video/mt9m111.c
@@ -960,13 +960,9 @@ static int mt9m111_video_probe(struct soc_camera_device *icd,
960 s32 data; 960 s32 data;
961 int ret; 961 int ret;
962 962
963 /* 963 /* We must have a parent by now. And it cannot be a wrong one. */
964 * We must have a parent by now. And it cannot be a wrong one. 964 BUG_ON(!icd->parent ||
965 * So this entire test is completely redundant. 965 to_soc_camera_host(icd->parent)->nr != icd->iface);
966 */
967 if (!icd->dev.parent ||
968 to_soc_camera_host(icd->dev.parent)->nr != icd->iface)
969 return -ENODEV;
970 966
971 mt9m111->autoexposure = 1; 967 mt9m111->autoexposure = 1;
972 mt9m111->autowhitebalance = 1; 968 mt9m111->autowhitebalance = 1;
diff --git a/drivers/media/video/mt9t031.c b/drivers/media/video/mt9t031.c
index 7ce279c3751d..30547cc3f89b 100644
--- a/drivers/media/video/mt9t031.c
+++ b/drivers/media/video/mt9t031.c
@@ -700,8 +700,7 @@ static int mt9t031_runtime_suspend(struct device *dev)
700static int mt9t031_runtime_resume(struct device *dev) 700static int mt9t031_runtime_resume(struct device *dev)
701{ 701{
702 struct video_device *vdev = to_video_device(dev); 702 struct video_device *vdev = to_video_device(dev);
703 struct soc_camera_device *icd = container_of(vdev->parent, 703 struct soc_camera_device *icd = dev_get_drvdata(vdev->parent);
704 struct soc_camera_device, dev);
705 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 704 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
706 struct i2c_client *client = v4l2_get_subdevdata(sd); 705 struct i2c_client *client = v4l2_get_subdevdata(sd);
707 struct mt9t031 *mt9t031 = to_mt9t031(client); 706 struct mt9t031 *mt9t031 = to_mt9t031(client);
diff --git a/drivers/media/video/mt9t112.c b/drivers/media/video/mt9t112.c
index bffa9ee10968..d2e0a50063a2 100644
--- a/drivers/media/video/mt9t112.c
+++ b/drivers/media/video/mt9t112.c
@@ -1057,13 +1057,9 @@ static int mt9t112_camera_probe(struct soc_camera_device *icd,
1057 const char *devname; 1057 const char *devname;
1058 int chipid; 1058 int chipid;
1059 1059
1060 /* 1060 /* We must have a parent by now. And it cannot be a wrong one. */
1061 * We must have a parent by now. And it cannot be a wrong one. 1061 BUG_ON(!icd->parent ||
1062 * So this entire test is completely redundant. 1062 to_soc_camera_host(icd->parent)->nr != icd->iface);
1063 */
1064 if (!icd->dev.parent ||
1065 to_soc_camera_host(icd->dev.parent)->nr != icd->iface)
1066 return -ENODEV;
1067 1063
1068 /* 1064 /*
1069 * check and show chip ID 1065 * check and show chip ID
diff --git a/drivers/media/video/mt9v022.c b/drivers/media/video/mt9v022.c
index fc76ed1c08e5..51b0fccbfe70 100644
--- a/drivers/media/video/mt9v022.c
+++ b/drivers/media/video/mt9v022.c
@@ -728,9 +728,9 @@ static int mt9v022_video_probe(struct soc_camera_device *icd,
728 int ret; 728 int ret;
729 unsigned long flags; 729 unsigned long flags;
730 730
731 if (!icd->dev.parent || 731 /* We must have a parent by now. And it cannot be a wrong one. */
732 to_soc_camera_host(icd->dev.parent)->nr != icd->iface) 732 BUG_ON(!icd->parent ||
733 return -ENODEV; 733 to_soc_camera_host(icd->parent)->nr != icd->iface);
734 734
735 /* Read out the chip version register */ 735 /* Read out the chip version register */
736 data = reg_read(client, MT9V022_CHIP_VERSION); 736 data = reg_read(client, MT9V022_CHIP_VERSION);
@@ -809,8 +809,8 @@ static void mt9v022_video_remove(struct soc_camera_device *icd)
809{ 809{
810 struct soc_camera_link *icl = to_soc_camera_link(icd); 810 struct soc_camera_link *icl = to_soc_camera_link(icd);
811 811
812 dev_dbg(&icd->dev, "Video removed: %p, %p\n", 812 dev_dbg(icd->pdev, "Video removed: %p, %p\n",
813 icd->dev.parent, icd->vdev); 813 icd->parent, icd->vdev);
814 if (icl->free_bus) 814 if (icl->free_bus)
815 icl->free_bus(icl); 815 icl->free_bus(icl);
816} 816}
diff --git a/drivers/media/video/mx1_camera.c b/drivers/media/video/mx1_camera.c
index 30a1364675c2..087db12a3a67 100644
--- a/drivers/media/video/mx1_camera.c
+++ b/drivers/media/video/mx1_camera.c
@@ -141,7 +141,7 @@ static int mx1_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
141 if (*size * *count > MAX_VIDEO_MEM * 1024 * 1024) 141 if (*size * *count > MAX_VIDEO_MEM * 1024 * 1024)
142 *count = (MAX_VIDEO_MEM * 1024 * 1024) / *size; 142 *count = (MAX_VIDEO_MEM * 1024 * 1024) / *size;
143 143
144 dev_dbg(icd->dev.parent, "count=%d, size=%d\n", *count, *size); 144 dev_dbg(icd->parent, "count=%d, size=%d\n", *count, *size);
145 145
146 return 0; 146 return 0;
147} 147}
@@ -153,7 +153,7 @@ static void free_buffer(struct videobuf_queue *vq, struct mx1_buffer *buf)
153 153
154 BUG_ON(in_interrupt()); 154 BUG_ON(in_interrupt());
155 155
156 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 156 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
157 vb, vb->baddr, vb->bsize); 157 vb, vb->baddr, vb->bsize);
158 158
159 /* 159 /*
@@ -178,7 +178,7 @@ static int mx1_videobuf_prepare(struct videobuf_queue *vq,
178 if (bytes_per_line < 0) 178 if (bytes_per_line < 0)
179 return bytes_per_line; 179 return bytes_per_line;
180 180
181 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 181 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
182 vb, vb->baddr, vb->bsize); 182 vb, vb->baddr, vb->bsize);
183 183
184 /* Added list head initialization on alloc */ 184 /* Added list head initialization on alloc */
@@ -231,7 +231,7 @@ out:
231static int mx1_camera_setup_dma(struct mx1_camera_dev *pcdev) 231static int mx1_camera_setup_dma(struct mx1_camera_dev *pcdev)
232{ 232{
233 struct videobuf_buffer *vbuf = &pcdev->active->vb; 233 struct videobuf_buffer *vbuf = &pcdev->active->vb;
234 struct device *dev = pcdev->icd->dev.parent; 234 struct device *dev = pcdev->icd->parent;
235 int ret; 235 int ret;
236 236
237 if (unlikely(!pcdev->active)) { 237 if (unlikely(!pcdev->active)) {
@@ -255,11 +255,11 @@ static void mx1_videobuf_queue(struct videobuf_queue *vq,
255 struct videobuf_buffer *vb) 255 struct videobuf_buffer *vb)
256{ 256{
257 struct soc_camera_device *icd = vq->priv_data; 257 struct soc_camera_device *icd = vq->priv_data;
258 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 258 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
259 struct mx1_camera_dev *pcdev = ici->priv; 259 struct mx1_camera_dev *pcdev = ici->priv;
260 struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb); 260 struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb);
261 261
262 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 262 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
263 vb, vb->baddr, vb->bsize); 263 vb, vb->baddr, vb->bsize);
264 264
265 list_add_tail(&vb->queue, &pcdev->capture); 265 list_add_tail(&vb->queue, &pcdev->capture);
@@ -286,7 +286,7 @@ static void mx1_videobuf_release(struct videobuf_queue *vq,
286 struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb); 286 struct mx1_buffer *buf = container_of(vb, struct mx1_buffer, vb);
287#ifdef DEBUG 287#ifdef DEBUG
288 struct soc_camera_device *icd = vq->priv_data; 288 struct soc_camera_device *icd = vq->priv_data;
289 struct device *dev = icd->dev.parent; 289 struct device *dev = icd->parent;
290 290
291 dev_dbg(dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 291 dev_dbg(dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
292 vb, vb->baddr, vb->bsize); 292 vb, vb->baddr, vb->bsize);
@@ -342,7 +342,7 @@ static void mx1_camera_wakeup(struct mx1_camera_dev *pcdev,
342static void mx1_camera_dma_irq(int channel, void *data) 342static void mx1_camera_dma_irq(int channel, void *data)
343{ 343{
344 struct mx1_camera_dev *pcdev = data; 344 struct mx1_camera_dev *pcdev = data;
345 struct device *dev = pcdev->icd->dev.parent; 345 struct device *dev = pcdev->icd->parent;
346 struct mx1_buffer *buf; 346 struct mx1_buffer *buf;
347 struct videobuf_buffer *vb; 347 struct videobuf_buffer *vb;
348 unsigned long flags; 348 unsigned long flags;
@@ -377,10 +377,10 @@ static struct videobuf_queue_ops mx1_videobuf_ops = {
377static void mx1_camera_init_videobuf(struct videobuf_queue *q, 377static void mx1_camera_init_videobuf(struct videobuf_queue *q,
378 struct soc_camera_device *icd) 378 struct soc_camera_device *icd)
379{ 379{
380 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 380 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
381 struct mx1_camera_dev *pcdev = ici->priv; 381 struct mx1_camera_dev *pcdev = ici->priv;
382 382
383 videobuf_queue_dma_contig_init(q, &mx1_videobuf_ops, icd->dev.parent, 383 videobuf_queue_dma_contig_init(q, &mx1_videobuf_ops, icd->parent,
384 &pcdev->lock, V4L2_BUF_TYPE_VIDEO_CAPTURE, 384 &pcdev->lock, V4L2_BUF_TYPE_VIDEO_CAPTURE,
385 V4L2_FIELD_NONE, 385 V4L2_FIELD_NONE,
386 sizeof(struct mx1_buffer), icd, &icd->video_lock); 386 sizeof(struct mx1_buffer), icd, &icd->video_lock);
@@ -400,7 +400,7 @@ static int mclk_get_divisor(struct mx1_camera_dev *pcdev)
400 */ 400 */
401 div = (lcdclk + 2 * mclk - 1) / (2 * mclk) - 1; 401 div = (lcdclk + 2 * mclk - 1) / (2 * mclk) - 1;
402 402
403 dev_dbg(pcdev->icd->dev.parent, 403 dev_dbg(pcdev->icd->parent,
404 "System clock %lukHz, target freq %dkHz, divisor %lu\n", 404 "System clock %lukHz, target freq %dkHz, divisor %lu\n",
405 lcdclk / 1000, mclk / 1000, div); 405 lcdclk / 1000, mclk / 1000, div);
406 406
@@ -411,7 +411,7 @@ static void mx1_camera_activate(struct mx1_camera_dev *pcdev)
411{ 411{
412 unsigned int csicr1 = CSICR1_EN; 412 unsigned int csicr1 = CSICR1_EN;
413 413
414 dev_dbg(pcdev->icd->dev.parent, "Activate device\n"); 414 dev_dbg(pcdev->icd->parent, "Activate device\n");
415 415
416 clk_enable(pcdev->clk); 416 clk_enable(pcdev->clk);
417 417
@@ -427,7 +427,7 @@ static void mx1_camera_activate(struct mx1_camera_dev *pcdev)
427 427
428static void mx1_camera_deactivate(struct mx1_camera_dev *pcdev) 428static void mx1_camera_deactivate(struct mx1_camera_dev *pcdev)
429{ 429{
430 dev_dbg(pcdev->icd->dev.parent, "Deactivate device\n"); 430 dev_dbg(pcdev->icd->parent, "Deactivate device\n");
431 431
432 /* Disable all CSI interface */ 432 /* Disable all CSI interface */
433 __raw_writel(0x00, pcdev->base + CSICR1); 433 __raw_writel(0x00, pcdev->base + CSICR1);
@@ -441,13 +441,13 @@ static void mx1_camera_deactivate(struct mx1_camera_dev *pcdev)
441 */ 441 */
442static int mx1_camera_add_device(struct soc_camera_device *icd) 442static int mx1_camera_add_device(struct soc_camera_device *icd)
443{ 443{
444 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 444 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
445 struct mx1_camera_dev *pcdev = ici->priv; 445 struct mx1_camera_dev *pcdev = ici->priv;
446 446
447 if (pcdev->icd) 447 if (pcdev->icd)
448 return -EBUSY; 448 return -EBUSY;
449 449
450 dev_info(icd->dev.parent, "MX1 Camera driver attached to camera %d\n", 450 dev_info(icd->parent, "MX1 Camera driver attached to camera %d\n",
451 icd->devnum); 451 icd->devnum);
452 452
453 mx1_camera_activate(pcdev); 453 mx1_camera_activate(pcdev);
@@ -459,7 +459,7 @@ static int mx1_camera_add_device(struct soc_camera_device *icd)
459 459
460static void mx1_camera_remove_device(struct soc_camera_device *icd) 460static void mx1_camera_remove_device(struct soc_camera_device *icd)
461{ 461{
462 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 462 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
463 struct mx1_camera_dev *pcdev = ici->priv; 463 struct mx1_camera_dev *pcdev = ici->priv;
464 unsigned int csicr1; 464 unsigned int csicr1;
465 465
@@ -472,7 +472,7 @@ static void mx1_camera_remove_device(struct soc_camera_device *icd)
472 /* Stop DMA engine */ 472 /* Stop DMA engine */
473 imx_dma_disable(pcdev->dma_chan); 473 imx_dma_disable(pcdev->dma_chan);
474 474
475 dev_info(icd->dev.parent, "MX1 Camera driver detached from camera %d\n", 475 dev_info(icd->parent, "MX1 Camera driver detached from camera %d\n",
476 icd->devnum); 476 icd->devnum);
477 477
478 mx1_camera_deactivate(pcdev); 478 mx1_camera_deactivate(pcdev);
@@ -490,7 +490,7 @@ static int mx1_camera_set_crop(struct soc_camera_device *icd,
490 490
491static int mx1_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt) 491static int mx1_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt)
492{ 492{
493 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 493 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
494 struct mx1_camera_dev *pcdev = ici->priv; 494 struct mx1_camera_dev *pcdev = ici->priv;
495 unsigned long camera_flags, common_flags; 495 unsigned long camera_flags, common_flags;
496 unsigned int csicr1; 496 unsigned int csicr1;
@@ -561,14 +561,14 @@ static int mx1_camera_set_fmt(struct soc_camera_device *icd,
561 561
562 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 562 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
563 if (!xlate) { 563 if (!xlate) {
564 dev_warn(icd->dev.parent, "Format %x not found\n", 564 dev_warn(icd->parent, "Format %x not found\n",
565 pix->pixelformat); 565 pix->pixelformat);
566 return -EINVAL; 566 return -EINVAL;
567 } 567 }
568 568
569 buswidth = xlate->host_fmt->bits_per_sample; 569 buswidth = xlate->host_fmt->bits_per_sample;
570 if (buswidth > 8) { 570 if (buswidth > 8) {
571 dev_warn(icd->dev.parent, 571 dev_warn(icd->parent,
572 "bits-per-sample %d for format %x unsupported\n", 572 "bits-per-sample %d for format %x unsupported\n",
573 buswidth, pix->pixelformat); 573 buswidth, pix->pixelformat);
574 return -EINVAL; 574 return -EINVAL;
@@ -608,7 +608,7 @@ static int mx1_camera_try_fmt(struct soc_camera_device *icd,
608 608
609 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 609 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
610 if (!xlate) { 610 if (!xlate) {
611 dev_warn(icd->dev.parent, "Format %x not found\n", 611 dev_warn(icd->parent, "Format %x not found\n",
612 pix->pixelformat); 612 pix->pixelformat);
613 return -EINVAL; 613 return -EINVAL;
614 } 614 }
diff --git a/drivers/media/video/mx2_camera.c b/drivers/media/video/mx2_camera.c
index 55d48442c2eb..ec2410c0c806 100644
--- a/drivers/media/video/mx2_camera.c
+++ b/drivers/media/video/mx2_camera.c
@@ -277,7 +277,7 @@ static void mx2_camera_deactivate(struct mx2_camera_dev *pcdev)
277 */ 277 */
278static int mx2_camera_add_device(struct soc_camera_device *icd) 278static int mx2_camera_add_device(struct soc_camera_device *icd)
279{ 279{
280 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 280 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
281 struct mx2_camera_dev *pcdev = ici->priv; 281 struct mx2_camera_dev *pcdev = ici->priv;
282 int ret; 282 int ret;
283 u32 csicr1; 283 u32 csicr1;
@@ -302,7 +302,7 @@ static int mx2_camera_add_device(struct soc_camera_device *icd)
302 302
303 pcdev->icd = icd; 303 pcdev->icd = icd;
304 304
305 dev_info(icd->dev.parent, "Camera driver attached to camera %d\n", 305 dev_info(icd->parent, "Camera driver attached to camera %d\n",
306 icd->devnum); 306 icd->devnum);
307 307
308 return 0; 308 return 0;
@@ -310,12 +310,12 @@ static int mx2_camera_add_device(struct soc_camera_device *icd)
310 310
311static void mx2_camera_remove_device(struct soc_camera_device *icd) 311static void mx2_camera_remove_device(struct soc_camera_device *icd)
312{ 312{
313 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 313 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
314 struct mx2_camera_dev *pcdev = ici->priv; 314 struct mx2_camera_dev *pcdev = ici->priv;
315 315
316 BUG_ON(icd != pcdev->icd); 316 BUG_ON(icd != pcdev->icd);
317 317
318 dev_info(icd->dev.parent, "Camera driver detached from camera %d\n", 318 dev_info(icd->parent, "Camera driver detached from camera %d\n",
319 icd->devnum); 319 icd->devnum);
320 320
321 mx2_camera_deactivate(pcdev); 321 mx2_camera_deactivate(pcdev);
@@ -436,7 +436,7 @@ static int mx2_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
436 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width, 436 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width,
437 icd->current_fmt->host_fmt); 437 icd->current_fmt->host_fmt);
438 438
439 dev_dbg(&icd->dev, "count=%d, size=%d\n", *count, *size); 439 dev_dbg(icd->parent, "count=%d, size=%d\n", *count, *size);
440 440
441 if (bytes_per_line < 0) 441 if (bytes_per_line < 0)
442 return bytes_per_line; 442 return bytes_per_line;
@@ -456,7 +456,7 @@ static void free_buffer(struct videobuf_queue *vq, struct mx2_buffer *buf)
456 struct soc_camera_device *icd = vq->priv_data; 456 struct soc_camera_device *icd = vq->priv_data;
457 struct videobuf_buffer *vb = &buf->vb; 457 struct videobuf_buffer *vb = &buf->vb;
458 458
459 dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 459 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
460 vb, vb->baddr, vb->bsize); 460 vb, vb->baddr, vb->bsize);
461 461
462 /* 462 /*
@@ -466,7 +466,7 @@ static void free_buffer(struct videobuf_queue *vq, struct mx2_buffer *buf)
466 videobuf_waiton(vq, vb, 0, 0); 466 videobuf_waiton(vq, vb, 0, 0);
467 467
468 videobuf_dma_contig_free(vq, vb); 468 videobuf_dma_contig_free(vq, vb);
469 dev_dbg(&icd->dev, "%s freed\n", __func__); 469 dev_dbg(icd->parent, "%s freed\n", __func__);
470 470
471 vb->state = VIDEOBUF_NEEDS_INIT; 471 vb->state = VIDEOBUF_NEEDS_INIT;
472} 472}
@@ -480,7 +480,7 @@ static int mx2_videobuf_prepare(struct videobuf_queue *vq,
480 icd->current_fmt->host_fmt); 480 icd->current_fmt->host_fmt);
481 int ret = 0; 481 int ret = 0;
482 482
483 dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 483 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
484 vb, vb->baddr, vb->bsize); 484 vb, vb->baddr, vb->bsize);
485 485
486 if (bytes_per_line < 0) 486 if (bytes_per_line < 0)
@@ -532,12 +532,12 @@ static void mx2_videobuf_queue(struct videobuf_queue *vq,
532{ 532{
533 struct soc_camera_device *icd = vq->priv_data; 533 struct soc_camera_device *icd = vq->priv_data;
534 struct soc_camera_host *ici = 534 struct soc_camera_host *ici =
535 to_soc_camera_host(icd->dev.parent); 535 to_soc_camera_host(icd->parent);
536 struct mx2_camera_dev *pcdev = ici->priv; 536 struct mx2_camera_dev *pcdev = ici->priv;
537 struct mx2_buffer *buf = container_of(vb, struct mx2_buffer, vb); 537 struct mx2_buffer *buf = container_of(vb, struct mx2_buffer, vb);
538 unsigned long flags; 538 unsigned long flags;
539 539
540 dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 540 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
541 vb, vb->baddr, vb->bsize); 541 vb, vb->baddr, vb->bsize);
542 542
543 spin_lock_irqsave(&pcdev->lock, flags); 543 spin_lock_irqsave(&pcdev->lock, flags);
@@ -610,27 +610,27 @@ static void mx2_videobuf_release(struct videobuf_queue *vq,
610 struct videobuf_buffer *vb) 610 struct videobuf_buffer *vb)
611{ 611{
612 struct soc_camera_device *icd = vq->priv_data; 612 struct soc_camera_device *icd = vq->priv_data;
613 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 613 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
614 struct mx2_camera_dev *pcdev = ici->priv; 614 struct mx2_camera_dev *pcdev = ici->priv;
615 struct mx2_buffer *buf = container_of(vb, struct mx2_buffer, vb); 615 struct mx2_buffer *buf = container_of(vb, struct mx2_buffer, vb);
616 unsigned long flags; 616 unsigned long flags;
617 617
618#ifdef DEBUG 618#ifdef DEBUG
619 dev_dbg(&icd->dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 619 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
620 vb, vb->baddr, vb->bsize); 620 vb, vb->baddr, vb->bsize);
621 621
622 switch (vb->state) { 622 switch (vb->state) {
623 case VIDEOBUF_ACTIVE: 623 case VIDEOBUF_ACTIVE:
624 dev_info(&icd->dev, "%s (active)\n", __func__); 624 dev_info(icd->parent, "%s (active)\n", __func__);
625 break; 625 break;
626 case VIDEOBUF_QUEUED: 626 case VIDEOBUF_QUEUED:
627 dev_info(&icd->dev, "%s (queued)\n", __func__); 627 dev_info(icd->parent, "%s (queued)\n", __func__);
628 break; 628 break;
629 case VIDEOBUF_PREPARED: 629 case VIDEOBUF_PREPARED:
630 dev_info(&icd->dev, "%s (prepared)\n", __func__); 630 dev_info(icd->parent, "%s (prepared)\n", __func__);
631 break; 631 break;
632 default: 632 default:
633 dev_info(&icd->dev, "%s (unknown) %d\n", __func__, 633 dev_info(icd->parent, "%s (unknown) %d\n", __func__,
634 vb->state); 634 vb->state);
635 break; 635 break;
636 } 636 }
@@ -677,7 +677,7 @@ static struct videobuf_queue_ops mx2_videobuf_ops = {
677static void mx2_camera_init_videobuf(struct videobuf_queue *q, 677static void mx2_camera_init_videobuf(struct videobuf_queue *q,
678 struct soc_camera_device *icd) 678 struct soc_camera_device *icd)
679{ 679{
680 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 680 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
681 struct mx2_camera_dev *pcdev = ici->priv; 681 struct mx2_camera_dev *pcdev = ici->priv;
682 682
683 videobuf_queue_dma_contig_init(q, &mx2_videobuf_ops, pcdev->dev, 683 videobuf_queue_dma_contig_init(q, &mx2_videobuf_ops, pcdev->dev,
@@ -718,7 +718,7 @@ static void mx27_camera_emma_buf_init(struct soc_camera_device *icd,
718 int bytesperline) 718 int bytesperline)
719{ 719{
720 struct soc_camera_host *ici = 720 struct soc_camera_host *ici =
721 to_soc_camera_host(icd->dev.parent); 721 to_soc_camera_host(icd->parent);
722 struct mx2_camera_dev *pcdev = ici->priv; 722 struct mx2_camera_dev *pcdev = ici->priv;
723 723
724 writel(pcdev->discard_buffer_dma, 724 writel(pcdev->discard_buffer_dma,
@@ -771,7 +771,7 @@ static int mx2_camera_set_bus_param(struct soc_camera_device *icd,
771 __u32 pixfmt) 771 __u32 pixfmt)
772{ 772{
773 struct soc_camera_host *ici = 773 struct soc_camera_host *ici =
774 to_soc_camera_host(icd->dev.parent); 774 to_soc_camera_host(icd->parent);
775 struct mx2_camera_dev *pcdev = ici->priv; 775 struct mx2_camera_dev *pcdev = ici->priv;
776 unsigned long camera_flags, common_flags; 776 unsigned long camera_flags, common_flags;
777 int ret = 0; 777 int ret = 0;
@@ -890,7 +890,7 @@ static int mx2_camera_set_crop(struct soc_camera_device *icd,
890 if (ret < 0) 890 if (ret < 0)
891 return ret; 891 return ret;
892 892
893 dev_dbg(icd->dev.parent, "Sensor cropped %dx%d\n", 893 dev_dbg(icd->parent, "Sensor cropped %dx%d\n",
894 mf.width, mf.height); 894 mf.width, mf.height);
895 895
896 icd->user_width = mf.width; 896 icd->user_width = mf.width;
@@ -910,7 +910,7 @@ static int mx2_camera_set_fmt(struct soc_camera_device *icd,
910 910
911 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 911 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
912 if (!xlate) { 912 if (!xlate) {
913 dev_warn(icd->dev.parent, "Format %x not found\n", 913 dev_warn(icd->parent, "Format %x not found\n",
914 pix->pixelformat); 914 pix->pixelformat);
915 return -EINVAL; 915 return -EINVAL;
916 } 916 }
@@ -950,7 +950,7 @@ static int mx2_camera_try_fmt(struct soc_camera_device *icd,
950 950
951 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); 951 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt);
952 if (pixfmt && !xlate) { 952 if (pixfmt && !xlate) {
953 dev_warn(icd->dev.parent, "Format %x not found\n", pixfmt); 953 dev_warn(icd->parent, "Format %x not found\n", pixfmt);
954 return -EINVAL; 954 return -EINVAL;
955 } 955 }
956 956
@@ -1000,7 +1000,7 @@ static int mx2_camera_try_fmt(struct soc_camera_device *icd,
1000 if (mf.field == V4L2_FIELD_ANY) 1000 if (mf.field == V4L2_FIELD_ANY)
1001 mf.field = V4L2_FIELD_NONE; 1001 mf.field = V4L2_FIELD_NONE;
1002 if (mf.field != V4L2_FIELD_NONE) { 1002 if (mf.field != V4L2_FIELD_NONE) {
1003 dev_err(icd->dev.parent, "Field type %d unsupported.\n", 1003 dev_err(icd->parent, "Field type %d unsupported.\n",
1004 mf.field); 1004 mf.field);
1005 return -EINVAL; 1005 return -EINVAL;
1006 } 1006 }
diff --git a/drivers/media/video/mx3_camera.c b/drivers/media/video/mx3_camera.c
index cdb7dad05c1e..c045b47803ad 100644
--- a/drivers/media/video/mx3_camera.c
+++ b/drivers/media/video/mx3_camera.c
@@ -194,7 +194,7 @@ static int mx3_videobuf_setup(struct vb2_queue *vq,
194 unsigned long sizes[], void *alloc_ctxs[]) 194 unsigned long sizes[], void *alloc_ctxs[])
195{ 195{
196 struct soc_camera_device *icd = soc_camera_from_vb2q(vq); 196 struct soc_camera_device *icd = soc_camera_from_vb2q(vq);
197 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 197 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
198 struct mx3_camera_dev *mx3_cam = ici->priv; 198 struct mx3_camera_dev *mx3_cam = ici->priv;
199 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width, 199 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width,
200 icd->current_fmt->host_fmt); 200 icd->current_fmt->host_fmt);
@@ -223,7 +223,7 @@ static int mx3_videobuf_setup(struct vb2_queue *vq,
223static int mx3_videobuf_prepare(struct vb2_buffer *vb) 223static int mx3_videobuf_prepare(struct vb2_buffer *vb)
224{ 224{
225 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 225 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
226 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 226 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
227 struct mx3_camera_dev *mx3_cam = ici->priv; 227 struct mx3_camera_dev *mx3_cam = ici->priv;
228 struct idmac_channel *ichan = mx3_cam->idmac_channel[0]; 228 struct idmac_channel *ichan = mx3_cam->idmac_channel[0];
229 struct scatterlist *sg; 229 struct scatterlist *sg;
@@ -241,7 +241,7 @@ static int mx3_videobuf_prepare(struct vb2_buffer *vb)
241 new_size = bytes_per_line * icd->user_height; 241 new_size = bytes_per_line * icd->user_height;
242 242
243 if (vb2_plane_size(vb, 0) < new_size) { 243 if (vb2_plane_size(vb, 0) < new_size) {
244 dev_err(icd->dev.parent, "Buffer too small (%lu < %zu)\n", 244 dev_err(icd->parent, "Buffer too small (%lu < %zu)\n",
245 vb2_plane_size(vb, 0), new_size); 245 vb2_plane_size(vb, 0), new_size);
246 return -ENOBUFS; 246 return -ENOBUFS;
247 } 247 }
@@ -283,7 +283,7 @@ static enum pixel_fmt fourcc_to_ipu_pix(__u32 fourcc)
283static void mx3_videobuf_queue(struct vb2_buffer *vb) 283static void mx3_videobuf_queue(struct vb2_buffer *vb)
284{ 284{
285 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 285 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
286 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 286 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
287 struct mx3_camera_dev *mx3_cam = ici->priv; 287 struct mx3_camera_dev *mx3_cam = ici->priv;
288 struct mx3_camera_buffer *buf = to_mx3_vb(vb); 288 struct mx3_camera_buffer *buf = to_mx3_vb(vb);
289 struct dma_async_tx_descriptor *txd = buf->txd; 289 struct dma_async_tx_descriptor *txd = buf->txd;
@@ -336,7 +336,7 @@ static void mx3_videobuf_queue(struct vb2_buffer *vb)
336 spin_unlock_irq(&mx3_cam->lock); 336 spin_unlock_irq(&mx3_cam->lock);
337 337
338 cookie = txd->tx_submit(txd); 338 cookie = txd->tx_submit(txd);
339 dev_dbg(icd->dev.parent, "Submitted cookie %d DMA 0x%08x\n", 339 dev_dbg(icd->parent, "Submitted cookie %d DMA 0x%08x\n",
340 cookie, sg_dma_address(&buf->sg)); 340 cookie, sg_dma_address(&buf->sg));
341 341
342 if (cookie >= 0) 342 if (cookie >= 0)
@@ -357,13 +357,13 @@ static void mx3_videobuf_queue(struct vb2_buffer *vb)
357static void mx3_videobuf_release(struct vb2_buffer *vb) 357static void mx3_videobuf_release(struct vb2_buffer *vb)
358{ 358{
359 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue); 359 struct soc_camera_device *icd = soc_camera_from_vb2q(vb->vb2_queue);
360 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 360 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
361 struct mx3_camera_dev *mx3_cam = ici->priv; 361 struct mx3_camera_dev *mx3_cam = ici->priv;
362 struct mx3_camera_buffer *buf = to_mx3_vb(vb); 362 struct mx3_camera_buffer *buf = to_mx3_vb(vb);
363 struct dma_async_tx_descriptor *txd = buf->txd; 363 struct dma_async_tx_descriptor *txd = buf->txd;
364 unsigned long flags; 364 unsigned long flags;
365 365
366 dev_dbg(icd->dev.parent, 366 dev_dbg(icd->parent,
367 "Release%s DMA 0x%08x, queue %sempty\n", 367 "Release%s DMA 0x%08x, queue %sempty\n",
368 mx3_cam->active == buf ? " active" : "", sg_dma_address(&buf->sg), 368 mx3_cam->active == buf ? " active" : "", sg_dma_address(&buf->sg),
369 list_empty(&buf->queue) ? "" : "not "); 369 list_empty(&buf->queue) ? "" : "not ");
@@ -402,7 +402,7 @@ static int mx3_videobuf_init(struct vb2_buffer *vb)
402static int mx3_stop_streaming(struct vb2_queue *q) 402static int mx3_stop_streaming(struct vb2_queue *q)
403{ 403{
404 struct soc_camera_device *icd = soc_camera_from_vb2q(q); 404 struct soc_camera_device *icd = soc_camera_from_vb2q(q);
405 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 405 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
406 struct mx3_camera_dev *mx3_cam = ici->priv; 406 struct mx3_camera_dev *mx3_cam = ici->priv;
407 struct idmac_channel *ichan = mx3_cam->idmac_channel[0]; 407 struct idmac_channel *ichan = mx3_cam->idmac_channel[0];
408 struct dma_chan *chan; 408 struct dma_chan *chan;
@@ -498,7 +498,7 @@ static void mx3_camera_activate(struct mx3_camera_dev *mx3_cam,
498 498
499 clk_enable(mx3_cam->clk); 499 clk_enable(mx3_cam->clk);
500 rate = clk_round_rate(mx3_cam->clk, mx3_cam->mclk); 500 rate = clk_round_rate(mx3_cam->clk, mx3_cam->mclk);
501 dev_dbg(icd->dev.parent, "Set SENS_CONF to %x, rate %ld\n", conf, rate); 501 dev_dbg(icd->parent, "Set SENS_CONF to %x, rate %ld\n", conf, rate);
502 if (rate) 502 if (rate)
503 clk_set_rate(mx3_cam->clk, rate); 503 clk_set_rate(mx3_cam->clk, rate);
504} 504}
@@ -506,7 +506,7 @@ static void mx3_camera_activate(struct mx3_camera_dev *mx3_cam,
506/* Called with .video_lock held */ 506/* Called with .video_lock held */
507static int mx3_camera_add_device(struct soc_camera_device *icd) 507static int mx3_camera_add_device(struct soc_camera_device *icd)
508{ 508{
509 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 509 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
510 struct mx3_camera_dev *mx3_cam = ici->priv; 510 struct mx3_camera_dev *mx3_cam = ici->priv;
511 511
512 if (mx3_cam->icd) 512 if (mx3_cam->icd)
@@ -516,7 +516,7 @@ static int mx3_camera_add_device(struct soc_camera_device *icd)
516 516
517 mx3_cam->icd = icd; 517 mx3_cam->icd = icd;
518 518
519 dev_info(icd->dev.parent, "MX3 Camera driver attached to camera %d\n", 519 dev_info(icd->parent, "MX3 Camera driver attached to camera %d\n",
520 icd->devnum); 520 icd->devnum);
521 521
522 return 0; 522 return 0;
@@ -525,7 +525,7 @@ static int mx3_camera_add_device(struct soc_camera_device *icd)
525/* Called with .video_lock held */ 525/* Called with .video_lock held */
526static void mx3_camera_remove_device(struct soc_camera_device *icd) 526static void mx3_camera_remove_device(struct soc_camera_device *icd)
527{ 527{
528 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 528 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
529 struct mx3_camera_dev *mx3_cam = ici->priv; 529 struct mx3_camera_dev *mx3_cam = ici->priv;
530 struct idmac_channel **ichan = &mx3_cam->idmac_channel[0]; 530 struct idmac_channel **ichan = &mx3_cam->idmac_channel[0];
531 531
@@ -540,7 +540,7 @@ static void mx3_camera_remove_device(struct soc_camera_device *icd)
540 540
541 mx3_cam->icd = NULL; 541 mx3_cam->icd = NULL;
542 542
543 dev_info(icd->dev.parent, "MX3 Camera driver detached from camera %d\n", 543 dev_info(icd->parent, "MX3 Camera driver detached from camera %d\n",
544 icd->devnum); 544 icd->devnum);
545} 545}
546 546
@@ -607,12 +607,12 @@ static int test_platform_param(struct mx3_camera_dev *mx3_cam,
607static int mx3_camera_try_bus_param(struct soc_camera_device *icd, 607static int mx3_camera_try_bus_param(struct soc_camera_device *icd,
608 const unsigned int depth) 608 const unsigned int depth)
609{ 609{
610 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 610 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
611 struct mx3_camera_dev *mx3_cam = ici->priv; 611 struct mx3_camera_dev *mx3_cam = ici->priv;
612 unsigned long bus_flags, camera_flags; 612 unsigned long bus_flags, camera_flags;
613 int ret = test_platform_param(mx3_cam, depth, &bus_flags); 613 int ret = test_platform_param(mx3_cam, depth, &bus_flags);
614 614
615 dev_dbg(icd->dev.parent, "request bus width %d bit: %d\n", depth, ret); 615 dev_dbg(icd->parent, "request bus width %d bit: %d\n", depth, ret);
616 616
617 if (ret < 0) 617 if (ret < 0)
618 return ret; 618 return ret;
@@ -621,7 +621,7 @@ static int mx3_camera_try_bus_param(struct soc_camera_device *icd,
621 621
622 ret = soc_camera_bus_param_compatible(camera_flags, bus_flags); 622 ret = soc_camera_bus_param_compatible(camera_flags, bus_flags);
623 if (ret < 0) 623 if (ret < 0)
624 dev_warn(icd->dev.parent, 624 dev_warn(icd->parent,
625 "Flags incompatible: camera %lx, host %lx\n", 625 "Flags incompatible: camera %lx, host %lx\n",
626 camera_flags, bus_flags); 626 camera_flags, bus_flags);
627 627
@@ -675,7 +675,7 @@ static int mx3_camera_get_formats(struct soc_camera_device *icd, unsigned int id
675 struct soc_camera_format_xlate *xlate) 675 struct soc_camera_format_xlate *xlate)
676{ 676{
677 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 677 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
678 struct device *dev = icd->dev.parent; 678 struct device *dev = icd->parent;
679 int formats = 0, ret; 679 int formats = 0, ret;
680 enum v4l2_mbus_pixelcode code; 680 enum v4l2_mbus_pixelcode code;
681 const struct soc_mbus_pixelfmt *fmt; 681 const struct soc_mbus_pixelfmt *fmt;
@@ -687,7 +687,7 @@ static int mx3_camera_get_formats(struct soc_camera_device *icd, unsigned int id
687 687
688 fmt = soc_mbus_get_fmtdesc(code); 688 fmt = soc_mbus_get_fmtdesc(code);
689 if (!fmt) { 689 if (!fmt) {
690 dev_warn(icd->dev.parent, 690 dev_warn(icd->parent,
691 "Unsupported format code #%u: %d\n", idx, code); 691 "Unsupported format code #%u: %d\n", idx, code);
692 return 0; 692 return 0;
693 } 693 }
@@ -815,7 +815,7 @@ static int mx3_camera_set_crop(struct soc_camera_device *icd,
815 struct v4l2_crop *a) 815 struct v4l2_crop *a)
816{ 816{
817 struct v4l2_rect *rect = &a->c; 817 struct v4l2_rect *rect = &a->c;
818 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 818 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
819 struct mx3_camera_dev *mx3_cam = ici->priv; 819 struct mx3_camera_dev *mx3_cam = ici->priv;
820 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 820 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
821 struct v4l2_mbus_framefmt mf; 821 struct v4l2_mbus_framefmt mf;
@@ -848,7 +848,7 @@ static int mx3_camera_set_crop(struct soc_camera_device *icd,
848 configure_geometry(mx3_cam, mf.width, mf.height, 848 configure_geometry(mx3_cam, mf.width, mf.height,
849 icd->current_fmt->host_fmt); 849 icd->current_fmt->host_fmt);
850 850
851 dev_dbg(icd->dev.parent, "Sensor cropped %dx%d\n", 851 dev_dbg(icd->parent, "Sensor cropped %dx%d\n",
852 mf.width, mf.height); 852 mf.width, mf.height);
853 853
854 icd->user_width = mf.width; 854 icd->user_width = mf.width;
@@ -860,7 +860,7 @@ static int mx3_camera_set_crop(struct soc_camera_device *icd,
860static int mx3_camera_set_fmt(struct soc_camera_device *icd, 860static int mx3_camera_set_fmt(struct soc_camera_device *icd,
861 struct v4l2_format *f) 861 struct v4l2_format *f)
862{ 862{
863 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 863 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
864 struct mx3_camera_dev *mx3_cam = ici->priv; 864 struct mx3_camera_dev *mx3_cam = ici->priv;
865 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 865 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
866 const struct soc_camera_format_xlate *xlate; 866 const struct soc_camera_format_xlate *xlate;
@@ -870,13 +870,13 @@ static int mx3_camera_set_fmt(struct soc_camera_device *icd,
870 870
871 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 871 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
872 if (!xlate) { 872 if (!xlate) {
873 dev_warn(icd->dev.parent, "Format %x not found\n", 873 dev_warn(icd->parent, "Format %x not found\n",
874 pix->pixelformat); 874 pix->pixelformat);
875 return -EINVAL; 875 return -EINVAL;
876 } 876 }
877 877
878 stride_align(&pix->width); 878 stride_align(&pix->width);
879 dev_dbg(icd->dev.parent, "Set format %dx%d\n", pix->width, pix->height); 879 dev_dbg(icd->parent, "Set format %dx%d\n", pix->width, pix->height);
880 880
881 /* 881 /*
882 * Might have to perform a complete interface initialisation like in 882 * Might have to perform a complete interface initialisation like in
@@ -912,7 +912,7 @@ static int mx3_camera_set_fmt(struct soc_camera_device *icd,
912 pix->colorspace = mf.colorspace; 912 pix->colorspace = mf.colorspace;
913 icd->current_fmt = xlate; 913 icd->current_fmt = xlate;
914 914
915 dev_dbg(icd->dev.parent, "Sensor set %dx%d\n", pix->width, pix->height); 915 dev_dbg(icd->parent, "Sensor set %dx%d\n", pix->width, pix->height);
916 916
917 return ret; 917 return ret;
918} 918}
@@ -929,7 +929,7 @@ static int mx3_camera_try_fmt(struct soc_camera_device *icd,
929 929
930 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); 930 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt);
931 if (pixfmt && !xlate) { 931 if (pixfmt && !xlate) {
932 dev_warn(icd->dev.parent, "Format %x not found\n", pixfmt); 932 dev_warn(icd->parent, "Format %x not found\n", pixfmt);
933 return -EINVAL; 933 return -EINVAL;
934 } 934 }
935 935
@@ -961,7 +961,7 @@ static int mx3_camera_try_fmt(struct soc_camera_device *icd,
961 case V4L2_FIELD_NONE: 961 case V4L2_FIELD_NONE:
962 break; 962 break;
963 default: 963 default:
964 dev_err(icd->dev.parent, "Field type %d unsupported.\n", 964 dev_err(icd->parent, "Field type %d unsupported.\n",
965 mf.field); 965 mf.field);
966 ret = -EINVAL; 966 ret = -EINVAL;
967 } 967 }
@@ -994,7 +994,7 @@ static int mx3_camera_querycap(struct soc_camera_host *ici,
994 994
995static int mx3_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt) 995static int mx3_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt)
996{ 996{
997 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 997 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
998 struct mx3_camera_dev *mx3_cam = ici->priv; 998 struct mx3_camera_dev *mx3_cam = ici->priv;
999 unsigned long bus_flags, camera_flags, common_flags; 999 unsigned long bus_flags, camera_flags, common_flags;
1000 u32 dw, sens_conf; 1000 u32 dw, sens_conf;
@@ -1002,7 +1002,7 @@ static int mx3_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt)
1002 int buswidth; 1002 int buswidth;
1003 int ret; 1003 int ret;
1004 const struct soc_camera_format_xlate *xlate; 1004 const struct soc_camera_format_xlate *xlate;
1005 struct device *dev = icd->dev.parent; 1005 struct device *dev = icd->parent;
1006 1006
1007 fmt = soc_mbus_get_fmtdesc(icd->current_fmt->code); 1007 fmt = soc_mbus_get_fmtdesc(icd->current_fmt->code);
1008 if (!fmt) 1008 if (!fmt)
diff --git a/drivers/media/video/omap1_camera.c b/drivers/media/video/omap1_camera.c
index 9bfe4c121a5c..8a947e603aca 100644
--- a/drivers/media/video/omap1_camera.c
+++ b/drivers/media/video/omap1_camera.c
@@ -207,7 +207,7 @@ static int omap1_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
207 struct soc_camera_device *icd = vq->priv_data; 207 struct soc_camera_device *icd = vq->priv_data;
208 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width, 208 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width,
209 icd->current_fmt->host_fmt); 209 icd->current_fmt->host_fmt);
210 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 210 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
211 struct omap1_cam_dev *pcdev = ici->priv; 211 struct omap1_cam_dev *pcdev = ici->priv;
212 212
213 if (bytes_per_line < 0) 213 if (bytes_per_line < 0)
@@ -221,7 +221,7 @@ static int omap1_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
221 if (*size * *count > MAX_VIDEO_MEM * 1024 * 1024) 221 if (*size * *count > MAX_VIDEO_MEM * 1024 * 1024)
222 *count = (MAX_VIDEO_MEM * 1024 * 1024) / *size; 222 *count = (MAX_VIDEO_MEM * 1024 * 1024) / *size;
223 223
224 dev_dbg(icd->dev.parent, 224 dev_dbg(icd->parent,
225 "%s: count=%d, size=%d\n", __func__, *count, *size); 225 "%s: count=%d, size=%d\n", __func__, *count, *size);
226 226
227 return 0; 227 return 0;
@@ -240,7 +240,7 @@ static void free_buffer(struct videobuf_queue *vq, struct omap1_cam_buf *buf,
240 videobuf_dma_contig_free(vq, vb); 240 videobuf_dma_contig_free(vq, vb);
241 } else { 241 } else {
242 struct soc_camera_device *icd = vq->priv_data; 242 struct soc_camera_device *icd = vq->priv_data;
243 struct device *dev = icd->dev.parent; 243 struct device *dev = icd->parent;
244 struct videobuf_dmabuf *dma = videobuf_to_dma(vb); 244 struct videobuf_dmabuf *dma = videobuf_to_dma(vb);
245 245
246 videobuf_dma_unmap(dev, dma); 246 videobuf_dma_unmap(dev, dma);
@@ -257,7 +257,7 @@ static int omap1_videobuf_prepare(struct videobuf_queue *vq,
257 struct omap1_cam_buf *buf = container_of(vb, struct omap1_cam_buf, vb); 257 struct omap1_cam_buf *buf = container_of(vb, struct omap1_cam_buf, vb);
258 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width, 258 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width,
259 icd->current_fmt->host_fmt); 259 icd->current_fmt->host_fmt);
260 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 260 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
261 struct omap1_cam_dev *pcdev = ici->priv; 261 struct omap1_cam_dev *pcdev = ici->priv;
262 int ret; 262 int ret;
263 263
@@ -489,7 +489,7 @@ static void omap1_videobuf_queue(struct videobuf_queue *vq,
489 struct videobuf_buffer *vb) 489 struct videobuf_buffer *vb)
490{ 490{
491 struct soc_camera_device *icd = vq->priv_data; 491 struct soc_camera_device *icd = vq->priv_data;
492 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 492 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
493 struct omap1_cam_dev *pcdev = ici->priv; 493 struct omap1_cam_dev *pcdev = ici->priv;
494 struct omap1_cam_buf *buf; 494 struct omap1_cam_buf *buf;
495 u32 mode; 495 u32 mode;
@@ -518,7 +518,7 @@ static void omap1_videobuf_queue(struct videobuf_queue *vq,
518 pcdev->active = buf; 518 pcdev->active = buf;
519 pcdev->ready = NULL; 519 pcdev->ready = NULL;
520 520
521 dev_dbg(icd->dev.parent, 521 dev_dbg(icd->parent,
522 "%s: capture not active, setup FIFO, start DMA\n", __func__); 522 "%s: capture not active, setup FIFO, start DMA\n", __func__);
523 mode = CAM_READ_CACHE(pcdev, MODE) & ~THRESHOLD_MASK; 523 mode = CAM_READ_CACHE(pcdev, MODE) & ~THRESHOLD_MASK;
524 mode |= THRESHOLD_LEVEL(pcdev->vb_mode) << THRESHOLD_SHIFT; 524 mode |= THRESHOLD_LEVEL(pcdev->vb_mode) << THRESHOLD_SHIFT;
@@ -542,8 +542,8 @@ static void omap1_videobuf_release(struct videobuf_queue *vq,
542 struct omap1_cam_buf *buf = 542 struct omap1_cam_buf *buf =
543 container_of(vb, struct omap1_cam_buf, vb); 543 container_of(vb, struct omap1_cam_buf, vb);
544 struct soc_camera_device *icd = vq->priv_data; 544 struct soc_camera_device *icd = vq->priv_data;
545 struct device *dev = icd->dev.parent; 545 struct device *dev = icd->parent;
546 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 546 struct soc_camera_host *ici = to_soc_camera_host(dev);
547 struct omap1_cam_dev *pcdev = ici->priv; 547 struct omap1_cam_dev *pcdev = ici->priv;
548 548
549 switch (vb->state) { 549 switch (vb->state) {
@@ -572,7 +572,7 @@ static void videobuf_done(struct omap1_cam_dev *pcdev,
572{ 572{
573 struct omap1_cam_buf *buf = pcdev->active; 573 struct omap1_cam_buf *buf = pcdev->active;
574 struct videobuf_buffer *vb; 574 struct videobuf_buffer *vb;
575 struct device *dev = pcdev->icd->dev.parent; 575 struct device *dev = pcdev->icd->parent;
576 576
577 if (WARN_ON(!buf)) { 577 if (WARN_ON(!buf)) {
578 suspend_capture(pcdev); 578 suspend_capture(pcdev);
@@ -798,7 +798,7 @@ out:
798static irqreturn_t cam_isr(int irq, void *data) 798static irqreturn_t cam_isr(int irq, void *data)
799{ 799{
800 struct omap1_cam_dev *pcdev = data; 800 struct omap1_cam_dev *pcdev = data;
801 struct device *dev = pcdev->icd->dev.parent; 801 struct device *dev = pcdev->icd->parent;
802 struct omap1_cam_buf *buf = pcdev->active; 802 struct omap1_cam_buf *buf = pcdev->active;
803 u32 it_status; 803 u32 it_status;
804 unsigned long flags; 804 unsigned long flags;
@@ -908,7 +908,7 @@ static void sensor_reset(struct omap1_cam_dev *pcdev, bool reset)
908 */ 908 */
909static int omap1_cam_add_device(struct soc_camera_device *icd) 909static int omap1_cam_add_device(struct soc_camera_device *icd)
910{ 910{
911 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 911 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
912 struct omap1_cam_dev *pcdev = ici->priv; 912 struct omap1_cam_dev *pcdev = ici->priv;
913 u32 ctrlclock; 913 u32 ctrlclock;
914 914
@@ -951,14 +951,14 @@ static int omap1_cam_add_device(struct soc_camera_device *icd)
951 951
952 pcdev->icd = icd; 952 pcdev->icd = icd;
953 953
954 dev_dbg(icd->dev.parent, "OMAP1 Camera driver attached to camera %d\n", 954 dev_dbg(icd->parent, "OMAP1 Camera driver attached to camera %d\n",
955 icd->devnum); 955 icd->devnum);
956 return 0; 956 return 0;
957} 957}
958 958
959static void omap1_cam_remove_device(struct soc_camera_device *icd) 959static void omap1_cam_remove_device(struct soc_camera_device *icd)
960{ 960{
961 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 961 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
962 struct omap1_cam_dev *pcdev = ici->priv; 962 struct omap1_cam_dev *pcdev = ici->priv;
963 u32 ctrlclock; 963 u32 ctrlclock;
964 964
@@ -984,7 +984,7 @@ static void omap1_cam_remove_device(struct soc_camera_device *icd)
984 984
985 pcdev->icd = NULL; 985 pcdev->icd = NULL;
986 986
987 dev_dbg(icd->dev.parent, 987 dev_dbg(icd->parent,
988 "OMAP1 Camera driver detached from camera %d\n", icd->devnum); 988 "OMAP1 Camera driver detached from camera %d\n", icd->devnum);
989} 989}
990 990
@@ -1069,7 +1069,7 @@ static int omap1_cam_get_formats(struct soc_camera_device *icd,
1069 unsigned int idx, struct soc_camera_format_xlate *xlate) 1069 unsigned int idx, struct soc_camera_format_xlate *xlate)
1070{ 1070{
1071 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1071 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1072 struct device *dev = icd->dev.parent; 1072 struct device *dev = icd->parent;
1073 int formats = 0, ret; 1073 int formats = 0, ret;
1074 enum v4l2_mbus_pixelcode code; 1074 enum v4l2_mbus_pixelcode code;
1075 const struct soc_mbus_pixelfmt *fmt; 1075 const struct soc_mbus_pixelfmt *fmt;
@@ -1221,9 +1221,9 @@ static int omap1_cam_set_crop(struct soc_camera_device *icd,
1221 struct v4l2_rect *rect = &crop->c; 1221 struct v4l2_rect *rect = &crop->c;
1222 const struct soc_camera_format_xlate *xlate = icd->current_fmt; 1222 const struct soc_camera_format_xlate *xlate = icd->current_fmt;
1223 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1223 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1224 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1224 struct device *dev = icd->parent;
1225 struct soc_camera_host *ici = to_soc_camera_host(dev);
1225 struct omap1_cam_dev *pcdev = ici->priv; 1226 struct omap1_cam_dev *pcdev = ici->priv;
1226 struct device *dev = icd->dev.parent;
1227 struct v4l2_mbus_framefmt mf; 1227 struct v4l2_mbus_framefmt mf;
1228 int ret; 1228 int ret;
1229 1229
@@ -1269,8 +1269,8 @@ static int omap1_cam_set_fmt(struct soc_camera_device *icd,
1269{ 1269{
1270 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1270 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1271 const struct soc_camera_format_xlate *xlate; 1271 const struct soc_camera_format_xlate *xlate;
1272 struct device *dev = icd->dev.parent; 1272 struct device *dev = icd->parent;
1273 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1273 struct soc_camera_host *ici = to_soc_camera_host(dev);
1274 struct omap1_cam_dev *pcdev = ici->priv; 1274 struct omap1_cam_dev *pcdev = ici->priv;
1275 struct v4l2_pix_format *pix = &f->fmt.pix; 1275 struct v4l2_pix_format *pix = &f->fmt.pix;
1276 struct v4l2_mbus_framefmt mf; 1276 struct v4l2_mbus_framefmt mf;
@@ -1325,7 +1325,7 @@ static int omap1_cam_try_fmt(struct soc_camera_device *icd,
1325 1325
1326 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat); 1326 xlate = soc_camera_xlate_by_fourcc(icd, pix->pixelformat);
1327 if (!xlate) { 1327 if (!xlate) {
1328 dev_warn(icd->dev.parent, "Format %#x not found\n", 1328 dev_warn(icd->parent, "Format %#x not found\n",
1329 pix->pixelformat); 1329 pix->pixelformat);
1330 return -EINVAL; 1330 return -EINVAL;
1331 } 1331 }
@@ -1361,7 +1361,7 @@ static int omap1_cam_mmap_mapper(struct videobuf_queue *q,
1361 struct vm_area_struct *vma) 1361 struct vm_area_struct *vma)
1362{ 1362{
1363 struct soc_camera_device *icd = q->priv_data; 1363 struct soc_camera_device *icd = q->priv_data;
1364 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1364 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1365 struct omap1_cam_dev *pcdev = ici->priv; 1365 struct omap1_cam_dev *pcdev = ici->priv;
1366 int ret; 1366 int ret;
1367 1367
@@ -1376,17 +1376,17 @@ static int omap1_cam_mmap_mapper(struct videobuf_queue *q,
1376static void omap1_cam_init_videobuf(struct videobuf_queue *q, 1376static void omap1_cam_init_videobuf(struct videobuf_queue *q,
1377 struct soc_camera_device *icd) 1377 struct soc_camera_device *icd)
1378{ 1378{
1379 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1379 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1380 struct omap1_cam_dev *pcdev = ici->priv; 1380 struct omap1_cam_dev *pcdev = ici->priv;
1381 1381
1382 if (!sg_mode) 1382 if (!sg_mode)
1383 videobuf_queue_dma_contig_init(q, &omap1_videobuf_ops, 1383 videobuf_queue_dma_contig_init(q, &omap1_videobuf_ops,
1384 icd->dev.parent, &pcdev->lock, 1384 icd->parent, &pcdev->lock,
1385 V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_NONE, 1385 V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_NONE,
1386 sizeof(struct omap1_cam_buf), icd, &icd->video_lock); 1386 sizeof(struct omap1_cam_buf), icd, &icd->video_lock);
1387 else 1387 else
1388 videobuf_queue_sg_init(q, &omap1_videobuf_ops, 1388 videobuf_queue_sg_init(q, &omap1_videobuf_ops,
1389 icd->dev.parent, &pcdev->lock, 1389 icd->parent, &pcdev->lock,
1390 V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_NONE, 1390 V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_NONE,
1391 sizeof(struct omap1_cam_buf), icd, &icd->video_lock); 1391 sizeof(struct omap1_cam_buf), icd, &icd->video_lock);
1392 1392
@@ -1438,9 +1438,9 @@ static int omap1_cam_querycap(struct soc_camera_host *ici,
1438static int omap1_cam_set_bus_param(struct soc_camera_device *icd, 1438static int omap1_cam_set_bus_param(struct soc_camera_device *icd,
1439 __u32 pixfmt) 1439 __u32 pixfmt)
1440{ 1440{
1441 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1441 struct device *dev = icd->parent;
1442 struct soc_camera_host *ici = to_soc_camera_host(dev);
1442 struct omap1_cam_dev *pcdev = ici->priv; 1443 struct omap1_cam_dev *pcdev = ici->priv;
1443 struct device *dev = icd->dev.parent;
1444 const struct soc_camera_format_xlate *xlate; 1444 const struct soc_camera_format_xlate *xlate;
1445 const struct soc_mbus_pixelfmt *fmt; 1445 const struct soc_mbus_pixelfmt *fmt;
1446 unsigned long camera_flags, common_flags; 1446 unsigned long camera_flags, common_flags;
diff --git a/drivers/media/video/ov2640.c b/drivers/media/video/ov2640.c
index 0cea0cf36679..9ce2fa037b94 100644
--- a/drivers/media/video/ov2640.c
+++ b/drivers/media/video/ov2640.c
@@ -1031,16 +1031,9 @@ static int ov2640_video_probe(struct soc_camera_device *icd,
1031 const char *devname; 1031 const char *devname;
1032 int ret; 1032 int ret;
1033 1033
1034 /* 1034 /* We must have a parent by now. And it cannot be a wrong one. */
1035 * we must have a parent by now. And it cannot be a wrong one. 1035 BUG_ON(!icd->parent ||
1036 * So this entire test is completely redundant. 1036 to_soc_camera_host(icd->parent)->nr != icd->iface);
1037 */
1038 if (!icd->dev.parent ||
1039 to_soc_camera_host(icd->dev.parent)->nr != icd->iface) {
1040 dev_err(&client->dev, "Parent missing or invalid!\n");
1041 ret = -ENODEV;
1042 goto err;
1043 }
1044 1037
1045 /* 1038 /*
1046 * check and show product ID and manufacturer ID 1039 * check and show product ID and manufacturer ID
diff --git a/drivers/media/video/ov772x.c b/drivers/media/video/ov772x.c
index 48895ef863ff..397870f076c1 100644
--- a/drivers/media/video/ov772x.c
+++ b/drivers/media/video/ov772x.c
@@ -1032,13 +1032,9 @@ static int ov772x_video_probe(struct soc_camera_device *icd,
1032 u8 pid, ver; 1032 u8 pid, ver;
1033 const char *devname; 1033 const char *devname;
1034 1034
1035 /* 1035 /* We must have a parent by now. And it cannot be a wrong one. */
1036 * We must have a parent by now. And it cannot be a wrong one. 1036 BUG_ON(!icd->parent ||
1037 * So this entire test is completely redundant. 1037 to_soc_camera_host(icd->parent)->nr != icd->iface);
1038 */
1039 if (!icd->dev.parent ||
1040 to_soc_camera_host(icd->dev.parent)->nr != icd->iface)
1041 return -ENODEV;
1042 1038
1043 /* 1039 /*
1044 * check and show product ID and manufacturer ID 1040 * check and show product ID and manufacturer ID
diff --git a/drivers/media/video/ov9640.c b/drivers/media/video/ov9640.c
index 5173ac449dd8..3681a6ff0815 100644
--- a/drivers/media/video/ov9640.c
+++ b/drivers/media/video/ov9640.c
@@ -657,16 +657,9 @@ static int ov9640_video_probe(struct soc_camera_device *icd,
657 const char *devname; 657 const char *devname;
658 int ret = 0; 658 int ret = 0;
659 659
660 /* 660 /* We must have a parent by now. And it cannot be a wrong one. */
661 * We must have a parent by now. And it cannot be a wrong one. 661 BUG_ON(!icd->parent ||
662 * So this entire test is completely redundant. 662 to_soc_camera_host(icd->parent)->nr != icd->iface);
663 */
664 if (!icd->dev.parent ||
665 to_soc_camera_host(icd->dev.parent)->nr != icd->iface) {
666 dev_err(&client->dev, "Parent missing or invalid!\n");
667 ret = -ENODEV;
668 goto err;
669 }
670 663
671 /* 664 /*
672 * check and show product ID and manufacturer ID 665 * check and show product ID and manufacturer ID
diff --git a/drivers/media/video/ov9740.c b/drivers/media/video/ov9740.c
index ede48f2ed70c..edd1ffcca30b 100644
--- a/drivers/media/video/ov9740.c
+++ b/drivers/media/video/ov9740.c
@@ -898,16 +898,9 @@ static int ov9740_video_probe(struct soc_camera_device *icd,
898 u8 modelhi, modello; 898 u8 modelhi, modello;
899 int ret; 899 int ret;
900 900
901 /* 901 /* We must have a parent by now. And it cannot be a wrong one. */
902 * We must have a parent by now. And it cannot be a wrong one. 902 BUG_ON(!icd->parent ||
903 * So this entire test is completely redundant. 903 to_soc_camera_host(icd->parent)->nr != icd->iface);
904 */
905 if (!icd->dev.parent ||
906 to_soc_camera_host(icd->dev.parent)->nr != icd->iface) {
907 dev_err(&client->dev, "Parent missing or invalid!\n");
908 ret = -ENODEV;
909 goto err;
910 }
911 904
912 /* 905 /*
913 * check and show product ID and manufacturer ID 906 * check and show product ID and manufacturer ID
diff --git a/drivers/media/video/pxa_camera.c b/drivers/media/video/pxa_camera.c
index 020de529b955..d07df22a5ec6 100644
--- a/drivers/media/video/pxa_camera.c
+++ b/drivers/media/video/pxa_camera.c
@@ -246,7 +246,7 @@ static int pxa_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
246 if (bytes_per_line < 0) 246 if (bytes_per_line < 0)
247 return bytes_per_line; 247 return bytes_per_line;
248 248
249 dev_dbg(icd->dev.parent, "count=%d, size=%d\n", *count, *size); 249 dev_dbg(icd->parent, "count=%d, size=%d\n", *count, *size);
250 250
251 *size = bytes_per_line * icd->user_height; 251 *size = bytes_per_line * icd->user_height;
252 252
@@ -261,13 +261,13 @@ static int pxa_videobuf_setup(struct videobuf_queue *vq, unsigned int *count,
261static void free_buffer(struct videobuf_queue *vq, struct pxa_buffer *buf) 261static void free_buffer(struct videobuf_queue *vq, struct pxa_buffer *buf)
262{ 262{
263 struct soc_camera_device *icd = vq->priv_data; 263 struct soc_camera_device *icd = vq->priv_data;
264 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 264 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
265 struct videobuf_dmabuf *dma = videobuf_to_dma(&buf->vb); 265 struct videobuf_dmabuf *dma = videobuf_to_dma(&buf->vb);
266 int i; 266 int i;
267 267
268 BUG_ON(in_interrupt()); 268 BUG_ON(in_interrupt());
269 269
270 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 270 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
271 &buf->vb, buf->vb.baddr, buf->vb.bsize); 271 &buf->vb, buf->vb.baddr, buf->vb.bsize);
272 272
273 /* 273 /*
@@ -428,7 +428,7 @@ static int pxa_videobuf_prepare(struct videobuf_queue *vq,
428 struct videobuf_buffer *vb, enum v4l2_field field) 428 struct videobuf_buffer *vb, enum v4l2_field field)
429{ 429{
430 struct soc_camera_device *icd = vq->priv_data; 430 struct soc_camera_device *icd = vq->priv_data;
431 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 431 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
432 struct pxa_camera_dev *pcdev = ici->priv; 432 struct pxa_camera_dev *pcdev = ici->priv;
433 struct device *dev = pcdev->soc_host.v4l2_dev.dev; 433 struct device *dev = pcdev->soc_host.v4l2_dev.dev;
434 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb); 434 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb);
@@ -635,11 +635,11 @@ static void pxa_videobuf_queue(struct videobuf_queue *vq,
635 struct videobuf_buffer *vb) 635 struct videobuf_buffer *vb)
636{ 636{
637 struct soc_camera_device *icd = vq->priv_data; 637 struct soc_camera_device *icd = vq->priv_data;
638 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 638 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
639 struct pxa_camera_dev *pcdev = ici->priv; 639 struct pxa_camera_dev *pcdev = ici->priv;
640 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb); 640 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb);
641 641
642 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%08lx %d active=%p\n", 642 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%08lx %d active=%p\n",
643 __func__, vb, vb->baddr, vb->bsize, pcdev->active); 643 __func__, vb, vb->baddr, vb->bsize, pcdev->active);
644 644
645 list_add_tail(&vb->queue, &pcdev->capture); 645 list_add_tail(&vb->queue, &pcdev->capture);
@@ -657,7 +657,7 @@ static void pxa_videobuf_release(struct videobuf_queue *vq,
657 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb); 657 struct pxa_buffer *buf = container_of(vb, struct pxa_buffer, vb);
658#ifdef DEBUG 658#ifdef DEBUG
659 struct soc_camera_device *icd = vq->priv_data; 659 struct soc_camera_device *icd = vq->priv_data;
660 struct device *dev = icd->dev.parent; 660 struct device *dev = icd->parent;
661 661
662 dev_dbg(dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__, 662 dev_dbg(dev, "%s (vb=0x%p) 0x%08lx %d\n", __func__,
663 vb, vb->baddr, vb->bsize); 663 vb, vb->baddr, vb->bsize);
@@ -842,7 +842,7 @@ static struct videobuf_queue_ops pxa_videobuf_ops = {
842static void pxa_camera_init_videobuf(struct videobuf_queue *q, 842static void pxa_camera_init_videobuf(struct videobuf_queue *q,
843 struct soc_camera_device *icd) 843 struct soc_camera_device *icd)
844{ 844{
845 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 845 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
846 struct pxa_camera_dev *pcdev = ici->priv; 846 struct pxa_camera_dev *pcdev = ici->priv;
847 847
848 /* 848 /*
@@ -971,7 +971,7 @@ static irqreturn_t pxa_camera_irq(int irq, void *data)
971 */ 971 */
972static int pxa_camera_add_device(struct soc_camera_device *icd) 972static int pxa_camera_add_device(struct soc_camera_device *icd)
973{ 973{
974 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 974 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
975 struct pxa_camera_dev *pcdev = ici->priv; 975 struct pxa_camera_dev *pcdev = ici->priv;
976 976
977 if (pcdev->icd) 977 if (pcdev->icd)
@@ -981,7 +981,7 @@ static int pxa_camera_add_device(struct soc_camera_device *icd)
981 981
982 pcdev->icd = icd; 982 pcdev->icd = icd;
983 983
984 dev_info(icd->dev.parent, "PXA Camera driver attached to camera %d\n", 984 dev_info(icd->parent, "PXA Camera driver attached to camera %d\n",
985 icd->devnum); 985 icd->devnum);
986 986
987 return 0; 987 return 0;
@@ -990,12 +990,12 @@ static int pxa_camera_add_device(struct soc_camera_device *icd)
990/* Called with .video_lock held */ 990/* Called with .video_lock held */
991static void pxa_camera_remove_device(struct soc_camera_device *icd) 991static void pxa_camera_remove_device(struct soc_camera_device *icd)
992{ 992{
993 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 993 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
994 struct pxa_camera_dev *pcdev = ici->priv; 994 struct pxa_camera_dev *pcdev = ici->priv;
995 995
996 BUG_ON(icd != pcdev->icd); 996 BUG_ON(icd != pcdev->icd);
997 997
998 dev_info(icd->dev.parent, "PXA Camera driver detached from camera %d\n", 998 dev_info(icd->parent, "PXA Camera driver detached from camera %d\n",
999 icd->devnum); 999 icd->devnum);
1000 1000
1001 /* disable capture, disable interrupts */ 1001 /* disable capture, disable interrupts */
@@ -1056,7 +1056,7 @@ static int test_platform_param(struct pxa_camera_dev *pcdev,
1056static void pxa_camera_setup_cicr(struct soc_camera_device *icd, 1056static void pxa_camera_setup_cicr(struct soc_camera_device *icd,
1057 unsigned long flags, __u32 pixfmt) 1057 unsigned long flags, __u32 pixfmt)
1058{ 1058{
1059 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1059 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1060 struct pxa_camera_dev *pcdev = ici->priv; 1060 struct pxa_camera_dev *pcdev = ici->priv;
1061 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1061 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1062 unsigned long dw, bpp; 1062 unsigned long dw, bpp;
@@ -1151,7 +1151,7 @@ static void pxa_camera_setup_cicr(struct soc_camera_device *icd,
1151 1151
1152static int pxa_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt) 1152static int pxa_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt)
1153{ 1153{
1154 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1154 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1155 struct pxa_camera_dev *pcdev = ici->priv; 1155 struct pxa_camera_dev *pcdev = ici->priv;
1156 unsigned long bus_flags, camera_flags, common_flags; 1156 unsigned long bus_flags, camera_flags, common_flags;
1157 int ret; 1157 int ret;
@@ -1209,7 +1209,7 @@ static int pxa_camera_set_bus_param(struct soc_camera_device *icd, __u32 pixfmt)
1209static int pxa_camera_try_bus_param(struct soc_camera_device *icd, 1209static int pxa_camera_try_bus_param(struct soc_camera_device *icd,
1210 unsigned char buswidth) 1210 unsigned char buswidth)
1211{ 1211{
1212 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1212 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1213 struct pxa_camera_dev *pcdev = ici->priv; 1213 struct pxa_camera_dev *pcdev = ici->priv;
1214 unsigned long bus_flags, camera_flags; 1214 unsigned long bus_flags, camera_flags;
1215 int ret = test_platform_param(pcdev, buswidth, &bus_flags); 1215 int ret = test_platform_param(pcdev, buswidth, &bus_flags);
@@ -1246,7 +1246,7 @@ static int pxa_camera_get_formats(struct soc_camera_device *icd, unsigned int id
1246 struct soc_camera_format_xlate *xlate) 1246 struct soc_camera_format_xlate *xlate)
1247{ 1247{
1248 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1248 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1249 struct device *dev = icd->dev.parent; 1249 struct device *dev = icd->parent;
1250 int formats = 0, ret; 1250 int formats = 0, ret;
1251 struct pxa_cam *cam; 1251 struct pxa_cam *cam;
1252 enum v4l2_mbus_pixelcode code; 1252 enum v4l2_mbus_pixelcode code;
@@ -1334,9 +1334,9 @@ static int pxa_camera_set_crop(struct soc_camera_device *icd,
1334 struct v4l2_crop *a) 1334 struct v4l2_crop *a)
1335{ 1335{
1336 struct v4l2_rect *rect = &a->c; 1336 struct v4l2_rect *rect = &a->c;
1337 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1337 struct device *dev = icd->parent;
1338 struct soc_camera_host *ici = to_soc_camera_host(dev);
1338 struct pxa_camera_dev *pcdev = ici->priv; 1339 struct pxa_camera_dev *pcdev = ici->priv;
1339 struct device *dev = icd->dev.parent;
1340 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1340 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1341 struct soc_camera_sense sense = { 1341 struct soc_camera_sense sense = {
1342 .master_clock = pcdev->mclk, 1342 .master_clock = pcdev->mclk,
@@ -1378,7 +1378,7 @@ static int pxa_camera_set_crop(struct soc_camera_device *icd,
1378 return ret; 1378 return ret;
1379 1379
1380 if (pxa_camera_check_frame(mf.width, mf.height)) { 1380 if (pxa_camera_check_frame(mf.width, mf.height)) {
1381 dev_warn(icd->dev.parent, 1381 dev_warn(icd->parent,
1382 "Inconsistent state. Use S_FMT to repair\n"); 1382 "Inconsistent state. Use S_FMT to repair\n");
1383 return -EINVAL; 1383 return -EINVAL;
1384 } 1384 }
@@ -1405,9 +1405,9 @@ static int pxa_camera_set_crop(struct soc_camera_device *icd,
1405static int pxa_camera_set_fmt(struct soc_camera_device *icd, 1405static int pxa_camera_set_fmt(struct soc_camera_device *icd,
1406 struct v4l2_format *f) 1406 struct v4l2_format *f)
1407{ 1407{
1408 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1408 struct device *dev = icd->parent;
1409 struct soc_camera_host *ici = to_soc_camera_host(dev);
1409 struct pxa_camera_dev *pcdev = ici->priv; 1410 struct pxa_camera_dev *pcdev = ici->priv;
1410 struct device *dev = icd->dev.parent;
1411 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1411 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1412 const struct soc_camera_format_xlate *xlate = NULL; 1412 const struct soc_camera_format_xlate *xlate = NULL;
1413 struct soc_camera_sense sense = { 1413 struct soc_camera_sense sense = {
@@ -1484,7 +1484,7 @@ static int pxa_camera_try_fmt(struct soc_camera_device *icd,
1484 1484
1485 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); 1485 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt);
1486 if (!xlate) { 1486 if (!xlate) {
1487 dev_warn(icd->dev.parent, "Format %x not found\n", pixfmt); 1487 dev_warn(icd->parent, "Format %x not found\n", pixfmt);
1488 return -EINVAL; 1488 return -EINVAL;
1489 } 1489 }
1490 1490
@@ -1521,7 +1521,7 @@ static int pxa_camera_try_fmt(struct soc_camera_device *icd,
1521 break; 1521 break;
1522 default: 1522 default:
1523 /* TODO: support interlaced at least in pass-through mode */ 1523 /* TODO: support interlaced at least in pass-through mode */
1524 dev_err(icd->dev.parent, "Field type %d unsupported.\n", 1524 dev_err(icd->parent, "Field type %d unsupported.\n",
1525 mf.field); 1525 mf.field);
1526 return -EINVAL; 1526 return -EINVAL;
1527 } 1527 }
diff --git a/drivers/media/video/rj54n1cb0c.c b/drivers/media/video/rj54n1cb0c.c
index 57e11b6f19fb..847ccc067e87 100644
--- a/drivers/media/video/rj54n1cb0c.c
+++ b/drivers/media/video/rj54n1cb0c.c
@@ -1364,10 +1364,9 @@ static int rj54n1_video_probe(struct soc_camera_device *icd,
1364 int data1, data2; 1364 int data1, data2;
1365 int ret; 1365 int ret;
1366 1366
1367 /* This could be a BUG_ON() or a WARN_ON(), or remove it completely */ 1367 /* We must have a parent by now. And it cannot be a wrong one. */
1368 if (!icd->dev.parent || 1368 BUG_ON(!icd->parent ||
1369 to_soc_camera_host(icd->dev.parent)->nr != icd->iface) 1369 to_soc_camera_host(icd->parent)->nr != icd->iface);
1370 return -ENODEV;
1371 1370
1372 /* Read out the chip version register */ 1371 /* Read out the chip version register */
1373 data1 = reg_read(client, RJ54N1_DEV_CODE); 1372 data1 = reg_read(client, RJ54N1_DEV_CODE);
diff --git a/drivers/media/video/sh_mobile_ceu_camera.c b/drivers/media/video/sh_mobile_ceu_camera.c
index 152a65993286..f86550703f8e 100644
--- a/drivers/media/video/sh_mobile_ceu_camera.c
+++ b/drivers/media/video/sh_mobile_ceu_camera.c
@@ -206,7 +206,7 @@ static int sh_mobile_ceu_soft_reset(struct sh_mobile_ceu_dev *pcdev)
206 206
207 207
208 if (2 != success) { 208 if (2 != success) {
209 dev_warn(&icd->dev, "soft reset time out\n"); 209 dev_warn(icd->pdev, "soft reset time out\n");
210 return -EIO; 210 return -EIO;
211 } 211 }
212 212
@@ -221,7 +221,7 @@ static int sh_mobile_ceu_videobuf_setup(struct vb2_queue *vq,
221 unsigned long sizes[], void *alloc_ctxs[]) 221 unsigned long sizes[], void *alloc_ctxs[])
222{ 222{
223 struct soc_camera_device *icd = container_of(vq, struct soc_camera_device, vb2_vidq); 223 struct soc_camera_device *icd = container_of(vq, struct soc_camera_device, vb2_vidq);
224 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 224 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
225 struct sh_mobile_ceu_dev *pcdev = ici->priv; 225 struct sh_mobile_ceu_dev *pcdev = ici->priv;
226 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width, 226 int bytes_per_line = soc_mbus_bytes_per_line(icd->user_width,
227 icd->current_fmt->host_fmt); 227 icd->current_fmt->host_fmt);
@@ -243,7 +243,7 @@ static int sh_mobile_ceu_videobuf_setup(struct vb2_queue *vq,
243 *count = pcdev->video_limit / PAGE_ALIGN(sizes[0]); 243 *count = pcdev->video_limit / PAGE_ALIGN(sizes[0]);
244 } 244 }
245 245
246 dev_dbg(icd->dev.parent, "count=%d, size=%lu\n", *count, sizes[0]); 246 dev_dbg(icd->parent, "count=%d, size=%lu\n", *count, sizes[0]);
247 247
248 return 0; 248 return 0;
249} 249}
@@ -352,7 +352,7 @@ static int sh_mobile_ceu_videobuf_prepare(struct vb2_buffer *vb)
352 352
353 buf = to_ceu_vb(vb); 353 buf = to_ceu_vb(vb);
354 354
355 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%p %lu\n", __func__, 355 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%p %lu\n", __func__,
356 vb, vb2_plane_vaddr(vb, 0), vb2_get_plane_payload(vb, 0)); 356 vb, vb2_plane_vaddr(vb, 0), vb2_get_plane_payload(vb, 0));
357 357
358 /* Added list head initialization on alloc */ 358 /* Added list head initialization on alloc */
@@ -372,7 +372,7 @@ static int sh_mobile_ceu_videobuf_prepare(struct vb2_buffer *vb)
372 size = icd->user_height * bytes_per_line; 372 size = icd->user_height * bytes_per_line;
373 373
374 if (vb2_plane_size(vb, 0) < size) { 374 if (vb2_plane_size(vb, 0) < size) {
375 dev_err(icd->dev.parent, "Buffer too small (%lu < %lu)\n", 375 dev_err(icd->parent, "Buffer too small (%lu < %lu)\n",
376 vb2_plane_size(vb, 0), size); 376 vb2_plane_size(vb, 0), size);
377 return -ENOBUFS; 377 return -ENOBUFS;
378 } 378 }
@@ -385,11 +385,11 @@ static int sh_mobile_ceu_videobuf_prepare(struct vb2_buffer *vb)
385static void sh_mobile_ceu_videobuf_queue(struct vb2_buffer *vb) 385static void sh_mobile_ceu_videobuf_queue(struct vb2_buffer *vb)
386{ 386{
387 struct soc_camera_device *icd = container_of(vb->vb2_queue, struct soc_camera_device, vb2_vidq); 387 struct soc_camera_device *icd = container_of(vb->vb2_queue, struct soc_camera_device, vb2_vidq);
388 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 388 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
389 struct sh_mobile_ceu_dev *pcdev = ici->priv; 389 struct sh_mobile_ceu_dev *pcdev = ici->priv;
390 struct sh_mobile_ceu_buffer *buf = to_ceu_vb(vb); 390 struct sh_mobile_ceu_buffer *buf = to_ceu_vb(vb);
391 391
392 dev_dbg(icd->dev.parent, "%s (vb=0x%p) 0x%p %lu\n", __func__, 392 dev_dbg(icd->parent, "%s (vb=0x%p) 0x%p %lu\n", __func__,
393 vb, vb2_plane_vaddr(vb, 0), vb2_get_plane_payload(vb, 0)); 393 vb, vb2_plane_vaddr(vb, 0), vb2_get_plane_payload(vb, 0));
394 394
395 spin_lock_irq(&pcdev->lock); 395 spin_lock_irq(&pcdev->lock);
@@ -410,7 +410,7 @@ static void sh_mobile_ceu_videobuf_queue(struct vb2_buffer *vb)
410static void sh_mobile_ceu_videobuf_release(struct vb2_buffer *vb) 410static void sh_mobile_ceu_videobuf_release(struct vb2_buffer *vb)
411{ 411{
412 struct soc_camera_device *icd = container_of(vb->vb2_queue, struct soc_camera_device, vb2_vidq); 412 struct soc_camera_device *icd = container_of(vb->vb2_queue, struct soc_camera_device, vb2_vidq);
413 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 413 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
414 struct sh_mobile_ceu_buffer *buf = to_ceu_vb(vb); 414 struct sh_mobile_ceu_buffer *buf = to_ceu_vb(vb);
415 struct sh_mobile_ceu_dev *pcdev = ici->priv; 415 struct sh_mobile_ceu_dev *pcdev = ici->priv;
416 416
@@ -438,7 +438,7 @@ static int sh_mobile_ceu_videobuf_init(struct vb2_buffer *vb)
438static int sh_mobile_ceu_stop_streaming(struct vb2_queue *q) 438static int sh_mobile_ceu_stop_streaming(struct vb2_queue *q)
439{ 439{
440 struct soc_camera_device *icd = container_of(q, struct soc_camera_device, vb2_vidq); 440 struct soc_camera_device *icd = container_of(q, struct soc_camera_device, vb2_vidq);
441 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 441 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
442 struct sh_mobile_ceu_dev *pcdev = ici->priv; 442 struct sh_mobile_ceu_dev *pcdev = ici->priv;
443 struct list_head *buf_head, *tmp; 443 struct list_head *buf_head, *tmp;
444 444
@@ -517,7 +517,7 @@ static struct v4l2_subdev *find_csi2(struct sh_mobile_ceu_dev *pcdev)
517/* Called with .video_lock held */ 517/* Called with .video_lock held */
518static int sh_mobile_ceu_add_device(struct soc_camera_device *icd) 518static int sh_mobile_ceu_add_device(struct soc_camera_device *icd)
519{ 519{
520 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 520 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
521 struct sh_mobile_ceu_dev *pcdev = ici->priv; 521 struct sh_mobile_ceu_dev *pcdev = ici->priv;
522 struct v4l2_subdev *csi2_sd; 522 struct v4l2_subdev *csi2_sd;
523 int ret; 523 int ret;
@@ -525,7 +525,7 @@ static int sh_mobile_ceu_add_device(struct soc_camera_device *icd)
525 if (pcdev->icd) 525 if (pcdev->icd)
526 return -EBUSY; 526 return -EBUSY;
527 527
528 dev_info(icd->dev.parent, 528 dev_info(icd->parent,
529 "SuperH Mobile CEU driver attached to camera %d\n", 529 "SuperH Mobile CEU driver attached to camera %d\n",
530 icd->devnum); 530 icd->devnum);
531 531
@@ -549,7 +549,7 @@ static int sh_mobile_ceu_add_device(struct soc_camera_device *icd)
549/* Called with .video_lock held */ 549/* Called with .video_lock held */
550static void sh_mobile_ceu_remove_device(struct soc_camera_device *icd) 550static void sh_mobile_ceu_remove_device(struct soc_camera_device *icd)
551{ 551{
552 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 552 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
553 struct sh_mobile_ceu_dev *pcdev = ici->priv; 553 struct sh_mobile_ceu_dev *pcdev = ici->priv;
554 struct v4l2_subdev *csi2_sd = find_csi2(pcdev); 554 struct v4l2_subdev *csi2_sd = find_csi2(pcdev);
555 555
@@ -571,7 +571,7 @@ static void sh_mobile_ceu_remove_device(struct soc_camera_device *icd)
571 571
572 pm_runtime_put_sync(ici->v4l2_dev.dev); 572 pm_runtime_put_sync(ici->v4l2_dev.dev);
573 573
574 dev_info(icd->dev.parent, 574 dev_info(icd->parent,
575 "SuperH Mobile CEU driver detached from camera %d\n", 575 "SuperH Mobile CEU driver detached from camera %d\n",
576 icd->devnum); 576 icd->devnum);
577 577
@@ -611,14 +611,14 @@ static u16 calc_scale(unsigned int src, unsigned int *dst)
611/* rect is guaranteed to not exceed the scaled camera rectangle */ 611/* rect is guaranteed to not exceed the scaled camera rectangle */
612static void sh_mobile_ceu_set_rect(struct soc_camera_device *icd) 612static void sh_mobile_ceu_set_rect(struct soc_camera_device *icd)
613{ 613{
614 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 614 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
615 struct sh_mobile_ceu_cam *cam = icd->host_priv; 615 struct sh_mobile_ceu_cam *cam = icd->host_priv;
616 struct sh_mobile_ceu_dev *pcdev = ici->priv; 616 struct sh_mobile_ceu_dev *pcdev = ici->priv;
617 unsigned int height, width, cdwdr_width, in_width, in_height; 617 unsigned int height, width, cdwdr_width, in_width, in_height;
618 unsigned int left_offset, top_offset; 618 unsigned int left_offset, top_offset;
619 u32 camor; 619 u32 camor;
620 620
621 dev_geo(icd->dev.parent, "Crop %ux%u@%u:%u\n", 621 dev_geo(icd->parent, "Crop %ux%u@%u:%u\n",
622 icd->user_width, icd->user_height, cam->ceu_left, cam->ceu_top); 622 icd->user_width, icd->user_height, cam->ceu_left, cam->ceu_top);
623 623
624 left_offset = cam->ceu_left; 624 left_offset = cam->ceu_left;
@@ -675,7 +675,7 @@ static void sh_mobile_ceu_set_rect(struct soc_camera_device *icd)
675 /* Set CAMOR, CAPWR, CFSZR, take care of CDWDR */ 675 /* Set CAMOR, CAPWR, CFSZR, take care of CDWDR */
676 camor = left_offset | (top_offset << 16); 676 camor = left_offset | (top_offset << 16);
677 677
678 dev_geo(icd->dev.parent, 678 dev_geo(icd->parent,
679 "CAMOR 0x%x, CAPWR 0x%x, CFSZR 0x%x, CDWDR 0x%x\n", camor, 679 "CAMOR 0x%x, CAPWR 0x%x, CFSZR 0x%x, CDWDR 0x%x\n", camor,
680 (in_height << 16) | in_width, (height << 16) | width, 680 (in_height << 16) | in_width, (height << 16) | width,
681 cdwdr_width); 681 cdwdr_width);
@@ -723,7 +723,7 @@ static void capture_restore(struct sh_mobile_ceu_dev *pcdev, u32 capsr)
723static int sh_mobile_ceu_set_bus_param(struct soc_camera_device *icd, 723static int sh_mobile_ceu_set_bus_param(struct soc_camera_device *icd,
724 __u32 pixfmt) 724 __u32 pixfmt)
725{ 725{
726 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 726 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
727 struct sh_mobile_ceu_dev *pcdev = ici->priv; 727 struct sh_mobile_ceu_dev *pcdev = ici->priv;
728 int ret; 728 int ret;
729 unsigned long camera_flags, common_flags, value; 729 unsigned long camera_flags, common_flags, value;
@@ -832,7 +832,7 @@ static int sh_mobile_ceu_set_bus_param(struct soc_camera_device *icd,
832 sh_mobile_ceu_set_rect(icd); 832 sh_mobile_ceu_set_rect(icd);
833 mdelay(1); 833 mdelay(1);
834 834
835 dev_geo(icd->dev.parent, "CFLCR 0x%x\n", pcdev->cflcr); 835 dev_geo(icd->parent, "CFLCR 0x%x\n", pcdev->cflcr);
836 ceu_write(pcdev, CFLCR, pcdev->cflcr); 836 ceu_write(pcdev, CFLCR, pcdev->cflcr);
837 837
838 /* 838 /*
@@ -855,7 +855,7 @@ static int sh_mobile_ceu_set_bus_param(struct soc_camera_device *icd,
855 ceu_write(pcdev, CDOCR, value); 855 ceu_write(pcdev, CDOCR, value);
856 ceu_write(pcdev, CFWCR, 0); /* keep "datafetch firewall" disabled */ 856 ceu_write(pcdev, CFWCR, 0); /* keep "datafetch firewall" disabled */
857 857
858 dev_dbg(icd->dev.parent, "S_FMT successful for %c%c%c%c %ux%u\n", 858 dev_dbg(icd->parent, "S_FMT successful for %c%c%c%c %ux%u\n",
859 pixfmt & 0xff, (pixfmt >> 8) & 0xff, 859 pixfmt & 0xff, (pixfmt >> 8) & 0xff,
860 (pixfmt >> 16) & 0xff, (pixfmt >> 24) & 0xff, 860 (pixfmt >> 16) & 0xff, (pixfmt >> 24) & 0xff,
861 icd->user_width, icd->user_height); 861 icd->user_width, icd->user_height);
@@ -869,7 +869,7 @@ static int sh_mobile_ceu_set_bus_param(struct soc_camera_device *icd,
869static int sh_mobile_ceu_try_bus_param(struct soc_camera_device *icd, 869static int sh_mobile_ceu_try_bus_param(struct soc_camera_device *icd,
870 unsigned char buswidth) 870 unsigned char buswidth)
871{ 871{
872 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 872 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
873 struct sh_mobile_ceu_dev *pcdev = ici->priv; 873 struct sh_mobile_ceu_dev *pcdev = ici->priv;
874 unsigned long camera_flags, common_flags; 874 unsigned long camera_flags, common_flags;
875 875
@@ -927,7 +927,7 @@ static int sh_mobile_ceu_get_formats(struct soc_camera_device *icd, unsigned int
927 struct soc_camera_format_xlate *xlate) 927 struct soc_camera_format_xlate *xlate)
928{ 928{
929 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 929 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
930 struct device *dev = icd->dev.parent; 930 struct device *dev = icd->parent;
931 struct soc_camera_host *ici = to_soc_camera_host(dev); 931 struct soc_camera_host *ici = to_soc_camera_host(dev);
932 struct sh_mobile_ceu_dev *pcdev = ici->priv; 932 struct sh_mobile_ceu_dev *pcdev = ici->priv;
933 int ret, k, n; 933 int ret, k, n;
@@ -1270,7 +1270,7 @@ static int client_s_fmt(struct soc_camera_device *icd,
1270{ 1270{
1271 struct sh_mobile_ceu_cam *cam = icd->host_priv; 1271 struct sh_mobile_ceu_cam *cam = icd->host_priv;
1272 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1272 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1273 struct device *dev = icd->dev.parent; 1273 struct device *dev = icd->parent;
1274 unsigned int width = mf->width, height = mf->height, tmp_w, tmp_h; 1274 unsigned int width = mf->width, height = mf->height, tmp_w, tmp_h;
1275 unsigned int max_width, max_height; 1275 unsigned int max_width, max_height;
1276 struct v4l2_cropcap cap; 1276 struct v4l2_cropcap cap;
@@ -1339,7 +1339,7 @@ static int client_scale(struct soc_camera_device *icd,
1339 bool ceu_can_scale) 1339 bool ceu_can_scale)
1340{ 1340{
1341 struct sh_mobile_ceu_cam *cam = icd->host_priv; 1341 struct sh_mobile_ceu_cam *cam = icd->host_priv;
1342 struct device *dev = icd->dev.parent; 1342 struct device *dev = icd->parent;
1343 struct v4l2_mbus_framefmt mf_tmp = *mf; 1343 struct v4l2_mbus_framefmt mf_tmp = *mf;
1344 unsigned int scale_h, scale_v; 1344 unsigned int scale_h, scale_v;
1345 int ret; 1345 int ret;
@@ -1389,13 +1389,13 @@ static int sh_mobile_ceu_set_crop(struct soc_camera_device *icd,
1389 struct v4l2_crop *a) 1389 struct v4l2_crop *a)
1390{ 1390{
1391 struct v4l2_rect *rect = &a->c; 1391 struct v4l2_rect *rect = &a->c;
1392 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1392 struct device *dev = icd->parent;
1393 struct soc_camera_host *ici = to_soc_camera_host(dev);
1393 struct sh_mobile_ceu_dev *pcdev = ici->priv; 1394 struct sh_mobile_ceu_dev *pcdev = ici->priv;
1394 struct v4l2_crop cam_crop; 1395 struct v4l2_crop cam_crop;
1395 struct sh_mobile_ceu_cam *cam = icd->host_priv; 1396 struct sh_mobile_ceu_cam *cam = icd->host_priv;
1396 struct v4l2_rect *cam_rect = &cam_crop.c; 1397 struct v4l2_rect *cam_rect = &cam_crop.c;
1397 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1398 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1398 struct device *dev = icd->dev.parent;
1399 struct v4l2_mbus_framefmt mf; 1399 struct v4l2_mbus_framefmt mf;
1400 unsigned int scale_cam_h, scale_cam_v, scale_ceu_h, scale_ceu_v, 1400 unsigned int scale_cam_h, scale_cam_v, scale_ceu_h, scale_ceu_v,
1401 out_width, out_height; 1401 out_width, out_height;
@@ -1537,7 +1537,7 @@ static void calculate_client_output(struct soc_camera_device *icd,
1537 struct v4l2_pix_format *pix, struct v4l2_mbus_framefmt *mf) 1537 struct v4l2_pix_format *pix, struct v4l2_mbus_framefmt *mf)
1538{ 1538{
1539 struct sh_mobile_ceu_cam *cam = icd->host_priv; 1539 struct sh_mobile_ceu_cam *cam = icd->host_priv;
1540 struct device *dev = icd->dev.parent; 1540 struct device *dev = icd->parent;
1541 struct v4l2_rect *cam_subrect = &cam->subrect; 1541 struct v4l2_rect *cam_subrect = &cam->subrect;
1542 unsigned int scale_v, scale_h; 1542 unsigned int scale_v, scale_h;
1543 1543
@@ -1581,12 +1581,12 @@ static void calculate_client_output(struct soc_camera_device *icd,
1581static int sh_mobile_ceu_set_fmt(struct soc_camera_device *icd, 1581static int sh_mobile_ceu_set_fmt(struct soc_camera_device *icd,
1582 struct v4l2_format *f) 1582 struct v4l2_format *f)
1583{ 1583{
1584 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1584 struct device *dev = icd->parent;
1585 struct soc_camera_host *ici = to_soc_camera_host(dev);
1585 struct sh_mobile_ceu_dev *pcdev = ici->priv; 1586 struct sh_mobile_ceu_dev *pcdev = ici->priv;
1586 struct sh_mobile_ceu_cam *cam = icd->host_priv; 1587 struct sh_mobile_ceu_cam *cam = icd->host_priv;
1587 struct v4l2_pix_format *pix = &f->fmt.pix; 1588 struct v4l2_pix_format *pix = &f->fmt.pix;
1588 struct v4l2_mbus_framefmt mf; 1589 struct v4l2_mbus_framefmt mf;
1589 struct device *dev = icd->dev.parent;
1590 __u32 pixfmt = pix->pixelformat; 1590 __u32 pixfmt = pix->pixelformat;
1591 const struct soc_camera_format_xlate *xlate; 1591 const struct soc_camera_format_xlate *xlate;
1592 /* Keep Compiler Happy */ 1592 /* Keep Compiler Happy */
@@ -1710,12 +1710,12 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd,
1710 int width, height; 1710 int width, height;
1711 int ret; 1711 int ret;
1712 1712
1713 dev_geo(icd->dev.parent, "TRY_FMT(pix=0x%x, %ux%u)\n", 1713 dev_geo(icd->parent, "TRY_FMT(pix=0x%x, %ux%u)\n",
1714 pixfmt, pix->width, pix->height); 1714 pixfmt, pix->width, pix->height);
1715 1715
1716 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt); 1716 xlate = soc_camera_xlate_by_fourcc(icd, pixfmt);
1717 if (!xlate) { 1717 if (!xlate) {
1718 dev_warn(icd->dev.parent, "Format %x not found\n", pixfmt); 1718 dev_warn(icd->parent, "Format %x not found\n", pixfmt);
1719 return -EINVAL; 1719 return -EINVAL;
1720 } 1720 }
1721 1721
@@ -1762,7 +1762,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd,
1762 try_mbus_fmt, &mf); 1762 try_mbus_fmt, &mf);
1763 if (ret < 0) { 1763 if (ret < 0) {
1764 /* Shouldn't actually happen... */ 1764 /* Shouldn't actually happen... */
1765 dev_err(icd->dev.parent, 1765 dev_err(icd->parent,
1766 "FIXME: client try_fmt() = %d\n", ret); 1766 "FIXME: client try_fmt() = %d\n", ret);
1767 return ret; 1767 return ret;
1768 } 1768 }
@@ -1774,7 +1774,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd,
1774 pix->height = height; 1774 pix->height = height;
1775 } 1775 }
1776 1776
1777 dev_geo(icd->dev.parent, "%s(): return %d, fmt 0x%x, %ux%u\n", 1777 dev_geo(icd->parent, "%s(): return %d, fmt 0x%x, %ux%u\n",
1778 __func__, ret, pix->pixelformat, pix->width, pix->height); 1778 __func__, ret, pix->pixelformat, pix->width, pix->height);
1779 1779
1780 return ret; 1780 return ret;
@@ -1784,7 +1784,7 @@ static int sh_mobile_ceu_set_livecrop(struct soc_camera_device *icd,
1784 struct v4l2_crop *a) 1784 struct v4l2_crop *a)
1785{ 1785{
1786 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 1786 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
1787 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1787 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1788 struct sh_mobile_ceu_dev *pcdev = ici->priv; 1788 struct sh_mobile_ceu_dev *pcdev = ici->priv;
1789 u32 out_width = icd->user_width, out_height = icd->user_height; 1789 u32 out_width = icd->user_width, out_height = icd->user_height;
1790 int ret; 1790 int ret;
@@ -1796,13 +1796,13 @@ static int sh_mobile_ceu_set_livecrop(struct soc_camera_device *icd,
1796 /* Stop the client */ 1796 /* Stop the client */
1797 ret = v4l2_subdev_call(sd, video, s_stream, 0); 1797 ret = v4l2_subdev_call(sd, video, s_stream, 0);
1798 if (ret < 0) 1798 if (ret < 0)
1799 dev_warn(icd->dev.parent, 1799 dev_warn(icd->parent,
1800 "Client failed to stop the stream: %d\n", ret); 1800 "Client failed to stop the stream: %d\n", ret);
1801 else 1801 else
1802 /* Do the crop, if it fails, there's nothing more we can do */ 1802 /* Do the crop, if it fails, there's nothing more we can do */
1803 sh_mobile_ceu_set_crop(icd, a); 1803 sh_mobile_ceu_set_crop(icd, a);
1804 1804
1805 dev_geo(icd->dev.parent, "Output after crop: %ux%u\n", icd->user_width, icd->user_height); 1805 dev_geo(icd->parent, "Output after crop: %ux%u\n", icd->user_width, icd->user_height);
1806 1806
1807 if (icd->user_width != out_width || icd->user_height != out_height) { 1807 if (icd->user_width != out_width || icd->user_height != out_height) {
1808 struct v4l2_format f = { 1808 struct v4l2_format f = {
@@ -1868,7 +1868,7 @@ static int sh_mobile_ceu_init_videobuf(struct vb2_queue *q,
1868static int sh_mobile_ceu_get_ctrl(struct soc_camera_device *icd, 1868static int sh_mobile_ceu_get_ctrl(struct soc_camera_device *icd,
1869 struct v4l2_control *ctrl) 1869 struct v4l2_control *ctrl)
1870{ 1870{
1871 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1871 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1872 struct sh_mobile_ceu_dev *pcdev = ici->priv; 1872 struct sh_mobile_ceu_dev *pcdev = ici->priv;
1873 u32 val; 1873 u32 val;
1874 1874
@@ -1884,7 +1884,7 @@ static int sh_mobile_ceu_get_ctrl(struct soc_camera_device *icd,
1884static int sh_mobile_ceu_set_ctrl(struct soc_camera_device *icd, 1884static int sh_mobile_ceu_set_ctrl(struct soc_camera_device *icd,
1885 struct v4l2_control *ctrl) 1885 struct v4l2_control *ctrl)
1886{ 1886{
1887 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1887 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1888 struct sh_mobile_ceu_dev *pcdev = ici->priv; 1888 struct sh_mobile_ceu_dev *pcdev = ici->priv;
1889 1889
1890 switch (ctrl->id) { 1890 switch (ctrl->id) {
diff --git a/drivers/media/video/soc_camera.c b/drivers/media/video/soc_camera.c
index 0df31b54e906..5bdfe7e16bc1 100644
--- a/drivers/media/video/soc_camera.c
+++ b/drivers/media/video/soc_camera.c
@@ -60,14 +60,14 @@ static int soc_camera_power_set(struct soc_camera_device *icd,
60 ret = regulator_bulk_enable(icl->num_regulators, 60 ret = regulator_bulk_enable(icl->num_regulators,
61 icl->regulators); 61 icl->regulators);
62 if (ret < 0) { 62 if (ret < 0) {
63 dev_err(&icd->dev, "Cannot enable regulators\n"); 63 dev_err(icd->pdev, "Cannot enable regulators\n");
64 return ret; 64 return ret;
65 } 65 }
66 66
67 if (icl->power) 67 if (icl->power)
68 ret = icl->power(icd->pdev, power_on); 68 ret = icl->power(icd->pdev, power_on);
69 if (ret < 0) { 69 if (ret < 0) {
70 dev_err(&icd->dev, 70 dev_err(icd->pdev,
71 "Platform failed to power-on the camera.\n"); 71 "Platform failed to power-on the camera.\n");
72 72
73 regulator_bulk_disable(icl->num_regulators, 73 regulator_bulk_disable(icl->num_regulators,
@@ -79,7 +79,7 @@ static int soc_camera_power_set(struct soc_camera_device *icd,
79 if (icl->power) 79 if (icl->power)
80 ret = icl->power(icd->pdev, 0); 80 ret = icl->power(icd->pdev, 0);
81 if (ret < 0) { 81 if (ret < 0) {
82 dev_err(&icd->dev, 82 dev_err(icd->pdev,
83 "Platform failed to power-off the camera.\n"); 83 "Platform failed to power-off the camera.\n");
84 return ret; 84 return ret;
85 } 85 }
@@ -87,7 +87,7 @@ static int soc_camera_power_set(struct soc_camera_device *icd,
87 ret = regulator_bulk_disable(icl->num_regulators, 87 ret = regulator_bulk_disable(icl->num_regulators,
88 icl->regulators); 88 icl->regulators);
89 if (ret < 0) { 89 if (ret < 0) {
90 dev_err(&icd->dev, "Cannot disable regulators\n"); 90 dev_err(icd->pdev, "Cannot disable regulators\n");
91 return ret; 91 return ret;
92 } 92 }
93 } 93 }
@@ -147,11 +147,11 @@ EXPORT_SYMBOL(soc_camera_apply_sensor_flags);
147static int soc_camera_try_fmt(struct soc_camera_device *icd, 147static int soc_camera_try_fmt(struct soc_camera_device *icd,
148 struct v4l2_format *f) 148 struct v4l2_format *f)
149{ 149{
150 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 150 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
151 struct v4l2_pix_format *pix = &f->fmt.pix; 151 struct v4l2_pix_format *pix = &f->fmt.pix;
152 int ret; 152 int ret;
153 153
154 dev_dbg(&icd->dev, "TRY_FMT(%c%c%c%c, %ux%u)\n", 154 dev_dbg(icd->pdev, "TRY_FMT(%c%c%c%c, %ux%u)\n",
155 pixfmtstr(pix->pixelformat), pix->width, pix->height); 155 pixfmtstr(pix->pixelformat), pix->width, pix->height);
156 156
157 pix->bytesperline = 0; 157 pix->bytesperline = 0;
@@ -237,7 +237,7 @@ static int soc_camera_enum_fsizes(struct file *file, void *fh,
237 struct v4l2_frmsizeenum *fsize) 237 struct v4l2_frmsizeenum *fsize)
238{ 238{
239 struct soc_camera_device *icd = file->private_data; 239 struct soc_camera_device *icd = file->private_data;
240 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 240 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
241 241
242 return ici->ops->enum_fsizes(icd, fsize); 242 return ici->ops->enum_fsizes(icd, fsize);
243} 243}
@@ -247,7 +247,7 @@ static int soc_camera_reqbufs(struct file *file, void *priv,
247{ 247{
248 int ret; 248 int ret;
249 struct soc_camera_device *icd = file->private_data; 249 struct soc_camera_device *icd = file->private_data;
250 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 250 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
251 251
252 WARN_ON(priv != file->private_data); 252 WARN_ON(priv != file->private_data);
253 253
@@ -274,7 +274,7 @@ static int soc_camera_querybuf(struct file *file, void *priv,
274 struct v4l2_buffer *p) 274 struct v4l2_buffer *p)
275{ 275{
276 struct soc_camera_device *icd = file->private_data; 276 struct soc_camera_device *icd = file->private_data;
277 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 277 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
278 278
279 WARN_ON(priv != file->private_data); 279 WARN_ON(priv != file->private_data);
280 280
@@ -288,7 +288,7 @@ static int soc_camera_qbuf(struct file *file, void *priv,
288 struct v4l2_buffer *p) 288 struct v4l2_buffer *p)
289{ 289{
290 struct soc_camera_device *icd = file->private_data; 290 struct soc_camera_device *icd = file->private_data;
291 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 291 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
292 292
293 WARN_ON(priv != file->private_data); 293 WARN_ON(priv != file->private_data);
294 294
@@ -305,7 +305,7 @@ static int soc_camera_dqbuf(struct file *file, void *priv,
305 struct v4l2_buffer *p) 305 struct v4l2_buffer *p)
306{ 306{
307 struct soc_camera_device *icd = file->private_data; 307 struct soc_camera_device *icd = file->private_data;
308 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 308 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
309 309
310 WARN_ON(priv != file->private_data); 310 WARN_ON(priv != file->private_data);
311 311
@@ -322,7 +322,7 @@ static int soc_camera_dqbuf(struct file *file, void *priv,
322static int soc_camera_init_user_formats(struct soc_camera_device *icd) 322static int soc_camera_init_user_formats(struct soc_camera_device *icd)
323{ 323{
324 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 324 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
325 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 325 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
326 unsigned int i, fmts = 0, raw_fmts = 0; 326 unsigned int i, fmts = 0, raw_fmts = 0;
327 int ret; 327 int ret;
328 enum v4l2_mbus_pixelcode code; 328 enum v4l2_mbus_pixelcode code;
@@ -356,7 +356,7 @@ static int soc_camera_init_user_formats(struct soc_camera_device *icd)
356 if (!icd->user_formats) 356 if (!icd->user_formats)
357 return -ENOMEM; 357 return -ENOMEM;
358 358
359 dev_dbg(&icd->dev, "Found %d supported formats.\n", fmts); 359 dev_dbg(icd->pdev, "Found %d supported formats.\n", fmts);
360 360
361 /* Second pass - actually fill data formats */ 361 /* Second pass - actually fill data formats */
362 fmts = 0; 362 fmts = 0;
@@ -388,7 +388,7 @@ egfmt:
388/* Always entered with .video_lock held */ 388/* Always entered with .video_lock held */
389static void soc_camera_free_user_formats(struct soc_camera_device *icd) 389static void soc_camera_free_user_formats(struct soc_camera_device *icd)
390{ 390{
391 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 391 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
392 392
393 if (ici->ops->put_formats) 393 if (ici->ops->put_formats)
394 ici->ops->put_formats(icd); 394 ici->ops->put_formats(icd);
@@ -402,11 +402,11 @@ static void soc_camera_free_user_formats(struct soc_camera_device *icd)
402static int soc_camera_set_fmt(struct soc_camera_device *icd, 402static int soc_camera_set_fmt(struct soc_camera_device *icd,
403 struct v4l2_format *f) 403 struct v4l2_format *f)
404{ 404{
405 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 405 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
406 struct v4l2_pix_format *pix = &f->fmt.pix; 406 struct v4l2_pix_format *pix = &f->fmt.pix;
407 int ret; 407 int ret;
408 408
409 dev_dbg(&icd->dev, "S_FMT(%c%c%c%c, %ux%u)\n", 409 dev_dbg(icd->pdev, "S_FMT(%c%c%c%c, %ux%u)\n",
410 pixfmtstr(pix->pixelformat), pix->width, pix->height); 410 pixfmtstr(pix->pixelformat), pix->width, pix->height);
411 411
412 /* We always call try_fmt() before set_fmt() or set_crop() */ 412 /* We always call try_fmt() before set_fmt() or set_crop() */
@@ -419,7 +419,7 @@ static int soc_camera_set_fmt(struct soc_camera_device *icd,
419 return ret; 419 return ret;
420 } else if (!icd->current_fmt || 420 } else if (!icd->current_fmt ||
421 icd->current_fmt->host_fmt->fourcc != pix->pixelformat) { 421 icd->current_fmt->host_fmt->fourcc != pix->pixelformat) {
422 dev_err(&icd->dev, 422 dev_err(icd->pdev,
423 "Host driver hasn't set up current format correctly!\n"); 423 "Host driver hasn't set up current format correctly!\n");
424 return -EINVAL; 424 return -EINVAL;
425 } 425 }
@@ -433,7 +433,7 @@ static int soc_camera_set_fmt(struct soc_camera_device *icd,
433 if (ici->ops->init_videobuf) 433 if (ici->ops->init_videobuf)
434 icd->vb_vidq.field = pix->field; 434 icd->vb_vidq.field = pix->field;
435 435
436 dev_dbg(&icd->dev, "set width: %d height: %d\n", 436 dev_dbg(icd->pdev, "set width: %d height: %d\n",
437 icd->user_width, icd->user_height); 437 icd->user_width, icd->user_height);
438 438
439 /* set physical bus parameters */ 439 /* set physical bus parameters */
@@ -443,9 +443,7 @@ static int soc_camera_set_fmt(struct soc_camera_device *icd,
443static int soc_camera_open(struct file *file) 443static int soc_camera_open(struct file *file)
444{ 444{
445 struct video_device *vdev = video_devdata(file); 445 struct video_device *vdev = video_devdata(file);
446 struct soc_camera_device *icd = container_of(vdev->parent, 446 struct soc_camera_device *icd = dev_get_drvdata(vdev->parent);
447 struct soc_camera_device,
448 dev);
449 struct soc_camera_link *icl = to_soc_camera_link(icd); 447 struct soc_camera_link *icl = to_soc_camera_link(icd);
450 struct soc_camera_host *ici; 448 struct soc_camera_host *ici;
451 int ret; 449 int ret;
@@ -454,10 +452,10 @@ static int soc_camera_open(struct file *file)
454 /* No device driver attached */ 452 /* No device driver attached */
455 return -ENODEV; 453 return -ENODEV;
456 454
457 ici = to_soc_camera_host(icd->dev.parent); 455 ici = to_soc_camera_host(icd->parent);
458 456
459 if (!try_module_get(ici->ops->owner)) { 457 if (!try_module_get(ici->ops->owner)) {
460 dev_err(&icd->dev, "Couldn't lock capture bus driver.\n"); 458 dev_err(icd->pdev, "Couldn't lock capture bus driver.\n");
461 return -EINVAL; 459 return -EINVAL;
462 } 460 }
463 461
@@ -488,7 +486,7 @@ static int soc_camera_open(struct file *file)
488 486
489 ret = ici->ops->add(icd); 487 ret = ici->ops->add(icd);
490 if (ret < 0) { 488 if (ret < 0) {
491 dev_err(&icd->dev, "Couldn't activate the camera: %d\n", ret); 489 dev_err(icd->pdev, "Couldn't activate the camera: %d\n", ret);
492 goto eiciadd; 490 goto eiciadd;
493 } 491 }
494 492
@@ -517,7 +515,7 @@ static int soc_camera_open(struct file *file)
517 } 515 }
518 516
519 file->private_data = icd; 517 file->private_data = icd;
520 dev_dbg(&icd->dev, "camera device open\n"); 518 dev_dbg(icd->pdev, "camera device open\n");
521 519
522 return 0; 520 return 0;
523 521
@@ -542,7 +540,7 @@ epower:
542static int soc_camera_close(struct file *file) 540static int soc_camera_close(struct file *file)
543{ 541{
544 struct soc_camera_device *icd = file->private_data; 542 struct soc_camera_device *icd = file->private_data;
545 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 543 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
546 544
547 icd->use_count--; 545 icd->use_count--;
548 if (!icd->use_count) { 546 if (!icd->use_count) {
@@ -563,7 +561,7 @@ static int soc_camera_close(struct file *file)
563 561
564 module_put(ici->ops->owner); 562 module_put(ici->ops->owner);
565 563
566 dev_dbg(&icd->dev, "camera device close\n"); 564 dev_dbg(icd->pdev, "camera device close\n");
567 565
568 return 0; 566 return 0;
569} 567}
@@ -574,7 +572,7 @@ static ssize_t soc_camera_read(struct file *file, char __user *buf,
574 struct soc_camera_device *icd = file->private_data; 572 struct soc_camera_device *icd = file->private_data;
575 int err = -EINVAL; 573 int err = -EINVAL;
576 574
577 dev_err(&icd->dev, "camera device read not implemented\n"); 575 dev_err(icd->pdev, "camera device read not implemented\n");
578 576
579 return err; 577 return err;
580} 578}
@@ -582,10 +580,10 @@ static ssize_t soc_camera_read(struct file *file, char __user *buf,
582static int soc_camera_mmap(struct file *file, struct vm_area_struct *vma) 580static int soc_camera_mmap(struct file *file, struct vm_area_struct *vma)
583{ 581{
584 struct soc_camera_device *icd = file->private_data; 582 struct soc_camera_device *icd = file->private_data;
585 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 583 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
586 int err; 584 int err;
587 585
588 dev_dbg(&icd->dev, "mmap called, vma=0x%08lx\n", (unsigned long)vma); 586 dev_dbg(icd->pdev, "mmap called, vma=0x%08lx\n", (unsigned long)vma);
589 587
590 if (icd->streamer != file) 588 if (icd->streamer != file)
591 return -EBUSY; 589 return -EBUSY;
@@ -595,7 +593,7 @@ static int soc_camera_mmap(struct file *file, struct vm_area_struct *vma)
595 else 593 else
596 err = vb2_mmap(&icd->vb2_vidq, vma); 594 err = vb2_mmap(&icd->vb2_vidq, vma);
597 595
598 dev_dbg(&icd->dev, "vma start=0x%08lx, size=%ld, ret=%d\n", 596 dev_dbg(icd->pdev, "vma start=0x%08lx, size=%ld, ret=%d\n",
599 (unsigned long)vma->vm_start, 597 (unsigned long)vma->vm_start,
600 (unsigned long)vma->vm_end - (unsigned long)vma->vm_start, 598 (unsigned long)vma->vm_end - (unsigned long)vma->vm_start,
601 err); 599 err);
@@ -606,13 +604,13 @@ static int soc_camera_mmap(struct file *file, struct vm_area_struct *vma)
606static unsigned int soc_camera_poll(struct file *file, poll_table *pt) 604static unsigned int soc_camera_poll(struct file *file, poll_table *pt)
607{ 605{
608 struct soc_camera_device *icd = file->private_data; 606 struct soc_camera_device *icd = file->private_data;
609 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 607 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
610 608
611 if (icd->streamer != file) 609 if (icd->streamer != file)
612 return -EBUSY; 610 return -EBUSY;
613 611
614 if (ici->ops->init_videobuf && list_empty(&icd->vb_vidq.stream)) { 612 if (ici->ops->init_videobuf && list_empty(&icd->vb_vidq.stream)) {
615 dev_err(&icd->dev, "Trying to poll with no queued buffers!\n"); 613 dev_err(icd->pdev, "Trying to poll with no queued buffers!\n");
616 return POLLERR; 614 return POLLERR;
617 } 615 }
618 616
@@ -652,15 +650,15 @@ static int soc_camera_s_fmt_vid_cap(struct file *file, void *priv,
652 WARN_ON(priv != file->private_data); 650 WARN_ON(priv != file->private_data);
653 651
654 if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) { 652 if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) {
655 dev_warn(&icd->dev, "Wrong buf-type %d\n", f->type); 653 dev_warn(icd->pdev, "Wrong buf-type %d\n", f->type);
656 return -EINVAL; 654 return -EINVAL;
657 } 655 }
658 656
659 if (icd->streamer && icd->streamer != file) 657 if (icd->streamer && icd->streamer != file)
660 return -EBUSY; 658 return -EBUSY;
661 659
662 if (is_streaming(to_soc_camera_host(icd->dev.parent), icd)) { 660 if (is_streaming(to_soc_camera_host(icd->parent), icd)) {
663 dev_err(&icd->dev, "S_FMT denied: queue initialised\n"); 661 dev_err(icd->pdev, "S_FMT denied: queue initialised\n");
664 return -EBUSY; 662 return -EBUSY;
665 } 663 }
666 664
@@ -709,7 +707,7 @@ static int soc_camera_g_fmt_vid_cap(struct file *file, void *priv,
709 pix->field = icd->field; 707 pix->field = icd->field;
710 pix->pixelformat = icd->current_fmt->host_fmt->fourcc; 708 pix->pixelformat = icd->current_fmt->host_fmt->fourcc;
711 pix->colorspace = icd->colorspace; 709 pix->colorspace = icd->colorspace;
712 dev_dbg(&icd->dev, "current_fmt->fourcc: 0x%08x\n", 710 dev_dbg(icd->pdev, "current_fmt->fourcc: 0x%08x\n",
713 icd->current_fmt->host_fmt->fourcc); 711 icd->current_fmt->host_fmt->fourcc);
714 return 0; 712 return 0;
715} 713}
@@ -718,7 +716,7 @@ static int soc_camera_querycap(struct file *file, void *priv,
718 struct v4l2_capability *cap) 716 struct v4l2_capability *cap)
719{ 717{
720 struct soc_camera_device *icd = file->private_data; 718 struct soc_camera_device *icd = file->private_data;
721 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 719 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
722 720
723 WARN_ON(priv != file->private_data); 721 WARN_ON(priv != file->private_data);
724 722
@@ -730,7 +728,7 @@ static int soc_camera_streamon(struct file *file, void *priv,
730 enum v4l2_buf_type i) 728 enum v4l2_buf_type i)
731{ 729{
732 struct soc_camera_device *icd = file->private_data; 730 struct soc_camera_device *icd = file->private_data;
733 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 731 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
734 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 732 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
735 int ret; 733 int ret;
736 734
@@ -759,7 +757,7 @@ static int soc_camera_streamoff(struct file *file, void *priv,
759{ 757{
760 struct soc_camera_device *icd = file->private_data; 758 struct soc_camera_device *icd = file->private_data;
761 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 759 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
762 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 760 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
763 761
764 WARN_ON(priv != file->private_data); 762 WARN_ON(priv != file->private_data);
765 763
@@ -787,7 +785,7 @@ static int soc_camera_queryctrl(struct file *file, void *priv,
787 struct v4l2_queryctrl *qc) 785 struct v4l2_queryctrl *qc)
788{ 786{
789 struct soc_camera_device *icd = file->private_data; 787 struct soc_camera_device *icd = file->private_data;
790 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 788 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
791 int i; 789 int i;
792 790
793 WARN_ON(priv != file->private_data); 791 WARN_ON(priv != file->private_data);
@@ -818,7 +816,7 @@ static int soc_camera_g_ctrl(struct file *file, void *priv,
818 struct v4l2_control *ctrl) 816 struct v4l2_control *ctrl)
819{ 817{
820 struct soc_camera_device *icd = file->private_data; 818 struct soc_camera_device *icd = file->private_data;
821 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 819 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
822 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 820 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
823 int ret; 821 int ret;
824 822
@@ -837,7 +835,7 @@ static int soc_camera_s_ctrl(struct file *file, void *priv,
837 struct v4l2_control *ctrl) 835 struct v4l2_control *ctrl)
838{ 836{
839 struct soc_camera_device *icd = file->private_data; 837 struct soc_camera_device *icd = file->private_data;
840 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 838 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
841 struct v4l2_subdev *sd = soc_camera_to_subdev(icd); 839 struct v4l2_subdev *sd = soc_camera_to_subdev(icd);
842 int ret; 840 int ret;
843 841
@@ -856,7 +854,7 @@ static int soc_camera_cropcap(struct file *file, void *fh,
856 struct v4l2_cropcap *a) 854 struct v4l2_cropcap *a)
857{ 855{
858 struct soc_camera_device *icd = file->private_data; 856 struct soc_camera_device *icd = file->private_data;
859 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 857 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
860 858
861 return ici->ops->cropcap(icd, a); 859 return ici->ops->cropcap(icd, a);
862} 860}
@@ -865,7 +863,7 @@ static int soc_camera_g_crop(struct file *file, void *fh,
865 struct v4l2_crop *a) 863 struct v4l2_crop *a)
866{ 864{
867 struct soc_camera_device *icd = file->private_data; 865 struct soc_camera_device *icd = file->private_data;
868 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 866 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
869 int ret; 867 int ret;
870 868
871 ret = ici->ops->get_crop(icd, a); 869 ret = ici->ops->get_crop(icd, a);
@@ -882,7 +880,7 @@ static int soc_camera_s_crop(struct file *file, void *fh,
882 struct v4l2_crop *a) 880 struct v4l2_crop *a)
883{ 881{
884 struct soc_camera_device *icd = file->private_data; 882 struct soc_camera_device *icd = file->private_data;
885 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 883 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
886 struct v4l2_rect *rect = &a->c; 884 struct v4l2_rect *rect = &a->c;
887 struct v4l2_crop current_crop; 885 struct v4l2_crop current_crop;
888 int ret; 886 int ret;
@@ -890,7 +888,7 @@ static int soc_camera_s_crop(struct file *file, void *fh,
890 if (a->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) 888 if (a->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
891 return -EINVAL; 889 return -EINVAL;
892 890
893 dev_dbg(&icd->dev, "S_CROP(%ux%u@%u:%u)\n", 891 dev_dbg(icd->pdev, "S_CROP(%ux%u@%u:%u)\n",
894 rect->width, rect->height, rect->left, rect->top); 892 rect->width, rect->height, rect->left, rect->top);
895 893
896 /* If get_crop fails, we'll let host and / or client drivers decide */ 894 /* If get_crop fails, we'll let host and / or client drivers decide */
@@ -898,7 +896,7 @@ static int soc_camera_s_crop(struct file *file, void *fh,
898 896
899 /* Prohibit window size change with initialised buffers */ 897 /* Prohibit window size change with initialised buffers */
900 if (ret < 0) { 898 if (ret < 0) {
901 dev_err(&icd->dev, 899 dev_err(icd->pdev,
902 "S_CROP denied: getting current crop failed\n"); 900 "S_CROP denied: getting current crop failed\n");
903 } else if ((a->c.width == current_crop.c.width && 901 } else if ((a->c.width == current_crop.c.width &&
904 a->c.height == current_crop.c.height) || 902 a->c.height == current_crop.c.height) ||
@@ -908,7 +906,7 @@ static int soc_camera_s_crop(struct file *file, void *fh,
908 } else if (ici->ops->set_livecrop) { 906 } else if (ici->ops->set_livecrop) {
909 ret = ici->ops->set_livecrop(icd, a); 907 ret = ici->ops->set_livecrop(icd, a);
910 } else { 908 } else {
911 dev_err(&icd->dev, 909 dev_err(icd->pdev,
912 "S_CROP denied: queue initialised and sizes differ\n"); 910 "S_CROP denied: queue initialised and sizes differ\n");
913 ret = -EBUSY; 911 ret = -EBUSY;
914 } 912 }
@@ -920,7 +918,7 @@ static int soc_camera_g_parm(struct file *file, void *fh,
920 struct v4l2_streamparm *a) 918 struct v4l2_streamparm *a)
921{ 919{
922 struct soc_camera_device *icd = file->private_data; 920 struct soc_camera_device *icd = file->private_data;
923 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 921 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
924 922
925 if (ici->ops->get_parm) 923 if (ici->ops->get_parm)
926 return ici->ops->get_parm(icd, a); 924 return ici->ops->get_parm(icd, a);
@@ -932,7 +930,7 @@ static int soc_camera_s_parm(struct file *file, void *fh,
932 struct v4l2_streamparm *a) 930 struct v4l2_streamparm *a)
933{ 931{
934 struct soc_camera_device *icd = file->private_data; 932 struct soc_camera_device *icd = file->private_data;
935 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 933 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
936 934
937 if (ici->ops->set_parm) 935 if (ici->ops->set_parm)
938 return ici->ops->set_parm(icd, a); 936 return ici->ops->set_parm(icd, a);
@@ -969,6 +967,8 @@ static int soc_camera_s_register(struct file *file, void *fh,
969} 967}
970#endif 968#endif
971 969
970static int soc_camera_probe(struct soc_camera_device *icd);
971
972/* So far this function cannot fail */ 972/* So far this function cannot fail */
973static void scan_add_host(struct soc_camera_host *ici) 973static void scan_add_host(struct soc_camera_host *ici)
974{ 974{
@@ -979,15 +979,9 @@ static void scan_add_host(struct soc_camera_host *ici)
979 list_for_each_entry(icd, &devices, list) { 979 list_for_each_entry(icd, &devices, list) {
980 if (icd->iface == ici->nr) { 980 if (icd->iface == ici->nr) {
981 int ret; 981 int ret;
982 icd->dev.parent = ici->v4l2_dev.dev; 982
983 dev_set_name(&icd->dev, "%u-%u", icd->iface, 983 icd->parent = ici->v4l2_dev.dev;
984 icd->devnum); 984 ret = soc_camera_probe(icd);
985 ret = device_register(&icd->dev);
986 if (ret < 0) {
987 icd->dev.parent = NULL;
988 dev_err(&icd->dev,
989 "Cannot register device: %d\n", ret);
990 }
991 } 985 }
992 } 986 }
993 987
@@ -999,12 +993,12 @@ static int soc_camera_init_i2c(struct soc_camera_device *icd,
999 struct soc_camera_link *icl) 993 struct soc_camera_link *icl)
1000{ 994{
1001 struct i2c_client *client; 995 struct i2c_client *client;
1002 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 996 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1003 struct i2c_adapter *adap = i2c_get_adapter(icl->i2c_adapter_id); 997 struct i2c_adapter *adap = i2c_get_adapter(icl->i2c_adapter_id);
1004 struct v4l2_subdev *subdev; 998 struct v4l2_subdev *subdev;
1005 999
1006 if (!adap) { 1000 if (!adap) {
1007 dev_err(&icd->dev, "Cannot get I2C adapter #%d. No driver?\n", 1001 dev_err(icd->pdev, "Cannot get I2C adapter #%d. No driver?\n",
1008 icl->i2c_adapter_id); 1002 icl->i2c_adapter_id);
1009 goto ei2cga; 1003 goto ei2cga;
1010 } 1004 }
@@ -1019,7 +1013,7 @@ static int soc_camera_init_i2c(struct soc_camera_device *icd,
1019 client = v4l2_get_subdevdata(subdev); 1013 client = v4l2_get_subdevdata(subdev);
1020 1014
1021 /* Use to_i2c_client(dev) to recover the i2c client */ 1015 /* Use to_i2c_client(dev) to recover the i2c client */
1022 dev_set_drvdata(&icd->dev, &client->dev); 1016 icd->control = &client->dev;
1023 1017
1024 return 0; 1018 return 0;
1025ei2cnd: 1019ei2cnd:
@@ -1033,7 +1027,8 @@ static void soc_camera_free_i2c(struct soc_camera_device *icd)
1033 struct i2c_client *client = 1027 struct i2c_client *client =
1034 to_i2c_client(to_soc_camera_control(icd)); 1028 to_i2c_client(to_soc_camera_control(icd));
1035 struct i2c_adapter *adap = client->adapter; 1029 struct i2c_adapter *adap = client->adapter;
1036 dev_set_drvdata(&icd->dev, NULL); 1030
1031 icd->control = NULL;
1037 v4l2_device_unregister_subdev(i2c_get_clientdata(client)); 1032 v4l2_device_unregister_subdev(i2c_get_clientdata(client));
1038 i2c_unregister_device(client); 1033 i2c_unregister_device(client);
1039 i2c_put_adapter(adap); 1034 i2c_put_adapter(adap);
@@ -1046,17 +1041,16 @@ static void soc_camera_free_i2c(struct soc_camera_device *icd)
1046static int soc_camera_video_start(struct soc_camera_device *icd); 1041static int soc_camera_video_start(struct soc_camera_device *icd);
1047static int video_dev_create(struct soc_camera_device *icd); 1042static int video_dev_create(struct soc_camera_device *icd);
1048/* Called during host-driver probe */ 1043/* Called during host-driver probe */
1049static int soc_camera_probe(struct device *dev) 1044static int soc_camera_probe(struct soc_camera_device *icd)
1050{ 1045{
1051 struct soc_camera_device *icd = to_soc_camera_dev(dev); 1046 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1052 struct soc_camera_host *ici = to_soc_camera_host(dev->parent);
1053 struct soc_camera_link *icl = to_soc_camera_link(icd); 1047 struct soc_camera_link *icl = to_soc_camera_link(icd);
1054 struct device *control = NULL; 1048 struct device *control = NULL;
1055 struct v4l2_subdev *sd; 1049 struct v4l2_subdev *sd;
1056 struct v4l2_mbus_framefmt mf; 1050 struct v4l2_mbus_framefmt mf;
1057 int ret; 1051 int ret;
1058 1052
1059 dev_info(dev, "Probing %s\n", dev_name(dev)); 1053 dev_info(icd->pdev, "Probing %s\n", dev_name(icd->pdev));
1060 1054
1061 ret = regulator_bulk_get(icd->pdev, icl->num_regulators, 1055 ret = regulator_bulk_get(icd->pdev, icl->num_regulators,
1062 icl->regulators); 1056 icl->regulators);
@@ -1092,7 +1086,7 @@ static int soc_camera_probe(struct device *dev)
1092 if (icl->module_name) 1086 if (icl->module_name)
1093 ret = request_module(icl->module_name); 1087 ret = request_module(icl->module_name);
1094 1088
1095 ret = icl->add_device(icl, &icd->dev); 1089 ret = icl->add_device(icd);
1096 if (ret < 0) 1090 if (ret < 0)
1097 goto eadddev; 1091 goto eadddev;
1098 1092
@@ -1103,7 +1097,7 @@ static int soc_camera_probe(struct device *dev)
1103 control = to_soc_camera_control(icd); 1097 control = to_soc_camera_control(icd);
1104 if (!control || !control->driver || !dev_get_drvdata(control) || 1098 if (!control || !control->driver || !dev_get_drvdata(control) ||
1105 !try_module_get(control->driver->owner)) { 1099 !try_module_get(control->driver->owner)) {
1106 icl->del_device(icl); 1100 icl->del_device(icd);
1107 goto enodrv; 1101 goto enodrv;
1108 } 1102 }
1109 } 1103 }
@@ -1137,11 +1131,6 @@ static int soc_camera_probe(struct device *dev)
1137 icd->field = mf.field; 1131 icd->field = mf.field;
1138 } 1132 }
1139 1133
1140 /* Do we have to sysfs_remove_link() before device_unregister()? */
1141 if (sysfs_create_link(&icd->dev.kobj, &to_soc_camera_control(icd)->kobj,
1142 "control"))
1143 dev_warn(&icd->dev, "Failed creating the control symlink\n");
1144
1145 ici->ops->remove(icd); 1134 ici->ops->remove(icd);
1146 1135
1147 soc_camera_power_set(icd, icl, 0); 1136 soc_camera_power_set(icd, icl, 0);
@@ -1157,7 +1146,7 @@ eiufmt:
1157 if (icl->board_info) { 1146 if (icl->board_info) {
1158 soc_camera_free_i2c(icd); 1147 soc_camera_free_i2c(icd);
1159 } else { 1148 } else {
1160 icl->del_device(icl); 1149 icl->del_device(icd);
1161 module_put(control->driver->owner); 1150 module_put(control->driver->owner);
1162 } 1151 }
1163enodrv: 1152enodrv:
@@ -1177,13 +1166,12 @@ ereg:
1177 * This is called on device_unregister, which only means we have to disconnect 1166 * This is called on device_unregister, which only means we have to disconnect
1178 * from the host, but not remove ourselves from the device list 1167 * from the host, but not remove ourselves from the device list
1179 */ 1168 */
1180static int soc_camera_remove(struct device *dev) 1169static int soc_camera_remove(struct soc_camera_device *icd)
1181{ 1170{
1182 struct soc_camera_device *icd = to_soc_camera_dev(dev);
1183 struct soc_camera_link *icl = to_soc_camera_link(icd); 1171 struct soc_camera_link *icl = to_soc_camera_link(icd);
1184 struct video_device *vdev = icd->vdev; 1172 struct video_device *vdev = icd->vdev;
1185 1173
1186 BUG_ON(!dev->parent); 1174 BUG_ON(!icd->parent);
1187 1175
1188 if (vdev) { 1176 if (vdev) {
1189 video_unregister_device(vdev); 1177 video_unregister_device(vdev);
@@ -1193,10 +1181,9 @@ static int soc_camera_remove(struct device *dev)
1193 if (icl->board_info) { 1181 if (icl->board_info) {
1194 soc_camera_free_i2c(icd); 1182 soc_camera_free_i2c(icd);
1195 } else { 1183 } else {
1196 struct device_driver *drv = to_soc_camera_control(icd) ? 1184 struct device_driver *drv = to_soc_camera_control(icd)->driver;
1197 to_soc_camera_control(icd)->driver : NULL;
1198 if (drv) { 1185 if (drv) {
1199 icl->del_device(icl); 1186 icl->del_device(icd);
1200 module_put(drv->owner); 1187 module_put(drv->owner);
1201 } 1188 }
1202 } 1189 }
@@ -1207,22 +1194,6 @@ static int soc_camera_remove(struct device *dev)
1207 return 0; 1194 return 0;
1208} 1195}
1209 1196
1210static struct bus_type soc_camera_bus_type = {
1211 .name = "soc-camera",
1212 .probe = soc_camera_probe,
1213 .remove = soc_camera_remove,
1214};
1215
1216static struct device_driver ic_drv = {
1217 .name = "camera",
1218 .bus = &soc_camera_bus_type,
1219 .owner = THIS_MODULE,
1220};
1221
1222static void dummy_release(struct device *dev)
1223{
1224}
1225
1226static int default_cropcap(struct soc_camera_device *icd, 1197static int default_cropcap(struct soc_camera_device *icd,
1227 struct v4l2_cropcap *a) 1198 struct v4l2_cropcap *a)
1228{ 1199{
@@ -1281,13 +1252,6 @@ static int default_enum_fsizes(struct soc_camera_device *icd,
1281 return 0; 1252 return 0;
1282} 1253}
1283 1254
1284static void soc_camera_device_init(struct device *dev, void *pdata)
1285{
1286 dev->platform_data = pdata;
1287 dev->bus = &soc_camera_bus_type;
1288 dev->release = dummy_release;
1289}
1290
1291int soc_camera_host_register(struct soc_camera_host *ici) 1255int soc_camera_host_register(struct soc_camera_host *ici)
1292{ 1256{
1293 struct soc_camera_host *ix; 1257 struct soc_camera_host *ix;
@@ -1353,24 +1317,9 @@ void soc_camera_host_unregister(struct soc_camera_host *ici)
1353 mutex_lock(&list_lock); 1317 mutex_lock(&list_lock);
1354 1318
1355 list_del(&ici->list); 1319 list_del(&ici->list);
1356 1320 list_for_each_entry(icd, &devices, list)
1357 list_for_each_entry(icd, &devices, list) { 1321 if (icd->iface == ici->nr && to_soc_camera_control(icd))
1358 if (icd->iface == ici->nr) { 1322 soc_camera_remove(icd);
1359 void *pdata = icd->dev.platform_data;
1360 /* The bus->remove will be called */
1361 device_unregister(&icd->dev);
1362 /*
1363 * Not before device_unregister(), .remove
1364 * needs parent to call ici->ops->remove().
1365 * If the host module is loaded again, device_register()
1366 * would complain "already initialised," since 2.6.32
1367 * this is also needed to prevent use-after-free of the
1368 * device private data.
1369 */
1370 memset(&icd->dev, 0, sizeof(icd->dev));
1371 soc_camera_device_init(&icd->dev, pdata);
1372 }
1373 }
1374 1323
1375 mutex_unlock(&list_lock); 1324 mutex_unlock(&list_lock);
1376 1325
@@ -1412,11 +1361,6 @@ static int soc_camera_device_register(struct soc_camera_device *icd)
1412 return 0; 1361 return 0;
1413} 1362}
1414 1363
1415static void soc_camera_device_unregister(struct soc_camera_device *icd)
1416{
1417 list_del(&icd->list);
1418}
1419
1420static const struct v4l2_ioctl_ops soc_camera_ioctl_ops = { 1364static const struct v4l2_ioctl_ops soc_camera_ioctl_ops = {
1421 .vidioc_querycap = soc_camera_querycap, 1365 .vidioc_querycap = soc_camera_querycap,
1422 .vidioc_g_fmt_vid_cap = soc_camera_g_fmt_vid_cap, 1366 .vidioc_g_fmt_vid_cap = soc_camera_g_fmt_vid_cap,
@@ -1451,7 +1395,7 @@ static const struct v4l2_ioctl_ops soc_camera_ioctl_ops = {
1451 1395
1452static int video_dev_create(struct soc_camera_device *icd) 1396static int video_dev_create(struct soc_camera_device *icd)
1453{ 1397{
1454 struct soc_camera_host *ici = to_soc_camera_host(icd->dev.parent); 1398 struct soc_camera_host *ici = to_soc_camera_host(icd->parent);
1455 struct video_device *vdev = video_device_alloc(); 1399 struct video_device *vdev = video_device_alloc();
1456 1400
1457 if (!vdev) 1401 if (!vdev)
@@ -1459,7 +1403,7 @@ static int video_dev_create(struct soc_camera_device *icd)
1459 1403
1460 strlcpy(vdev->name, ici->drv_name, sizeof(vdev->name)); 1404 strlcpy(vdev->name, ici->drv_name, sizeof(vdev->name));
1461 1405
1462 vdev->parent = &icd->dev; 1406 vdev->parent = icd->pdev;
1463 vdev->current_norm = V4L2_STD_UNKNOWN; 1407 vdev->current_norm = V4L2_STD_UNKNOWN;
1464 vdev->fops = &soc_camera_fops; 1408 vdev->fops = &soc_camera_fops;
1465 vdev->ioctl_ops = &soc_camera_ioctl_ops; 1409 vdev->ioctl_ops = &soc_camera_ioctl_ops;
@@ -1480,7 +1424,7 @@ static int soc_camera_video_start(struct soc_camera_device *icd)
1480 const struct device_type *type = icd->vdev->dev.type; 1424 const struct device_type *type = icd->vdev->dev.type;
1481 int ret; 1425 int ret;
1482 1426
1483 if (!icd->dev.parent) 1427 if (!icd->parent)
1484 return -ENODEV; 1428 return -ENODEV;
1485 1429
1486 if (!icd->ops || 1430 if (!icd->ops ||
@@ -1490,7 +1434,7 @@ static int soc_camera_video_start(struct soc_camera_device *icd)
1490 1434
1491 ret = video_register_device(icd->vdev, VFL_TYPE_GRABBER, -1); 1435 ret = video_register_device(icd->vdev, VFL_TYPE_GRABBER, -1);
1492 if (ret < 0) { 1436 if (ret < 0) {
1493 dev_err(&icd->dev, "video_register_device failed: %d\n", ret); 1437 dev_err(icd->pdev, "video_register_device failed: %d\n", ret);
1494 return ret; 1438 return ret;
1495 } 1439 }
1496 1440
@@ -1514,6 +1458,7 @@ static int __devinit soc_camera_pdrv_probe(struct platform_device *pdev)
1514 return -ENOMEM; 1458 return -ENOMEM;
1515 1459
1516 icd->iface = icl->bus_id; 1460 icd->iface = icl->bus_id;
1461 icd->link = icl;
1517 icd->pdev = &pdev->dev; 1462 icd->pdev = &pdev->dev;
1518 platform_set_drvdata(pdev, icd); 1463 platform_set_drvdata(pdev, icd);
1519 1464
@@ -1521,8 +1466,6 @@ static int __devinit soc_camera_pdrv_probe(struct platform_device *pdev)
1521 if (ret < 0) 1466 if (ret < 0)
1522 goto escdevreg; 1467 goto escdevreg;
1523 1468
1524 soc_camera_device_init(&icd->dev, icl);
1525
1526 icd->user_width = DEFAULT_WIDTH; 1469 icd->user_width = DEFAULT_WIDTH;
1527 icd->user_height = DEFAULT_HEIGHT; 1470 icd->user_height = DEFAULT_HEIGHT;
1528 1471
@@ -1546,7 +1489,7 @@ static int __devexit soc_camera_pdrv_remove(struct platform_device *pdev)
1546 if (!icd) 1489 if (!icd)
1547 return -EINVAL; 1490 return -EINVAL;
1548 1491
1549 soc_camera_device_unregister(icd); 1492 list_del(&icd->list);
1550 1493
1551 kfree(icd); 1494 kfree(icd);
1552 1495
@@ -1563,31 +1506,12 @@ static struct platform_driver __refdata soc_camera_pdrv = {
1563 1506
1564static int __init soc_camera_init(void) 1507static int __init soc_camera_init(void)
1565{ 1508{
1566 int ret = bus_register(&soc_camera_bus_type); 1509 return platform_driver_probe(&soc_camera_pdrv, soc_camera_pdrv_probe);
1567 if (ret)
1568 return ret;
1569 ret = driver_register(&ic_drv);
1570 if (ret)
1571 goto edrvr;
1572
1573 ret = platform_driver_probe(&soc_camera_pdrv, soc_camera_pdrv_probe);
1574 if (ret)
1575 goto epdr;
1576
1577 return 0;
1578
1579epdr:
1580 driver_unregister(&ic_drv);
1581edrvr:
1582 bus_unregister(&soc_camera_bus_type);
1583 return ret;
1584} 1510}
1585 1511
1586static void __exit soc_camera_exit(void) 1512static void __exit soc_camera_exit(void)
1587{ 1513{
1588 platform_driver_unregister(&soc_camera_pdrv); 1514 platform_driver_unregister(&soc_camera_pdrv);
1589 driver_unregister(&ic_drv);
1590 bus_unregister(&soc_camera_bus_type);
1591} 1515}
1592 1516
1593module_init(soc_camera_init); 1517module_init(soc_camera_init);
diff --git a/drivers/media/video/soc_camera_platform.c b/drivers/media/video/soc_camera_platform.c
index bf406e89c992..8069cd6bc5e8 100644
--- a/drivers/media/video/soc_camera_platform.c
+++ b/drivers/media/video/soc_camera_platform.c
@@ -146,7 +146,7 @@ static int soc_camera_platform_probe(struct platform_device *pdev)
146 if (!p) 146 if (!p)
147 return -EINVAL; 147 return -EINVAL;
148 148
149 if (!p->dev) { 149 if (!p->icd) {
150 dev_err(&pdev->dev, 150 dev_err(&pdev->dev,
151 "Platform has not set soc_camera_device pointer!\n"); 151 "Platform has not set soc_camera_device pointer!\n");
152 return -EINVAL; 152 return -EINVAL;
@@ -156,16 +156,16 @@ static int soc_camera_platform_probe(struct platform_device *pdev)
156 if (!priv) 156 if (!priv)
157 return -ENOMEM; 157 return -ENOMEM;
158 158
159 icd = to_soc_camera_dev(p->dev); 159 icd = p->icd;
160 160
161 /* soc-camera convention: control's drvdata points to the subdev */ 161 /* soc-camera convention: control's drvdata points to the subdev */
162 platform_set_drvdata(pdev, &priv->subdev); 162 platform_set_drvdata(pdev, &priv->subdev);
163 /* Set the control device reference */ 163 /* Set the control device reference */
164 dev_set_drvdata(&icd->dev, &pdev->dev); 164 icd->control = &pdev->dev;
165 165
166 icd->ops = &soc_camera_platform_ops; 166 icd->ops = &soc_camera_platform_ops;
167 167
168 ici = to_soc_camera_host(icd->dev.parent); 168 ici = to_soc_camera_host(icd->parent);
169 169
170 v4l2_subdev_init(&priv->subdev, &platform_subdev_ops); 170 v4l2_subdev_init(&priv->subdev, &platform_subdev_ops);
171 v4l2_set_subdevdata(&priv->subdev, p); 171 v4l2_set_subdevdata(&priv->subdev, p);
@@ -188,7 +188,7 @@ static int soc_camera_platform_remove(struct platform_device *pdev)
188{ 188{
189 struct soc_camera_platform_priv *priv = get_priv(pdev); 189 struct soc_camera_platform_priv *priv = get_priv(pdev);
190 struct soc_camera_platform_info *p = pdev->dev.platform_data; 190 struct soc_camera_platform_info *p = pdev->dev.platform_data;
191 struct soc_camera_device *icd = to_soc_camera_dev(p->dev); 191 struct soc_camera_device *icd = p->icd;
192 192
193 v4l2_device_unregister_subdev(&priv->subdev); 193 v4l2_device_unregister_subdev(&priv->subdev);
194 icd->ops = NULL; 194 icd->ops = NULL;
diff --git a/drivers/media/video/tw9910.c b/drivers/media/video/tw9910.c
index a722f66c3f23..742482e30011 100644
--- a/drivers/media/video/tw9910.c
+++ b/drivers/media/video/tw9910.c
@@ -836,13 +836,9 @@ static int tw9910_video_probe(struct soc_camera_device *icd,
836 struct tw9910_priv *priv = to_tw9910(client); 836 struct tw9910_priv *priv = to_tw9910(client);
837 s32 id; 837 s32 id;
838 838
839 /* 839 /* We must have a parent by now. And it cannot be a wrong one. */
840 * We must have a parent by now. And it cannot be a wrong one. 840 BUG_ON(!icd->parent ||
841 * So this entire test is completely redundant. 841 to_soc_camera_host(icd->parent)->nr != icd->iface);
842 */
843 if (!icd->dev.parent ||
844 to_soc_camera_host(icd->dev.parent)->nr != icd->iface)
845 return -ENODEV;
846 842
847 /* 843 /*
848 * tw9910 only use 8 or 16 bit bus width 844 * tw9910 only use 8 or 16 bit bus width
diff --git a/include/media/soc_camera.h b/include/media/soc_camera.h
index c31d55be3e17..7582952dceae 100644
--- a/include/media/soc_camera.h
+++ b/include/media/soc_camera.h
@@ -21,11 +21,14 @@
21#include <media/v4l2-device.h> 21#include <media/v4l2-device.h>
22 22
23struct file; 23struct file;
24struct soc_camera_link;
24 25
25struct soc_camera_device { 26struct soc_camera_device {
26 struct list_head list; /* list of all registered devices */ 27 struct list_head list; /* list of all registered devices */
27 struct device dev; 28 struct soc_camera_link *link;
28 struct device *pdev; /* Platform device */ 29 struct device *pdev; /* Platform device */
30 struct device *parent; /* Camera host device */
31 struct device *control; /* E.g., the i2c client */
29 s32 user_width; 32 s32 user_width;
30 s32 user_height; 33 s32 user_height;
31 u32 bytesperline; /* for padding, zero if unused */ 34 u32 bytesperline; /* for padding, zero if unused */
@@ -127,8 +130,8 @@ struct soc_camera_link {
127 * For non-I2C devices platform has to provide methods to add a device 130 * For non-I2C devices platform has to provide methods to add a device
128 * to the system and to remove it 131 * to the system and to remove it
129 */ 132 */
130 int (*add_device)(struct soc_camera_link *, struct device *); 133 int (*add_device)(struct soc_camera_device *);
131 void (*del_device)(struct soc_camera_link *); 134 void (*del_device)(struct soc_camera_device *);
132 /* Optional callbacks to power on or off and reset the sensor */ 135 /* Optional callbacks to power on or off and reset the sensor */
133 int (*power)(struct device *, int); 136 int (*power)(struct device *, int);
134 int (*reset)(struct device *); 137 int (*reset)(struct device *);
@@ -142,12 +145,6 @@ struct soc_camera_link {
142 void (*free_bus)(struct soc_camera_link *); 145 void (*free_bus)(struct soc_camera_link *);
143}; 146};
144 147
145static inline struct soc_camera_device *to_soc_camera_dev(
146 const struct device *dev)
147{
148 return container_of(dev, struct soc_camera_device, dev);
149}
150
151static inline struct soc_camera_host *to_soc_camera_host( 148static inline struct soc_camera_host *to_soc_camera_host(
152 const struct device *dev) 149 const struct device *dev)
153{ 150{
@@ -159,13 +156,13 @@ static inline struct soc_camera_host *to_soc_camera_host(
159static inline struct soc_camera_link *to_soc_camera_link( 156static inline struct soc_camera_link *to_soc_camera_link(
160 const struct soc_camera_device *icd) 157 const struct soc_camera_device *icd)
161{ 158{
162 return icd->dev.platform_data; 159 return icd->link;
163} 160}
164 161
165static inline struct device *to_soc_camera_control( 162static inline struct device *to_soc_camera_control(
166 const struct soc_camera_device *icd) 163 const struct soc_camera_device *icd)
167{ 164{
168 return dev_get_drvdata(&icd->dev); 165 return icd->control;
169} 166}
170 167
171static inline struct v4l2_subdev *soc_camera_to_subdev( 168static inline struct v4l2_subdev *soc_camera_to_subdev(
diff --git a/include/media/soc_camera_platform.h b/include/media/soc_camera_platform.h
index 6d7a4fd00fc0..74f0fa15ca47 100644
--- a/include/media/soc_camera_platform.h
+++ b/include/media/soc_camera_platform.h
@@ -21,7 +21,7 @@ struct soc_camera_platform_info {
21 unsigned long format_depth; 21 unsigned long format_depth;
22 struct v4l2_mbus_framefmt format; 22 struct v4l2_mbus_framefmt format;
23 unsigned long bus_param; 23 unsigned long bus_param;
24 struct device *dev; 24 struct soc_camera_device *icd;
25 int (*set_capture)(struct soc_camera_platform_info *info, int enable); 25 int (*set_capture)(struct soc_camera_platform_info *info, int enable);
26}; 26};
27 27
@@ -30,8 +30,7 @@ static inline void soc_camera_platform_release(struct platform_device **pdev)
30 *pdev = NULL; 30 *pdev = NULL;
31} 31}
32 32
33static inline int soc_camera_platform_add(const struct soc_camera_link *icl, 33static inline int soc_camera_platform_add(struct soc_camera_device *icd,
34 struct device *dev,
35 struct platform_device **pdev, 34 struct platform_device **pdev,
36 struct soc_camera_link *plink, 35 struct soc_camera_link *plink,
37 void (*release)(struct device *dev), 36 void (*release)(struct device *dev),
@@ -40,7 +39,7 @@ static inline int soc_camera_platform_add(const struct soc_camera_link *icl,
40 struct soc_camera_platform_info *info = plink->priv; 39 struct soc_camera_platform_info *info = plink->priv;
41 int ret; 40 int ret;
42 41
43 if (icl != plink) 42 if (icd->link != plink)
44 return -ENODEV; 43 return -ENODEV;
45 44
46 if (*pdev) 45 if (*pdev)
@@ -50,7 +49,7 @@ static inline int soc_camera_platform_add(const struct soc_camera_link *icl,
50 if (!*pdev) 49 if (!*pdev)
51 return -ENOMEM; 50 return -ENOMEM;
52 51
53 info->dev = dev; 52 info->icd = icd;
54 53
55 (*pdev)->dev.platform_data = info; 54 (*pdev)->dev.platform_data = info;
56 (*pdev)->dev.release = release; 55 (*pdev)->dev.release = release;
@@ -59,17 +58,17 @@ static inline int soc_camera_platform_add(const struct soc_camera_link *icl,
59 if (ret < 0) { 58 if (ret < 0) {
60 platform_device_put(*pdev); 59 platform_device_put(*pdev);
61 *pdev = NULL; 60 *pdev = NULL;
62 info->dev = NULL; 61 info->icd = NULL;
63 } 62 }
64 63
65 return ret; 64 return ret;
66} 65}
67 66
68static inline void soc_camera_platform_del(const struct soc_camera_link *icl, 67static inline void soc_camera_platform_del(const struct soc_camera_device *icd,
69 struct platform_device *pdev, 68 struct platform_device *pdev,
70 const struct soc_camera_link *plink) 69 const struct soc_camera_link *plink)
71{ 70{
72 if (icl != plink || !pdev) 71 if (icd->link != plink || !pdev)
73 return; 72 return;
74 73
75 platform_device_unregister(pdev); 74 platform_device_unregister(pdev);