aba378dee6
LLVM's linker, LLD, supports the keyword "INSERT AFTER", starting with version 11. However, when multiple sections are defined in the same "INSERT AFTER", they are added in a reversed order, compared to BFD's LD. This patch makes fork_fuzz.ld generic enough to work with both linkers. Each section now has its own "INSERT AFTER" keyword, so proper ordering is defined between the sections added. Signed-off-by: Daniele Buono <dbuono@linux.vnet.ibm.com> Message-Id: <20201105221905.1350-2-dbuono@linux.vnet.ibm.com> Reviewed-by: Alexander Bulekov <alxndr@bu.edu> Tested-by: Alexander Bulekov <alxndr@bu.edu> Signed-off-by: Thomas Huth <thuth@redhat.com>
57 lines
1.3 KiB
Plaintext
57 lines
1.3 KiB
Plaintext
/*
|
|
* We adjust linker script modification to place all of the stuff that needs to
|
|
* persist across fuzzing runs into a contiguous section of memory. Then, it is
|
|
* easy to re-map the counter-related memory as shared.
|
|
*/
|
|
|
|
SECTIONS
|
|
{
|
|
.data.fuzz_start : ALIGN(4K)
|
|
{
|
|
__FUZZ_COUNTERS_START = .;
|
|
__start___sancov_cntrs = .;
|
|
*(_*sancov_cntrs);
|
|
__stop___sancov_cntrs = .;
|
|
|
|
/* Lowest stack counter */
|
|
*(__sancov_lowest_stack);
|
|
}
|
|
}
|
|
INSERT AFTER .data;
|
|
|
|
SECTIONS
|
|
{
|
|
.data.fuzz_ordered :
|
|
{
|
|
/*
|
|
* Coverage counters. They're not necessary for fuzzing, but are useful
|
|
* for analyzing the fuzzing performance
|
|
*/
|
|
__start___llvm_prf_cnts = .;
|
|
*(*llvm_prf_cnts);
|
|
__stop___llvm_prf_cnts = .;
|
|
|
|
/* Internal Libfuzzer TracePC object which contains the ValueProfileMap */
|
|
FuzzerTracePC*(.bss*);
|
|
/*
|
|
* In case the above line fails, explicitly specify the (mangled) name of
|
|
* the object we care about
|
|
*/
|
|
*(.bss._ZN6fuzzer3TPCE);
|
|
}
|
|
}
|
|
INSERT AFTER .data.fuzz_start;
|
|
|
|
SECTIONS
|
|
{
|
|
.data.fuzz_end : ALIGN(4K)
|
|
{
|
|
__FUZZ_COUNTERS_END = .;
|
|
}
|
|
}
|
|
/*
|
|
* Don't overwrite the SECTIONS in the default linker script. Instead insert the
|
|
* above into the default script
|
|
*/
|
|
INSERT AFTER .data.fuzz_ordered;
|