diff options
-rw-r--r-- | drivers/media/video/bt8xx/bttv-driver.c | 6 | ||||
-rw-r--r-- | drivers/media/video/v4l2-ioctl.c | 39 | ||||
-rw-r--r-- | include/media/v4l2-ioctl.h | 1 |
3 files changed, 21 insertions, 25 deletions
diff --git a/drivers/media/video/bt8xx/bttv-driver.c b/drivers/media/video/bt8xx/bttv-driver.c index 826ca60b42e6..1f606d816a58 100644 --- a/drivers/media/video/bt8xx/bttv-driver.c +++ b/drivers/media/video/bt8xx/bttv-driver.c | |||
@@ -2932,13 +2932,11 @@ static int bttv_g_parm(struct file *file, void *f, | |||
2932 | { | 2932 | { |
2933 | struct bttv_fh *fh = f; | 2933 | struct bttv_fh *fh = f; |
2934 | struct bttv *btv = fh->btv; | 2934 | struct bttv *btv = fh->btv; |
2935 | struct v4l2_standard s; | ||
2936 | 2935 | ||
2937 | if (parm->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | 2936 | if (parm->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) |
2938 | return -EINVAL; | 2937 | return -EINVAL; |
2939 | v4l2_video_std_construct(&s, bttv_tvnorms[btv->tvnorm].v4l2_id, | 2938 | v4l2_video_std_frame_period(bttv_tvnorms[btv->tvnorm].v4l2_id, |
2940 | bttv_tvnorms[btv->tvnorm].name); | 2939 | &parm->parm.capture.timeperframe); |
2941 | parm->parm.capture.timeperframe = s.frameperiod; | ||
2942 | return 0; | 2940 | return 0; |
2943 | } | 2941 | } |
2944 | 2942 | ||
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 | ||
diff --git a/include/media/v4l2-ioctl.h b/include/media/v4l2-ioctl.h index b01c044868d0..a8b4c0b678ec 100644 --- a/include/media/v4l2-ioctl.h +++ b/include/media/v4l2-ioctl.h | |||
@@ -267,6 +267,7 @@ struct v4l2_ioctl_ops { | |||
267 | 267 | ||
268 | /* Video standard functions */ | 268 | /* Video standard functions */ |
269 | extern const char *v4l2_norm_to_name(v4l2_std_id id); | 269 | extern const char *v4l2_norm_to_name(v4l2_std_id id); |
270 | extern void v4l2_video_std_frame_period(int id, struct v4l2_fract *frameperiod); | ||
270 | extern int v4l2_video_std_construct(struct v4l2_standard *vs, | 271 | extern int v4l2_video_std_construct(struct v4l2_standard *vs, |
271 | int id, const char *name); | 272 | int id, const char *name); |
272 | /* Prints the ioctl in a human-readable format */ | 273 | /* Prints the ioctl in a human-readable format */ |