0
0
mirror of https://github.com/netwide-assembler/nasm.git synced 2025-10-10 00:25:06 -04:00

omit input filename from COFF output when --reproducible

Before this patch, COFF output always contained the first 18 bytes of the
input filename. This breaks reproducibility and may also leak sensitive
data to objects (esp. with input filenames with absolute paths.)

This patch makes this output respect the --reproducible option, and omits
the input filename from the COFF output, when set.
This commit is contained in:
Viktor Szakats
2022-07-12 06:07:48 +00:00
parent 3aebb20f12
commit e1423b0573

View File

@@ -1275,6 +1275,9 @@ static void coff_write_symbols(void)
* The `.file' record, and the file name auxiliary record. * The `.file' record, and the file name auxiliary record.
*/ */
coff_symbol(".file", 0L, 0L, -2, 0, 0x67, 1); coff_symbol(".file", 0L, 0L, -2, 0, 0x67, 1);
if (reproducible)
memset(filename, 0, 18);
else
strncpy(filename, inname, 18); strncpy(filename, inname, 18);
nasm_write(filename, 18, ofile); nasm_write(filename, 18, ofile);