Commit 2fae4d6a authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

media: v4l2-ctrls: v4l2_ctrl_request_complete() should always set ref->req

When the request is completed, all controls are copied to the request object.
However, when VIDIOC_G_EXT_CTRLS attempts to read control values from the
request it will read the current value instead for any control reference that
has a NULL ref->req pointer. But that's wrong: after completing the request
*all* controls should have a non-NULL ref->req pointer since they are after
all copied to the request.

So set ref->req if it wasn't set already.
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Reported-by: default avatarPaul Kocialkowski <paul.kocialkowski@bootlin.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 34217262
...@@ -4296,10 +4296,17 @@ void v4l2_ctrl_request_complete(struct media_request *req, ...@@ -4296,10 +4296,17 @@ void v4l2_ctrl_request_complete(struct media_request *req,
continue; continue;
v4l2_ctrl_lock(ctrl); v4l2_ctrl_lock(ctrl);
if (ref->req) if (ref->req) {
ptr_to_ptr(ctrl, ref->req->p_req, ref->p_req); ptr_to_ptr(ctrl, ref->req->p_req, ref->p_req);
else } else {
ptr_to_ptr(ctrl, ctrl->p_cur, ref->p_req); ptr_to_ptr(ctrl, ctrl->p_cur, ref->p_req);
/*
* Set ref->req to ensure that when userspace wants to
* obtain the controls of this request it will take
* this value and not the current value of the control.
*/
ref->req = ref;
}
v4l2_ctrl_unlock(ctrl); v4l2_ctrl_unlock(ctrl);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment