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-sensor.c | 8 |
2 files changed, 11 insertions, 1 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-sensor.c b/drivers/media/platform/vimc/vimc-sensor.c index 457e211514c6..54184cd9e0ff 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 | }; |