diff options
author | Patrick Boettcher <pb@linuxtv.org> | 2006-05-14 18:29:48 +0200 |
---|---|---|
committer | Patrick Boettcher <pb@linuxtv.org> | 2006-05-14 18:29:48 +0200 |
commit | c7b8d03d39aaf7055bb88d7983839eaee56c62db (patch) | |
tree | d5ce54b5173ad592bd3a7bf2541f2db7003bbe61 /linux/drivers/media/dvb/dvb-usb/gp8psk.c | |
parent | 8a6284b4819ca82de31709838a3a83f2b4e2288b (diff) | |
download | mediapointer-dvb-s2-c7b8d03d39aaf7055bb88d7983839eaee56c62db.tar.gz mediapointer-dvb-s2-c7b8d03d39aaf7055bb88d7983839eaee56c62db.tar.bz2 |
Minor code cleanup on the genpix-module
From: Patrick Boettcher <pb@linuxtv.org>
Minor code cleanup on the genpix-module.
Signed-off-by: Patrick Boettcher <pb@linuxtv.org>
Diffstat (limited to 'linux/drivers/media/dvb/dvb-usb/gp8psk.c')
-rw-r--r-- | linux/drivers/media/dvb/dvb-usb/gp8psk.c | 28 |
1 files changed, 15 insertions, 13 deletions
diff --git a/linux/drivers/media/dvb/dvb-usb/gp8psk.c b/linux/drivers/media/dvb/dvb-usb/gp8psk.c index 387433b26..feeff77c8 100644 --- a/linux/drivers/media/dvb/dvb-usb/gp8psk.c +++ b/linux/drivers/media/dvb/dvb-usb/gp8psk.c @@ -92,36 +92,38 @@ static int gp8psk_load_bcm4500fw(struct dvb_usb_device *d) return ret; } - if (gp8psk_usb_out_op(d, LOAD_BCM4500,1,0,NULL, 0)) { - release_firmware(fw); - return -EINVAL; - } + ret = -EINVAL; + + if (gp8psk_usb_out_op(d, LOAD_BCM4500,1,0,NULL, 0)) + goto out_rel_fw; info("downloaidng bcm4500 firmware from file '%s'",bcm4500_firmware); ptr = fw->data; - buf = (u8 *) kmalloc(512, GFP_KERNEL | GFP_DMA); + buf = kmalloc(512, GFP_KERNEL | GFP_DMA); while (ptr[0] != 0xff) { u16 buflen = ptr[0] + 4; if (ptr + buflen >= fw->data + fw->size) { err("failed to load bcm4500 firmware."); - release_firmware(fw); - kfree(buf); - return -EINVAL; + goto out_free; } memcpy(buf, ptr, buflen); if (dvb_usb_generic_write(d, buf, buflen)) { err("failed to load bcm4500 firmware."); - release_firmware(fw); - kfree(buf); - return -EIO; + goto out_free; } ptr += buflen; } - release_firmware(fw); + + ret = 0; + +out_free: kfree(buf); - return 0; +out_rel_fw: + release_firmware(fw); + + return ret; } static int gp8psk_power_ctrl(struct dvb_usb_device *d, int onoff) |