mirror of
https://kernel.googlesource.com/pub/scm/linux/kernel/git/torvalds/linux
synced 2025-09-30 20:58:02 +10:00
rwonce: fix crash by removing READ_ONCE() for unaligned read
When arm64 is built with LTO, it upgrades READ_ONCE() to ldar / ldapr
(load-acquire) to avoid issues that can be caused by the compiler
optimizing away implicit address dependencies.
Unlike plain loads, these load-acquire instructions actually require an
aligned address.
For now, fix it by removing the READ_ONCE() that the buggy commit
introduced.
Fixes: ece69af2ed
("rwonce: handle KCSAN like KASAN in read_word_at_a_time()")
Reported-by: Nathan Chancellor <nathan@kernel.org>
Closes: https://lore.kernel.org/r/20250326203926.GA10484@ax162
Signed-off-by: Jann Horn <jannh@google.com>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
ece69af2ed
commit
47a60391ae
@ -86,7 +86,12 @@ unsigned long read_word_at_a_time(const void *addr)
|
||||
kasan_check_read(addr, 1);
|
||||
kcsan_check_read(addr, 1);
|
||||
|
||||
return READ_ONCE(*(unsigned long *)addr);
|
||||
/*
|
||||
* This load can race with concurrent stores to out-of-bounds memory,
|
||||
* but READ_ONCE() can't be used because it requires higher alignment
|
||||
* than plain loads in arm64 builds with LTO.
|
||||
*/
|
||||
return *(unsigned long *)addr;
|
||||
}
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
Loading…
Reference in New Issue
Block a user