Home | History | Annotate | Download | only in X86
      1 ; RUN: llc < %s -O0 -march=x86-64 -mcpu=corei7 -verify-machineinstrs | FileCheck %s --check-prefix X64
      2 
      3 @sc64 = external global i64
      4 
      5 define void @atomic_fetch_add64() nounwind {
      6 ; X64-LABEL:   atomic_fetch_add64:
      7 ; X32-LABEL:   atomic_fetch_add64:
      8 entry:
      9   %t1 = atomicrmw add  i64* @sc64, i64 1 acquire
     10 ; X64:       lock
     11 ; X64:       incq
     12   %t2 = atomicrmw add  i64* @sc64, i64 3 acquire
     13 ; X64:       lock
     14 ; X64:       addq $3
     15   %t3 = atomicrmw add  i64* @sc64, i64 5 acquire
     16 ; X64:       lock
     17 ; X64:       xaddq
     18   %t4 = atomicrmw add  i64* @sc64, i64 %t3 acquire
     19 ; X64:       lock
     20 ; X64:       addq
     21   ret void
     22 ; X64:       ret
     23 }
     24 
     25 define void @atomic_fetch_sub64() nounwind {
     26 ; X64-LABEL:   atomic_fetch_sub64:
     27 ; X32-LABEL:   atomic_fetch_sub64:
     28   %t1 = atomicrmw sub  i64* @sc64, i64 1 acquire
     29 ; X64:       lock
     30 ; X64:       decq
     31   %t2 = atomicrmw sub  i64* @sc64, i64 3 acquire
     32 ; X64:       lock
     33 ; X64:       subq $3
     34   %t3 = atomicrmw sub  i64* @sc64, i64 5 acquire
     35 ; X64:       lock
     36 ; X64:       xaddq
     37   %t4 = atomicrmw sub  i64* @sc64, i64 %t3 acquire
     38 ; X64:       lock
     39 ; X64:       subq
     40   ret void
     41 ; X64:       ret
     42 }
     43 
     44 define void @atomic_fetch_and64() nounwind {
     45 ; X64-LABEL:   atomic_fetch_and64:
     46 ; X32-LABEL:   atomic_fetch_and64:
     47   %t1 = atomicrmw and  i64* @sc64, i64 3 acquire
     48 ; X64:       lock
     49 ; X64:       andq $3
     50   %t2 = atomicrmw and  i64* @sc64, i64 5 acquire
     51 ; X64:       andq
     52 ; X64:       lock
     53 ; X64:       cmpxchgq
     54   %t3 = atomicrmw and  i64* @sc64, i64 %t2 acquire
     55 ; X64:       lock
     56 ; X64:       andq
     57   ret void
     58 ; X64:       ret
     59 }
     60 
     61 define void @atomic_fetch_or64() nounwind {
     62 ; X64-LABEL:   atomic_fetch_or64:
     63 ; X32-LABEL:   atomic_fetch_or64:
     64   %t1 = atomicrmw or   i64* @sc64, i64 3 acquire
     65 ; X64:       lock
     66 ; X64:       orq $3
     67   %t2 = atomicrmw or   i64* @sc64, i64 5 acquire
     68 ; X64:       orq
     69 ; X64:       lock
     70 ; X64:       cmpxchgq
     71   %t3 = atomicrmw or   i64* @sc64, i64 %t2 acquire
     72 ; X64:       lock
     73 ; X64:       orq
     74   ret void
     75 ; X64:       ret
     76 }
     77 
     78 define void @atomic_fetch_xor64() nounwind {
     79 ; X64-LABEL:   atomic_fetch_xor64:
     80 ; X32-LABEL:   atomic_fetch_xor64:
     81   %t1 = atomicrmw xor  i64* @sc64, i64 3 acquire
     82 ; X64:       lock
     83 ; X64:       xorq $3
     84   %t2 = atomicrmw xor  i64* @sc64, i64 5 acquire
     85 ; X64:       xorq
     86 ; X64:       lock
     87 ; X64:       cmpxchgq
     88   %t3 = atomicrmw xor  i64* @sc64, i64 %t2 acquire
     89 ; X64:       lock
     90 ; X64:       xorq
     91   ret void
     92 ; X64:       ret
     93 }
     94 
     95 define void @atomic_fetch_nand64(i64 %x) nounwind {
     96 ; X64-LABEL:   atomic_fetch_nand64:
     97 ; X32-LABEL:   atomic_fetch_nand64:
     98   %t1 = atomicrmw nand i64* @sc64, i64 %x acquire
     99 ; X64:       andq
    100 ; X64:       notq
    101 ; X64:       lock
    102 ; X64:       cmpxchgq
    103 ; X32:       andl
    104 ; X32:       andl
    105 ; X32:       notl
    106 ; X32:       notl
    107 ; X32:       lock
    108 ; X32:       cmpxchg8b
    109   ret void
    110 ; X64:       ret
    111 ; X32:       ret
    112 }
    113 
    114 define void @atomic_fetch_max64(i64 %x) nounwind {
    115 ; X64-LABEL:   atomic_fetch_max64:
    116 ; X32-LABEL:   atomic_fetch_max64:
    117   %t1 = atomicrmw max  i64* @sc64, i64 %x acquire
    118 ; X64:       subq
    119 ; X64:       cmov
    120 ; X64:       lock
    121 ; X64:       cmpxchgq
    122 
    123 ; X32:       cmpl
    124 ; X32:       cmpl
    125 ; X32:       cmov
    126 ; X32:       cmov
    127 ; X32:       cmov
    128 ; X32:       lock
    129 ; X32:       cmpxchg8b
    130   ret void
    131 ; X64:       ret
    132 ; X32:       ret
    133 }
    134 
    135 define void @atomic_fetch_min64(i64 %x) nounwind {
    136 ; X64-LABEL:   atomic_fetch_min64:
    137 ; X32-LABEL:   atomic_fetch_min64:
    138   %t1 = atomicrmw min  i64* @sc64, i64 %x acquire
    139 ; X64:       subq
    140 ; X64:       cmov
    141 ; X64:       lock
    142 ; X64:       cmpxchgq
    143 
    144 ; X32:       cmpl
    145 ; X32:       cmpl
    146 ; X32:       cmov
    147 ; X32:       cmov
    148 ; X32:       cmov
    149 ; X32:       lock
    150 ; X32:       cmpxchg8b
    151   ret void
    152 ; X64:       ret
    153 ; X32:       ret
    154 }
    155 
    156 define void @atomic_fetch_umax64(i64 %x) nounwind {
    157 ; X64-LABEL:   atomic_fetch_umax64:
    158 ; X32-LABEL:   atomic_fetch_umax64:
    159   %t1 = atomicrmw umax i64* @sc64, i64 %x acquire
    160 ; X64:       subq
    161 ; X64:       cmov
    162 ; X64:       lock
    163 ; X64:       cmpxchgq
    164 
    165 ; X32:       cmpl
    166 ; X32:       cmpl
    167 ; X32:       cmov
    168 ; X32:       cmov
    169 ; X32:       cmov
    170 ; X32:       lock
    171 ; X32:       cmpxchg8b
    172   ret void
    173 ; X64:       ret
    174 ; X32:       ret
    175 }
    176 
    177 define void @atomic_fetch_umin64(i64 %x) nounwind {
    178 ; X64-LABEL:   atomic_fetch_umin64:
    179 ; X32-LABEL:   atomic_fetch_umin64:
    180   %t1 = atomicrmw umin i64* @sc64, i64 %x acquire
    181 ; X64:       subq
    182 ; X64:       cmov
    183 ; X64:       lock
    184 ; X64:       cmpxchgq
    185 
    186 ; X32:       cmpl
    187 ; X32:       cmpl
    188 ; X32:       cmov
    189 ; X32:       cmov
    190 ; X32:       cmov
    191 ; X32:       lock
    192 ; X32:       cmpxchg8b
    193   ret void
    194 ; X64:       ret
    195 ; X32:       ret
    196 }
    197 
    198 define void @atomic_fetch_cmpxchg64() nounwind {
    199 ; X64-LABEL:   atomic_fetch_cmpxchg64:
    200 ; X32-LABEL:   atomic_fetch_cmpxchg64:
    201   %t1 = cmpxchg i64* @sc64, i64 0, i64 1 acquire acquire
    202 ; X64:       lock
    203 ; X64:       cmpxchgq
    204 ; X32:       lock
    205 ; X32:       cmpxchg8b
    206   ret void
    207 ; X64:       ret
    208 ; X32:       ret
    209 }
    210 
    211 define void @atomic_fetch_store64(i64 %x) nounwind {
    212 ; X64-LABEL:   atomic_fetch_store64:
    213 ; X32-LABEL:   atomic_fetch_store64:
    214   store atomic i64 %x, i64* @sc64 release, align 8
    215 ; X64-NOT:   lock
    216 ; X64:       movq
    217 ; X32:       lock
    218 ; X32:       cmpxchg8b
    219   ret void
    220 ; X64:       ret
    221 ; X32:       ret
    222 }
    223 
    224 define void @atomic_fetch_swap64(i64 %x) nounwind {
    225 ; X64-LABEL:   atomic_fetch_swap64:
    226 ; X32-LABEL:   atomic_fetch_swap64:
    227   %t1 = atomicrmw xchg i64* @sc64, i64 %x acquire
    228 ; X64-NOT:   lock
    229 ; X64:       xchgq
    230 ; X32:       lock
    231 ; X32:       xchg8b
    232   ret void
    233 ; X64:       ret
    234 ; X32:       ret
    235 }
    236