RFR: 8293422: DWARF emitted by Clang cannot be parsed
Thomas Schatzl
tschatzl at openjdk.org
Wed Sep 21 10:52:51 UTC 2022
On Wed, 21 Sep 2022 07:04:12 GMT, Christian Hagedorn <chagedorn at openjdk.org> wrote:
> Thanks Thomas for that link. I was not aware of this `-gdwarf-aranges` flag. I've tried it out and it indeed seems to work. But I was not able to build with `-flto=thin` as it resulted in build failures.
I only thought that maybe we do compile with `-flto=thin` already, and so we could not use these flags.
>So, I'm not sure what would happen and if it's even possible to build with it in general. Nevertheless, I suggest to go with that `-gdwarf-aranges` flag solution for now and remove the previously suggested bailout fix for Clang.
I agree.
>
> However, `-gdwarf-aranges` (and `-gdwarf-4` which I think we should also add to avoid getting the unsupported DWARF 5 format) was only added in Clang 5.0. But we must support down to 3.5 according to:
>
> https://github.com/openjdk/jdk/blob/cb72f80925965c73e32c44ce3196866272306d7f/doc/building.md?plain=1#L353-L354
>
> I therefore changed the previous complete bailout fix to a bailout fix for Clang versions older than 5.0.
>
> I've noticed that Clang is emitting a full relative path for the filename in the form of `src/hotspot/share/compiler/compilerThread.cpp:58` with debug builds (it only emits the filename with release builds). I therefore added an additional method `strip_path_prefix()` to get rid of the path prefix.
Okay.
-------------
PR: https://git.openjdk.org/jdk/pull/10287
More information about the hotspot-dev
mailing list