From d1000cc47d222fd0ceddc2a15faf3cbfe3a2b979 Mon Sep 17 00:00:00 2001 From: Oliver Endriss Date: Sat, 27 Dec 2003 18:07:39 +0000 Subject: Memory optimization: do not allocate firmware buffer if firmware is compiled into the driver. Saves 220KB vmem. --- linux/drivers/media/dvb/ttpci/av7110.c | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) (limited to 'linux/drivers/media/dvb') diff --git a/linux/drivers/media/dvb/ttpci/av7110.c b/linux/drivers/media/dvb/ttpci/av7110.c index fcb7cdd61..1dd270b43 100644 --- a/linux/drivers/media/dvb/ttpci/av7110.c +++ b/linux/drivers/media/dvb/ttpci/av7110.c @@ -4512,8 +4512,6 @@ static int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_ { #ifndef CONFIG_DVB_AV7110_FIRMWARE_FILE const struct firmware *fw; -#else - struct firmware *fw; #endif struct av7110 *av7110 = NULL; int ret = 0; @@ -4529,20 +4527,12 @@ static int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_ printk("dvb-ttpci: cannot request firmware!\n"); return -EINVAL; } -#else - fw = vmalloc(sizeof(struct firmware)); - if (NULL == fw) { - printk("dvb-ttpci: not enough memory\n"); - return -ENOMEM; - } - fw->size = sizeof(dvb_ttpci_fw); - fw->data = dvb_ttpci_fw; -#endif if (fw->size <= 200000) { printk("dvb-ttpci: this firmware is way too small.\n"); return -EINVAL; } +#endif /* prepare the av7110 device struct */ if (!(av7110 = kmalloc (sizeof (struct av7110), GFP_KERNEL))) { @@ -4551,6 +4541,7 @@ static int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_ } memset(av7110, 0, sizeof(struct av7110)); +#ifndef CONFIG_DVB_AV7110_FIRMWARE_FILE /* check if the firmware is available */ av7110->bin_fw = (unsigned char*)vmalloc(fw->size); if (NULL == av7110->bin_fw) { @@ -4560,6 +4551,10 @@ static int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_ } memcpy(av7110->bin_fw, fw->data, fw->size); av7110->size_fw = fw->size; +#else + av7110->bin_fw = dvb_ttpci_fw; + av7110->size_fw = sizeof dvb_ttpci_fw; +#endif /* check for firmware magic */ ptr = av7110->bin_fw; @@ -4604,9 +4599,6 @@ static int av7110_attach (struct saa7146_dev* dev, struct saa7146_pci_extension_ av7110->bin_root = ptr; av7110->size_root = len; -#ifdef CONFIG_DVB_AV7110_FIRMWARE_FILE - vfree(fw); -#endif /* go on with regular device initialization */ av7110->card_name = (char*)pci_ext->ext_priv; av7110->dev=(struct saa7146_dev *)dev; @@ -4877,7 +4869,9 @@ err: return ret; fw_error: +#ifndef CONFIG_DVB_AV7110_FIRMWARE_FILE vfree(av7110->bin_fw); +#endif kfree(av7110); return -EINVAL; } @@ -4921,9 +4915,11 @@ static int av7110_detach (struct saa7146_dev* saa) dvb_unregister_adapter (av7110->dvb_adapter); av7110_num--; +#ifndef CONFIG_DVB_AV7110_FIRMWARE_FILE if (NULL != av7110->bin_fw ) { vfree(av7110->bin_fw); } +#endif kfree (av7110); saa->ext_priv = NULL; -- cgit v1.2.3