diff options
author | Jiri Slaby <jirislaby@gmail.com> | 2007-02-10 04:45:20 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-02-11 13:51:29 -0500 |
commit | 45257fa9a5070e4c0739af1f81848ad557472b40 (patch) | |
tree | 9d258e4ca9f76a60ab190d2d49c8d0c8f0af3b15 | |
parent | 18b95576bc6b9ef9270ec778e1d545c0ca8bbbbb (diff) |
[PATCH] Char: mxser_new, fix twice resource releasing
Because brd->info is not NULLed, resources are released twice. NULL it in
pci_remove function. Also take care of retval and releasing in pci_probe --
mxser_initbrd alreasy releases resource, do not do it again in fail path in
probe function.
Cc: Sergei Organov <osv@javad.com>
Signed-off-by: Jiri Slaby <jirislaby@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | drivers/char/mxser_new.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/drivers/char/mxser_new.c b/drivers/char/mxser_new.c index 042d1381ff6f..f078ddf48b79 100644 --- a/drivers/char/mxser_new.c +++ b/drivers/char/mxser_new.c | |||
@@ -2403,9 +2403,8 @@ static int __devinit mxser_initbrd(struct mxser_board *brd, | |||
2403 | brd->info->name, brd->irq); | 2403 | brd->info->name, brd->irq); |
2404 | /* We hold resources, we need to release them. */ | 2404 | /* We hold resources, we need to release them. */ |
2405 | mxser_release_res(brd, pdev, 0); | 2405 | mxser_release_res(brd, pdev, 0); |
2406 | return retval; | ||
2407 | } | 2406 | } |
2408 | return 0; | 2407 | return retval; |
2409 | } | 2408 | } |
2410 | 2409 | ||
2411 | static int __init mxser_get_ISA_conf(int cap, struct mxser_board *brd) | 2410 | static int __init mxser_get_ISA_conf(int cap, struct mxser_board *brd) |
@@ -2590,8 +2589,9 @@ static int __devinit mxser_probe(struct pci_dev *pdev, | |||
2590 | } | 2589 | } |
2591 | 2590 | ||
2592 | /* mxser_initbrd will hook ISR. */ | 2591 | /* mxser_initbrd will hook ISR. */ |
2593 | if (mxser_initbrd(brd, pdev) < 0) | 2592 | retval = mxser_initbrd(brd, pdev); |
2594 | goto err_relvec; | 2593 | if (retval) |
2594 | goto err_null; | ||
2595 | 2595 | ||
2596 | for (i = 0; i < brd->info->nports; i++) | 2596 | for (i = 0; i < brd->info->nports; i++) |
2597 | tty_register_device(mxvar_sdriver, brd->idx + i, &pdev->dev); | 2597 | tty_register_device(mxvar_sdriver, brd->idx + i, &pdev->dev); |
@@ -2599,10 +2599,9 @@ static int __devinit mxser_probe(struct pci_dev *pdev, | |||
2599 | pci_set_drvdata(pdev, brd); | 2599 | pci_set_drvdata(pdev, brd); |
2600 | 2600 | ||
2601 | return 0; | 2601 | return 0; |
2602 | err_relvec: | ||
2603 | pci_release_region(pdev, 3); | ||
2604 | err_relio: | 2602 | err_relio: |
2605 | pci_release_region(pdev, 2); | 2603 | pci_release_region(pdev, 2); |
2604 | err_null: | ||
2606 | brd->info = NULL; | 2605 | brd->info = NULL; |
2607 | err: | 2606 | err: |
2608 | return retval; | 2607 | return retval; |
@@ -2620,6 +2619,7 @@ static void __devexit mxser_remove(struct pci_dev *pdev) | |||
2620 | tty_unregister_device(mxvar_sdriver, brd->idx + i); | 2619 | tty_unregister_device(mxvar_sdriver, brd->idx + i); |
2621 | 2620 | ||
2622 | mxser_release_res(brd, pdev, 1); | 2621 | mxser_release_res(brd, pdev, 1); |
2622 | brd->info = NULL; | ||
2623 | } | 2623 | } |
2624 | 2624 | ||
2625 | static struct pci_driver mxser_driver = { | 2625 | static struct pci_driver mxser_driver = { |