mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-03 11:13:56 +08:00
media: v4l2-dev: fix is_tch checks
Touch devices mark too many ioctls as valid. Restrict the list of valid ioctls for touch devices. Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
This commit is contained in:
parent
8e72244b4e
commit
4fbd54bbd2
@ -596,8 +596,8 @@ static void determine_valid_ioctls(struct video_device *vdev)
|
|||||||
if (ops->vidioc_enum_freq_bands || ops->vidioc_g_tuner || ops->vidioc_g_modulator)
|
if (ops->vidioc_enum_freq_bands || ops->vidioc_g_tuner || ops->vidioc_g_modulator)
|
||||||
set_bit(_IOC_NR(VIDIOC_ENUM_FREQ_BANDS), valid_ioctls);
|
set_bit(_IOC_NR(VIDIOC_ENUM_FREQ_BANDS), valid_ioctls);
|
||||||
|
|
||||||
if (is_vid || is_tch) {
|
if (is_vid) {
|
||||||
/* video and touch specific ioctls */
|
/* video specific ioctls */
|
||||||
if ((is_rx && (ops->vidioc_enum_fmt_vid_cap ||
|
if ((is_rx && (ops->vidioc_enum_fmt_vid_cap ||
|
||||||
ops->vidioc_enum_fmt_vid_overlay)) ||
|
ops->vidioc_enum_fmt_vid_overlay)) ||
|
||||||
(is_tx && ops->vidioc_enum_fmt_vid_out))
|
(is_tx && ops->vidioc_enum_fmt_vid_out))
|
||||||
@ -675,6 +675,19 @@ static void determine_valid_ioctls(struct video_device *vdev)
|
|||||||
ops->vidioc_try_fmt_sliced_vbi_out)))
|
ops->vidioc_try_fmt_sliced_vbi_out)))
|
||||||
set_bit(_IOC_NR(VIDIOC_TRY_FMT), valid_ioctls);
|
set_bit(_IOC_NR(VIDIOC_TRY_FMT), valid_ioctls);
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_G_SLICED_VBI_CAP, vidioc_g_sliced_vbi_cap);
|
SET_VALID_IOCTL(ops, VIDIOC_G_SLICED_VBI_CAP, vidioc_g_sliced_vbi_cap);
|
||||||
|
} else if (is_tch) {
|
||||||
|
/* touch specific ioctls */
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_ENUM_FMT, vidioc_enum_fmt_vid_cap);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_G_FMT, vidioc_g_fmt_vid_cap);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_S_FMT, vidioc_s_fmt_vid_cap);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_TRY_FMT, vidioc_try_fmt_vid_cap);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_ENUM_FRAMESIZES, vidioc_enum_framesizes);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_ENUM_FRAMEINTERVALS, vidioc_enum_frameintervals);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_ENUMINPUT, vidioc_enum_input);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_G_INPUT, vidioc_g_input);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_S_INPUT, vidioc_s_input);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_G_PARM, vidioc_g_parm);
|
||||||
|
SET_VALID_IOCTL(ops, VIDIOC_S_PARM, vidioc_s_parm);
|
||||||
} else if (is_sdr && is_rx) {
|
} else if (is_sdr && is_rx) {
|
||||||
/* SDR receiver specific ioctls */
|
/* SDR receiver specific ioctls */
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_ENUM_FMT, vidioc_enum_fmt_sdr_cap);
|
SET_VALID_IOCTL(ops, VIDIOC_ENUM_FMT, vidioc_enum_fmt_sdr_cap);
|
||||||
@ -702,8 +715,8 @@ static void determine_valid_ioctls(struct video_device *vdev)
|
|||||||
SET_VALID_IOCTL(ops, VIDIOC_STREAMOFF, vidioc_streamoff);
|
SET_VALID_IOCTL(ops, VIDIOC_STREAMOFF, vidioc_streamoff);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_vid || is_vbi || is_tch || is_meta) {
|
if (is_vid || is_vbi || is_meta) {
|
||||||
/* ioctls valid for video, vbi, touch and metadata */
|
/* ioctls valid for video, vbi and metadata */
|
||||||
if (ops->vidioc_s_std)
|
if (ops->vidioc_s_std)
|
||||||
set_bit(_IOC_NR(VIDIOC_ENUMSTD), valid_ioctls);
|
set_bit(_IOC_NR(VIDIOC_ENUMSTD), valid_ioctls);
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_S_STD, vidioc_s_std);
|
SET_VALID_IOCTL(ops, VIDIOC_S_STD, vidioc_s_std);
|
||||||
@ -727,8 +740,7 @@ static void determine_valid_ioctls(struct video_device *vdev)
|
|||||||
SET_VALID_IOCTL(ops, VIDIOC_G_AUDOUT, vidioc_g_audout);
|
SET_VALID_IOCTL(ops, VIDIOC_G_AUDOUT, vidioc_g_audout);
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_S_AUDOUT, vidioc_s_audout);
|
SET_VALID_IOCTL(ops, VIDIOC_S_AUDOUT, vidioc_s_audout);
|
||||||
}
|
}
|
||||||
if (ops->vidioc_g_parm || (vdev->vfl_type == VFL_TYPE_GRABBER &&
|
if (ops->vidioc_g_parm || ops->vidioc_g_std)
|
||||||
ops->vidioc_g_std))
|
|
||||||
set_bit(_IOC_NR(VIDIOC_G_PARM), valid_ioctls);
|
set_bit(_IOC_NR(VIDIOC_G_PARM), valid_ioctls);
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_S_PARM, vidioc_s_parm);
|
SET_VALID_IOCTL(ops, VIDIOC_S_PARM, vidioc_s_parm);
|
||||||
SET_VALID_IOCTL(ops, VIDIOC_S_DV_TIMINGS, vidioc_s_dv_timings);
|
SET_VALID_IOCTL(ops, VIDIOC_S_DV_TIMINGS, vidioc_s_dv_timings);
|
||||||
|
Loading…
Reference in New Issue
Block a user