summaryrefslogtreecommitdiff
path: root/linux/drivers/media/video/cx23885/cx23885-video.c
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers/media/video/cx23885/cx23885-video.c')
-rw-r--r--linux/drivers/media/video/cx23885/cx23885-video.c79
1 files changed, 16 insertions, 63 deletions
diff --git a/linux/drivers/media/video/cx23885/cx23885-video.c b/linux/drivers/media/video/cx23885/cx23885-video.c
index cc0b16d26..66a3528dc 100644
--- a/linux/drivers/media/video/cx23885/cx23885-video.c
+++ b/linux/drivers/media/video/cx23885/cx23885-video.c
@@ -320,16 +320,13 @@ void cx23885_video_wakeup(struct cx23885_dev *dev,
break;
buf = list_entry(q->active.next,
struct cx23885_buffer, vb.queue);
-#if 0
- if (buf->count > count)
- break;
-#else
+
/* count comes from the hw and is is 16bit wide --
* this trick handles wrap-arounds correctly for
* up to 32767 buffers in flight... */
if ((s16) (count - buf->count) < 0)
break;
-#endif
+
do_gettimeofday(&buf->vb.ts);
dprintk(2, "[%p/%d] wakeup reg=%d buf=%d\n", buf, buf->vb.i,
count, buf->count);
@@ -356,10 +353,6 @@ int cx23885_set_tvnorm(struct cx23885_dev *dev, v4l2_std_id norm)
dev->tvnorm = norm;
-#if 0
- set_tvaudio(core);
-#endif
-
/* Tell the analog tuner/demods */
cx23885_call_i2c_clients(&dev->i2c_bus[1], VIDIOC_S_STD, &norm);
@@ -520,6 +513,7 @@ static int cx23885_start_video_dma(struct cx23885_dev *dev,
return 0;
}
+#if 0
#ifdef CONFIG_PM
static int cx23885_stop_video_dma(struct cx23885_dev *dev)
{
@@ -534,6 +528,7 @@ static int cx23885_stop_video_dma(struct cx23885_dev *dev)
return 0;
}
#endif
+#endif
static int cx23885_restart_video_queue(struct cx23885_dev *dev,
struct cx23885_dmaqueue *q)
@@ -960,11 +955,11 @@ static int video_release(struct inode *inode, struct file *file)
file->private_data = NULL;
kfree(fh);
-#if 0
- /* FIXME: We are not putting the tuner to sleep here on exit, because
+ /* We are not putting the tuner to sleep here on exit, because
* we want to use the mpeg encoder in another session to capture
* tuner video. Closing this will result in no video to the encoder.
*/
+#if 0
cx23885_call_i2c_clients(&dev->i2c_bus[1], TUNER_SET_STANDBY, NULL);
#endif
@@ -1313,9 +1308,6 @@ static int vidioc_s_input(struct file *file, void *priv, unsigned int i)
}
mutex_lock(&dev->lock);
-#if 0
- cx23885_newstation(dev);
-#endif
cx23885_video_mux(dev, i);
mutex_unlock(&dev->lock);
return 0;
@@ -1442,14 +1434,11 @@ static int vidioc_g_register(struct file *file, void *fh,
{
struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev;
- cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_G_REGISTER, reg);
-
-#if 0
if (!v4l2_chip_match_host(reg->match_type, reg->match_chip))
return -EINVAL;
- /* cx2388x has a 24-bit register space */
- reg->val = cx_read(reg->reg&0xffffff);
-#endif
+
+ cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_G_REGISTER, reg);
+
return 0;
}
@@ -1458,16 +1447,16 @@ static int vidioc_s_register(struct file *file, void *fh,
{
struct cx23885_dev *dev = ((struct cx23885_fh *)fh)->dev;
- cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_S_REGISTER, reg);
-#if 0
if (!v4l2_chip_match_host(reg->match_type, reg->match_chip))
return -EINVAL;
- cx_write(reg->reg&0xffffff, reg->val);
-#endif
+
+ cx23885_call_i2c_clients(&dev->i2c_bus[2], VIDIOC_DBG_S_REGISTER, reg);
+
return 0;
}
#endif
+#if 0
/* ----------------------------------------------------------- */
/* RADIO ESPECIFIC IOCTLS */
/* ----------------------------------------------------------- */
@@ -1565,7 +1554,7 @@ static int radio_queryctrl(struct file *file, void *priv,
*c = no_ctl;
return 0;
}
-
+#endif
/* ----------------------------------------------------------- */
static void cx23885_vid_timeout(unsigned long data)
@@ -1653,41 +1642,6 @@ int cx23885_video_irq(struct cx23885_dev *dev, u32 status)
return handled;
}
-#if 0
-#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19)
-static irqreturn_t cx8800_irq(int irq, void *dev_id, struct pt_regs *regs)
-#else
-static irqreturn_t cx8800_irq(int irq, void *dev_id)
-#endif
-{
- struct cx8800_dev *dev = dev_id;
- struct cx88_core *core = dev->core;
- u32 status;
- int loop, handled = 0;
-
- for (loop = 0; loop < 10; loop++) {
- status = cx_read(MO_PCI_INTSTAT) & (core->pci_irqmask | 0x01);
- if (0 == status)
- goto out;
- cx_write(MO_PCI_INTSTAT, status);
- handled = 1;
-
- if (status & core->pci_irqmask)
- cx88_core_irq(core, status);
- if (status & 0x01)
- cx8800_vid_irq(dev);
- };
- if (10 == loop) {
- printk(KERN_WARNING "%s/0: irq loop -- clearing mask\n",
- core->name);
- cx_write(MO_PCI_INTMSK, 0);
- }
-
- out:
- return IRQ_RETVAL(handled);
-}
-#endif
-
/* ----------------------------------------------------------- */
/* exported stuff */
@@ -1762,7 +1716,6 @@ static const struct file_operations radio_fops = {
static struct video_device cx23885_radio_template = {
.name = "cx23885-radio",
.type = VID_TYPE_TUNER,
- .hardware = 0,
.fops = &radio_fops,
.minor = -1,
.vidioc_querycap = radio_querycap,
@@ -1837,6 +1790,7 @@ int cx23885_video_register(struct cx23885_dev *dev)
cx23885_risc_stopper(dev->pci, &dev->vidq.stopper,
VID_A_DMA_CTL, 0x11, 0x00);
+ /* Don't enable VBI yet */
#if 0
/* init vbi dma queues */
INIT_LIST_HEAD(&dev->vbiq.active);
@@ -1850,6 +1804,7 @@ int cx23885_video_register(struct cx23885_dev *dev)
cx_set(PCI_INT_MSK, 1);
#if 0
+ /* FIXME: These should be correctly defined */
/* load and configure helper modules */
if (TUNER_ABSENT != core->tuner_type)
request_module("tuner");
@@ -1904,8 +1859,6 @@ int cx23885_video_register(struct cx23885_dev *dev)
cx23885_video_mux(dev, 0);
mutex_unlock(&dev->lock);
- /* FIXME start tvaudio thread */
-
return 0;
fail_unreg: