[PATCH] D115325: [DWARF] Fix PR51087 Extraneous enum record in DWARF with type units
Orlando Cazalet-Hyams via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Dec 8 02:02:15 PST 2021
Orlando added a comment.
More info about the fix:
I've moved most of the body of addDwarfTypeUnitType into a new function getOrCreateDwarfTypeUnit, which addDwarfTypeUnitType now wraps. getOrCreateDwarfTypeUnit only gets or creates a type unit, and addDwarfTypeUnitType maintains its previous behaviour which is: get or create a type unit and add the info to a DIE (passed in as a parameter) if successful, otherwise construct the type in that DIE directly.
With the patch we call getOrCreateDwarfTypeUnit for each enum, which generates a type unit without adding a skeleton DIE to the CU. If the call fails because a type unit cannot be emitted then we fall back to the old behaviour. If a CU DIE is needed later on it is created via getOrCreateTypeDIE (unchanged with the patch) and the (unchanged) call to addDwarfTypeUnitType will find the already-created type unit signature to add to the DIE.
Possible future improvement:
I think there could be some further work to reduce redundancy with the retained types (see the loop just below the getEnumTypes loop). Firstly, retained types are not actually referenced in the CU, so I don't think there is any point generating a DW_TAG_pointer_type DIE in the CU with skeleton DIEs referencing a type unit for a type. If a type unit is emitted for the pointed-to retained type we could probably skip the CU emission entirely? Secondly, applying the same same fix as for enums (try to emit only the type unit) could remove additional redundancy, more so when coupled with the previous point.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D115325/new/
https://reviews.llvm.org/D115325
More information about the llvm-commits
mailing list