samitolvanen accepted this revision.
samitolvanen added a comment.
This revision is now accepted and ready to land.

In D140035#3996066 <https://reviews.llvm.org/D140035#3996066>, @joaomoreira 
wrote:

> Regarding not being able to reproduce this in kernel -- never mind... I was 
> misled by setup issues while running IBT kernels in QEMU. I managed to fix 
> the setup and confirm that kernel won't boot.

OK, great. Thanks for double checking!

The patch itself looks good to me, but I suspect ibt-seal in general has the 
same issue as D138337 <https://reviews.llvm.org/D138337> where it can drop 
endbr instructions from `isUsedInRegularObj` symbols that are not address-taken 
in the bitcode (e.g. functions whose address is only taken in stand-alone 
assembly). I saw this issue only in the arm64 Linux kernel, but there's always 
a chance a similar code pattern emerges on the x86 side at some point in future 
too. This can obviously be worked around in the kernel, but just something to 
keep in mind.



================
Comment at: clang/lib/Frontend/CompilerInvocation.cpp:1856
 
-  if (Opts.PrepareForLTO && Args.hasArg(OPT_mibt_seal))
+  if (Opts.PrepareForLTO &&
+      !Opts.PrepareForThinLTO &&
----------------
Please run `git clang-format` for the patch.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D140035/new/

https://reviews.llvm.org/D140035

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to