~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/sh/include/asm/cmpxchg-llsc.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef __ASM_SH_CMPXCHG_LLSC_H
  3 #define __ASM_SH_CMPXCHG_LLSC_H
  4 
  5 static inline unsigned long xchg_u32(volatile u32 *m, unsigned long val)
  6 {
  7         unsigned long retval;
  8         unsigned long tmp;
  9 
 10         __asm__ __volatile__ (
 11                 "1:                                     \n\t"
 12                 "movli.l        @%2, %0 ! xchg_u32      \n\t"
 13                 "mov            %0, %1                  \n\t"
 14                 "mov            %3, %0                  \n\t"
 15                 "movco.l        %0, @%2                 \n\t"
 16                 "bf             1b                      \n\t"
 17                 "synco                                  \n\t"
 18                 : "=&z"(tmp), "=&r" (retval)
 19                 : "r" (m), "r" (val)
 20                 : "t", "memory"
 21         );
 22 
 23         return retval;
 24 }
 25 
 26 static inline unsigned long
 27 __cmpxchg_u32(volatile u32 *m, unsigned long old, unsigned long new)
 28 {
 29         unsigned long retval;
 30         unsigned long tmp;
 31 
 32         __asm__ __volatile__ (
 33                 "1:                                             \n\t"
 34                 "movli.l        @%2, %0 ! __cmpxchg_u32         \n\t"
 35                 "mov            %0, %1                          \n\t"
 36                 "cmp/eq         %1, %3                          \n\t"
 37                 "bf             2f                              \n\t"
 38                 "mov            %4, %0                          \n\t"
 39                 "2:                                             \n\t"
 40                 "movco.l        %0, @%2                         \n\t"
 41                 "bf             1b                              \n\t"
 42                 "synco                                          \n\t"
 43                 : "=&z" (tmp), "=&r" (retval)
 44                 : "r" (m), "r" (old), "r" (new)
 45                 : "t", "memory"
 46         );
 47 
 48         return retval;
 49 }
 50 
 51 #include <asm/cmpxchg-xchg.h>
 52 
 53 #endif /* __ASM_SH_CMPXCHG_LLSC_H */
 54 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php