diff options
author | Jeff Dike <jdike@addtoit.com> | 2006-09-29 04:58:51 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-29 12:18:04 -0400 |
commit | 80c13749140284abdc23bbeed2507b7e5a3dc459 (patch) | |
tree | 9d5a56f718e8f467af3daf0089309d3b1ac9d12e /arch/um/drivers/ubd_kern.c | |
parent | 730760e90a173ef81f89beed2f1dad2fab310f68 (diff) |
[PATCH] uml: close file descriptor leaks
Close two file descriptor leaks, one in the ubd driver and one to
/proc/mounts. The ubd driver bug also leaked some vmalloc space. The
/proc/mounts leak was a descriptor that was just never closed.
Signed-off-by: Jeff Dike <jdike@addtoit.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/um/drivers/ubd_kern.c')
-rw-r--r-- | arch/um/drivers/ubd_kern.c | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/arch/um/drivers/ubd_kern.c b/arch/um/drivers/ubd_kern.c index 34085315aa57..5fa4c8e258a4 100644 --- a/arch/um/drivers/ubd_kern.c +++ b/arch/um/drivers/ubd_kern.c | |||
@@ -668,18 +668,15 @@ static int ubd_add(int n) | |||
668 | if(dev->file == NULL) | 668 | if(dev->file == NULL) |
669 | goto out; | 669 | goto out; |
670 | 670 | ||
671 | if (ubd_open_dev(dev)) | ||
672 | goto out; | ||
673 | |||
674 | err = ubd_file_size(dev, &dev->size); | 671 | err = ubd_file_size(dev, &dev->size); |
675 | if(err < 0) | 672 | if(err < 0) |
676 | goto out_close; | 673 | goto out; |
677 | 674 | ||
678 | dev->size = ROUND_BLOCK(dev->size); | 675 | dev->size = ROUND_BLOCK(dev->size); |
679 | 676 | ||
680 | err = ubd_new_disk(MAJOR_NR, dev->size, n, &ubd_gendisk[n]); | 677 | err = ubd_new_disk(MAJOR_NR, dev->size, n, &ubd_gendisk[n]); |
681 | if(err) | 678 | if(err) |
682 | goto out_close; | 679 | goto out; |
683 | 680 | ||
684 | if(fake_major != MAJOR_NR) | 681 | if(fake_major != MAJOR_NR) |
685 | ubd_new_disk(fake_major, dev->size, n, | 682 | ubd_new_disk(fake_major, dev->size, n, |
@@ -691,8 +688,6 @@ static int ubd_add(int n) | |||
691 | make_ide_entries(ubd_gendisk[n]->disk_name); | 688 | make_ide_entries(ubd_gendisk[n]->disk_name); |
692 | 689 | ||
693 | err = 0; | 690 | err = 0; |
694 | out_close: | ||
695 | ubd_close(dev); | ||
696 | out: | 691 | out: |
697 | return err; | 692 | return err; |
698 | } | 693 | } |