diff options
author | Sakari Ailus <sakari.ailus@linux.intel.com> | 2014-06-12 12:09:42 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <m.chehab@samsung.com> | 2014-07-21 19:10:48 -0400 |
commit | 0c4348ada001181637b8f73482242166ba2fb56e (patch) | |
tree | 819c95c0cc6a31fea3730f3c9254d04cc1cb2c6a /drivers/media/v4l2-core/v4l2-ctrls.c | |
parent | 5a573925159aeec1dd159627d849dc6c66000faf (diff) |
[media] v4l: ctrls: Unlocked variants of v4l2_ctrl_s_ctrl{,_int64}()
Implement unlocked variants of v4l2_ctrl_s_ctrl() and
v4l2_ctrl_s_ctrl_int64(). As drivers need to set controls as they access
driver internal state elsewhere than in the control framework unlocked
variants of these functions become handy.
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
Diffstat (limited to 'drivers/media/v4l2-core/v4l2-ctrls.c')
-rw-r--r-- | drivers/media/v4l2-core/v4l2-ctrls.c | 26 |
1 files changed, 20 insertions, 6 deletions
diff --git a/drivers/media/v4l2-core/v4l2-ctrls.c b/drivers/media/v4l2-core/v4l2-ctrls.c index 9cd978334b89..1acc7aa9d7e2 100644 --- a/drivers/media/v4l2-core/v4l2-ctrls.c +++ b/drivers/media/v4l2-core/v4l2-ctrls.c | |||
@@ -3175,27 +3175,41 @@ int v4l2_subdev_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *control) | |||
3175 | } | 3175 | } |
3176 | EXPORT_SYMBOL(v4l2_subdev_s_ctrl); | 3176 | EXPORT_SYMBOL(v4l2_subdev_s_ctrl); |
3177 | 3177 | ||
3178 | int v4l2_ctrl_s_ctrl(struct v4l2_ctrl *ctrl, s32 val) | 3178 | int __v4l2_ctrl_s_ctrl(struct v4l2_ctrl *ctrl, s32 val) |
3179 | { | 3179 | { |
3180 | struct v4l2_ext_control c; | 3180 | struct v4l2_ext_control c; |
3181 | int rval; | ||
3182 | |||
3183 | lockdep_assert_held(ctrl->handler->lock); | ||
3181 | 3184 | ||
3182 | /* It's a driver bug if this happens. */ | 3185 | /* It's a driver bug if this happens. */ |
3183 | WARN_ON(!ctrl->is_int); | 3186 | WARN_ON(!ctrl->is_int); |
3184 | c.value = val; | 3187 | c.value = val; |
3185 | return set_ctrl_lock(NULL, ctrl, &c); | 3188 | rval = set_ctrl(NULL, ctrl, &c, 0); |
3189 | if (!rval) | ||
3190 | cur_to_user(&c, ctrl); | ||
3191 | |||
3192 | return rval; | ||
3186 | } | 3193 | } |
3187 | EXPORT_SYMBOL(v4l2_ctrl_s_ctrl); | 3194 | EXPORT_SYMBOL(__v4l2_ctrl_s_ctrl); |
3188 | 3195 | ||
3189 | int v4l2_ctrl_s_ctrl_int64(struct v4l2_ctrl *ctrl, s64 val) | 3196 | int __v4l2_ctrl_s_ctrl_int64(struct v4l2_ctrl *ctrl, s64 val) |
3190 | { | 3197 | { |
3191 | struct v4l2_ext_control c; | 3198 | struct v4l2_ext_control c; |
3199 | int rval; | ||
3200 | |||
3201 | lockdep_assert_held(ctrl->handler->lock); | ||
3192 | 3202 | ||
3193 | /* It's a driver bug if this happens. */ | 3203 | /* It's a driver bug if this happens. */ |
3194 | WARN_ON(ctrl->is_ptr || ctrl->type != V4L2_CTRL_TYPE_INTEGER64); | 3204 | WARN_ON(ctrl->is_ptr || ctrl->type != V4L2_CTRL_TYPE_INTEGER64); |
3195 | c.value64 = val; | 3205 | c.value64 = val; |
3196 | return set_ctrl_lock(NULL, ctrl, &c); | 3206 | rval = set_ctrl(NULL, ctrl, &c, 0); |
3207 | if (!rval) | ||
3208 | cur_to_user(&c, ctrl); | ||
3209 | |||
3210 | return rval; | ||
3197 | } | 3211 | } |
3198 | EXPORT_SYMBOL(v4l2_ctrl_s_ctrl_int64); | 3212 | EXPORT_SYMBOL(__v4l2_ctrl_s_ctrl_int64); |
3199 | 3213 | ||
3200 | void v4l2_ctrl_notify(struct v4l2_ctrl *ctrl, v4l2_ctrl_notify_fnc notify, void *priv) | 3214 | void v4l2_ctrl_notify(struct v4l2_ctrl *ctrl, v4l2_ctrl_notify_fnc notify, void *priv) |
3201 | { | 3215 | { |