diff options
Diffstat (limited to 'linux/drivers')
-rw-r--r-- | linux/drivers/media/dvb/dvb-core/dvb_net.c | 37 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttpci/av7110.c | 193 | ||||
-rw-r--r-- | linux/drivers/media/dvb/ttpci/av7110.h | 21 |
3 files changed, 124 insertions, 127 deletions
diff --git a/linux/drivers/media/dvb/dvb-core/dvb_net.c b/linux/drivers/media/dvb/dvb-core/dvb_net.c index 64977ba4b..2a4d70a5e 100644 --- a/linux/drivers/media/dvb/dvb-core/dvb_net.c +++ b/linux/drivers/media/dvb/dvb-core/dvb_net.c @@ -123,7 +123,6 @@ static void hexdump( const unsigned char *buf, unsigned short len ) struct dvb_net_priv { int in_use; struct net_device_stats stats; - char name[7]; u16 pid; struct dvb_net *host; struct dmx_demux *demux; @@ -228,7 +227,7 @@ int ule_bridged_sndu( struct dvb_net_priv *p ) /* BRIDGE SNDU handling sucks in draft-ietf-ipdvb-ule-03.txt. * This has to be the last extension header, otherwise it won't work. * Blame the authors! - */ + */ p->ule_bridged = 1; return 0; } @@ -237,7 +236,7 @@ int ule_bridged_sndu( struct dvb_net_priv *p ) /** Handle ULE extension headers. * Function is called after a successful CRC32 verification of an ULE SNDU to complete its decoding. * Returns: >= 0: nr. of bytes consumed by next extension header - * -1: Mandatory extension header that is not recognized or TEST SNDU; discard. + * -1: Mandatory extension header that is not recognized or TEST SNDU; discard. */ static int handle_one_ule_extension( struct dvb_net_priv *p ) { @@ -1157,30 +1156,25 @@ static int dvb_net_add_if(struct dvb_net *dvbnet, u16 pid, u8 feedtype) struct dvb_net_priv *priv; int result; int if_num; - char name[20]; - - memset(name, 0, sizeof(name)); - + if (feedtype != DVB_NET_FEEDTYPE_MPE && feedtype != DVB_NET_FEEDTYPE_ULE) return -EINVAL; if ((if_num = get_if(dvbnet)) < 0) return -EINVAL; - sprintf(name, "dvb%1d%1d%1d", - dvbnet->dvbdev->adapter->num, dvbnet->dvbdev->id, if_num); - /* compatibility fix to keep dvb0_0 format */ - if(name[4] == '0') - name[4] = '_'; - - net = alloc_netdev(sizeof(struct dvb_net_priv), name, - dvb_net_setup); + net = alloc_netdev(sizeof(struct dvb_net_priv), "dvb", dvb_net_setup); if (!net) return -ENOMEM; - sprintf(net->name, "%s", name); - printk("dvb_net: created network interface %s\n", net->name); - - net->addr_len = 6; + if (dvbnet->dvbdev->id) + snprintf(net->name, IFNAMSIZ, "dvb%d%u%d", + dvbnet->dvbdev->adapter->num, dvbnet->dvbdev->id, if_num); + else + /* compatibility fix to keep dvb0_0 format */ + snprintf(net->name, IFNAMSIZ, "dvb%d_%d", + dvbnet->dvbdev->adapter->num, if_num); + + net->addr_len = 6; memcpy(net->dev_addr, dvbnet->dvbdev->adapter->proposed_mac, 6); dvbnet->device[if_num] = net; @@ -1204,6 +1198,7 @@ static int dvb_net_add_if(struct dvb_net *dvbnet, u16 pid, u8 feedtype) free_netdev(net); return result; } + printk("dvb_net: created network interface %s\n", net->name); return if_num; } @@ -1222,7 +1217,7 @@ static int dvb_net_remove_if(struct dvb_net *dvbnet, unsigned int num) dvb_net_stop(net); flush_scheduled_work(); printk("dvb_net: removed network interface %s\n", net->name); - unregister_netdev(net); + unregister_netdev(net); dvbnet->state[num]=0; dvbnet->device[num] = NULL; free_netdev(net); @@ -1247,7 +1242,7 @@ static int dvb_net_do_ioctl(struct inode *inode, struct file *file, if (!capable(CAP_SYS_ADMIN)) return -EPERM; - + if (!try_module_get(dvbdev->adapter->module)) return -EPERM; diff --git a/linux/drivers/media/dvb/ttpci/av7110.c b/linux/drivers/media/dvb/ttpci/av7110.c index 433fc6449..2ae489243 100644 --- a/linux/drivers/media/dvb/ttpci/av7110.c +++ b/linux/drivers/media/dvb/ttpci/av7110.c @@ -66,8 +66,9 @@ #include "av7110_av.h" #include "av7110_ca.h" #include "av7110_ipack.h" -#define TS_WIDTH (376) -#define TS_HEIGHT (512) + +#define TS_WIDTH 376 +#define TS_HEIGHT 512 #define TS_BUFLEN (TS_WIDTH*TS_HEIGHT) #define TS_MAX_PACKETS (TS_BUFLEN/TS_SIZE) @@ -1207,10 +1208,10 @@ static void vpeirq(unsigned long data) u32 olddma = budget->ttbp; u32 newdma = saa7146_read(budget->dev, PCI_VDP3); - if(budgetpatch == 0) { + if (!budgetpatch) { printk("av7110.c: vpeirq() called while budgetpatch disabled!" " check saa7146 IER register\n"); - return; + BUG(); } /* nearest lower position divisible by 188 */ newdma -= newdma % 188; @@ -1220,19 +1221,21 @@ static void vpeirq(unsigned long data) budget->ttbp = newdma; - if (budget->feeding1 == 0 || newdma == olddma) + if (!budget->feeding1 || (newdma == olddma)) return; #if 0 /* track rps1 activity */ - printk("vpeirq: %02x Event Counter 1 0x%04x\n", + printk("vpeirq: %02x Event Counter 1 0x%04x\n", mem[olddma], - saa7146_read(budget->dev, EC1R) & 0x3fff ); + saa7146_read(budget->dev, EC1R) & 0x3fff); #endif - if (newdma > olddma) /* no wraparound, dump olddma..newdma */ + if (newdma > olddma) + /* no wraparound, dump olddma..newdma */ dvb_dmx_swfilter_packets(&budget->demux1, mem + olddma, (newdma - olddma) / 188); - else { /* wraparound, dump olddma..buflen and 0..newdma */ + else { + /* wraparound, dump olddma..buflen and 0..newdma */ dvb_dmx_swfilter_packets(&budget->demux1, mem + olddma, (TS_BUFLEN - olddma) / 188); dvb_dmx_swfilter_packets(&budget->demux1, mem, newdma / 188); } @@ -1302,7 +1305,7 @@ static int av7110_register(struct av7110 *av7110) dvb_net_init(av7110->dvb_adapter, &av7110->dvb_net, &dvbdemux->dmx); - if(budgetpatch) { + if (budgetpatch) { /* initialize software demux1 without its own frontend * demux1 hardware is connected to frontend0 of demux0 */ @@ -1316,7 +1319,7 @@ static int av7110_register(struct av7110 *av7110) dvbdemux1->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING | DMX_MEMORY_BASED_FILTERING); - + dvb_dmx_init(&av7110->demux1); av7110->dmxdev1.filternum = 256; @@ -1325,12 +1328,8 @@ static int av7110_register(struct av7110 *av7110) dvb_dmxdev_init(&av7110->dmxdev1, av7110->dvb_adapter); - /* demux1 is without it's own frontend */ - dvb_net_init(av7110->dvb_adapter, &av7110->dvb_net1, &dvbdemux1->dmx); printk("dvb-ttpci: additional demux1 for budget-patch registered\n"); - - /* end software demux1 */ } return 0; } @@ -2082,70 +2081,70 @@ static void frontend_init(struct av7110 *av7110) } } -/* Budgetpatch note: - * Original hardware design by Roberto Deza: - * There is a DVB_Wiki at - * http://212.227.36.83/linuxtv/wiki/index.php/Main_Page - * where is described this 'DVB TT Budget Patch', on Card Modding: - * http://212.227.36.83/linuxtv/wiki/index.php/DVB_TT_Budget_Patch - * On the short description there is also a link to a external file, - * with more details: - * http://perso.wanadoo.es/jesussolano/Ttf_tsc1.zip +/* Budgetpatch note: + * Original hardware design by Roberto Deza: + * There is a DVB_Wiki at + * http://212.227.36.83/linuxtv/wiki/index.php/Main_Page + * where is described this 'DVB TT Budget Patch', on Card Modding: + * http://212.227.36.83/linuxtv/wiki/index.php/DVB_TT_Budget_Patch + * On the short description there is also a link to a external file, + * with more details: + * http://perso.wanadoo.es/jesussolano/Ttf_tsc1.zip * - * New software triggering design by Emard that works on - * original Roberto Deza's hardware: + * New software triggering design by Emard that works on + * original Roberto Deza's hardware: * - * rps1 code for budgetpatch will copy internal HS event to GPIO3 pin. - * GPIO3 is in budget-patch hardware connectd to port B VSYNC - * HS is an internal event of 7146, accessible with RPS - * and temporarily raised high every n lines - * (n in defined in the RPS_THRESH1 counter threshold) - * I think HS is raised high on the beginning of the n-th line - * and remains high until this n-th line that triggered - * it is completely received. When the receiption of n-th line - * ends, HS is lowered. + * rps1 code for budgetpatch will copy internal HS event to GPIO3 pin. + * GPIO3 is in budget-patch hardware connectd to port B VSYNC + * HS is an internal event of 7146, accessible with RPS + * and temporarily raised high every n lines + * (n in defined in the RPS_THRESH1 counter threshold) + * I think HS is raised high on the beginning of the n-th line + * and remains high until this n-th line that triggered + * it is completely received. When the receiption of n-th line + * ends, HS is lowered. * - * To transmit data over DMA, 7146 needs changing state at - * port B VSYNC pin. Any changing of port B VSYNC will - * cause some DMA data transfer, with more or less packets loss. - * It depends on the phase and frequency of VSYNC and - * the way of 7146 is instructed to trigger on port B (defined - * in DD1_INIT register, 3rd nibble from the right valid - * numbers are 0-7, see datasheet) + * To transmit data over DMA, 7146 needs changing state at + * port B VSYNC pin. Any changing of port B VSYNC will + * cause some DMA data transfer, with more or less packets loss. + * It depends on the phase and frequency of VSYNC and + * the way of 7146 is instructed to trigger on port B (defined + * in DD1_INIT register, 3rd nibble from the right valid + * numbers are 0-7, see datasheet) * - * The correct triggering can minimize packet loss, - * dvbtraffic should give this stable bandwidths: - * 22k transponder = 33814 kbit/s - * 27.5k transponder = 38045 kbit/s - * by experiment it is found that the best results - * (stable bandwidths and almost no packet loss) - * are obtained using DD1_INIT triggering number 2 - * (Va at rising edge of VS Fa = HS x VS-failing forced toggle) - * and a VSYNC phase that occurs in the middle of DMA transfer - * (about byte 188*512=96256 in the DMA window). + * The correct triggering can minimize packet loss, + * dvbtraffic should give this stable bandwidths: + * 22k transponder = 33814 kbit/s + * 27.5k transponder = 38045 kbit/s + * by experiment it is found that the best results + * (stable bandwidths and almost no packet loss) + * are obtained using DD1_INIT triggering number 2 + * (Va at rising edge of VS Fa = HS x VS-failing forced toggle) + * and a VSYNC phase that occurs in the middle of DMA transfer + * (about byte 188*512=96256 in the DMA window). * - * Phase of HS is still not clear to me how to control, - * It just happens to be so. It can be seen if one enables - * RPS_IRQ and print Event Counter 1 in vpeirq(). Every - * time RPS_INTERRUPT is called, the Event Counter 1 will - * increment. That's how the 7146 is programmed to do event - * counting in this budget-patch.c - * I *think* HPS setting has something to do with the phase - * of HS but I cant be 100% sure in that. + * Phase of HS is still not clear to me how to control, + * It just happens to be so. It can be seen if one enables + * RPS_IRQ and print Event Counter 1 in vpeirq(). Every + * time RPS_INTERRUPT is called, the Event Counter 1 will + * increment. That's how the 7146 is programmed to do event + * counting in this budget-patch.c + * I *think* HPS setting has something to do with the phase + * of HS but I cant be 100% sure in that. * - * hardware debug note: a working budget card (including budget patch) - * with vpeirq() interrupt setup in mode "0x90" (every 64K) will - * generate 3 interrupts per 25-Hz DMA frame of 2*188*512 bytes - * and that means 3*25=75 Hz of interrupt freqency, as seen by - * watch cat /proc/interrupts + * hardware debug note: a working budget card (including budget patch) + * with vpeirq() interrupt setup in mode "0x90" (every 64K) will + * generate 3 interrupts per 25-Hz DMA frame of 2*188*512 bytes + * and that means 3*25=75 Hz of interrupt freqency, as seen by + * watch cat /proc/interrupts * - * If this frequency is 3x lower (and data received in the DMA - * buffer don't start with 0x47, but in the middle of packets, - * whose lengths appear to be like 188 292 188 104 etc. - * this means VSYNC line is not connected in the hardware. - * (check soldering pcb and pins) - * The same behaviour of missing VSYNC can be duplicated on budget - * cards, by seting DD1_INIT trigger mode 7 in 3rd nibble. + * If this frequency is 3x lower (and data received in the DMA + * buffer don't start with 0x47, but in the middle of packets, + * whose lengths appear to be like 188 292 188 104 etc. + * this means VSYNC line is not connected in the hardware. + * (check soldering pcb and pins) + * The same behaviour of missing VSYNC can be duplicated on budget + * cards, by seting DD1_INIT trigger mode 7 in 3rd nibble. */ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_data *pci_ext) { @@ -2155,22 +2154,22 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d int count = 0; dprintk(4, "dev: %p\n", dev); - + /* Set RPS_IRQ to 1 to track rps1 activity. * Enabling this won't send any interrupt to PC CPU. */ #define RPS_IRQ 0 - if(budgetpatch == 1) { + if (budgetpatch == 1) { budgetpatch = 0; - /* autodetect the presence of budget patch + /* autodetect the presence of budget patch * this only works if saa7146 has been recently * reset with with MASK_31 to MC1 - * + * * will wait for VBI_B event (vertical blank at port B) * and will reset GPIO3 after VBI_B is detected. * (GPIO3 should be raised high by CPU to - * test if GPIO3 will generate vertical blank signal + * test if GPIO3 will generate vertical blank signal * in budget patch GPIO3 is connected to VSYNC_B */ @@ -2183,16 +2182,16 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d /* set vsync_b triggering */ saa7146_write(dev, DD1_STREAM_B, 0); /* port B VSYNC at rising edge */ - saa7146_write(dev, DD1_INIT, 0x00000200); + saa7146_write(dev, DD1_INIT, 0x00000200); saa7146_write(dev, BRS_CTRL, 0x00000000); // VBI - saa7146_write(dev, MC2, + saa7146_write(dev, MC2, 1 * (MASK_08 | MASK_24) | // BRS control 0 * (MASK_09 | MASK_25) | // a 1 * (MASK_10 | MASK_26) | // b 0 * (MASK_06 | MASK_22) | // HPS_CTRL1 0 * (MASK_05 | MASK_21) | // HPS_CTRL2 0 * (MASK_01 | MASK_15) // DEBI - ); + ); /* start writing RPS1 code from beginning */ count = 0; @@ -2216,7 +2215,7 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d #if RPS_IRQ /* set event counter 1 source as RPS1 interrupt (0x03) (rE4 p53) * use 0x03 to track RPS1 interrupts - increase by 1 every gpio3 is toggled - * use 0x15 to track VPE interrupts - increase by 1 every vpeirq() is called + * use 0x15 to track VPE interrupts - increase by 1 every vpeirq() is called */ saa7146_write(dev, EC1SSR, (0x03<<2) | 3 ); /* set event counter 1 treshold to maximum allowed value (rEC p55) */ @@ -2231,11 +2230,11 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d /* now send VSYNC_B to rps1 by rising GPIO3 */ saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTHI); mdelay(10); - /* if rps1 responded by lowering the GPIO3, + /* if rps1 responded by lowering the GPIO3, * then we have budgetpatch hardware */ - if( (saa7146_read(dev, GPIO_CTRL) & 0x10000000) == 0) { - budgetpatch |= 1; + if ((saa7146_read(dev, GPIO_CTRL) & 0x10000000) == 0) { + budgetpatch = 1; printk("dvb-ttpci: BUDGET-PATCH DETECTED.\n"); } /* Disable RPS1 */ @@ -2278,6 +2277,7 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d saa7146_i2c_adapter_prepare(dev, &av7110->i2c_adap, SAA7146_I2C_BUS_BIT_RATE_120); /* 275 kHz */ if (i2c_add_adapter(&av7110->i2c_adap) < 0) { +err_no_mem: dvb_unregister_adapter (av7110->dvb_adapter); kfree(av7110); return -ENOMEM; @@ -2285,11 +2285,12 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d ttpci_eeprom_parse_mac(&av7110->i2c_adap, av7110->dvb_adapter->proposed_mac); - if(budgetpatch) { - if (NULL == - (av7110->grabbing = - saa7146_vmalloc_build_pgtable(dev->pci, length, &av7110->pt))) - return -ENOMEM; + if (budgetpatch) { + spin_lock_init(&av7110->feedlock1); + av7110->grabbing = saa7146_vmalloc_build_pgtable( + dev->pci, length, &av7110->pt); + if (!av7110->grabbing) + goto err_no_mem; saa7146_write(dev, PCI_BT_V1, 0x1c1c101f); saa7146_write(dev, BCS_CTRL, 0x80400040); /* set dd1 stream a & b */ @@ -2353,9 +2354,9 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d * this is related to TS_WIDTH set in register * NUM_LINE_BYTE3. If NUM_LINE_BYTE low 16 bits * are set to TS_WIDTH bytes (TS_WIDTH=2*188), - * then RPS_THRESH1 should be set to trigger + * then RPS_THRESH1 should be set to trigger * every TS_HEIGHT (512) lines. - */ + */ saa7146_write(dev, RPS_THRESH1, (TS_HEIGHT*1) | MASK_12 ); /* Enable RPS1 (rFC p33) */ @@ -2375,9 +2376,6 @@ static int av7110_attach(struct saa7146_dev* dev, struct saa7146_pci_extension_d saa7146_write(dev, MC2, 0x077c077c); saa7146_write(dev, GPIO_CTRL, 0x000000); } - - if(budgetpatch) - spin_lock_init(&av7110->feedlock1); tasklet_init (&av7110->vpe_tasklet, vpeirq, (unsigned long) av7110); tasklet_init (&av7110->debi_tasklet, debiirq, (unsigned long) av7110); @@ -2485,17 +2483,16 @@ err: return ret; } -static int av7110_detach (struct saa7146_dev* saa) +static int av7110_detach(struct saa7146_dev* saa) { struct av7110 *av7110 = (struct av7110*)saa->ext_priv; dprintk(4, "%p\n", av7110); - if( 0 == av7110->device_initialized ) { + if (!av7110->device_initialized ) return 0; - } tasklet_kill(&av7110->vpe_tasklet); - if(budgetpatch) + if (budgetpatch) saa7146_pgtable_free(saa->pci, &av7110->pt); av7110_exit_v4l(av7110); diff --git a/linux/drivers/media/dvb/ttpci/av7110.h b/linux/drivers/media/dvb/ttpci/av7110.h index ba45214d1..a01f5bdfc 100644 --- a/linux/drivers/media/dvb/ttpci/av7110.h +++ b/linux/drivers/media/dvb/ttpci/av7110.h @@ -75,7 +75,7 @@ struct av7110 { /* devices */ struct dvb_device dvb_dev; - struct dvb_net dvb_net, dvb_net1; + struct dvb_net dvb_net; struct video_device *v4l_dev; struct video_device *vbi_dev; @@ -152,19 +152,24 @@ struct av7110 { ca_slot_info_t ci_slot[2]; int vidmode; - struct dmxdev dmxdev, dmxdev1; - struct dvb_demux demux, demux1; - spinlock_t feedlock1; /* for budget mode demux1 */ + struct dmxdev dmxdev; + struct dvb_demux demux; + + struct dmx_frontend hw_frontend; + struct dmx_frontend mem_frontend; + + /* for budget mode demux1 */ + struct dmxdev dmxdev1; + struct dvb_demux demux1; + struct dvb_net dvb_net1; + spinlock_t feedlock1; int feeding1; u8 tsf; u32 ttbp; unsigned char *grabbing; struct saa7146_pgtable pt; struct tasklet_struct vpe_tasklet; - - struct dmx_frontend hw_frontend, hw_frontend1; - struct dmx_frontend mem_frontend, mem_frontend1; - + int fe_synced; struct semaphore pid_mutex; |