diff options
Diffstat (limited to 'drivers/media/video/v4l2-ioctl.c')
-rw-r--r-- | drivers/media/video/v4l2-ioctl.c | 39 |
1 files changed, 18 insertions, 21 deletions
diff --git a/drivers/media/video/v4l2-ioctl.c b/drivers/media/video/v4l2-ioctl.c index 64b4fda08dd5..efbc47004657 100644 --- a/drivers/media/video/v4l2-ioctl.c +++ b/drivers/media/video/v4l2-ioctl.c | |||
@@ -101,25 +101,27 @@ const char *v4l2_norm_to_name(v4l2_std_id id) | |||
101 | } | 101 | } |
102 | EXPORT_SYMBOL(v4l2_norm_to_name); | 102 | EXPORT_SYMBOL(v4l2_norm_to_name); |
103 | 103 | ||
104 | /* Returns frame period for the given standard */ | ||
105 | void v4l2_video_std_frame_period(int id, struct v4l2_fract *frameperiod) | ||
106 | { | ||
107 | if (id & V4L2_STD_525_60) { | ||
108 | frameperiod->numerator = 1001; | ||
109 | frameperiod->denominator = 30000; | ||
110 | } else { | ||
111 | frameperiod->numerator = 1; | ||
112 | frameperiod->denominator = 25; | ||
113 | } | ||
114 | } | ||
115 | EXPORT_SYMBOL(v4l2_video_std_frame_period); | ||
116 | |||
104 | /* Fill in the fields of a v4l2_standard structure according to the | 117 | /* Fill in the fields of a v4l2_standard structure according to the |
105 | 'id' and 'transmission' parameters. Returns negative on error. */ | 118 | 'id' and 'transmission' parameters. Returns negative on error. */ |
106 | int v4l2_video_std_construct(struct v4l2_standard *vs, | 119 | int v4l2_video_std_construct(struct v4l2_standard *vs, |
107 | int id, const char *name) | 120 | int id, const char *name) |
108 | { | 121 | { |
109 | u32 index = vs->index; | 122 | vs->id = id; |
110 | 123 | v4l2_video_std_frame_period(id, &vs->frameperiod); | |
111 | memset(vs, 0, sizeof(struct v4l2_standard)); | 124 | vs->framelines = (id & V4L2_STD_525_60) ? 525 : 625; |
112 | vs->index = index; | ||
113 | vs->id = id; | ||
114 | if (id & V4L2_STD_525_60) { | ||
115 | vs->frameperiod.numerator = 1001; | ||
116 | vs->frameperiod.denominator = 30000; | ||
117 | vs->framelines = 525; | ||
118 | } else { | ||
119 | vs->frameperiod.numerator = 1; | ||
120 | vs->frameperiod.denominator = 25; | ||
121 | vs->framelines = 625; | ||
122 | } | ||
123 | strlcpy(vs->name, name, sizeof(vs->name)); | 125 | strlcpy(vs->name, name, sizeof(vs->name)); |
124 | return 0; | 126 | return 0; |
125 | } | 127 | } |
@@ -1076,7 +1078,6 @@ static long __video_do_ioctl(struct file *file, | |||
1076 | return -EINVAL; | 1078 | return -EINVAL; |
1077 | 1079 | ||
1078 | v4l2_video_std_construct(p, curr_id, descr); | 1080 | v4l2_video_std_construct(p, curr_id, descr); |
1079 | p->index = index; | ||
1080 | 1081 | ||
1081 | dbgarg(cmd, "index=%d, id=0x%Lx, name=%s, fps=%d/%d, " | 1082 | dbgarg(cmd, "index=%d, id=0x%Lx, name=%s, fps=%d/%d, " |
1082 | "framelines=%d\n", p->index, | 1083 | "framelines=%d\n", p->index, |
@@ -1565,15 +1566,11 @@ static long __video_do_ioctl(struct file *file, | |||
1565 | if (ops->vidioc_g_parm) { | 1566 | if (ops->vidioc_g_parm) { |
1566 | ret = ops->vidioc_g_parm(file, fh, p); | 1567 | ret = ops->vidioc_g_parm(file, fh, p); |
1567 | } else { | 1568 | } else { |
1568 | struct v4l2_standard s; | ||
1569 | |||
1570 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | 1569 | if (p->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) |
1571 | return -EINVAL; | 1570 | return -EINVAL; |
1572 | 1571 | ||
1573 | v4l2_video_std_construct(&s, vfd->current_norm, | 1572 | v4l2_video_std_frame_period(vfd->current_norm, |
1574 | v4l2_norm_to_name(vfd->current_norm)); | 1573 | &p->parm.capture.timeperframe); |
1575 | |||
1576 | p->parm.capture.timeperframe = s.frameperiod; | ||
1577 | ret = 0; | 1574 | ret = 0; |
1578 | } | 1575 | } |
1579 | 1576 | ||