MIPS: tools: Fix resource leak in elf-entry.c
authorKaige Li <likaige@loongson.cn>
Thu, 14 May 2020 12:59:41 +0000 (20:59 +0800)
committerThomas Bogendoerfer <tsbogend@alpha.franken.de>
Sun, 24 May 2020 07:29:48 +0000 (09:29 +0200)
There is a file descriptor resource leak in elf-entry.c, fix this
by adding fclose() before return and die.

Signed-off-by: Kaige Li <likaige@loongson.cn>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
arch/mips/tools/elf-entry.c

index adde79c..dbd14ff 100644 (file)
@@ -51,11 +51,14 @@ int main(int argc, const char *argv[])
        nread = fread(&hdr, 1, sizeof(hdr), file);
        if (nread != sizeof(hdr)) {
                perror("Unable to read input file");
+               fclose(file);
                return EXIT_FAILURE;
        }
 
-       if (memcmp(hdr.ehdr32.e_ident, ELFMAG, SELFMAG))
+       if (memcmp(hdr.ehdr32.e_ident, ELFMAG, SELFMAG)) {
+               fclose(file);
                die("Input is not an ELF\n");
+       }
 
        switch (hdr.ehdr32.e_ident[EI_CLASS]) {
        case ELFCLASS32:
@@ -67,6 +70,7 @@ int main(int argc, const char *argv[])
                        entry = be32toh(hdr.ehdr32.e_entry);
                        break;
                default:
+                       fclose(file);
                        die("Invalid ELF encoding\n");
                }
 
@@ -83,14 +87,17 @@ int main(int argc, const char *argv[])
                        entry = be64toh(hdr.ehdr64.e_entry);
                        break;
                default:
+                       fclose(file);
                        die("Invalid ELF encoding\n");
                }
                break;
 
        default:
+               fclose(file);
                die("Invalid ELF class\n");
        }
 
        printf("0x%016" PRIx64 "\n", entry);
+       fclose(file);
        return EXIT_SUCCESS;
 }