ref: 3e0b7d428f7a600ab9d899996176a2b514b116e2
parent: bcb78f5d186592d66127f7f07e6c85d059f7ccb9
author: Rangi <remy.oukaour+rangi42@gmail.com>
date: Tue Apr 13 05:19:59 EDT 2021
Fix an unclosed file and unfreed memory in out_BinaryFileSlice Use 'goto cleanup' in both out_BinaryFileSlice and out_BinaryFile
--- a/src/asm/section.c
+++ b/src/asm/section.c
@@ -781,8 +781,7 @@
if (startPos > fsize) { error("Specified start position is greater than length of file\n");- fclose(f);
- return;
+ goto cleanup;
}
fseek(f, startPos, SEEK_SET);
@@ -805,6 +804,7 @@
if (ferror(f))
error("Error reading INCBIN file '%s': %s\n", s, strerror(errno));+cleanup:
fclose(f);
}
@@ -828,16 +828,16 @@
if (fstk_FindFile(s, &fullPath, &size))
f = fopen(fullPath, "rb");
+ free(fullPath);
if (!f) {- free(fullPath);
if (oGeneratedMissingIncludes) {if (verbose)
printf("Aborting (-MG) on INCBIN file '%s' (%s)\n", s, strerror(errno));oFailedOnMissingInclude = true;
- return;
+ } else {+ error("Error opening INCBIN file '%s': %s\n", s, strerror(errno));}
- error("Error opening INCBIN file '%s': %s\n", s, strerror(errno));return;
}
@@ -851,13 +851,13 @@
if (start_pos > fsize) { error("Specified start position is greater than length of file\n");- return;
+ goto cleanup;
}
if ((start_pos + length) > fsize) { error("Specified range in INCBIN is out of bounds (%" PRIu32 " + %" PRIu32" > %" PRIu32 ")\n", start_pos, length, fsize);
- return;
+ goto cleanup;
}
fseek(f, start_pos, SEEK_SET);
@@ -885,8 +885,8 @@
}
}
+cleanup:
fclose(f);
- free(fullPath);
}
/*
--
⑨