On Fri, Jul 15, 2022 at 03:13:17AM +0200, Miguel Ojeda wrote: > On Wed, Jul 13, 2022 at 1:40 PM Peter Zijlstra <peterz@xxxxxxxxxxxxx> wrote: > > > > Does Rust have the equivalent of -mfunction-return=thunk-extern ? > > While GCC has had it for a while, Nick just landed 2 days ago the > X86ReturnThunks pass in LLVM, so it will take some time to arrive in > rustc. > > I have naively backported it to rustc and hacked it so that I set the > LLVM attribute for all functions, and I am getting the rets replaced > in Rust functions, e.g. > > (gdb) disassemble a::f > Dump of assembler code for function _ZN1a1f17hdc6112b1b4a4fe99E: > ... > 0x0000000000008a1f <+31>: pop %rbp > 0x0000000000008a20 <+32>: jmp 0x8ce0 <__x86_return_thunk> > > A trivial userspace program that counts the times that it goes through > the return thunk also appears to work. Ok; I'm supposing that'll be sorted by the time rust happens. > > Related, how does Rust deal with all the various CC_HAS_ Kconfig stuff? > > What if C has the relevant option but Rust does not; then we must not > > have the feature enabled or there will be a mis-match. > > I guess that would depend on the particular option: whether it applies > to Rust at all, whether it creates an incompatibility or not, etc. There's quite a few things affecting code-gen; rustc not using the exact same compiler arguments is going to create a head-ache. > > Do we now have to litter everythign with RUSTC_HAS_ ? > > Why? Only a single `rustc` version is targeted at the moment, so it is > possible to statically know what it supports. But does it support everything clang does now? If not, you need to express that in Kconfig and disable the features it doesn't carry. So even for a single rustc version will you need RUSTC_HAS_ stuff. What about CC_HAS_IBT? Can rust generate sane IBT code? Current next doesn't seem to have anything there, suggesting I can't build an IBT enabled kernel if rust is on (or rather, it'll build, but it'll also burn at boot). What if LLVM were to grow -mindirect-branch-cs-prefix (please!) and rust doesn't have it? Same if LLVM finally stops generating those pesky conditional tail-calls, will rust continue emitting them? I'm thinking of the kCFI work, will rustc support that from day 1 or will that only work when not building any rust. There being a single rustc is not a single target, every compiler version grows (and breaks) new features. And for some reason we seem to change the actual kernel calling convetion a lot of late :/ Currently we can support a feature when one compiler version supports it (either gcc or clang), but the moment rust becomes a mandatory part of the kernel build (and I dread that day) we'll need to wait/update/wrangle at least two different toolchains to implement the feature in a consistent manner before we can use it. I also don't see any RUST -mfentry support...