|
|
@@ -408,109 +408,39 @@ static __always_inline bool atomic64_add_negative(s64 i, atomic64_t *v)
|
|
|
}
|
|
|
#endif
|
|
|
|
|
|
-static __always_inline unsigned long
|
|
|
-cmpxchg_size(volatile void *ptr, unsigned long old, unsigned long new, int size)
|
|
|
-{
|
|
|
- kasan_check_write(ptr, size);
|
|
|
- switch (size) {
|
|
|
- case 1:
|
|
|
- return arch_cmpxchg((u8 *)ptr, (u8)old, (u8)new);
|
|
|
- case 2:
|
|
|
- return arch_cmpxchg((u16 *)ptr, (u16)old, (u16)new);
|
|
|
- case 4:
|
|
|
- return arch_cmpxchg((u32 *)ptr, (u32)old, (u32)new);
|
|
|
- case 8:
|
|
|
- BUILD_BUG_ON(sizeof(unsigned long) != 8);
|
|
|
- return arch_cmpxchg((u64 *)ptr, (u64)old, (u64)new);
|
|
|
- }
|
|
|
- BUILD_BUG();
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
#define cmpxchg(ptr, old, new) \
|
|
|
({ \
|
|
|
- ((__typeof__(*(ptr)))cmpxchg_size((ptr), (unsigned long)(old), \
|
|
|
- (unsigned long)(new), sizeof(*(ptr)))); \
|
|
|
+ typeof(ptr) __ai_ptr = (ptr); \
|
|
|
+ kasan_check_write(__ai_ptr, sizeof(*__ai_ptr)); \
|
|
|
+ arch_cmpxchg(__ai_ptr, (old), (new)); \
|
|
|
})
|
|
|
|
|
|
-static __always_inline unsigned long
|
|
|
-sync_cmpxchg_size(volatile void *ptr, unsigned long old, unsigned long new,
|
|
|
- int size)
|
|
|
-{
|
|
|
- kasan_check_write(ptr, size);
|
|
|
- switch (size) {
|
|
|
- case 1:
|
|
|
- return arch_sync_cmpxchg((u8 *)ptr, (u8)old, (u8)new);
|
|
|
- case 2:
|
|
|
- return arch_sync_cmpxchg((u16 *)ptr, (u16)old, (u16)new);
|
|
|
- case 4:
|
|
|
- return arch_sync_cmpxchg((u32 *)ptr, (u32)old, (u32)new);
|
|
|
- case 8:
|
|
|
- BUILD_BUG_ON(sizeof(unsigned long) != 8);
|
|
|
- return arch_sync_cmpxchg((u64 *)ptr, (u64)old, (u64)new);
|
|
|
- }
|
|
|
- BUILD_BUG();
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
#define sync_cmpxchg(ptr, old, new) \
|
|
|
({ \
|
|
|
- ((__typeof__(*(ptr)))sync_cmpxchg_size((ptr), \
|
|
|
- (unsigned long)(old), (unsigned long)(new), \
|
|
|
- sizeof(*(ptr)))); \
|
|
|
+ typeof(ptr) __ai_ptr = (ptr); \
|
|
|
+ kasan_check_write(__ai_ptr, sizeof(*__ai_ptr)); \
|
|
|
+ arch_sync_cmpxchg(__ai_ptr, (old), (new)); \
|
|
|
})
|
|
|
|
|
|
-static __always_inline unsigned long
|
|
|
-cmpxchg_local_size(volatile void *ptr, unsigned long old, unsigned long new,
|
|
|
- int size)
|
|
|
-{
|
|
|
- kasan_check_write(ptr, size);
|
|
|
- switch (size) {
|
|
|
- case 1:
|
|
|
- return arch_cmpxchg_local((u8 *)ptr, (u8)old, (u8)new);
|
|
|
- case 2:
|
|
|
- return arch_cmpxchg_local((u16 *)ptr, (u16)old, (u16)new);
|
|
|
- case 4:
|
|
|
- return arch_cmpxchg_local((u32 *)ptr, (u32)old, (u32)new);
|
|
|
- case 8:
|
|
|
- BUILD_BUG_ON(sizeof(unsigned long) != 8);
|
|
|
- return arch_cmpxchg_local((u64 *)ptr, (u64)old, (u64)new);
|
|
|
- }
|
|
|
- BUILD_BUG();
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
#define cmpxchg_local(ptr, old, new) \
|
|
|
({ \
|
|
|
- ((__typeof__(*(ptr)))cmpxchg_local_size((ptr), \
|
|
|
- (unsigned long)(old), (unsigned long)(new), \
|
|
|
- sizeof(*(ptr)))); \
|
|
|
+ typeof(ptr) __ai_ptr = (ptr); \
|
|
|
+ kasan_check_write(__ai_ptr, sizeof(*__ai_ptr)); \
|
|
|
+ arch_cmpxchg_local(__ai_ptr, (old), (new)); \
|
|
|
})
|
|
|
|
|
|
-static __always_inline u64
|
|
|
-cmpxchg64_size(volatile u64 *ptr, u64 old, u64 new)
|
|
|
-{
|
|
|
- kasan_check_write(ptr, sizeof(*ptr));
|
|
|
- return arch_cmpxchg64(ptr, old, new);
|
|
|
-}
|
|
|
-
|
|
|
#define cmpxchg64(ptr, old, new) \
|
|
|
({ \
|
|
|
- ((__typeof__(*(ptr)))cmpxchg64_size((ptr), (u64)(old), \
|
|
|
- (u64)(new))); \
|
|
|
+ typeof(ptr) __ai_ptr = (ptr); \
|
|
|
+ kasan_check_write(__ai_ptr, sizeof(*__ai_ptr)); \
|
|
|
+ arch_cmpxchg64(__ai_ptr, (old), (new)); \
|
|
|
})
|
|
|
|
|
|
-static __always_inline u64
|
|
|
-cmpxchg64_local_size(volatile u64 *ptr, u64 old, u64 new)
|
|
|
-{
|
|
|
- kasan_check_write(ptr, sizeof(*ptr));
|
|
|
- return arch_cmpxchg64_local(ptr, old, new);
|
|
|
-}
|
|
|
-
|
|
|
#define cmpxchg64_local(ptr, old, new) \
|
|
|
({ \
|
|
|
- ((__typeof__(*(ptr)))cmpxchg64_local_size((ptr), (u64)(old), \
|
|
|
- (u64)(new))); \
|
|
|
+ typeof(ptr) __ai_ptr = (ptr); \
|
|
|
+ kasan_check_write(__ai_ptr, sizeof(*__ai_ptr)); \
|
|
|
+ arch_cmpxchg64_local(__ai_ptr, (old), (new)); \
|
|
|
})
|
|
|
|
|
|
/*
|