|
@@ -482,7 +482,7 @@ struct v4l2_buffer32 {
|
|
|
} m;
|
|
|
__u32 length;
|
|
|
__u32 reserved2;
|
|
|
- __u32 reserved;
|
|
|
+ __s32 request_fd;
|
|
|
};
|
|
|
|
|
|
static int get_v4l2_plane32(struct v4l2_plane __user *p64,
|
|
@@ -581,6 +581,7 @@ static int get_v4l2_buffer32(struct v4l2_buffer __user *p64,
|
|
|
{
|
|
|
u32 type;
|
|
|
u32 length;
|
|
|
+ s32 request_fd;
|
|
|
enum v4l2_memory memory;
|
|
|
struct v4l2_plane32 __user *uplane32;
|
|
|
struct v4l2_plane __user *uplane;
|
|
@@ -595,7 +596,9 @@ static int get_v4l2_buffer32(struct v4l2_buffer __user *p64,
|
|
|
get_user(memory, &p32->memory) ||
|
|
|
put_user(memory, &p64->memory) ||
|
|
|
get_user(length, &p32->length) ||
|
|
|
- put_user(length, &p64->length))
|
|
|
+ put_user(length, &p64->length) ||
|
|
|
+ get_user(request_fd, &p32->request_fd) ||
|
|
|
+ put_user(request_fd, &p64->request_fd))
|
|
|
return -EFAULT;
|
|
|
|
|
|
if (V4L2_TYPE_IS_OUTPUT(type))
|
|
@@ -699,7 +702,7 @@ static int put_v4l2_buffer32(struct v4l2_buffer __user *p64,
|
|
|
copy_in_user(&p32->timecode, &p64->timecode, sizeof(p64->timecode)) ||
|
|
|
assign_in_user(&p32->sequence, &p64->sequence) ||
|
|
|
assign_in_user(&p32->reserved2, &p64->reserved2) ||
|
|
|
- assign_in_user(&p32->reserved, &p64->reserved) ||
|
|
|
+ assign_in_user(&p32->request_fd, &p64->request_fd) ||
|
|
|
get_user(length, &p64->length) ||
|
|
|
put_user(length, &p32->length))
|
|
|
return -EFAULT;
|