Commit 93d5a30b authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

[media] v4l2-ioctl: more -ENOTTY fixes

  explicitly instead of using a macro.
  ioctls and the ENUMSTD, S_STD and G_PARM ioctls.
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 2b5d9480
...@@ -55,13 +55,18 @@ ...@@ -55,13 +55,18 @@
memset((u8 *)(p) + offsetof(typeof(*(p)), field) + sizeof((p)->field), \ memset((u8 *)(p) + offsetof(typeof(*(p)), field) + sizeof((p)->field), \
0, sizeof(*(p)) - offsetof(typeof(*(p)), field) - sizeof((p)->field)) 0, sizeof(*(p)) - offsetof(typeof(*(p)), field) - sizeof((p)->field))
#define no_ioctl_err(foo) ( ( \ #define have_fmt_ops(foo) ( \
ops->vidioc_##foo##_fmt_vid_cap || \ ops->vidioc_##foo##_fmt_vid_cap || \
ops->vidioc_##foo##_fmt_vid_out || \ ops->vidioc_##foo##_fmt_vid_out || \
ops->vidioc_##foo##_fmt_vid_cap_mplane || \ ops->vidioc_##foo##_fmt_vid_cap_mplane || \
ops->vidioc_##foo##_fmt_vid_out_mplane || \ ops->vidioc_##foo##_fmt_vid_out_mplane || \
ops->vidioc_##foo##_fmt_vid_overlay || \ ops->vidioc_##foo##_fmt_vid_overlay || \
ops->vidioc_##foo##_fmt_type_private) ? -EINVAL : -ENOTTY) ops->vidioc_##foo##_fmt_vbi_cap || \
ops->vidioc_##foo##_fmt_vid_out_overlay || \
ops->vidioc_##foo##_fmt_vbi_out || \
ops->vidioc_##foo##_fmt_sliced_vbi_cap || \
ops->vidioc_##foo##_fmt_sliced_vbi_out || \
ops->vidioc_##foo##_fmt_type_private)
struct std_descr { struct std_descr {
v4l2_std_id std; v4l2_std_id std;
...@@ -551,6 +556,7 @@ static long __video_do_ioctl(struct file *file, ...@@ -551,6 +556,7 @@ static long __video_do_ioctl(struct file *file,
struct v4l2_fh *vfh = NULL; struct v4l2_fh *vfh = NULL;
struct v4l2_format f_copy; struct v4l2_format f_copy;
int use_fh_prio = 0; int use_fh_prio = 0;
long ret_prio = 0;
long ret = -ENOTTY; long ret = -ENOTTY;
if (ops == NULL) { if (ops == NULL) {
...@@ -570,39 +576,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -570,39 +576,8 @@ static long __video_do_ioctl(struct file *file,
use_fh_prio = test_bit(V4L2_FL_USE_FH_PRIO, &vfd->flags); use_fh_prio = test_bit(V4L2_FL_USE_FH_PRIO, &vfd->flags);
} }
if (use_fh_prio) { if (use_fh_prio)
switch (cmd) { ret_prio = v4l2_prio_check(vfd->prio, vfh->prio);
case VIDIOC_S_CTRL:
case VIDIOC_S_STD:
case VIDIOC_S_INPUT:
case VIDIOC_S_OUTPUT:
case VIDIOC_S_TUNER:
case VIDIOC_S_FREQUENCY:
case VIDIOC_S_FMT:
case VIDIOC_S_CROP:
case VIDIOC_S_AUDIO:
case VIDIOC_S_AUDOUT:
case VIDIOC_S_EXT_CTRLS:
case VIDIOC_S_FBUF:
case VIDIOC_S_PRIORITY:
case VIDIOC_S_DV_PRESET:
case VIDIOC_S_DV_TIMINGS:
case VIDIOC_S_JPEGCOMP:
case VIDIOC_S_MODULATOR:
case VIDIOC_S_PARM:
case VIDIOC_S_HW_FREQ_SEEK:
case VIDIOC_ENCODER_CMD:
case VIDIOC_OVERLAY:
case VIDIOC_REQBUFS:
case VIDIOC_STREAMON:
case VIDIOC_STREAMOFF:
ret = v4l2_prio_check(vfd->prio, vfh->prio);
if (ret)
goto exit_prio;
ret = -ENOTTY;
break;
}
}
switch (cmd) { switch (cmd) {
...@@ -651,7 +626,9 @@ static long __video_do_ioctl(struct file *file, ...@@ -651,7 +626,9 @@ static long __video_do_ioctl(struct file *file,
if (ops->vidioc_s_priority) if (ops->vidioc_s_priority)
ret = ops->vidioc_s_priority(file, fh, *p); ret = ops->vidioc_s_priority(file, fh, *p);
else else
ret = v4l2_prio_change(&vfd->v4l2_dev->prio, &vfh->prio, *p); ret = ret_prio ? ret_prio :
v4l2_prio_change(&vfd->v4l2_dev->prio,
&vfh->prio, *p);
break; break;
} }
...@@ -701,8 +678,14 @@ static long __video_do_ioctl(struct file *file, ...@@ -701,8 +678,14 @@ static long __video_do_ioctl(struct file *file,
(f->pixelformat >> 16) & 0xff, (f->pixelformat >> 16) & 0xff,
(f->pixelformat >> 24) & 0xff, (f->pixelformat >> 24) & 0xff,
f->description); f->description);
else if (ret == -ENOTTY) else if (ret == -ENOTTY &&
ret = no_ioctl_err(enum); (ops->vidioc_enum_fmt_vid_cap ||
ops->vidioc_enum_fmt_vid_out ||
ops->vidioc_enum_fmt_vid_cap_mplane ||
ops->vidioc_enum_fmt_vid_out_mplane ||
ops->vidioc_enum_fmt_vid_overlay ||
ops->vidioc_enum_fmt_type_private))
ret = -EINVAL;
break; break;
} }
case VIDIOC_G_FMT: case VIDIOC_G_FMT:
...@@ -827,8 +810,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -827,8 +810,8 @@ static long __video_do_ioctl(struct file *file,
fh, f); fh, f);
break; break;
} }
if (unlikely(ret == -ENOTTY)) if (unlikely(ret == -ENOTTY && have_fmt_ops(g)))
ret = no_ioctl_err(g); ret = -EINVAL;
break; break;
} }
...@@ -836,6 +819,14 @@ static long __video_do_ioctl(struct file *file, ...@@ -836,6 +819,14 @@ static long __video_do_ioctl(struct file *file,
{ {
struct v4l2_format *f = (struct v4l2_format *)arg; struct v4l2_format *f = (struct v4l2_format *)arg;
if (!have_fmt_ops(s))
break;
if (ret_prio) {
ret = ret_prio;
break;
}
ret = -EINVAL;
/* FIXME: Should be one dump per type */ /* FIXME: Should be one dump per type */
dbgarg(cmd, "type=%s\n", prt_names(f->type, v4l2_type_names)); dbgarg(cmd, "type=%s\n", prt_names(f->type, v4l2_type_names));
...@@ -966,8 +957,6 @@ static long __video_do_ioctl(struct file *file, ...@@ -966,8 +957,6 @@ static long __video_do_ioctl(struct file *file,
fh, f); fh, f);
break; break;
} }
if (unlikely(ret == -ENOTTY))
ret = no_ioctl_err(g);
break; break;
} }
case VIDIOC_TRY_FMT: case VIDIOC_TRY_FMT:
...@@ -1097,8 +1086,6 @@ static long __video_do_ioctl(struct file *file, ...@@ -1097,8 +1086,6 @@ static long __video_do_ioctl(struct file *file,
if (likely(ops->vidioc_try_fmt_sliced_vbi_out)) if (likely(ops->vidioc_try_fmt_sliced_vbi_out))
ret = ops->vidioc_try_fmt_sliced_vbi_out(file, ret = ops->vidioc_try_fmt_sliced_vbi_out(file,
fh, f); fh, f);
else
ret = no_ioctl_err(try);
break; break;
case V4L2_BUF_TYPE_PRIVATE: case V4L2_BUF_TYPE_PRIVATE:
/* CLEAR_AFTER_FIELD(f, fmt.raw_data); <- does nothing */ /* CLEAR_AFTER_FIELD(f, fmt.raw_data); <- does nothing */
...@@ -1107,8 +1094,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -1107,8 +1094,8 @@ static long __video_do_ioctl(struct file *file,
fh, f); fh, f);
break; break;
} }
if (unlikely(ret == -ENOTTY)) if (unlikely(ret == -ENOTTY && have_fmt_ops(try)))
ret = no_ioctl_err(g); ret = -EINVAL;
break; break;
} }
/* FIXME: Those buf reqs could be handled here, /* FIXME: Those buf reqs could be handled here,
...@@ -1121,6 +1108,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1121,6 +1108,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_reqbufs) if (!ops->vidioc_reqbufs)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
ret = check_fmt(ops, p->type); ret = check_fmt(ops, p->type);
if (ret) if (ret)
break; break;
...@@ -1186,6 +1177,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1186,6 +1177,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_overlay) if (!ops->vidioc_overlay)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "value=%d\n", *i); dbgarg(cmd, "value=%d\n", *i);
ret = ops->vidioc_overlay(file, fh, *i); ret = ops->vidioc_overlay(file, fh, *i);
break; break;
...@@ -1211,6 +1206,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1211,6 +1206,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_fbuf) if (!ops->vidioc_s_fbuf)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "capability=0x%x, flags=%d, base=0x%08lx\n", dbgarg(cmd, "capability=0x%x, flags=%d, base=0x%08lx\n",
p->capability, p->flags, (unsigned long)p->base); p->capability, p->flags, (unsigned long)p->base);
v4l_print_pix_fmt(vfd, &p->fmt); v4l_print_pix_fmt(vfd, &p->fmt);
...@@ -1223,6 +1222,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1223,6 +1222,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_streamon) if (!ops->vidioc_streamon)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "type=%s\n", prt_names(i, v4l2_type_names)); dbgarg(cmd, "type=%s\n", prt_names(i, v4l2_type_names));
ret = ops->vidioc_streamon(file, fh, i); ret = ops->vidioc_streamon(file, fh, i);
break; break;
...@@ -1233,6 +1236,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1233,6 +1236,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_streamoff) if (!ops->vidioc_streamoff)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "type=%s\n", prt_names(i, v4l2_type_names)); dbgarg(cmd, "type=%s\n", prt_names(i, v4l2_type_names));
ret = ops->vidioc_streamoff(file, fh, i); ret = ops->vidioc_streamoff(file, fh, i);
break; break;
...@@ -1245,6 +1252,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1245,6 +1252,10 @@ static long __video_do_ioctl(struct file *file,
unsigned int index = p->index, i, j = 0; unsigned int index = p->index, i, j = 0;
const char *descr = ""; const char *descr = "";
if (id == 0)
break;
ret = -EINVAL;
/* Return norm array in a canonical way */ /* Return norm array in a canonical way */
for (i = 0; i <= index && id; i++) { for (i = 0; i <= index && id; i++) {
/* last std value in the standards array is 0, so this /* last std value in the standards array is 0, so this
...@@ -1298,13 +1309,20 @@ static long __video_do_ioctl(struct file *file, ...@@ -1298,13 +1309,20 @@ static long __video_do_ioctl(struct file *file,
dbgarg(cmd, "std=%08Lx\n", (long long unsigned)*id); dbgarg(cmd, "std=%08Lx\n", (long long unsigned)*id);
if (!ops->vidioc_s_std)
break;
if (ret_prio) {
ret = ret_prio;
break;
}
ret = -EINVAL;
norm = (*id) & vfd->tvnorms; norm = (*id) & vfd->tvnorms;
if (vfd->tvnorms && !norm) /* Check if std is supported */ if (vfd->tvnorms && !norm) /* Check if std is supported */
break; break;
/* Calls the specific handler */ /* Calls the specific handler */
if (ops->vidioc_s_std) ret = ops->vidioc_s_std(file, fh, &norm);
ret = ops->vidioc_s_std(file, fh, &norm);
/* Updates standard information */ /* Updates standard information */
if (ret >= 0) if (ret >= 0)
...@@ -1373,6 +1391,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1373,6 +1391,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_input) if (!ops->vidioc_s_input)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "value=%d\n", *i); dbgarg(cmd, "value=%d\n", *i);
ret = ops->vidioc_s_input(file, fh, *i); ret = ops->vidioc_s_input(file, fh, *i);
break; break;
...@@ -1425,6 +1447,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1425,6 +1447,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_output) if (!ops->vidioc_s_output)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "value=%d\n", *i); dbgarg(cmd, "value=%d\n", *i);
ret = ops->vidioc_s_output(file, fh, *i); ret = ops->vidioc_s_output(file, fh, *i);
break; break;
...@@ -1494,6 +1520,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1494,6 +1520,10 @@ static long __video_do_ioctl(struct file *file,
if (!(vfh && vfh->ctrl_handler) && !vfd->ctrl_handler && if (!(vfh && vfh->ctrl_handler) && !vfd->ctrl_handler &&
!ops->vidioc_s_ctrl && !ops->vidioc_s_ext_ctrls) !ops->vidioc_s_ctrl && !ops->vidioc_s_ext_ctrls)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "id=0x%x, value=%d\n", p->id, p->value); dbgarg(cmd, "id=0x%x, value=%d\n", p->id, p->value);
...@@ -1519,6 +1549,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -1519,6 +1549,8 @@ static long __video_do_ioctl(struct file *file,
ctrl.value = p->value; ctrl.value = p->value;
if (check_ext_ctrls(&ctrls, 1)) if (check_ext_ctrls(&ctrls, 1))
ret = ops->vidioc_s_ext_ctrls(file, fh, &ctrls); ret = ops->vidioc_s_ext_ctrls(file, fh, &ctrls);
else
ret = -EINVAL;
break; break;
} }
case VIDIOC_G_EXT_CTRLS: case VIDIOC_G_EXT_CTRLS:
...@@ -1530,8 +1562,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1530,8 +1562,10 @@ static long __video_do_ioctl(struct file *file,
ret = v4l2_g_ext_ctrls(vfh->ctrl_handler, p); ret = v4l2_g_ext_ctrls(vfh->ctrl_handler, p);
else if (vfd->ctrl_handler) else if (vfd->ctrl_handler)
ret = v4l2_g_ext_ctrls(vfd->ctrl_handler, p); ret = v4l2_g_ext_ctrls(vfd->ctrl_handler, p);
else if (ops->vidioc_g_ext_ctrls && check_ext_ctrls(p, 0)) else if (ops->vidioc_g_ext_ctrls)
ret = ops->vidioc_g_ext_ctrls(file, fh, p); ret = check_ext_ctrls(p, 0) ?
ops->vidioc_g_ext_ctrls(file, fh, p) :
-EINVAL;
else else
break; break;
v4l_print_ext_ctrls(cmd, vfd, p, !ret); v4l_print_ext_ctrls(cmd, vfd, p, !ret);
...@@ -1545,6 +1579,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1545,6 +1579,10 @@ static long __video_do_ioctl(struct file *file,
if (!(vfh && vfh->ctrl_handler) && !vfd->ctrl_handler && if (!(vfh && vfh->ctrl_handler) && !vfd->ctrl_handler &&
!ops->vidioc_s_ext_ctrls) !ops->vidioc_s_ext_ctrls)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
v4l_print_ext_ctrls(cmd, vfd, p, 1); v4l_print_ext_ctrls(cmd, vfd, p, 1);
if (vfh && vfh->ctrl_handler) if (vfh && vfh->ctrl_handler)
ret = v4l2_s_ext_ctrls(vfh, vfh->ctrl_handler, p); ret = v4l2_s_ext_ctrls(vfh, vfh->ctrl_handler, p);
...@@ -1552,6 +1590,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -1552,6 +1590,8 @@ static long __video_do_ioctl(struct file *file,
ret = v4l2_s_ext_ctrls(NULL, vfd->ctrl_handler, p); ret = v4l2_s_ext_ctrls(NULL, vfd->ctrl_handler, p);
else if (check_ext_ctrls(p, 0)) else if (check_ext_ctrls(p, 0))
ret = ops->vidioc_s_ext_ctrls(file, fh, p); ret = ops->vidioc_s_ext_ctrls(file, fh, p);
else
ret = -EINVAL;
break; break;
} }
case VIDIOC_TRY_EXT_CTRLS: case VIDIOC_TRY_EXT_CTRLS:
...@@ -1569,6 +1609,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -1569,6 +1609,8 @@ static long __video_do_ioctl(struct file *file,
ret = v4l2_try_ext_ctrls(vfd->ctrl_handler, p); ret = v4l2_try_ext_ctrls(vfd->ctrl_handler, p);
else if (check_ext_ctrls(p, 0)) else if (check_ext_ctrls(p, 0))
ret = ops->vidioc_try_ext_ctrls(file, fh, p); ret = ops->vidioc_try_ext_ctrls(file, fh, p);
else
ret = -EINVAL;
break; break;
} }
case VIDIOC_QUERYMENU: case VIDIOC_QUERYMENU:
...@@ -1629,6 +1671,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1629,6 +1671,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_audio) if (!ops->vidioc_s_audio)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "index=%d, name=%s, capability=0x%x, " dbgarg(cmd, "index=%d, name=%s, capability=0x%x, "
"mode=0x%x\n", p->index, p->name, "mode=0x%x\n", p->index, p->name,
p->capability, p->mode); p->capability, p->mode);
...@@ -1669,6 +1715,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1669,6 +1715,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_audout) if (!ops->vidioc_s_audout)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "index=%d, name=%s, capability=%d, " dbgarg(cmd, "index=%d, name=%s, capability=%d, "
"mode=%d\n", p->index, p->name, "mode=%d\n", p->index, p->name,
p->capability, p->mode); p->capability, p->mode);
...@@ -1698,6 +1748,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1698,6 +1748,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_modulator) if (!ops->vidioc_s_modulator)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "index=%d, name=%s, capability=%d, " dbgarg(cmd, "index=%d, name=%s, capability=%d, "
"rangelow=%d, rangehigh=%d, txsubchans=%d\n", "rangelow=%d, rangehigh=%d, txsubchans=%d\n",
p->index, p->name, p->capability, p->rangelow, p->index, p->name, p->capability, p->rangelow,
...@@ -1724,6 +1778,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1724,6 +1778,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_crop) if (!ops->vidioc_s_crop)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "type=%s\n", prt_names(p->type, v4l2_type_names)); dbgarg(cmd, "type=%s\n", prt_names(p->type, v4l2_type_names));
dbgrect(vfd, "", &p->c); dbgrect(vfd, "", &p->c);
ret = ops->vidioc_s_crop(file, fh, p); ret = ops->vidioc_s_crop(file, fh, p);
...@@ -1767,11 +1825,15 @@ static long __video_do_ioctl(struct file *file, ...@@ -1767,11 +1825,15 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_g_jpegcomp) if (!ops->vidioc_g_jpegcomp)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "quality=%d, APPn=%d, APP_len=%d, " dbgarg(cmd, "quality=%d, APPn=%d, APP_len=%d, "
"COM_len=%d, jpeg_markers=%d\n", "COM_len=%d, jpeg_markers=%d\n",
p->quality, p->APPn, p->APP_len, p->quality, p->APPn, p->APP_len,
p->COM_len, p->jpeg_markers); p->COM_len, p->jpeg_markers);
ret = ops->vidioc_s_jpegcomp(file, fh, p); ret = ops->vidioc_s_jpegcomp(file, fh, p);
break; break;
} }
case VIDIOC_G_ENC_INDEX: case VIDIOC_G_ENC_INDEX:
...@@ -1792,6 +1854,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1792,6 +1854,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_encoder_cmd) if (!ops->vidioc_encoder_cmd)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
ret = ops->vidioc_encoder_cmd(file, fh, p); ret = ops->vidioc_encoder_cmd(file, fh, p);
if (!ret) if (!ret)
dbgarg(cmd, "cmd=%d, flags=%x\n", p->cmd, p->flags); dbgarg(cmd, "cmd=%d, flags=%x\n", p->cmd, p->flags);
...@@ -1812,6 +1878,8 @@ static long __video_do_ioctl(struct file *file, ...@@ -1812,6 +1878,8 @@ static long __video_do_ioctl(struct file *file,
{ {
struct v4l2_streamparm *p = arg; struct v4l2_streamparm *p = arg;
if (!ops->vidioc_g_parm && !vfd->current_norm)
break;
if (ops->vidioc_g_parm) { if (ops->vidioc_g_parm) {
ret = check_fmt(ops, p->type); ret = check_fmt(ops, p->type);
if (ret) if (ret)
...@@ -1820,14 +1888,13 @@ static long __video_do_ioctl(struct file *file, ...@@ -1820,14 +1888,13 @@ static long __video_do_ioctl(struct file *file,
} else { } else {
v4l2_std_id std = vfd->current_norm; v4l2_std_id std = vfd->current_norm;
ret = -EINVAL;
if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
break; break;
ret = 0; ret = 0;
if (ops->vidioc_g_std) if (ops->vidioc_g_std)
ret = ops->vidioc_g_std(file, fh, &std); ret = ops->vidioc_g_std(file, fh, &std);
else if (std == 0)
ret = -ENOTTY;
if (ret == 0) if (ret == 0)
v4l2_video_std_frame_period(std, v4l2_video_std_frame_period(std,
&p->parm.capture.timeperframe); &p->parm.capture.timeperframe);
...@@ -1842,6 +1909,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1842,6 +1909,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_parm) if (!ops->vidioc_s_parm)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
ret = check_fmt(ops, p->type); ret = check_fmt(ops, p->type);
if (ret) if (ret)
break; break;
...@@ -1877,6 +1948,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1877,6 +1948,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_tuner) if (!ops->vidioc_s_tuner)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
p->type = (vfd->vfl_type == VFL_TYPE_RADIO) ? p->type = (vfd->vfl_type == VFL_TYPE_RADIO) ?
V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV;
dbgarg(cmd, "index=%d, name=%s, type=%d, " dbgarg(cmd, "index=%d, name=%s, type=%d, "
...@@ -1911,6 +1986,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1911,6 +1986,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_frequency) if (!ops->vidioc_s_frequency)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "tuner=%d, type=%d, frequency=%d\n", dbgarg(cmd, "tuner=%d, type=%d, frequency=%d\n",
p->tuner, p->type, p->frequency); p->tuner, p->type, p->frequency);
ret = ops->vidioc_s_frequency(file, fh, p); ret = ops->vidioc_s_frequency(file, fh, p);
...@@ -1985,6 +2064,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -1985,6 +2064,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_hw_freq_seek) if (!ops->vidioc_s_hw_freq_seek)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
type = (vfd->vfl_type == VFL_TYPE_RADIO) ? type = (vfd->vfl_type == VFL_TYPE_RADIO) ?
V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV;
dbgarg(cmd, dbgarg(cmd,
...@@ -2089,6 +2172,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -2089,6 +2172,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_dv_preset) if (!ops->vidioc_s_dv_preset)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
dbgarg(cmd, "preset=%d\n", p->preset); dbgarg(cmd, "preset=%d\n", p->preset);
ret = ops->vidioc_s_dv_preset(file, fh, p); ret = ops->vidioc_s_dv_preset(file, fh, p);
...@@ -2124,6 +2211,10 @@ static long __video_do_ioctl(struct file *file, ...@@ -2124,6 +2211,10 @@ static long __video_do_ioctl(struct file *file,
if (!ops->vidioc_s_dv_timings) if (!ops->vidioc_s_dv_timings)
break; break;
if (ret_prio) {
ret = ret_prio;
break;
}
switch (p->type) { switch (p->type) {
case V4L2_DV_BT_656_1120: case V4L2_DV_BT_656_1120:
...@@ -2232,19 +2323,12 @@ static long __video_do_ioctl(struct file *file, ...@@ -2232,19 +2323,12 @@ static long __video_do_ioctl(struct file *file,
break; break;
} }
default: default:
{
bool valid_prio = true;
if (!ops->vidioc_default) if (!ops->vidioc_default)
break; break;
if (use_fh_prio) ret = ops->vidioc_default(file, fh, ret_prio >= 0, cmd, arg);
valid_prio = v4l2_prio_check(vfd->prio, vfh->prio) >= 0;
ret = ops->vidioc_default(file, fh, valid_prio, cmd, arg);
break; break;
}
} /* switch */ } /* switch */
exit_prio:
if (vfd->debug & V4L2_DEBUG_IOCTL_ARG) { if (vfd->debug & V4L2_DEBUG_IOCTL_ARG) {
if (ret < 0) { if (ret < 0) {
v4l_print_ioctl(vfd->name, cmd); v4l_print_ioctl(vfd->name, cmd);
......
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