diff options
Diffstat (limited to 'drivers/media/platform/vimc')
-rw-r--r-- | drivers/media/platform/vimc/vimc-common.c | 4 | ||||
-rw-r--r-- | drivers/media/platform/vimc/vimc-debayer.c | 2 | ||||
-rw-r--r-- | drivers/media/platform/vimc/vimc-scaler.c | 2 | ||||
-rw-r--r-- | drivers/media/platform/vimc/vimc-sensor.c | 10 |
4 files changed, 14 insertions, 4 deletions
diff --git a/drivers/media/platform/vimc/vimc-common.c b/drivers/media/platform/vimc/vimc-common.c index 9d63c84a9876..617415c224fe 100644 --- a/drivers/media/platform/vimc/vimc-common.c +++ b/drivers/media/platform/vimc/vimc-common.c | |||
@@ -434,7 +434,9 @@ int vimc_ent_sd_register(struct vimc_ent_device *ved, | |||
434 | v4l2_set_subdevdata(sd, ved); | 434 | v4l2_set_subdevdata(sd, ved); |
435 | 435 | ||
436 | /* Expose this subdev to user space */ | 436 | /* Expose this subdev to user space */ |
437 | sd->flags = V4L2_SUBDEV_FL_HAS_DEVNODE; | 437 | sd->flags |= V4L2_SUBDEV_FL_HAS_DEVNODE; |
438 | if (sd->ctrl_handler) | ||
439 | sd->flags |= V4L2_SUBDEV_FL_HAS_EVENTS; | ||
438 | 440 | ||
439 | /* Initialize the media entity */ | 441 | /* Initialize the media entity */ |
440 | ret = media_entity_pads_init(&sd->entity, num_pads, ved->pads); | 442 | ret = media_entity_pads_init(&sd->entity, num_pads, ved->pads); |
diff --git a/drivers/media/platform/vimc/vimc-debayer.c b/drivers/media/platform/vimc/vimc-debayer.c index 4d663e89d33f..6e10b63ba9ec 100644 --- a/drivers/media/platform/vimc/vimc-debayer.c +++ b/drivers/media/platform/vimc/vimc-debayer.c | |||
@@ -533,7 +533,7 @@ static int vimc_deb_comp_bind(struct device *comp, struct device *master, | |||
533 | /* Initialize ved and sd */ | 533 | /* Initialize ved and sd */ |
534 | ret = vimc_ent_sd_register(&vdeb->ved, &vdeb->sd, v4l2_dev, | 534 | ret = vimc_ent_sd_register(&vdeb->ved, &vdeb->sd, v4l2_dev, |
535 | pdata->entity_name, | 535 | pdata->entity_name, |
536 | MEDIA_ENT_F_ATV_DECODER, 2, | 536 | MEDIA_ENT_F_PROC_VIDEO_PIXEL_ENC_CONV, 2, |
537 | (const unsigned long[2]) {MEDIA_PAD_FL_SINK, | 537 | (const unsigned long[2]) {MEDIA_PAD_FL_SINK, |
538 | MEDIA_PAD_FL_SOURCE}, | 538 | MEDIA_PAD_FL_SOURCE}, |
539 | &vimc_deb_ops); | 539 | &vimc_deb_ops); |
diff --git a/drivers/media/platform/vimc/vimc-scaler.c b/drivers/media/platform/vimc/vimc-scaler.c index e1602e0bc230..e583ec7a91da 100644 --- a/drivers/media/platform/vimc/vimc-scaler.c +++ b/drivers/media/platform/vimc/vimc-scaler.c | |||
@@ -395,7 +395,7 @@ static int vimc_sca_comp_bind(struct device *comp, struct device *master, | |||
395 | /* Initialize ved and sd */ | 395 | /* Initialize ved and sd */ |
396 | ret = vimc_ent_sd_register(&vsca->ved, &vsca->sd, v4l2_dev, | 396 | ret = vimc_ent_sd_register(&vsca->ved, &vsca->sd, v4l2_dev, |
397 | pdata->entity_name, | 397 | pdata->entity_name, |
398 | MEDIA_ENT_F_ATV_DECODER, 2, | 398 | MEDIA_ENT_F_PROC_VIDEO_SCALER, 2, |
399 | (const unsigned long[2]) {MEDIA_PAD_FL_SINK, | 399 | (const unsigned long[2]) {MEDIA_PAD_FL_SINK, |
400 | MEDIA_PAD_FL_SOURCE}, | 400 | MEDIA_PAD_FL_SOURCE}, |
401 | &vimc_sca_ops); | 401 | &vimc_sca_ops); |
diff --git a/drivers/media/platform/vimc/vimc-sensor.c b/drivers/media/platform/vimc/vimc-sensor.c index 457e211514c6..605e2a2d5dd5 100644 --- a/drivers/media/platform/vimc/vimc-sensor.c +++ b/drivers/media/platform/vimc/vimc-sensor.c | |||
@@ -23,6 +23,7 @@ | |||
23 | #include <linux/v4l2-mediabus.h> | 23 | #include <linux/v4l2-mediabus.h> |
24 | #include <linux/vmalloc.h> | 24 | #include <linux/vmalloc.h> |
25 | #include <media/v4l2-ctrls.h> | 25 | #include <media/v4l2-ctrls.h> |
26 | #include <media/v4l2-event.h> | ||
26 | #include <media/v4l2-subdev.h> | 27 | #include <media/v4l2-subdev.h> |
27 | #include <media/tpg/v4l2-tpg.h> | 28 | #include <media/tpg/v4l2-tpg.h> |
28 | 29 | ||
@@ -284,11 +285,18 @@ static int vimc_sen_s_stream(struct v4l2_subdev *sd, int enable) | |||
284 | return 0; | 285 | return 0; |
285 | } | 286 | } |
286 | 287 | ||
288 | static struct v4l2_subdev_core_ops vimc_sen_core_ops = { | ||
289 | .log_status = v4l2_ctrl_subdev_log_status, | ||
290 | .subscribe_event = v4l2_ctrl_subdev_subscribe_event, | ||
291 | .unsubscribe_event = v4l2_event_subdev_unsubscribe, | ||
292 | }; | ||
293 | |||
287 | static const struct v4l2_subdev_video_ops vimc_sen_video_ops = { | 294 | static const struct v4l2_subdev_video_ops vimc_sen_video_ops = { |
288 | .s_stream = vimc_sen_s_stream, | 295 | .s_stream = vimc_sen_s_stream, |
289 | }; | 296 | }; |
290 | 297 | ||
291 | static const struct v4l2_subdev_ops vimc_sen_ops = { | 298 | static const struct v4l2_subdev_ops vimc_sen_ops = { |
299 | .core = &vimc_sen_core_ops, | ||
292 | .pad = &vimc_sen_pad_ops, | 300 | .pad = &vimc_sen_pad_ops, |
293 | .video = &vimc_sen_video_ops, | 301 | .video = &vimc_sen_video_ops, |
294 | }; | 302 | }; |
@@ -378,7 +386,7 @@ static int vimc_sen_comp_bind(struct device *comp, struct device *master, | |||
378 | /* Initialize ved and sd */ | 386 | /* Initialize ved and sd */ |
379 | ret = vimc_ent_sd_register(&vsen->ved, &vsen->sd, v4l2_dev, | 387 | ret = vimc_ent_sd_register(&vsen->ved, &vsen->sd, v4l2_dev, |
380 | pdata->entity_name, | 388 | pdata->entity_name, |
381 | MEDIA_ENT_F_ATV_DECODER, 1, | 389 | MEDIA_ENT_F_CAM_SENSOR, 1, |
382 | (const unsigned long[1]) {MEDIA_PAD_FL_SOURCE}, | 390 | (const unsigned long[1]) {MEDIA_PAD_FL_SOURCE}, |
383 | &vimc_sen_ops); | 391 | &vimc_sen_ops); |
384 | if (ret) | 392 | if (ret) |