Commit 243a273ee0168fc373f342479ae92fe3028b45c1
1 parent
c3d78997
fd leak fix (Igor Kovalenko)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2118 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
4 additions
and
8 deletions
osdep.c
| @@ -120,7 +120,8 @@ void *kqemu_vmalloc(size_t size) | @@ -120,7 +120,8 @@ void *kqemu_vmalloc(size_t size) | ||
| 120 | } | 120 | } |
| 121 | snprintf(phys_ram_file, sizeof(phys_ram_file), "%s/qemuXXXXXX", | 121 | snprintf(phys_ram_file, sizeof(phys_ram_file), "%s/qemuXXXXXX", |
| 122 | tmpdir); | 122 | tmpdir); |
| 123 | - if (mkstemp(phys_ram_file) < 0) { | 123 | + phys_ram_fd = mkstemp(phys_ram_file); |
| 124 | + if (phys_ram_fd < 0) { | ||
| 124 | fprintf(stderr, | 125 | fprintf(stderr, |
| 125 | "warning: could not create temporary file in '%s'.\n" | 126 | "warning: could not create temporary file in '%s'.\n" |
| 126 | "Use QEMU_TMPDIR to select a directory in a tmpfs filesystem.\n" | 127 | "Use QEMU_TMPDIR to select a directory in a tmpfs filesystem.\n" |
| @@ -128,18 +129,13 @@ void *kqemu_vmalloc(size_t size) | @@ -128,18 +129,13 @@ void *kqemu_vmalloc(size_t size) | ||
| 128 | tmpdir); | 129 | tmpdir); |
| 129 | snprintf(phys_ram_file, sizeof(phys_ram_file), "%s/qemuXXXXXX", | 130 | snprintf(phys_ram_file, sizeof(phys_ram_file), "%s/qemuXXXXXX", |
| 130 | "/tmp"); | 131 | "/tmp"); |
| 131 | - if (mkstemp(phys_ram_file) < 0) { | 132 | + phys_ram_fd = mkstemp(phys_ram_file); |
| 133 | + if (phys_ram_fd < 0) { | ||
| 132 | fprintf(stderr, "Could not create temporary memory file '%s'\n", | 134 | fprintf(stderr, "Could not create temporary memory file '%s'\n", |
| 133 | phys_ram_file); | 135 | phys_ram_file); |
| 134 | exit(1); | 136 | exit(1); |
| 135 | } | 137 | } |
| 136 | } | 138 | } |
| 137 | - phys_ram_fd = open(phys_ram_file, O_CREAT | O_TRUNC | O_RDWR, 0600); | ||
| 138 | - if (phys_ram_fd < 0) { | ||
| 139 | - fprintf(stderr, "Could not open temporary memory file '%s'\n", | ||
| 140 | - phys_ram_file); | ||
| 141 | - exit(1); | ||
| 142 | - } | ||
| 143 | unlink(phys_ram_file); | 139 | unlink(phys_ram_file); |
| 144 | } | 140 | } |
| 145 | size = (size + 4095) & ~4095; | 141 | size = (size + 4095) & ~4095; |