[RESEND] pcmcia: vrc4173_cardu: Fix error path for pci_release_regions and pci_disable_device
Rahul Ruikar
rahul.ruikar at gmail.com
Tue Sep 28 23:34:22 EDT 2010
anyone to review / accept ???
I could not find any particular maintainer for this patch through
"./scripts/get_maintainer.pl" except these 2 lists.
Regards,
Rahul Ruikar
On 26 September 2010 22:41, Rahul Ruikar <rahul.ruikar at gmail.com> wrote:
> patchwork link not showing latest changes of RESEND patch. hence
> attaching in mail
> https://patchwork.kernel.org/patch/210152/
>
> - Rahul Ruikar
>
>
>
>
>
> On 26 September 2010 22:20, Rahul Ruikar <rahul.ruikar at gmail.com> wrote:
>> - pci_release_regions called during return error path.
>> - pci_disable_device called for cases where earlier it was enabled.
>> - code duplication avoided/reduced by adding resource release at goto statements.
>>
>> Signed-off-by: Rahul Ruikar <rahul.ruikar at gmail.com>
>> ---
>> drivers/pcmcia/vrc4173_cardu.c | 58 +++++++++++++++++++++++++++-------------
>> 1 files changed, 39 insertions(+), 19 deletions(-)
>>
>> diff --git a/drivers/pcmcia/vrc4173_cardu.c b/drivers/pcmcia/vrc4173_cardu.c
>> index 9b3c158..c6d36b3 100644
>> --- a/drivers/pcmcia/vrc4173_cardu.c
>> +++ b/drivers/pcmcia/vrc4173_cardu.c
>> @@ -461,7 +461,7 @@ static int __devinit vrc4173_cardu_probe(struct pci_dev *dev,
>> {
>> vrc4173_socket_t *socket;
>> unsigned long start, len, flags;
>> - int slot, err;
>> + int slot, err, ret;
>>
>> slot = vrc4173_cardu_slots++;
>> socket = &cardu_sockets[slot];
>> @@ -474,43 +474,63 @@ static int __devinit vrc4173_cardu_probe(struct pci_dev *dev,
>> return err;
>>
>> start = pci_resource_start(dev, 0);
>> - if (start == 0)
>> - return -ENODEV;
>> + if (start == 0) {
>> + ret = -ENODEV;
>> + goto disable;
>> + }
>>
>> len = pci_resource_len(dev, 0);
>> - if (len == 0)
>> - return -ENODEV;
>> + if (len == 0) {
>> + ret = -ENODEV;
>> + goto disable;
>> + }
>>
>> - if (((flags = pci_resource_flags(dev, 0)) & IORESOURCE_MEM) == 0)
>> - return -EBUSY;
>> + flags = pci_resource_flags(dev, 0);
>> + if ((flags & IORESOURCE_MEM) == 0) {
>> + ret = -EBUSY;
>> + goto disable;
>> + }
>>
>> - if ((err = pci_request_regions(dev, socket->name)) < 0)
>> - return err;
>> + err = pci_request_regions(dev, socket->name);
>> + if (err < 0) {
>> + ret = err;
>> + goto disable;
>> + }
>>
>> socket->base = ioremap(start, len);
>> - if (socket->base == NULL)
>> - return -ENODEV;
>> + if (socket->base == NULL) {
>> + ret = -ENODEV;
>> + goto release;
>> + }
>>
>> socket->dev = dev;
>>
>> socket->pcmcia_socket = pcmcia_register_socket(slot, &cardu_operations, 1);
>> if (socket->pcmcia_socket == NULL) {
>> - iounmap(socket->base);
>> - socket->base = NULL;
>> - return -ENOMEM;
>> + ret = -ENOMEM;
>> + goto unmap;
>> }
>>
>> if (request_irq(dev->irq, cardu_interrupt, IRQF_SHARED, socket->name, socket) < 0) {
>> - pcmcia_unregister_socket(socket->pcmcia_socket);
>> - socket->pcmcia_socket = NULL;
>> - iounmap(socket->base);
>> - socket->base = NULL;
>> - return -EBUSY;
>> + ret = -EBUSY;
>> + goto unregister;
>> }
>>
>> printk(KERN_INFO "%s at %#08lx, IRQ %d\n", socket->name, start, dev->irq);
>>
>> return 0;
>> +
>> +unregister:
>> + pcmcia_unregister_socket(socket->pcmcia_socket);
>> + socket->pcmcia_socket = NULL;
>> +unmap:
>> + iounmap(socket->base);
>> + socket->base = NULL;
>> +release:
>> + pci_release_regions(dev);
>> +disable:
>> + pci_disable_device(dev);
>> + return ret;
>> }
>>
>> static int __devinit vrc4173_cardu_setup(char *options)
>> --
>> 1.7.2.3
>>
>>
>
More information about the linux-pcmcia
mailing list