aboutsummaryrefslogtreecommitdiff
path: root/libctf/ctf-dedup.c
diff options
context:
space:
mode:
authorNick Alcock <nick.alcock@oracle.com>2023-01-09 13:43:09 +0000
committerNick Alcock <nick.alcock@oracle.com>2023-01-12 15:23:06 +0000
commitc777aa9765b6892c1ef7d7584385b9377071248e (patch)
tree9ae80d04113534a6ac5008814a88d15ff5c775b3 /libctf/ctf-dedup.c
parente2dc08c6f0642ca2c94e91997a8d4e971bea9971 (diff)
downloadgdb-c777aa9765b6892c1ef7d7584385b9377071248e.zip
gdb-c777aa9765b6892c1ef7d7584385b9377071248e.tar.gz
gdb-c777aa9765b6892c1ef7d7584385b9377071248e.tar.bz2
libctf: ctf-link outdated input check faulty
This check has a pair of faults which, combined, can lead to memory corruption. Firstly, it assumes that the values of the ctf_link_inputs hash are ctf_dict_t's: they are not, they are ctf_link_input_t's, a much shorter structure. So the flags check which is the core of this is faulty (but happens, by chance, to give the right output on most architectures, since usually we happen to get a 0 here, so the test that checks this usually passes). Worse, the warning that is emitted when the test fails is added to the wrong dict -- it's added to the input dict, whose warning list is never consumed, rendering the whole check useless. But the dict it adds to is still the wrong type, so we end up overwriting something deep in memory (or, much more likely, dereferencing a garbage pointer and crashing). Fixing both reveals another problem: the link input is an *archive* consisting of multiple members, so we have to consider whether to check all of them for the outdated-func-info thing we are checking here. However, no compiler exists that emits a mixture of members with this flag on and members with it off, and the linker always reserializes (and upgrades) such things when it sees them: so all members in a given archive must have the same value of the flag, so we only need to check one member per input archive. libctf/ PR libctf/29983 * ctf-link.c (ctf_link_warn_outdated_inputs): Get the types of members of ctf_link_inputs right, fixing a possible spurious tesst failure / wild pointer deref / overwrite. Emit the warning message into the right dict.
Diffstat (limited to 'libctf/ctf-dedup.c')
0 files changed, 0 insertions, 0 deletions