aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/platform/vimc
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/platform/vimc')
-rw-r--r--drivers/media/platform/vimc/vimc-common.c4
-rw-r--r--drivers/media/platform/vimc/vimc-debayer.c2
-rw-r--r--drivers/media/platform/vimc/vimc-scaler.c2
-rw-r--r--drivers/media/platform/vimc/vimc-sensor.c10
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
288static 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
287static const struct v4l2_subdev_video_ops vimc_sen_video_ops = { 294static 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
291static const struct v4l2_subdev_ops vimc_sen_ops = { 298static 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)