samitolvanen wrote:

> Sami, I'm guessing you're mainly talking about rustc and clang needing to use 
> llvm versions that agree on the kCFI implementation in use?

Correct. Both compilers must use the same hashing scheme for cross-language 
indirect calls to work, so unconditionally changing how X86 type hashes are 
calculated in Clang breaks compatibility with current versions of rustc. Using 
compiler versions to figure out which scheme is being used is tedious, so we 
should have a better way to figure this out in Kconfig.

> Either way, it would be nice to have some way to set the hashing method being 
> used, or at least, a way to query which hashing strategy is used. We are 
> going to want logic in Kconfig to ensure that rustc and clang use the same 
> strategy, or at least a way to detect when they don't so we can fail the 
> build with a good error message.

Exactly. I would prefer to have a command line option for this, perhaps 
something similar to 
[-fsanitize-cfi-icall-experimental-normalize-integers](https://clang.llvm.org/docs/ControlFlowIntegrity.html#fsanitize-cfi-icall-experimental-normalize-integers),
 or even a flag that accepts the scheme to use as an argument. As long as we 
default to the original scheme to avoid breaking compatibility with other KCFI 
implementations.

https://github.com/llvm/llvm-project/pull/117121
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to