diff options
-rw-r--r-- | linux/drivers/media/dvb/ttpci-budget/budget-core.c | 47 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttpci-budget/budget.c | 2 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttpci-budget/budget.h | 3 |
3 files changed, 42 insertions, 10 deletions
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); diff --git a/linux/drivers/media/dvb/ttpci-budget/budget.c b/linux/drivers/media/dvb/ttpci-budget/budget.c index 4c207f83a..4d0207476 100644 --- a/linux/drivers/media/dvb/ttpci-budget/budget.c +++ b/linux/drivers/media/dvb/ttpci-budget/budget.c @@ -86,7 +86,7 @@ struct saa7146_extension budget_extension = { .attach = this_budget_attach, .detach = budget_detach, - .irq_mask = MASK_07, + .irq_mask = MASK_07|MASK_10, .irq_func = budget_irq, }; diff --git a/linux/drivers/media/dvb/ttpci-budget/budget.h b/linux/drivers/media/dvb/ttpci-budget/budget.h index 0a0a5b16b..47c5b6225 100644 --- a/linux/drivers/media/dvb/ttpci-budget/budget.h +++ b/linux/drivers/media/dvb/ttpci-budget/budget.h @@ -35,6 +35,7 @@ struct budget_s { struct saa7146_pgtable pt; struct tasklet_struct fidb_tasklet; + struct tasklet_struct vpe_tasklet; dmxdev_t dmxdev; struct dvb_demux demux; @@ -47,7 +48,7 @@ struct budget_s { struct semaphore pid_mutex; u8 tsf; - u16 ttbp; + u32 ttbp; int feeding; int registered; |