From 2a205e6a6e1a42bac744aaa6e6acb104f6429dc7 Mon Sep 17 00:00:00 2001 From: Holger Waechtler Date: Thu, 13 Feb 2003 19:52:51 +0000 Subject: outcom sanity checks and code readability review --- linux/drivers/media/dvb/ttpci/av7110.c | 316 ++++++++++++++++----------------- 1 file changed, 151 insertions(+), 165 deletions(-) (limited to 'linux/drivers/media/dvb/ttpci') diff --git a/linux/drivers/media/dvb/ttpci/av7110.c b/linux/drivers/media/dvb/ttpci/av7110.c index d7766996a..76c1266ff 100644 --- a/linux/drivers/media/dvb/ttpci/av7110.c +++ b/linux/drivers/media/dvb/ttpci/av7110.c @@ -702,7 +702,8 @@ void av7110_setup_irc_config (av7110_t *av7110, u32 ir_config) else last = av7110; - outcom(av7110, COMTYPE_PIDFILTER, SetIR, 1, ir_config); + if (av7110) + outcom(av7110, COMTYPE_PIDFILTER, SetIR, 1, ir_config); } static void (*irc_handler)(u32); @@ -2287,48 +2288,36 @@ inline static void Set22K(av7110_t *av7110, int state) { DEB_EE(("av7110: %p\n",av7110)); -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) - outcom(av7110, COMTYPE_AUDIODAC, (state ? ON22K : OFF22K), 0); + outcom(av7110, COMTYPE_AUDIODAC, (state ? ON22K : OFF22K), 0); } -inline static int -SendDiSEqCMsg(av7110_t *av7110, int len, u8 *msg, int burst) + +static +int SendDiSEqCMsg(av7110_t *av7110, int len, u8 *msg, int burst) { int i; + u16 buf[18] = { ((COMTYPE_AUDIODAC << 8) + SendDiSEqC), + 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; DEB_EE(("av7110: %p\n",av7110)); -/* - switch (av7110->card_type->type) { - case DVB_CARD_TT_SIEMENS: -*/ - { - u16 buf[18] = { ((COMTYPE_AUDIODAC << 8) + SendDiSEqC), - 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; - - if (len>10) - len=10; - buf[1] = len+2; - buf[2] = len; - - if (burst!=-1) - buf[3]=burst ? 0x01 : 0x00; + if (len>10) + len=10; + + buf[1] = len+2; + buf[2] = len; + + if (burst!=-1) + buf[3]=burst ? 0x01 : 0x00; + else + buf[3]=0xffff; + + for (i=0; iregistered=1; -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) - dvb_add_frontend_notifier (av7110->dvb_adapter, - av7110_before_after_tune, av7110); + dvb_add_frontend_notifier (av7110->dvb_adapter, + av7110_before_after_tune, av7110); + /** * init DiSEqC stuff */ -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) - dvb_add_frontend_ioctls (av7110->dvb_adapter, - av7110_diseqc_ioctl, NULL, av7110); + dvb_add_frontend_ioctls (av7110->dvb_adapter, + av7110_diseqc_ioctl, NULL, av7110); av7110->audiostate.AV_sync_state=0; av7110->audiostate.mute_state=0; @@ -4058,67 +4046,64 @@ int av7110_register(av7110_t *av7110) av7110->demux_id[5] = av7110->dvb_adapter->num + '0'; dvbdemux->priv = (void *) av7110; -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) { - for (i=0; i<32; i++) - av7110->handle2filter[i]=NULL; - - dvbdemux->filternum=32; - dvbdemux->feednum=32; - dvbdemux->start_feed = av7110_start_feed; - dvbdemux->stop_feed = av7110_stop_feed; - dvbdemux->write_to_decoder = av7110_write_to_decoder; - - dvbdemux->dmx.vendor="TI"; - dvbdemux->dmx.model="AV7110"; - dvbdemux->dmx.id=av7110->demux_id; - dvbdemux->dmx.capabilities=(DMX_TS_FILTERING| - DMX_SECTION_FILTERING| - DMX_MEMORY_BASED_FILTERING); - - dvb_dmx_init(&av7110->demux); - - - dvbfront->id="hw_frontend"; - dvbfront->vendor="VLSI"; - dvbfront->model="DVB Frontend"; - dvbfront->source=DMX_FRONTEND_0; - - av7110->dmxdev.filternum=32; - av7110->dmxdev.demux=&dvbdemux->dmx; - av7110->dmxdev.capabilities=0; - - dvb_dmxdev_init(&av7110->dmxdev, av7110->dvb_adapter); -// } + for (i=0; i<32; i++) + av7110->handle2filter[i]=NULL; + + dvbdemux->filternum = 32; + dvbdemux->feednum = 32; + dvbdemux->start_feed = av7110_start_feed; + dvbdemux->stop_feed = av7110_stop_feed; + dvbdemux->write_to_decoder = av7110_write_to_decoder; + dvbdemux->dmx.vendor = "TI"; + dvbdemux->dmx.model = "AV7110"; + dvbdemux->dmx.id = av7110->demux_id; + dvbdemux->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING | + DMX_MEMORY_BASED_FILTERING); + + dvb_dmx_init(&av7110->demux); + + dvbfront->id = "hw_frontend"; + dvbfront->vendor = "VLSI"; + dvbfront->model = "DVB Frontend"; + dvbfront->source = DMX_FRONTEND_0; + + av7110->dmxdev.filternum = 32; + av7110->dmxdev.demux = &dvbdemux->dmx; + av7110->dmxdev.capabilities = 0; + + dvb_dmxdev_init(&av7110->dmxdev, av7110->dvb_adapter); - ret=dvbdemux->dmx.add_frontend(&dvbdemux->dmx, - &av7110->hw_frontend); - if (ret<0) + ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, + &av7110->hw_frontend); + if (ret < 0) return ret; - av7110->mem_frontend.id="mem_frontend"; - av7110->mem_frontend.vendor="memory"; - av7110->mem_frontend.model="sw"; - av7110->mem_frontend.source=DMX_MEMORY_FE; - ret=dvbdemux->dmx.add_frontend(&dvbdemux->dmx, - &av7110->mem_frontend); - if (ret<0) + av7110->mem_frontend.id = "mem_frontend"; + av7110->mem_frontend.vendor = "memory"; + av7110->mem_frontend.model = "sw"; + av7110->mem_frontend.source = DMX_MEMORY_FE; + + ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &av7110->mem_frontend); + + if (ret < 0) return ret; - ret=dvbdemux->dmx.connect_frontend(&dvbdemux->dmx, - &av7110->hw_frontend); - if (ret<0) + ret = dvbdemux->dmx.connect_frontend(&dvbdemux->dmx, + &av7110->hw_frontend); + if (ret < 0) return ret; -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) { - dvb_register_device(av7110->dvb_adapter, &av7110->video_dev, - &dvbdev_video, av7110, DVB_DEVICE_VIDEO); - dvb_register_device(av7110->dvb_adapter, &av7110->audio_dev, - &dvbdev_audio, av7110, DVB_DEVICE_AUDIO); - dvb_register_device(av7110->dvb_adapter, &av7110->ca_dev, + dvb_register_device(av7110->dvb_adapter, &av7110->video_dev, + &dvbdev_video, av7110, DVB_DEVICE_VIDEO); + + dvb_register_device(av7110->dvb_adapter, &av7110->audio_dev, + &dvbdev_audio, av7110, DVB_DEVICE_AUDIO); + + dvb_register_device(av7110->dvb_adapter, &av7110->ca_dev, &dvbdev_ca, av7110, DVB_DEVICE_CA); #ifdef CONFIG_DVB_AV7110_OSD - dvb_register_device(av7110->dvb_adapter, &av7110->osd_dev, - &dvbdev_osd, av7110, DVB_DEVICE_OSD); + dvb_register_device(av7110->dvb_adapter, &av7110->osd_dev, + &dvbdev_osd, av7110, DVB_DEVICE_OSD); #endif #ifdef USE_DVB_DSP dvb->dsp_dev = dvb_register_dsp(dvb_audio_open, @@ -4155,20 +4140,18 @@ dvb_unregister(av7110_t *av7110) dvb_dmxdev_release(&av7110->dmxdev); dvb_dmx_release(&av7110->demux); -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) - dvb_remove_frontend_notifier (av7110->dvb_adapter, - av7110_before_after_tune); + dvb_remove_frontend_notifier (av7110->dvb_adapter, + av7110_before_after_tune); dvb_remove_frontend_ioctls (av7110->dvb_adapter, av7110_diseqc_ioctl, NULL); -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) { - dvb_unregister_device(av7110->audio_dev); - dvb_unregister_device(av7110->video_dev); - dvb_unregister_device(av7110->osd_dev); - dvb_unregister_device(av7110->ca_dev); + dvb_unregister_device(av7110->audio_dev); + dvb_unregister_device(av7110->video_dev); + dvb_unregister_device(av7110->osd_dev); + dvb_unregister_device(av7110->ca_dev); #ifdef USE_DVB_DSP - dvb_unregister_dsp(av7110->dsp_dev); + dvb_unregister_dsp(av7110->dsp_dev); #endif // } } @@ -4201,20 +4184,21 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p printk ("%s: out of memory!\n", __FUNCTION__); return -ENOMEM; } - memset(av7110, 0, sizeof(av7110_t)); + + memset(av7110, 0, sizeof(av7110_t)); av7110->card_name = (char*)pci_ext->ext_priv; (av7110_t*)dev->ext_priv = av7110; DEB_EE(("dev: %p, av7110: %p\n",dev,av7110)); - if( 0 != saa7146_vv_init(dev)) { + if (saa7146_vv_init(dev)) { ERR(("cannot init capture device. skipping.\n")); kfree(av7110); return -1; } - if( 0 != saa7146_register_device(&av7110->vd, dev, "av7710", VFL_TYPE_GRABBER)) { + if (saa7146_register_device(&av7110->vd, dev, "av7710", VFL_TYPE_GRABBER)) { ERR(("cannot register capture device. skipping.\n")); saa7146_vv_release(dev); kfree(av7110); @@ -4229,7 +4213,9 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p saa7146_write(dev, GPIO_CTRL, 0x500000); saa7146_i2c_adapter_prepare(dev, NULL, SAA7146_I2C_BUS_BIT_RATE_3200); - av7110->i2c_bus = dvb_register_i2c_bus (master_xfer, dev, av7110->dvb_adapter, 0); + + av7110->i2c_bus = dvb_register_i2c_bus (master_xfer, dev, + av7110->dvb_adapter, 0); if (!av7110->i2c_bus) { saa7146_unregister_device(&av7110->vd, dev); @@ -4238,6 +4224,7 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p kfree(av7110); return -ENOMEM; } + saa7146_write(dev, PCI_BT_V1, 0x1c00101f); saa7146_write(dev, BCS_CTRL, 0x80400040); @@ -4282,13 +4269,13 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p /* allocate and init buffers */ av7110->debi_virt = pci_alloc_consistent(dev->pci, 8192, &av7110->debi_bus); - if (!av7110->debi_virt) { + if (!av7110->debi_virt) { ret = -ENOMEM; goto err; } av7110->iobuf = vmalloc(AVOUTLEN+AOUTLEN+BMPLEN+4*IPACKS); - if (!av7110->iobuf) { + if (!av7110->iobuf) { ret = -ENOMEM; goto err; } @@ -4309,61 +4296,57 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p /* handle different card types */ /* load firmware into AV7110 cards */ -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) { - bootarm(av7110); - firmversion(av7110); - if ((av7110->arm_app&0xffff)<0x2501) { - printk("av7110: Warning, firmware version 0x%04x is too old. " - "System might be unstable!\n", - (av7110->arm_app&0xffff)); - } - kernel_thread(arm_thread, (void *) av7110, 0); -// } - SetVolume(av7110, 0xff, 0xff); + bootarm(av7110); + firmversion(av7110); -// if (av7110->card_type->type==DVB_CARD_TT_SIEMENS) { - VidMode(av7110, vidmode); + if ((av7110->arm_app&0xffff)<0x2501) + printk ("av7110: Warning, firmware version 0x%04x is too old. " + "System might be unstable!\n", av7110->arm_app&0xffff); - /* remaining inits according to card and frontend type */ + kernel_thread(arm_thread, (void *) av7110, 0); - if (i2c_writereg(av7110, 0x20, 0x00, 0x00)==1) { - printk("av7110%d: Crystal audio DAC detected\n", - av7110->dvb_adapter->num); - av7110->adac_type = DVB_ADAC_CRYSTAL; - i2c_writereg(av7110, 0x20, 0x01, 0xd2); - i2c_writereg(av7110, 0x20, 0x02, 0x49); - i2c_writereg(av7110, 0x20, 0x03, 0x00); - i2c_writereg(av7110, 0x20, 0x04, 0x00); - } + SetVolume(av7110, 0xff, 0xff); + VidMode(av7110, vidmode); + + /* remaining inits according to card and frontend type */ + if (i2c_writereg(av7110, 0x20, 0x00, 0x00)==1) { + printk ("av7110%d: Crystal audio DAC detected\n", + av7110->dvb_adapter->num); + av7110->adac_type = DVB_ADAC_CRYSTAL; + i2c_writereg(av7110, 0x20, 0x01, 0xd2); + i2c_writereg(av7110, 0x20, 0x02, 0x49); + i2c_writereg(av7110, 0x20, 0x03, 0x00); + i2c_writereg(av7110, 0x20, 0x04, 0x00); + } - /** - * some special handling for the Siemens DVB-C card... - */ - if (dev->pci->subsystem_vendor == 0x110a) { - if (i2c_writereg(av7110, 0x80, 0x0, 0x80)==1) { - i2c_writereg(av7110, 0x80, 0x0, 0); - printk("av7110: DVB-C analog module detected, " - "initializing MSP3400\n"); - ddelay(10); - msp_writereg(av7110, 0x12, 0x0013, 0x0c00); - msp_writereg(av7110, 0x12, 0x0000, 0x7f00); // loudspeaker + headphone - msp_writereg(av7110, 0x12, 0x0008, 0x0220); // loudspeaker source - msp_writereg(av7110, 0x12, 0x0004, 0x7f00); // loudspeaker volume - msp_writereg(av7110, 0x12, 0x000a, 0x0220); // SCART 1 source - msp_writereg(av7110, 0x12, 0x0007, 0x7f00); // SCART 1 volume - msp_writereg(av7110, 0x12, 0x000d, 0x4800); // prescale SCART - } + + /** + * some special handling for the Siemens DVB-C card... + */ + if (dev->pci->subsystem_vendor == 0x110a) { + if (i2c_writereg(av7110, 0x80, 0x0, 0x80)==1) { + i2c_writereg(av7110, 0x80, 0x0, 0); + printk ("av7110: DVB-C analog module detected, " + "initializing MSP3400\n"); + ddelay(10); + msp_writereg(av7110, 0x12, 0x0013, 0x0c00); + msp_writereg(av7110, 0x12, 0x0000, 0x7f00); // loudspeaker + headphone + msp_writereg(av7110, 0x12, 0x0008, 0x0220); // loudspeaker source + msp_writereg(av7110, 0x12, 0x0004, 0x7f00); // loudspeaker volume + msp_writereg(av7110, 0x12, 0x000a, 0x0220); // SCART 1 source + msp_writereg(av7110, 0x12, 0x0007, 0x7f00); // SCART 1 volume + msp_writereg(av7110, 0x12, 0x000d, 0x4800); // prescale SCART + } - // switch DVB SCART on - outcom(av7110, COMTYPE_AUDIODAC, MainSwitch, 1, 0); - outcom(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 1); - - //saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI); // RGB on, SCART pin 16 - //saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO); // SCARTpin 8 - av7110->adac_type = DVB_ADAC_NONE; - } -// } + + // switch DVB SCART on + outcom(av7110, COMTYPE_AUDIODAC, MainSwitch, 1, 0); + outcom(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 1); + //saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI); // RGB on, SCART pin 16 + //saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO); // SCARTpin 8 + av7110->adac_type = DVB_ADAC_NONE; + } av7110_setup_irc_config (av7110, 0); av7110_register(av7110); @@ -4373,14 +4356,18 @@ int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_data *p return 0; err: - if( NULL != av7110 ) { + if (av7110 ) kfree(av7110); - } - /* FIXME: error handling is totally bogus: memory does not get freed ... */ + + /* FIXME: error handling is pretty bogus: memory does not get freed...*/ saa7146_unregister_device(&av7110->vd, dev); saa7146_vv_release(dev); - dvb_unregister_i2c_bus (master_xfer,av7110->i2c_bus->adapter, av7110->i2c_bus->id); + + dvb_unregister_i2c_bus (master_xfer,av7110->i2c_bus->adapter, + av7110->i2c_bus->id); + dvb_unregister_adapter (av7110->dvb_adapter); + return ret; } @@ -4432,15 +4419,14 @@ void av7110_irq(struct saa7146_dev* dev, u32 *isr) DEB_EE(("dev: %p, av7110: %p\n",dev,av7110)); - if (*isr & MASK_19) { + if (*isr & MASK_19) tasklet_schedule (&av7110->debi_tasklet); - } - if (*isr & MASK_03) { + if (*isr & MASK_03) tasklet_schedule (&av7110->gpio_tasklet); - } } + /* FIXME: these values are experimental values that look better than the values from the latest "official" driver -- at least for me... (MiHu) */ static -- cgit v1.2.3