Re: [PATCH] rust: kasan/kbuild: fix missing flags on first build
From: Alice Ryhl
Date: Mon Apr 14 2025 - 07:22:35 EST
On Wed, Apr 9, 2025 at 12:03 AM Miguel Ojeda <ojeda@xxxxxxxxxx> wrote:
>
> If KASAN is enabled, and one runs in a clean repository e.g.:
>
> make LLVM=1 prepare
> make LLVM=1 prepare
>
> Then the Rust code gets rebuilt, which should not happen.
>
> The reason is some of the LLVM KASAN `rustc` flags are added in the
> second run:
>
> -Cllvm-args=-asan-instrumentation-with-call-threshold=10000
> -Cllvm-args=-asan-stack=0
> -Cllvm-args=-asan-globals=1
> -Cllvm-args=-asan-kernel-mem-intrinsic-prefix=1
>
> Further runs do not rebuild Rust because the flags do not change anymore.
>
> Rebuilding like that in the second run is bad, even if this just happens
> with KASAN enabled, but missing flags in the first one is even worse.
>
> The root issue is that we pass, for some architectures and for the moment,
> a generated `target.json` file. That file is not ready by the time `rustc`
> gets called for the flag test, and thus the flag test fails just because
> the file is not available, e.g.:
>
> $ ... --target=./scripts/target.json ... -Cllvm-args=...
> error: target file "./scripts/target.json" does not exist
>
> There are a few approaches we could take here to solve this. For instance,
> we could ensure that every time that the config is rebuilt, we regenerate
> the file and recompute the flags. Or we could use the LLVM version to
> check for these flags, instead of testing the flag (which may have other
> advantages, such as allowing us to detect renames on the LLVM side).
>
> However, it may be easier than that: `rustc` is aware of the `-Cllvm-args`
> regardless of the `--target` (e.g. I checked that the list printed
> is the same, plus that I can check for these flags even if I pass
> a completely unrelated target), and thus we can just eliminate the
> dependency completely.
>
> Thus filter out the target.
>
> This does mean that `rustc-option` cannot be used to test a flag that
> requires the right target, but we don't have other users yet, it is a
> minimal change and we want to get rid of custom targets in the future.
>
> We could only filter in the case `target.json` is used, to make it work
> in more cases, but then it would be harder to notice that it may not
> work in a couple architectures.
>
> Cc: Matthew Maurer <mmaurer@xxxxxxxxxx>
> Cc: Sami Tolvanen <samitolvanen@xxxxxxxxxx>
> Cc: stable@xxxxxxxxxxxxxxx
> Fixes: e3117404b411 ("kbuild: rust: Enable KASAN support")
> Signed-off-by: Miguel Ojeda <ojeda@xxxxxxxxxx>
I've boot-tested Android's KASAN configuration with this patch, and it
continues to work. It also passes Android CI [1].
Tested-by: Alice Ryhl <aliceryhl@xxxxxxxxxx>
Alice
[1]: http://r.android.com/3584874