aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/cx23885/cx23885-video.c128
1 files changed, 13 insertions, 115 deletions
diff --git a/drivers/media/video/cx23885/cx23885-video.c b/drivers/media/video/cx23885/cx23885-video.c
index 40d5e778aa25..44c809474ba1 100644
--- a/drivers/media/video/cx23885/cx23885-video.c
+++ b/drivers/media/video/cx23885/cx23885-video.c
@@ -270,11 +270,13 @@ void cx23885_video_wakeup(struct cx23885_dev *dev,
270 break; 270 break;
271 buf = list_entry(q->active.next, 271 buf = list_entry(q->active.next,
272 struct cx23885_buffer, vb.queue); 272 struct cx23885_buffer, vb.queue);
273
273 /* count comes from the hw and is is 16bit wide -- 274 /* count comes from the hw and is is 16bit wide --
274 * this trick handles wrap-arounds correctly for 275 * this trick handles wrap-arounds correctly for
275 * up to 32767 buffers in flight... */ 276 * up to 32767 buffers in flight... */
276 if ((s16) (count - buf->count) < 0) 277 if ((s16) (count - buf->count) < 0)
277 break; 278 break;
279
278 do_gettimeofday(&buf->vb.ts); 280 do_gettimeofday(&buf->vb.ts);
279 dprintk(2, "[%p/%d] wakeup reg=%d buf=%d\n", buf, buf->vb.i, 281 dprintk(2, "[%p/%d] wakeup reg=%d buf=%d\n", buf, buf->vb.i,
280 count, buf->count); 282 count, buf->count);
@@ -301,7 +303,6 @@ int cx23885_set_tvnorm(struct cx23885_dev *dev, v4l2_std_id norm)
301 303
302 dev->tvnorm = norm; 304 dev->tvnorm = norm;
303 305
304
305 /* Tell the analog tuner/demods */ 306 /* Tell the analog tuner/demods */
306 cx23885_call_i2c_clients(&dev->i2c_bus[1], VIDIOC_S_STD, &norm); 307 cx23885_call_i2c_clients(&dev->i2c_bus[1], VIDIOC_S_STD, &norm);
307 308
@@ -455,20 +456,6 @@ static int cx23885_start_video_dma(struct cx23885_dev *dev,
455 return 0; 456 return 0;
456} 457}
457 458
458#ifdef CONFIG_PM
459static int cx23885_stop_video_dma(struct cx23885_dev *dev)
460{
461 dprintk(1, "%s()\n", __FUNCTION__);
462 /* stop dma */
463 cx_clear(VID_A_DMA_CTL, 0x11);
464
465 /* disable irqs */
466 cx_clear(PCI_INT_MSK, 0x000001);
467 cx_clear(VID_A_INT_MSK, 0x000011);
468
469 return 0;
470}
471#endif
472 459
473static int cx23885_restart_video_queue(struct cx23885_dev *dev, 460static int cx23885_restart_video_queue(struct cx23885_dev *dev,
474 struct cx23885_dmaqueue *q) 461 struct cx23885_dmaqueue *q)
@@ -877,6 +864,10 @@ static int video_release(struct inode *inode, struct file *file)
877 file->private_data = NULL; 864 file->private_data = NULL;
878 kfree(fh); 865 kfree(fh);
879 866
867 /* We are not putting the tuner to sleep here on exit, because
868 * we want to use the mpeg encoder in another session to capture
869 * tuner video. Closing this will result in no video to the encoder.
870 */
880 871
881 return 0; 872 return 0;
882} 873}
@@ -1337,6 +1328,9 @@ static int vidioc_g_register(struct file *file, void *fh,
1337{ 1328{
1338 struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev; 1329 struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev;
1339 1330
1331 if (!v4l2_chip_match_host(reg->match_type, reg->match_chip))
1332 return -EINVAL;
1333
1340 cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_G_REGISTER, reg); 1334 cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_G_REGISTER, reg);
1341 1335
1342 return 0; 1336 return 0;
@@ -1347,108 +1341,14 @@ static int vidioc_s_register(struct file *file, void *fh,
1347{ 1341{
1348 struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev; 1342 struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev;
1349 1343
1350 cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_S_REGISTER, reg); 1344 if (!v4l2_chip_match_host(reg->match_type, reg->match_chip))
1351 return 0;
1352}
1353#endif
1354
1355/* ----------------------------------------------------------- */
1356/* RADIO ESPECIFIC IOCTLS */
1357/* ----------------------------------------------------------- */
1358
1359static int radio_querycap(struct file *file, void *priv,
1360 struct v4l2_capability *cap)
1361{
1362 struct cx23885_dev *dev = ((struct cx23885_fh *)priv)->dev;
1363
1364 strcpy(cap->driver, "cx23885");
1365 strlcpy(cap->card, cx23885_boards[dev->board].name,
1366 sizeof(cap->card));
1367 sprintf(cap->bus_info, "PCIe:%s", pci_name(dev->pci));
1368 cap->version = CX23885_VERSION_CODE;
1369 cap->capabilities = V4L2_CAP_TUNER;
1370 return 0;
1371}
1372
1373static int radio_g_tuner(struct file *file, void *priv,
1374 struct v4l2_tuner *t)
1375{
1376 struct cx23885_dev *dev = ((struct cx23885_fh *)priv)->dev;
1377
1378 if (unlikely(t->index > 0))
1379 return -EINVAL;
1380
1381 strcpy(t->name, "Radio");
1382 t->type = V4L2_TUNER_RADIO;
1383
1384 cx23885_call_i2c_clients(&dev->i2c_bus[1], VIDIOC_G_TUNER, t);
1385 return 0;
1386}
1387
1388static int radio_enum_input(struct file *file, void *priv,
1389 struct v4l2_input *i)
1390{
1391 if (i->index != 0)
1392 return -EINVAL;
1393 strcpy(i->name, "Radio");
1394 i->type = V4L2_INPUT_TYPE_TUNER;
1395
1396 return 0;
1397}
1398
1399static int radio_g_audio(struct file *file, void *priv, struct v4l2_audio *a)
1400{
1401 if (unlikely(a->index))
1402 return -EINVAL;
1403
1404 memset(a, 0, sizeof(*a));
1405 strcpy(a->name, "Radio");
1406 return 0;
1407}
1408
1409/* FIXME: Should add a standard for radio */
1410
1411static int radio_s_tuner(struct file *file, void *priv,
1412 struct v4l2_tuner *t)
1413{
1414 struct cx23885_dev *dev = ((struct cx23885_fh *)priv)->dev;
1415
1416 if (0 != t->index)
1417 return -EINVAL; 1345 return -EINVAL;
1418 1346
1419 cx23885_call_i2c_clients(&dev->i2c_bus[1], VIDIOC_S_TUNER, t); 1347 cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_S_REGISTER, reg);
1420
1421 return 0;
1422}
1423
1424static int radio_s_audio(struct file *file, void *fh,
1425 struct v4l2_audio *a)
1426{
1427 return 0;
1428}
1429
1430static int radio_s_input(struct file *file, void *fh, unsigned int i)
1431{
1432 return 0;
1433}
1434
1435static int radio_queryctrl(struct file *file, void *priv,
1436 struct v4l2_queryctrl *c)
1437{
1438 int i;
1439 1348
1440 if (c->id < V4L2_CID_BASE ||
1441 c->id >= V4L2_CID_LASTP1)
1442 return -EINVAL;
1443 if (c->id == V4L2_CID_AUDIO_MUTE) {
1444 for (i = 0; i < CX23885_CTLS; i++)
1445 if (cx23885_ctls[i].v.id == c->id)
1446 break;
1447 *c = cx23885_ctls[i].v;
1448 } else
1449 *c = no_ctl;
1450 return 0; 1349 return 0;
1451} 1350}
1351#endif
1452 1352
1453/* ----------------------------------------------------------- */ 1353/* ----------------------------------------------------------- */
1454 1354
@@ -1517,7 +1417,6 @@ int cx23885_video_irq(struct cx23885_dev *dev, u32 status)
1517 return handled; 1417 return handled;
1518} 1418}
1519 1419
1520
1521/* ----------------------------------------------------------- */ 1420/* ----------------------------------------------------------- */
1522/* exported stuff */ 1421/* exported stuff */
1523 1422
@@ -1625,6 +1524,7 @@ int cx23885_video_register(struct cx23885_dev *dev)
1625 cx23885_risc_stopper(dev->pci, &dev->vidq.stopper, 1524 cx23885_risc_stopper(dev->pci, &dev->vidq.stopper,
1626 VID_A_DMA_CTL, 0x11, 0x00); 1525 VID_A_DMA_CTL, 0x11, 0x00);
1627 1526
1527 /* Don't enable VBI yet */
1628 cx_set(PCI_INT_MSK, 1); 1528 cx_set(PCI_INT_MSK, 1);
1629 1529
1630 1530
@@ -1647,8 +1547,6 @@ int cx23885_video_register(struct cx23885_dev *dev)
1647 cx23885_video_mux(dev, 0); 1547 cx23885_video_mux(dev, 0);
1648 mutex_unlock(&dev->lock); 1548 mutex_unlock(&dev->lock);
1649 1549
1650 /* FIXME start tvaudio thread */
1651
1652 return 0; 1550 return 0;
1653 1551
1654fail_unreg: 1552fail_unreg: