From bb7e4b9a970806b7e6b6f8d29db533c363928836 Mon Sep 17 00:00:00 2001 From: Holger Waechtler Date: Fri, 7 Feb 2003 14:19:11 +0000 Subject: apply new irq handler for Nova cards contributed by Marian Durkovic , ported by Emard to the 2.5 kernel tree --- linux/drivers/media/dvb/ttpci-budget/budget-core.c | 47 ++++++++++++++++++---- 1 file changed, 39 insertions(+), 8 deletions(-) (limited to 'linux/drivers/media/dvb/ttpci-budget/budget-core.c') diff --git a/linux/drivers/media/dvb/ttpci-budget/budget-core.c b/linux/drivers/media/dvb/ttpci-budget/budget-core.c index 0f109a12f..1d899c3d9 100644 --- a/linux/drivers/media/dvb/ttpci-budget/budget-core.c +++ b/linux/drivers/media/dvb/ttpci-budget/budget-core.c @@ -58,7 +58,7 @@ TTBStop(struct budget_s *budget) return budget->feeding; saa7146_write(budget->dev, MC1, MASK_20); // DMA3 off - IER_DISABLE(budget->dev, MASK_07); + IER_DISABLE(budget->dev, MASK_07|MASK_10); return 0; } @@ -81,7 +81,7 @@ TTBStart(struct budget_s *budget) budget->tsf=0xff; budget->ttbp=0; - saa7146_write(dev, DD1_INIT, 0x020006c0); + saa7146_write(dev, DD1_INIT, 0x02000600); saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26)); saa7146_write(dev, BRS_CTRL, 0x60000000); @@ -91,20 +91,48 @@ TTBStart(struct budget_s *budget) saa7146_write(dev, BASE_ODD3, 0); saa7146_write(dev, BASE_EVEN3, TS_WIDTH*TS_HEIGHT/2); saa7146_write(dev, PROT_ADDR3, TS_WIDTH*TS_HEIGHT); - saa7146_write(dev, BASE_PAGE3, budget->pt.dma |ME1|0xb0); - saa7146_write(dev, PITCH3, TS_WIDTH); + saa7146_write(dev, BASE_PAGE3, budget->pt.dma |ME1|0x90); + saa7146_write(dev, PITCH3, TS_WIDTH); saa7146_write(dev, NUM_LINE_BYTE3, ((TS_HEIGHT/2)<<16)|TS_WIDTH); saa7146_write(dev, MC2, (MASK_04 | MASK_20)); - saa7146_write(dev, MC1, (MASK_04 | MASK_20)); // DMA3 on - // FIDB - IER_ENABLE(budget->dev, MASK_07); + IER_ENABLE(budget->dev, MASK_07|MASK_10); // FIDB + VPE return ++budget->feeding; } +static void vpeirq (unsigned long data) +{ + struct budget_s *budget = (struct budget_s*) data; + u8 *mem=(u8 *)(budget->grabbing); + int num; + u32 dmapos; + + dmapos=saa7146_read(budget->dev, PCI_VDP3); + dmapos-=(dmapos%188); + + if (dmapos >= TS_BUFLEN) + return; + + if (dmapos > budget->ttbp) { + mem+=budget->ttbp; + num=(dmapos-budget->ttbp)/188; + } else { + if (budget->feeding && mem[budget->ttbp]==0x47) + dvb_dmx_swfilter_packets(&budget->demux, + mem+budget->ttbp, 1024-budget->ttbp/188); + + num=dmapos/188; + } + + budget->ttbp=dmapos; + + if (budget->feeding && mem[0]==0x47) + dvb_dmx_swfilter_packets(&budget->demux, mem, num); +} + /* TS_PACKETS is minumum number of accumulated 188-byte packets ** (TS_SIZE=188) that is considered 'complete' and can ** be delivered to the sw_demux in one 'quantum'. @@ -123,7 +151,7 @@ void fidbirq (unsigned long data) u16 newpkt = saa7146_read(budget->dev, PCI_VDP3)/TS_QUANTUM; /* PCI_VDP3 = 0..TS_BUFLEN-1 */ u8 *olddma = mem + oldpkt*TS_QUANTUM; /* rounded to first complete packet */ - DEB_EE(("budget: %p\n",budget)); + DEB_EE(("budget: %p\n", budget)); /* Zero-Packet-Loss fidbirq by EMARD */ @@ -545,6 +573,7 @@ int budget_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *i saa7146_write(dev, GPIO_CTRL, 0x000000); tasklet_init (&budget->fidb_tasklet, fidbirq, (unsigned long) budget); + tasklet_init (&budget->vpe_tasklet, vpeirq, (unsigned long) budget); saa7146_setgpio(dev, 2, SAA7146_GPIO_OUTHI); /* frontend power on */ return 0; @@ -590,6 +619,8 @@ void budget_irq(struct saa7146_dev* dev, u32 *isr) if (*isr & MASK_07) tasklet_schedule (&budget->fidb_tasklet); + if (*isr & MASK_10) + tasklet_schedule (&budget->vpe_tasklet); } EXPORT_SYMBOL_GPL(budget_register); -- cgit v1.2.3