mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
asm-generic: remove extra type checking in acquire/release for non-SMP case
If CONFIG_SMP is not enabled, the smp_load_acquire/smp_store_release is implemented as READ_ONCE/READ_ONCE and barrier() and type checking. READ_ONCE/READ_ONCE already checks the pointer type, and then checks it more stringently outside, but the non-SMP case simply isn't relevant, so remove the extra compiletime_assert_atomic_type() to avoid compilation errors. Reported-by: kernel test robot <lkp@intel.com> Closes: https://lore.kernel.org/oe-kbuild-all/202401230837.TXro0PHi-lkp@intel.com/ Suggested-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Baokun Li <libaokun1@huawei.com> Link: https://lore.kernel.org/r/20240124142857.4146716-4-libaokun1@huawei.com Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
parent
4b944f8ef9
commit
ad72872eb3
@ -193,7 +193,6 @@ do { \
|
|||||||
#ifndef smp_store_release
|
#ifndef smp_store_release
|
||||||
#define smp_store_release(p, v) \
|
#define smp_store_release(p, v) \
|
||||||
do { \
|
do { \
|
||||||
compiletime_assert_atomic_type(*p); \
|
|
||||||
barrier(); \
|
barrier(); \
|
||||||
WRITE_ONCE(*p, v); \
|
WRITE_ONCE(*p, v); \
|
||||||
} while (0)
|
} while (0)
|
||||||
@ -203,7 +202,6 @@ do { \
|
|||||||
#define smp_load_acquire(p) \
|
#define smp_load_acquire(p) \
|
||||||
({ \
|
({ \
|
||||||
__unqual_scalar_typeof(*p) ___p1 = READ_ONCE(*p); \
|
__unqual_scalar_typeof(*p) ___p1 = READ_ONCE(*p); \
|
||||||
compiletime_assert_atomic_type(*p); \
|
|
||||||
barrier(); \
|
barrier(); \
|
||||||
(typeof(*p))___p1; \
|
(typeof(*p))___p1; \
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user