aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/ivtv/ivtv-ioctl.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/ivtv/ivtv-ioctl.c')
-rw-r--r--drivers/media/video/ivtv/ivtv-ioctl.c22
1 files changed, 7 insertions, 15 deletions
diff --git a/drivers/media/video/ivtv/ivtv-ioctl.c b/drivers/media/video/ivtv/ivtv-ioctl.c
index e1a31830e9f6..eb4485991a58 100644
--- a/drivers/media/video/ivtv/ivtv-ioctl.c
+++ b/drivers/media/video/ivtv/ivtv-ioctl.c
@@ -508,6 +508,11 @@ static int ivtv_try_fmt_vid_cap(struct file *file, void *fh, struct v4l2_format
508 ivtv_g_fmt_vid_cap(file, fh, fmt); 508 ivtv_g_fmt_vid_cap(file, fh, fmt);
509 fmt->fmt.pix.width = w; 509 fmt->fmt.pix.width = w;
510 fmt->fmt.pix.height = h; 510 fmt->fmt.pix.height = h;
511 if (itv->params.width != 720 ||
512 itv->params.height != (itv->is_50hz ? 576 : 480))
513 itv->params.video_temporal_filter = 0;
514 else
515 itv->params.video_temporal_filter = 8;
511 return 0; 516 return 0;
512} 517}
513 518
@@ -762,15 +767,11 @@ static int ivtv_querycap(struct file *file, void *fh, struct v4l2_capability *vc
762{ 767{
763 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv; 768 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv;
764 769
765 memset(vcap, 0, sizeof(*vcap));
766 strlcpy(vcap->driver, IVTV_DRIVER_NAME, sizeof(vcap->driver)); 770 strlcpy(vcap->driver, IVTV_DRIVER_NAME, sizeof(vcap->driver));
767 strlcpy(vcap->card, itv->card_name, sizeof(vcap->card)); 771 strlcpy(vcap->card, itv->card_name, sizeof(vcap->card));
768 strlcpy(vcap->bus_info, pci_name(itv->dev), sizeof(vcap->bus_info)); 772 strlcpy(vcap->bus_info, pci_name(itv->dev), sizeof(vcap->bus_info));
769 vcap->version = IVTV_DRIVER_VERSION; /* version */ 773 vcap->version = IVTV_DRIVER_VERSION; /* version */
770 vcap->capabilities = itv->v4l2_cap; /* capabilities */ 774 vcap->capabilities = itv->v4l2_cap; /* capabilities */
771 /* reserved.. must set to 0! */
772 vcap->reserved[0] = vcap->reserved[1] =
773 vcap->reserved[2] = vcap->reserved[3] = 0;
774 return 0; 775 return 0;
775} 776}
776 777
@@ -1168,7 +1169,6 @@ static int ivtv_g_tuner(struct file *file, void *fh, struct v4l2_tuner *vt)
1168 if (vt->index != 0) 1169 if (vt->index != 0)
1169 return -EINVAL; 1170 return -EINVAL;
1170 1171
1171 memset(vt, 0, sizeof(*vt));
1172 ivtv_call_i2c_clients(itv, VIDIOC_G_TUNER, vt); 1172 ivtv_call_i2c_clients(itv, VIDIOC_G_TUNER, vt);
1173 1173
1174 if (test_bit(IVTV_F_I_RADIO_USER, &itv->i_flags)) { 1174 if (test_bit(IVTV_F_I_RADIO_USER, &itv->i_flags)) {
@@ -1187,11 +1187,8 @@ static int ivtv_g_sliced_vbi_cap(struct file *file, void *fh, struct v4l2_sliced
1187 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv; 1187 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv;
1188 int set = itv->is_50hz ? V4L2_SLICED_VBI_625 : V4L2_SLICED_VBI_525; 1188 int set = itv->is_50hz ? V4L2_SLICED_VBI_625 : V4L2_SLICED_VBI_525;
1189 int f, l; 1189 int f, l;
1190 enum v4l2_buf_type type = cap->type;
1191 1190
1192 memset(cap, 0, sizeof(*cap)); 1191 if (cap->type == V4L2_BUF_TYPE_SLICED_VBI_CAPTURE) {
1193 cap->type = type;
1194 if (type == V4L2_BUF_TYPE_SLICED_VBI_CAPTURE) {
1195 for (f = 0; f < 2; f++) { 1192 for (f = 0; f < 2; f++) {
1196 for (l = 0; l < 24; l++) { 1193 for (l = 0; l < 24; l++) {
1197 if (valid_service_line(f, l, itv->is_50hz)) 1194 if (valid_service_line(f, l, itv->is_50hz))
@@ -1200,7 +1197,7 @@ static int ivtv_g_sliced_vbi_cap(struct file *file, void *fh, struct v4l2_sliced
1200 } 1197 }
1201 return 0; 1198 return 0;
1202 } 1199 }
1203 if (type == V4L2_BUF_TYPE_SLICED_VBI_OUTPUT) { 1200 if (cap->type == V4L2_BUF_TYPE_SLICED_VBI_OUTPUT) {
1204 if (!(itv->v4l2_cap & V4L2_CAP_SLICED_VBI_OUTPUT)) 1201 if (!(itv->v4l2_cap & V4L2_CAP_SLICED_VBI_OUTPUT))
1205 return -EINVAL; 1202 return -EINVAL;
1206 if (itv->is_60hz) { 1203 if (itv->is_60hz) {
@@ -1243,7 +1240,6 @@ static int ivtv_encoder_cmd(struct file *file, void *fh, struct v4l2_encoder_cmd
1243 struct ivtv_open_id *id = fh; 1240 struct ivtv_open_id *id = fh;
1244 struct ivtv *itv = id->itv; 1241 struct ivtv *itv = id->itv;
1245 1242
1246 memset(&enc->raw, 0, sizeof(enc->raw));
1247 1243
1248 switch (enc->cmd) { 1244 switch (enc->cmd) {
1249 case V4L2_ENC_CMD_START: 1245 case V4L2_ENC_CMD_START:
@@ -1295,8 +1291,6 @@ static int ivtv_try_encoder_cmd(struct file *file, void *fh, struct v4l2_encoder
1295{ 1291{
1296 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv; 1292 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv;
1297 1293
1298 memset(&enc->raw, 0, sizeof(enc->raw));
1299
1300 switch (enc->cmd) { 1294 switch (enc->cmd) {
1301 case V4L2_ENC_CMD_START: 1295 case V4L2_ENC_CMD_START:
1302 IVTV_DEBUG_IOCTL("V4L2_ENC_CMD_START\n"); 1296 IVTV_DEBUG_IOCTL("V4L2_ENC_CMD_START\n");
@@ -1349,8 +1343,6 @@ static int ivtv_g_fbuf(struct file *file, void *fh, struct v4l2_framebuffer *fb)
1349 0, 1343 0,
1350 }; 1344 };
1351 1345
1352 memset(fb, 0, sizeof(*fb));
1353
1354 if (!(itv->v4l2_cap & V4L2_CAP_VIDEO_OUTPUT_OVERLAY)) 1346 if (!(itv->v4l2_cap & V4L2_CAP_VIDEO_OUTPUT_OVERLAY))
1355 return -EINVAL; 1347 return -EINVAL;
1356 1348