aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/em28xx/em28xx-video.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/em28xx/em28xx-video.c')
-rw-r--r--drivers/media/video/em28xx/em28xx-video.c92
1 files changed, 10 insertions, 82 deletions
diff --git a/drivers/media/video/em28xx/em28xx-video.c b/drivers/media/video/em28xx/em28xx-video.c
index a0627cdb706b..741c4fcf0d28 100644
--- a/drivers/media/video/em28xx/em28xx-video.c
+++ b/drivers/media/video/em28xx/em28xx-video.c
@@ -863,17 +863,14 @@ static int res_get(struct em28xx_fh *fh, unsigned int bit)
863 return 1; 863 return 1;
864 864
865 /* is it free? */ 865 /* is it free? */
866 mutex_lock(&dev->lock);
867 if (dev->resources & bit) { 866 if (dev->resources & bit) {
868 /* no, someone else uses it */ 867 /* no, someone else uses it */
869 mutex_unlock(&dev->lock);
870 return 0; 868 return 0;
871 } 869 }
872 /* it's free, grab it */ 870 /* it's free, grab it */
873 fh->resources |= bit; 871 fh->resources |= bit;
874 dev->resources |= bit; 872 dev->resources |= bit;
875 em28xx_videodbg("res: get %d\n", bit); 873 em28xx_videodbg("res: get %d\n", bit);
876 mutex_unlock(&dev->lock);
877 return 1; 874 return 1;
878} 875}
879 876
@@ -893,11 +890,9 @@ static void res_free(struct em28xx_fh *fh, unsigned int bits)
893 890
894 BUG_ON((fh->resources & bits) != bits); 891 BUG_ON((fh->resources & bits) != bits);
895 892
896 mutex_lock(&dev->lock);
897 fh->resources &= ~bits; 893 fh->resources &= ~bits;
898 dev->resources &= ~bits; 894 dev->resources &= ~bits;
899 em28xx_videodbg("res: put %d\n", bits); 895 em28xx_videodbg("res: put %d\n", bits);
900 mutex_unlock(&dev->lock);
901} 896}
902 897
903static int get_ressource(struct em28xx_fh *fh) 898static int get_ressource(struct em28xx_fh *fh)
@@ -1024,8 +1019,6 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void *priv,
1024 struct em28xx_fh *fh = priv; 1019 struct em28xx_fh *fh = priv;
1025 struct em28xx *dev = fh->dev; 1020 struct em28xx *dev = fh->dev;
1026 1021
1027 mutex_lock(&dev->lock);
1028
1029 f->fmt.pix.width = dev->width; 1022 f->fmt.pix.width = dev->width;
1030 f->fmt.pix.height = dev->height; 1023 f->fmt.pix.height = dev->height;
1031 f->fmt.pix.pixelformat = dev->format->fourcc; 1024 f->fmt.pix.pixelformat = dev->format->fourcc;
@@ -1039,8 +1032,6 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void *priv,
1039 else 1032 else
1040 f->fmt.pix.field = dev->interlaced ? 1033 f->fmt.pix.field = dev->interlaced ?
1041 V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP; 1034 V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP;
1042
1043 mutex_unlock(&dev->lock);
1044 return 0; 1035 return 0;
1045} 1036}
1046 1037
@@ -1138,22 +1129,15 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void *priv,
1138 if (rc < 0) 1129 if (rc < 0)
1139 return rc; 1130 return rc;
1140 1131
1141 mutex_lock(&dev->lock);
1142
1143 vidioc_try_fmt_vid_cap(file, priv, f); 1132 vidioc_try_fmt_vid_cap(file, priv, f);
1144 1133
1145 if (videobuf_queue_is_busy(&fh->vb_vidq)) { 1134 if (videobuf_queue_is_busy(&fh->vb_vidq)) {
1146 em28xx_errdev("%s queue busy\n", __func__); 1135 em28xx_errdev("%s queue busy\n", __func__);
1147 rc = -EBUSY; 1136 return -EBUSY;
1148 goto out;
1149 } 1137 }
1150 1138
1151 rc = em28xx_set_video_format(dev, f->fmt.pix.pixelformat, 1139 return em28xx_set_video_format(dev, f->fmt.pix.pixelformat,
1152 f->fmt.pix.width, f->fmt.pix.height); 1140 f->fmt.pix.width, f->fmt.pix.height);
1153
1154out:
1155 mutex_unlock(&dev->lock);
1156 return rc;
1157} 1141}
1158 1142
1159static int vidioc_g_std(struct file *file, void *priv, v4l2_std_id *norm) 1143static int vidioc_g_std(struct file *file, void *priv, v4l2_std_id *norm)
@@ -1182,7 +1166,6 @@ static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id *norm)
1182 if (rc < 0) 1166 if (rc < 0)
1183 return rc; 1167 return rc;
1184 1168
1185 mutex_lock(&dev->lock);
1186 dev->norm = *norm; 1169 dev->norm = *norm;
1187 1170
1188 /* Adjusts width/height, if needed */ 1171 /* Adjusts width/height, if needed */
@@ -1198,7 +1181,6 @@ static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id *norm)
1198 em28xx_resolution_set(dev); 1181 em28xx_resolution_set(dev);
1199 v4l2_device_call_all(&dev->v4l2_dev, 0, core, s_std, dev->norm); 1182 v4l2_device_call_all(&dev->v4l2_dev, 0, core, s_std, dev->norm);
1200 1183
1201 mutex_unlock(&dev->lock);
1202 return 0; 1184 return 0;
1203} 1185}
1204 1186
@@ -1303,9 +1285,7 @@ static int vidioc_s_input(struct file *file, void *priv, unsigned int i)
1303 1285
1304 dev->ctl_input = i; 1286 dev->ctl_input = i;
1305 1287
1306 mutex_lock(&dev->lock);
1307 video_mux(dev, dev->ctl_input); 1288 video_mux(dev, dev->ctl_input);
1308 mutex_unlock(&dev->lock);
1309 return 0; 1289 return 0;
1310} 1290}
1311 1291
@@ -1366,15 +1346,12 @@ static int vidioc_s_audio(struct file *file, void *priv, struct v4l2_audio *a)
1366 if (0 == INPUT(a->index)->type) 1346 if (0 == INPUT(a->index)->type)
1367 return -EINVAL; 1347 return -EINVAL;
1368 1348
1369 mutex_lock(&dev->lock);
1370
1371 dev->ctl_ainput = INPUT(a->index)->amux; 1349 dev->ctl_ainput = INPUT(a->index)->amux;
1372 dev->ctl_aoutput = INPUT(a->index)->aout; 1350 dev->ctl_aoutput = INPUT(a->index)->aout;
1373 1351
1374 if (!dev->ctl_aoutput) 1352 if (!dev->ctl_aoutput)
1375 dev->ctl_aoutput = EM28XX_AOUT_MASTER; 1353 dev->ctl_aoutput = EM28XX_AOUT_MASTER;
1376 1354
1377 mutex_unlock(&dev->lock);
1378 return 0; 1355 return 0;
1379} 1356}
1380 1357
@@ -1394,17 +1371,15 @@ static int vidioc_queryctrl(struct file *file, void *priv,
1394 1371
1395 qc->id = id; 1372 qc->id = id;
1396 1373
1397 /* enumberate AC97 controls */ 1374 /* enumerate AC97 controls */
1398 if (dev->audio_mode.ac97 != EM28XX_NO_AC97) { 1375 if (dev->audio_mode.ac97 != EM28XX_NO_AC97) {
1399 rc = ac97_queryctrl(qc); 1376 rc = ac97_queryctrl(qc);
1400 if (!rc) 1377 if (!rc)
1401 return 0; 1378 return 0;
1402 } 1379 }
1403 1380
1404 /* enumberate V4L2 device controls */ 1381 /* enumerate V4L2 device controls */
1405 mutex_lock(&dev->lock);
1406 v4l2_device_call_all(&dev->v4l2_dev, 0, core, queryctrl, qc); 1382 v4l2_device_call_all(&dev->v4l2_dev, 0, core, queryctrl, qc);
1407 mutex_unlock(&dev->lock);
1408 1383
1409 if (qc->type) 1384 if (qc->type)
1410 return 0; 1385 return 0;
@@ -1424,7 +1399,6 @@ static int vidioc_g_ctrl(struct file *file, void *priv,
1424 return rc; 1399 return rc;
1425 rc = 0; 1400 rc = 0;
1426 1401
1427 mutex_lock(&dev->lock);
1428 1402
1429 /* Set an AC97 control */ 1403 /* Set an AC97 control */
1430 if (dev->audio_mode.ac97 != EM28XX_NO_AC97) 1404 if (dev->audio_mode.ac97 != EM28XX_NO_AC97)
@@ -1438,7 +1412,6 @@ static int vidioc_g_ctrl(struct file *file, void *priv,
1438 rc = 0; 1412 rc = 0;
1439 } 1413 }
1440 1414
1441 mutex_unlock(&dev->lock);
1442 return rc; 1415 return rc;
1443} 1416}
1444 1417
@@ -1453,8 +1426,6 @@ static int vidioc_s_ctrl(struct file *file, void *priv,
1453 if (rc < 0) 1426 if (rc < 0)
1454 return rc; 1427 return rc;
1455 1428
1456 mutex_lock(&dev->lock);
1457
1458 /* Set an AC97 control */ 1429 /* Set an AC97 control */
1459 if (dev->audio_mode.ac97 != EM28XX_NO_AC97) 1430 if (dev->audio_mode.ac97 != EM28XX_NO_AC97)
1460 rc = ac97_set_ctrl(dev, ctrl); 1431 rc = ac97_set_ctrl(dev, ctrl);
@@ -1481,8 +1452,6 @@ static int vidioc_s_ctrl(struct file *file, void *priv,
1481 rc = em28xx_audio_analog_set(dev); 1452 rc = em28xx_audio_analog_set(dev);
1482 } 1453 }
1483 } 1454 }
1484
1485 mutex_unlock(&dev->lock);
1486 return rc; 1455 return rc;
1487} 1456}
1488 1457
@@ -1503,10 +1472,7 @@ static int vidioc_g_tuner(struct file *file, void *priv,
1503 strcpy(t->name, "Tuner"); 1472 strcpy(t->name, "Tuner");
1504 t->type = V4L2_TUNER_ANALOG_TV; 1473 t->type = V4L2_TUNER_ANALOG_TV;
1505 1474
1506 mutex_lock(&dev->lock);
1507 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, g_tuner, t); 1475 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, g_tuner, t);
1508 mutex_unlock(&dev->lock);
1509
1510 return 0; 1476 return 0;
1511} 1477}
1512 1478
@@ -1524,10 +1490,7 @@ static int vidioc_s_tuner(struct file *file, void *priv,
1524 if (0 != t->index) 1490 if (0 != t->index)
1525 return -EINVAL; 1491 return -EINVAL;
1526 1492
1527 mutex_lock(&dev->lock);
1528 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_tuner, t); 1493 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_tuner, t);
1529 mutex_unlock(&dev->lock);
1530
1531 return 0; 1494 return 0;
1532} 1495}
1533 1496
@@ -1537,11 +1500,8 @@ static int vidioc_g_frequency(struct file *file, void *priv,
1537 struct em28xx_fh *fh = priv; 1500 struct em28xx_fh *fh = priv;
1538 struct em28xx *dev = fh->dev; 1501 struct em28xx *dev = fh->dev;
1539 1502
1540 mutex_lock(&dev->lock);
1541 f->type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; 1503 f->type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV;
1542 f->frequency = dev->ctl_freq; 1504 f->frequency = dev->ctl_freq;
1543 mutex_unlock(&dev->lock);
1544
1545 return 0; 1505 return 0;
1546} 1506}
1547 1507
@@ -1564,13 +1524,9 @@ static int vidioc_s_frequency(struct file *file, void *priv,
1564 if (unlikely(1 == fh->radio && f->type != V4L2_TUNER_RADIO)) 1524 if (unlikely(1 == fh->radio && f->type != V4L2_TUNER_RADIO))
1565 return -EINVAL; 1525 return -EINVAL;
1566 1526
1567 mutex_lock(&dev->lock);
1568
1569 dev->ctl_freq = f->frequency; 1527 dev->ctl_freq = f->frequency;
1570 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_frequency, f); 1528 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_frequency, f);
1571 1529
1572 mutex_unlock(&dev->lock);
1573
1574 return 0; 1530 return 0;
1575} 1531}
1576 1532
@@ -1611,9 +1567,7 @@ static int vidioc_g_register(struct file *file, void *priv,
1611 1567
1612 switch (reg->match.type) { 1568 switch (reg->match.type) {
1613 case V4L2_CHIP_MATCH_AC97: 1569 case V4L2_CHIP_MATCH_AC97:
1614 mutex_lock(&dev->lock);
1615 ret = em28xx_read_ac97(dev, reg->reg); 1570 ret = em28xx_read_ac97(dev, reg->reg);
1616 mutex_unlock(&dev->lock);
1617 if (ret < 0) 1571 if (ret < 0)
1618 return ret; 1572 return ret;
1619 1573
@@ -1635,9 +1589,7 @@ static int vidioc_g_register(struct file *file, void *priv,
1635 /* Match host */ 1589 /* Match host */
1636 reg->size = em28xx_reg_len(reg->reg); 1590 reg->size = em28xx_reg_len(reg->reg);
1637 if (reg->size == 1) { 1591 if (reg->size == 1) {
1638 mutex_lock(&dev->lock);
1639 ret = em28xx_read_reg(dev, reg->reg); 1592 ret = em28xx_read_reg(dev, reg->reg);
1640 mutex_unlock(&dev->lock);
1641 1593
1642 if (ret < 0) 1594 if (ret < 0)
1643 return ret; 1595 return ret;
@@ -1645,10 +1597,8 @@ static int vidioc_g_register(struct file *file, void *priv,
1645 reg->val = ret; 1597 reg->val = ret;
1646 } else { 1598 } else {
1647 __le16 val = 0; 1599 __le16 val = 0;
1648 mutex_lock(&dev->lock);
1649 ret = em28xx_read_reg_req_len(dev, USB_REQ_GET_STATUS, 1600 ret = em28xx_read_reg_req_len(dev, USB_REQ_GET_STATUS,
1650 reg->reg, (char *)&val, 2); 1601 reg->reg, (char *)&val, 2);
1651 mutex_unlock(&dev->lock);
1652 if (ret < 0) 1602 if (ret < 0)
1653 return ret; 1603 return ret;
1654 1604
@@ -1668,11 +1618,7 @@ static int vidioc_s_register(struct file *file, void *priv,
1668 1618
1669 switch (reg->match.type) { 1619 switch (reg->match.type) {
1670 case V4L2_CHIP_MATCH_AC97: 1620 case V4L2_CHIP_MATCH_AC97:
1671 mutex_lock(&dev->lock); 1621 return em28xx_write_ac97(dev, reg->reg, reg->val);
1672 rc = em28xx_write_ac97(dev, reg->reg, reg->val);
1673 mutex_unlock(&dev->lock);
1674
1675 return rc;
1676 case V4L2_CHIP_MATCH_I2C_DRIVER: 1622 case V4L2_CHIP_MATCH_I2C_DRIVER:
1677 v4l2_device_call_all(&dev->v4l2_dev, 0, core, s_register, reg); 1623 v4l2_device_call_all(&dev->v4l2_dev, 0, core, s_register, reg);
1678 return 0; 1624 return 0;
@@ -1688,12 +1634,8 @@ static int vidioc_s_register(struct file *file, void *priv,
1688 /* Match host */ 1634 /* Match host */
1689 buf = cpu_to_le16(reg->val); 1635 buf = cpu_to_le16(reg->val);
1690 1636
1691 mutex_lock(&dev->lock); 1637 return em28xx_write_regs(dev, reg->reg, (char *)&buf,
1692 rc = em28xx_write_regs(dev, reg->reg, (char *)&buf,
1693 em28xx_reg_len(reg->reg)); 1638 em28xx_reg_len(reg->reg));
1694 mutex_unlock(&dev->lock);
1695
1696 return rc;
1697} 1639}
1698#endif 1640#endif
1699 1641
@@ -1830,16 +1772,12 @@ static int vidioc_g_fmt_sliced_vbi_cap(struct file *file, void *priv,
1830 if (rc < 0) 1772 if (rc < 0)
1831 return rc; 1773 return rc;
1832 1774
1833 mutex_lock(&dev->lock);
1834
1835 f->fmt.sliced.service_set = 0; 1775 f->fmt.sliced.service_set = 0;
1836 v4l2_device_call_all(&dev->v4l2_dev, 0, vbi, g_sliced_fmt, &f->fmt.sliced); 1776 v4l2_device_call_all(&dev->v4l2_dev, 0, vbi, g_sliced_fmt, &f->fmt.sliced);
1837 1777
1838 if (f->fmt.sliced.service_set == 0) 1778 if (f->fmt.sliced.service_set == 0)
1839 rc = -EINVAL; 1779 rc = -EINVAL;
1840 1780
1841 mutex_unlock(&dev->lock);
1842
1843 return rc; 1781 return rc;
1844} 1782}
1845 1783
@@ -1854,9 +1792,7 @@ static int vidioc_try_set_sliced_vbi_cap(struct file *file, void *priv,
1854 if (rc < 0) 1792 if (rc < 0)
1855 return rc; 1793 return rc;
1856 1794
1857 mutex_lock(&dev->lock);
1858 v4l2_device_call_all(&dev->v4l2_dev, 0, vbi, g_sliced_fmt, &f->fmt.sliced); 1795 v4l2_device_call_all(&dev->v4l2_dev, 0, vbi, g_sliced_fmt, &f->fmt.sliced);
1859 mutex_unlock(&dev->lock);
1860 1796
1861 if (f->fmt.sliced.service_set == 0) 1797 if (f->fmt.sliced.service_set == 0)
1862 return -EINVAL; 1798 return -EINVAL;
@@ -2041,9 +1977,7 @@ static int radio_g_tuner(struct file *file, void *priv,
2041 strcpy(t->name, "Radio"); 1977 strcpy(t->name, "Radio");
2042 t->type = V4L2_TUNER_RADIO; 1978 t->type = V4L2_TUNER_RADIO;
2043 1979
2044 mutex_lock(&dev->lock);
2045 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, g_tuner, t); 1980 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, g_tuner, t);
2046 mutex_unlock(&dev->lock);
2047 1981
2048 return 0; 1982 return 0;
2049} 1983}
@@ -2076,9 +2010,7 @@ static int radio_s_tuner(struct file *file, void *priv,
2076 if (0 != t->index) 2010 if (0 != t->index)
2077 return -EINVAL; 2011 return -EINVAL;
2078 2012
2079 mutex_lock(&dev->lock);
2080 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_tuner, t); 2013 v4l2_device_call_all(&dev->v4l2_dev, 0, tuner, s_tuner, t);
2081 mutex_unlock(&dev->lock);
2082 2014
2083 return 0; 2015 return 0;
2084} 2016}
@@ -2138,8 +2070,6 @@ static int em28xx_v4l2_open(struct file *filp)
2138 break; 2070 break;
2139 } 2071 }
2140 2072
2141 mutex_lock(&dev->lock);
2142
2143 em28xx_videodbg("open dev=%s type=%s users=%d\n", 2073 em28xx_videodbg("open dev=%s type=%s users=%d\n",
2144 video_device_node_name(vdev), v4l2_type_names[fh_type], 2074 video_device_node_name(vdev), v4l2_type_names[fh_type],
2145 dev->users); 2075 dev->users);
@@ -2148,7 +2078,6 @@ static int em28xx_v4l2_open(struct file *filp)
2148 fh = kzalloc(sizeof(struct em28xx_fh), GFP_KERNEL); 2078 fh = kzalloc(sizeof(struct em28xx_fh), GFP_KERNEL);
2149 if (!fh) { 2079 if (!fh) {
2150 em28xx_errdev("em28xx-video.c: Out of memory?!\n"); 2080 em28xx_errdev("em28xx-video.c: Out of memory?!\n");
2151 mutex_unlock(&dev->lock);
2152 return -ENOMEM; 2081 return -ENOMEM;
2153 } 2082 }
2154 fh->dev = dev; 2083 fh->dev = dev;
@@ -2182,15 +2111,13 @@ static int em28xx_v4l2_open(struct file *filp)
2182 videobuf_queue_vmalloc_init(&fh->vb_vidq, &em28xx_video_qops, 2111 videobuf_queue_vmalloc_init(&fh->vb_vidq, &em28xx_video_qops,
2183 NULL, &dev->slock, 2112 NULL, &dev->slock,
2184 V4L2_BUF_TYPE_VIDEO_CAPTURE, field, 2113 V4L2_BUF_TYPE_VIDEO_CAPTURE, field,
2185 sizeof(struct em28xx_buffer), fh, NULL); 2114 sizeof(struct em28xx_buffer), fh, &dev->lock);
2186 2115
2187 videobuf_queue_vmalloc_init(&fh->vb_vbiq, &em28xx_vbi_qops, 2116 videobuf_queue_vmalloc_init(&fh->vb_vbiq, &em28xx_vbi_qops,
2188 NULL, &dev->slock, 2117 NULL, &dev->slock,
2189 V4L2_BUF_TYPE_VBI_CAPTURE, 2118 V4L2_BUF_TYPE_VBI_CAPTURE,
2190 V4L2_FIELD_SEQ_TB, 2119 V4L2_FIELD_SEQ_TB,
2191 sizeof(struct em28xx_buffer), fh, NULL); 2120 sizeof(struct em28xx_buffer), fh, &dev->lock);
2192
2193 mutex_unlock(&dev->lock);
2194 2121
2195 return errCode; 2122 return errCode;
2196} 2123}
@@ -2389,7 +2316,7 @@ static const struct v4l2_file_operations em28xx_v4l_fops = {
2389 .read = em28xx_v4l2_read, 2316 .read = em28xx_v4l2_read,
2390 .poll = em28xx_v4l2_poll, 2317 .poll = em28xx_v4l2_poll,
2391 .mmap = em28xx_v4l2_mmap, 2318 .mmap = em28xx_v4l2_mmap,
2392 .ioctl = video_ioctl2, 2319 .unlocked_ioctl = video_ioctl2,
2393}; 2320};
2394 2321
2395static const struct v4l2_ioctl_ops video_ioctl_ops = { 2322static const struct v4l2_ioctl_ops video_ioctl_ops = {
@@ -2497,6 +2424,7 @@ static struct video_device *em28xx_vdev_init(struct em28xx *dev,
2497 vfd->v4l2_dev = &dev->v4l2_dev; 2424 vfd->v4l2_dev = &dev->v4l2_dev;
2498 vfd->release = video_device_release; 2425 vfd->release = video_device_release;
2499 vfd->debug = video_debug; 2426 vfd->debug = video_debug;
2427 vfd->lock = &dev->lock;
2500 2428
2501 snprintf(vfd->name, sizeof(vfd->name), "%s %s", 2429 snprintf(vfd->name, sizeof(vfd->name), "%s %s",
2502 dev->name, type_name); 2430 dev->name, type_name);