mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 23:32:58 +00:00
8f2a85e099
This commit adds a weak variant of the cmpxchg operation, as described in C++11. A cmpxchg instruction with this modifier is permitted to fail to store, even if the comparison indicated it should. As a result, cmpxchg instructions must return a flag indicating success in addition to their original iN value loaded. Thus, for uniformity *all* cmpxchg instructions now return "{ iN, i1 }". The second flag is 1 when the store succeeded. At the DAG level, a new ATOMIC_CMP_SWAP_WITH_SUCCESS node has been added as the natural representation for the new cmpxchg instructions. It is a strong cmpxchg. By default this gets Expanded to the existing ATOMIC_CMP_SWAP during Legalization, so existing backends should see no change in behaviour. If they wish to deal with the enhanced node instead, they can call setOperationAction on it. Beware: as a node with 2 results, it cannot be selected from TableGen. Currently, no use is made of the extra information provided in this patch. Test updates are almost entirely adapting the input IR to the new scheme. Summary for out of tree users: ------------------------------ + Legacy Bitcode files are upgraded during read. + Legacy assembly IR files will be invalid. + Front-ends must adapt to different type for "cmpxchg". + Backends should be unaffected by default. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@210903 91177308-0d34-0410-b5e6-96231b3b80d8
716 lines
28 KiB
LLVM
716 lines
28 KiB
LLVM
; RUN: llc < %s -march=ppc32
|
|
target datalayout = "E-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f128:64:128"
|
|
target triple = "powerpc-apple-darwin9"
|
|
|
|
@sc = common global i8 0
|
|
@uc = common global i8 0
|
|
@ss = common global i16 0
|
|
@us = common global i16 0
|
|
@si = common global i32 0
|
|
@ui = common global i32 0
|
|
@sl = common global i32 0
|
|
@ul = common global i32 0
|
|
@sll = common global i64 0, align 8
|
|
@ull = common global i64 0, align 8
|
|
|
|
define void @test_op_ignore() nounwind {
|
|
entry:
|
|
%0 = atomicrmw add i8* @sc, i8 1 monotonic
|
|
%1 = atomicrmw add i8* @uc, i8 1 monotonic
|
|
%2 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%3 = atomicrmw add i16* %2, i16 1 monotonic
|
|
%4 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%5 = atomicrmw add i16* %4, i16 1 monotonic
|
|
%6 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%7 = atomicrmw add i32* %6, i32 1 monotonic
|
|
%8 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%9 = atomicrmw add i32* %8, i32 1 monotonic
|
|
%10 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%11 = atomicrmw add i32* %10, i32 1 monotonic
|
|
%12 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%13 = atomicrmw add i32* %12, i32 1 monotonic
|
|
%14 = atomicrmw sub i8* @sc, i8 1 monotonic
|
|
%15 = atomicrmw sub i8* @uc, i8 1 monotonic
|
|
%16 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%17 = atomicrmw sub i16* %16, i16 1 monotonic
|
|
%18 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%19 = atomicrmw sub i16* %18, i16 1 monotonic
|
|
%20 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%21 = atomicrmw sub i32* %20, i32 1 monotonic
|
|
%22 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%23 = atomicrmw sub i32* %22, i32 1 monotonic
|
|
%24 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%25 = atomicrmw sub i32* %24, i32 1 monotonic
|
|
%26 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%27 = atomicrmw sub i32* %26, i32 1 monotonic
|
|
%28 = atomicrmw or i8* @sc, i8 1 monotonic
|
|
%29 = atomicrmw or i8* @uc, i8 1 monotonic
|
|
%30 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%31 = atomicrmw or i16* %30, i16 1 monotonic
|
|
%32 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%33 = atomicrmw or i16* %32, i16 1 monotonic
|
|
%34 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%35 = atomicrmw or i32* %34, i32 1 monotonic
|
|
%36 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%37 = atomicrmw or i32* %36, i32 1 monotonic
|
|
%38 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%39 = atomicrmw or i32* %38, i32 1 monotonic
|
|
%40 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%41 = atomicrmw or i32* %40, i32 1 monotonic
|
|
%42 = atomicrmw xor i8* @sc, i8 1 monotonic
|
|
%43 = atomicrmw xor i8* @uc, i8 1 monotonic
|
|
%44 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%45 = atomicrmw xor i16* %44, i16 1 monotonic
|
|
%46 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%47 = atomicrmw xor i16* %46, i16 1 monotonic
|
|
%48 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%49 = atomicrmw xor i32* %48, i32 1 monotonic
|
|
%50 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%51 = atomicrmw xor i32* %50, i32 1 monotonic
|
|
%52 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%53 = atomicrmw xor i32* %52, i32 1 monotonic
|
|
%54 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%55 = atomicrmw xor i32* %54, i32 1 monotonic
|
|
%56 = atomicrmw and i8* @sc, i8 1 monotonic
|
|
%57 = atomicrmw and i8* @uc, i8 1 monotonic
|
|
%58 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%59 = atomicrmw and i16* %58, i16 1 monotonic
|
|
%60 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%61 = atomicrmw and i16* %60, i16 1 monotonic
|
|
%62 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%63 = atomicrmw and i32* %62, i32 1 monotonic
|
|
%64 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%65 = atomicrmw and i32* %64, i32 1 monotonic
|
|
%66 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%67 = atomicrmw and i32* %66, i32 1 monotonic
|
|
%68 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%69 = atomicrmw and i32* %68, i32 1 monotonic
|
|
%70 = atomicrmw nand i8* @sc, i8 1 monotonic
|
|
%71 = atomicrmw nand i8* @uc, i8 1 monotonic
|
|
%72 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%73 = atomicrmw nand i16* %72, i16 1 monotonic
|
|
%74 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%75 = atomicrmw nand i16* %74, i16 1 monotonic
|
|
%76 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%77 = atomicrmw nand i32* %76, i32 1 monotonic
|
|
%78 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%79 = atomicrmw nand i32* %78, i32 1 monotonic
|
|
%80 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%81 = atomicrmw nand i32* %80, i32 1 monotonic
|
|
%82 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%83 = atomicrmw nand i32* %82, i32 1 monotonic
|
|
br label %return
|
|
|
|
return: ; preds = %entry
|
|
ret void
|
|
}
|
|
|
|
define void @test_fetch_and_op() nounwind {
|
|
entry:
|
|
%0 = atomicrmw add i8* @sc, i8 11 monotonic
|
|
store i8 %0, i8* @sc, align 1
|
|
%1 = atomicrmw add i8* @uc, i8 11 monotonic
|
|
store i8 %1, i8* @uc, align 1
|
|
%2 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%3 = atomicrmw add i16* %2, i16 11 monotonic
|
|
store i16 %3, i16* @ss, align 2
|
|
%4 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%5 = atomicrmw add i16* %4, i16 11 monotonic
|
|
store i16 %5, i16* @us, align 2
|
|
%6 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%7 = atomicrmw add i32* %6, i32 11 monotonic
|
|
store i32 %7, i32* @si, align 4
|
|
%8 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%9 = atomicrmw add i32* %8, i32 11 monotonic
|
|
store i32 %9, i32* @ui, align 4
|
|
%10 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%11 = atomicrmw add i32* %10, i32 11 monotonic
|
|
store i32 %11, i32* @sl, align 4
|
|
%12 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%13 = atomicrmw add i32* %12, i32 11 monotonic
|
|
store i32 %13, i32* @ul, align 4
|
|
%14 = atomicrmw sub i8* @sc, i8 11 monotonic
|
|
store i8 %14, i8* @sc, align 1
|
|
%15 = atomicrmw sub i8* @uc, i8 11 monotonic
|
|
store i8 %15, i8* @uc, align 1
|
|
%16 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%17 = atomicrmw sub i16* %16, i16 11 monotonic
|
|
store i16 %17, i16* @ss, align 2
|
|
%18 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%19 = atomicrmw sub i16* %18, i16 11 monotonic
|
|
store i16 %19, i16* @us, align 2
|
|
%20 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%21 = atomicrmw sub i32* %20, i32 11 monotonic
|
|
store i32 %21, i32* @si, align 4
|
|
%22 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%23 = atomicrmw sub i32* %22, i32 11 monotonic
|
|
store i32 %23, i32* @ui, align 4
|
|
%24 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%25 = atomicrmw sub i32* %24, i32 11 monotonic
|
|
store i32 %25, i32* @sl, align 4
|
|
%26 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%27 = atomicrmw sub i32* %26, i32 11 monotonic
|
|
store i32 %27, i32* @ul, align 4
|
|
%28 = atomicrmw or i8* @sc, i8 11 monotonic
|
|
store i8 %28, i8* @sc, align 1
|
|
%29 = atomicrmw or i8* @uc, i8 11 monotonic
|
|
store i8 %29, i8* @uc, align 1
|
|
%30 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%31 = atomicrmw or i16* %30, i16 11 monotonic
|
|
store i16 %31, i16* @ss, align 2
|
|
%32 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%33 = atomicrmw or i16* %32, i16 11 monotonic
|
|
store i16 %33, i16* @us, align 2
|
|
%34 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%35 = atomicrmw or i32* %34, i32 11 monotonic
|
|
store i32 %35, i32* @si, align 4
|
|
%36 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%37 = atomicrmw or i32* %36, i32 11 monotonic
|
|
store i32 %37, i32* @ui, align 4
|
|
%38 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%39 = atomicrmw or i32* %38, i32 11 monotonic
|
|
store i32 %39, i32* @sl, align 4
|
|
%40 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%41 = atomicrmw or i32* %40, i32 11 monotonic
|
|
store i32 %41, i32* @ul, align 4
|
|
%42 = atomicrmw xor i8* @sc, i8 11 monotonic
|
|
store i8 %42, i8* @sc, align 1
|
|
%43 = atomicrmw xor i8* @uc, i8 11 monotonic
|
|
store i8 %43, i8* @uc, align 1
|
|
%44 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%45 = atomicrmw xor i16* %44, i16 11 monotonic
|
|
store i16 %45, i16* @ss, align 2
|
|
%46 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%47 = atomicrmw xor i16* %46, i16 11 monotonic
|
|
store i16 %47, i16* @us, align 2
|
|
%48 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%49 = atomicrmw xor i32* %48, i32 11 monotonic
|
|
store i32 %49, i32* @si, align 4
|
|
%50 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%51 = atomicrmw xor i32* %50, i32 11 monotonic
|
|
store i32 %51, i32* @ui, align 4
|
|
%52 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%53 = atomicrmw xor i32* %52, i32 11 monotonic
|
|
store i32 %53, i32* @sl, align 4
|
|
%54 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%55 = atomicrmw xor i32* %54, i32 11 monotonic
|
|
store i32 %55, i32* @ul, align 4
|
|
%56 = atomicrmw and i8* @sc, i8 11 monotonic
|
|
store i8 %56, i8* @sc, align 1
|
|
%57 = atomicrmw and i8* @uc, i8 11 monotonic
|
|
store i8 %57, i8* @uc, align 1
|
|
%58 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%59 = atomicrmw and i16* %58, i16 11 monotonic
|
|
store i16 %59, i16* @ss, align 2
|
|
%60 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%61 = atomicrmw and i16* %60, i16 11 monotonic
|
|
store i16 %61, i16* @us, align 2
|
|
%62 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%63 = atomicrmw and i32* %62, i32 11 monotonic
|
|
store i32 %63, i32* @si, align 4
|
|
%64 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%65 = atomicrmw and i32* %64, i32 11 monotonic
|
|
store i32 %65, i32* @ui, align 4
|
|
%66 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%67 = atomicrmw and i32* %66, i32 11 monotonic
|
|
store i32 %67, i32* @sl, align 4
|
|
%68 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%69 = atomicrmw and i32* %68, i32 11 monotonic
|
|
store i32 %69, i32* @ul, align 4
|
|
%70 = atomicrmw nand i8* @sc, i8 11 monotonic
|
|
store i8 %70, i8* @sc, align 1
|
|
%71 = atomicrmw nand i8* @uc, i8 11 monotonic
|
|
store i8 %71, i8* @uc, align 1
|
|
%72 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%73 = atomicrmw nand i16* %72, i16 11 monotonic
|
|
store i16 %73, i16* @ss, align 2
|
|
%74 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%75 = atomicrmw nand i16* %74, i16 11 monotonic
|
|
store i16 %75, i16* @us, align 2
|
|
%76 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%77 = atomicrmw nand i32* %76, i32 11 monotonic
|
|
store i32 %77, i32* @si, align 4
|
|
%78 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%79 = atomicrmw nand i32* %78, i32 11 monotonic
|
|
store i32 %79, i32* @ui, align 4
|
|
%80 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%81 = atomicrmw nand i32* %80, i32 11 monotonic
|
|
store i32 %81, i32* @sl, align 4
|
|
%82 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%83 = atomicrmw nand i32* %82, i32 11 monotonic
|
|
store i32 %83, i32* @ul, align 4
|
|
br label %return
|
|
|
|
return: ; preds = %entry
|
|
ret void
|
|
}
|
|
|
|
define void @test_op_and_fetch() nounwind {
|
|
entry:
|
|
%0 = load i8* @uc, align 1
|
|
%1 = atomicrmw add i8* @sc, i8 %0 monotonic
|
|
%2 = add i8 %1, %0
|
|
store i8 %2, i8* @sc, align 1
|
|
%3 = load i8* @uc, align 1
|
|
%4 = atomicrmw add i8* @uc, i8 %3 monotonic
|
|
%5 = add i8 %4, %3
|
|
store i8 %5, i8* @uc, align 1
|
|
%6 = load i8* @uc, align 1
|
|
%7 = zext i8 %6 to i16
|
|
%8 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%9 = atomicrmw add i16* %8, i16 %7 monotonic
|
|
%10 = add i16 %9, %7
|
|
store i16 %10, i16* @ss, align 2
|
|
%11 = load i8* @uc, align 1
|
|
%12 = zext i8 %11 to i16
|
|
%13 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%14 = atomicrmw add i16* %13, i16 %12 monotonic
|
|
%15 = add i16 %14, %12
|
|
store i16 %15, i16* @us, align 2
|
|
%16 = load i8* @uc, align 1
|
|
%17 = zext i8 %16 to i32
|
|
%18 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%19 = atomicrmw add i32* %18, i32 %17 monotonic
|
|
%20 = add i32 %19, %17
|
|
store i32 %20, i32* @si, align 4
|
|
%21 = load i8* @uc, align 1
|
|
%22 = zext i8 %21 to i32
|
|
%23 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%24 = atomicrmw add i32* %23, i32 %22 monotonic
|
|
%25 = add i32 %24, %22
|
|
store i32 %25, i32* @ui, align 4
|
|
%26 = load i8* @uc, align 1
|
|
%27 = zext i8 %26 to i32
|
|
%28 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%29 = atomicrmw add i32* %28, i32 %27 monotonic
|
|
%30 = add i32 %29, %27
|
|
store i32 %30, i32* @sl, align 4
|
|
%31 = load i8* @uc, align 1
|
|
%32 = zext i8 %31 to i32
|
|
%33 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%34 = atomicrmw add i32* %33, i32 %32 monotonic
|
|
%35 = add i32 %34, %32
|
|
store i32 %35, i32* @ul, align 4
|
|
%36 = load i8* @uc, align 1
|
|
%37 = atomicrmw sub i8* @sc, i8 %36 monotonic
|
|
%38 = sub i8 %37, %36
|
|
store i8 %38, i8* @sc, align 1
|
|
%39 = load i8* @uc, align 1
|
|
%40 = atomicrmw sub i8* @uc, i8 %39 monotonic
|
|
%41 = sub i8 %40, %39
|
|
store i8 %41, i8* @uc, align 1
|
|
%42 = load i8* @uc, align 1
|
|
%43 = zext i8 %42 to i16
|
|
%44 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%45 = atomicrmw sub i16* %44, i16 %43 monotonic
|
|
%46 = sub i16 %45, %43
|
|
store i16 %46, i16* @ss, align 2
|
|
%47 = load i8* @uc, align 1
|
|
%48 = zext i8 %47 to i16
|
|
%49 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%50 = atomicrmw sub i16* %49, i16 %48 monotonic
|
|
%51 = sub i16 %50, %48
|
|
store i16 %51, i16* @us, align 2
|
|
%52 = load i8* @uc, align 1
|
|
%53 = zext i8 %52 to i32
|
|
%54 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%55 = atomicrmw sub i32* %54, i32 %53 monotonic
|
|
%56 = sub i32 %55, %53
|
|
store i32 %56, i32* @si, align 4
|
|
%57 = load i8* @uc, align 1
|
|
%58 = zext i8 %57 to i32
|
|
%59 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%60 = atomicrmw sub i32* %59, i32 %58 monotonic
|
|
%61 = sub i32 %60, %58
|
|
store i32 %61, i32* @ui, align 4
|
|
%62 = load i8* @uc, align 1
|
|
%63 = zext i8 %62 to i32
|
|
%64 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%65 = atomicrmw sub i32* %64, i32 %63 monotonic
|
|
%66 = sub i32 %65, %63
|
|
store i32 %66, i32* @sl, align 4
|
|
%67 = load i8* @uc, align 1
|
|
%68 = zext i8 %67 to i32
|
|
%69 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%70 = atomicrmw sub i32* %69, i32 %68 monotonic
|
|
%71 = sub i32 %70, %68
|
|
store i32 %71, i32* @ul, align 4
|
|
%72 = load i8* @uc, align 1
|
|
%73 = atomicrmw or i8* @sc, i8 %72 monotonic
|
|
%74 = or i8 %73, %72
|
|
store i8 %74, i8* @sc, align 1
|
|
%75 = load i8* @uc, align 1
|
|
%76 = atomicrmw or i8* @uc, i8 %75 monotonic
|
|
%77 = or i8 %76, %75
|
|
store i8 %77, i8* @uc, align 1
|
|
%78 = load i8* @uc, align 1
|
|
%79 = zext i8 %78 to i16
|
|
%80 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%81 = atomicrmw or i16* %80, i16 %79 monotonic
|
|
%82 = or i16 %81, %79
|
|
store i16 %82, i16* @ss, align 2
|
|
%83 = load i8* @uc, align 1
|
|
%84 = zext i8 %83 to i16
|
|
%85 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%86 = atomicrmw or i16* %85, i16 %84 monotonic
|
|
%87 = or i16 %86, %84
|
|
store i16 %87, i16* @us, align 2
|
|
%88 = load i8* @uc, align 1
|
|
%89 = zext i8 %88 to i32
|
|
%90 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%91 = atomicrmw or i32* %90, i32 %89 monotonic
|
|
%92 = or i32 %91, %89
|
|
store i32 %92, i32* @si, align 4
|
|
%93 = load i8* @uc, align 1
|
|
%94 = zext i8 %93 to i32
|
|
%95 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%96 = atomicrmw or i32* %95, i32 %94 monotonic
|
|
%97 = or i32 %96, %94
|
|
store i32 %97, i32* @ui, align 4
|
|
%98 = load i8* @uc, align 1
|
|
%99 = zext i8 %98 to i32
|
|
%100 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%101 = atomicrmw or i32* %100, i32 %99 monotonic
|
|
%102 = or i32 %101, %99
|
|
store i32 %102, i32* @sl, align 4
|
|
%103 = load i8* @uc, align 1
|
|
%104 = zext i8 %103 to i32
|
|
%105 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%106 = atomicrmw or i32* %105, i32 %104 monotonic
|
|
%107 = or i32 %106, %104
|
|
store i32 %107, i32* @ul, align 4
|
|
%108 = load i8* @uc, align 1
|
|
%109 = atomicrmw xor i8* @sc, i8 %108 monotonic
|
|
%110 = xor i8 %109, %108
|
|
store i8 %110, i8* @sc, align 1
|
|
%111 = load i8* @uc, align 1
|
|
%112 = atomicrmw xor i8* @uc, i8 %111 monotonic
|
|
%113 = xor i8 %112, %111
|
|
store i8 %113, i8* @uc, align 1
|
|
%114 = load i8* @uc, align 1
|
|
%115 = zext i8 %114 to i16
|
|
%116 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%117 = atomicrmw xor i16* %116, i16 %115 monotonic
|
|
%118 = xor i16 %117, %115
|
|
store i16 %118, i16* @ss, align 2
|
|
%119 = load i8* @uc, align 1
|
|
%120 = zext i8 %119 to i16
|
|
%121 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%122 = atomicrmw xor i16* %121, i16 %120 monotonic
|
|
%123 = xor i16 %122, %120
|
|
store i16 %123, i16* @us, align 2
|
|
%124 = load i8* @uc, align 1
|
|
%125 = zext i8 %124 to i32
|
|
%126 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%127 = atomicrmw xor i32* %126, i32 %125 monotonic
|
|
%128 = xor i32 %127, %125
|
|
store i32 %128, i32* @si, align 4
|
|
%129 = load i8* @uc, align 1
|
|
%130 = zext i8 %129 to i32
|
|
%131 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%132 = atomicrmw xor i32* %131, i32 %130 monotonic
|
|
%133 = xor i32 %132, %130
|
|
store i32 %133, i32* @ui, align 4
|
|
%134 = load i8* @uc, align 1
|
|
%135 = zext i8 %134 to i32
|
|
%136 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%137 = atomicrmw xor i32* %136, i32 %135 monotonic
|
|
%138 = xor i32 %137, %135
|
|
store i32 %138, i32* @sl, align 4
|
|
%139 = load i8* @uc, align 1
|
|
%140 = zext i8 %139 to i32
|
|
%141 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%142 = atomicrmw xor i32* %141, i32 %140 monotonic
|
|
%143 = xor i32 %142, %140
|
|
store i32 %143, i32* @ul, align 4
|
|
%144 = load i8* @uc, align 1
|
|
%145 = atomicrmw and i8* @sc, i8 %144 monotonic
|
|
%146 = and i8 %145, %144
|
|
store i8 %146, i8* @sc, align 1
|
|
%147 = load i8* @uc, align 1
|
|
%148 = atomicrmw and i8* @uc, i8 %147 monotonic
|
|
%149 = and i8 %148, %147
|
|
store i8 %149, i8* @uc, align 1
|
|
%150 = load i8* @uc, align 1
|
|
%151 = zext i8 %150 to i16
|
|
%152 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%153 = atomicrmw and i16* %152, i16 %151 monotonic
|
|
%154 = and i16 %153, %151
|
|
store i16 %154, i16* @ss, align 2
|
|
%155 = load i8* @uc, align 1
|
|
%156 = zext i8 %155 to i16
|
|
%157 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%158 = atomicrmw and i16* %157, i16 %156 monotonic
|
|
%159 = and i16 %158, %156
|
|
store i16 %159, i16* @us, align 2
|
|
%160 = load i8* @uc, align 1
|
|
%161 = zext i8 %160 to i32
|
|
%162 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%163 = atomicrmw and i32* %162, i32 %161 monotonic
|
|
%164 = and i32 %163, %161
|
|
store i32 %164, i32* @si, align 4
|
|
%165 = load i8* @uc, align 1
|
|
%166 = zext i8 %165 to i32
|
|
%167 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%168 = atomicrmw and i32* %167, i32 %166 monotonic
|
|
%169 = and i32 %168, %166
|
|
store i32 %169, i32* @ui, align 4
|
|
%170 = load i8* @uc, align 1
|
|
%171 = zext i8 %170 to i32
|
|
%172 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%173 = atomicrmw and i32* %172, i32 %171 monotonic
|
|
%174 = and i32 %173, %171
|
|
store i32 %174, i32* @sl, align 4
|
|
%175 = load i8* @uc, align 1
|
|
%176 = zext i8 %175 to i32
|
|
%177 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%178 = atomicrmw and i32* %177, i32 %176 monotonic
|
|
%179 = and i32 %178, %176
|
|
store i32 %179, i32* @ul, align 4
|
|
%180 = load i8* @uc, align 1
|
|
%181 = atomicrmw nand i8* @sc, i8 %180 monotonic
|
|
%182 = xor i8 %181, -1
|
|
%183 = and i8 %182, %180
|
|
store i8 %183, i8* @sc, align 1
|
|
%184 = load i8* @uc, align 1
|
|
%185 = atomicrmw nand i8* @uc, i8 %184 monotonic
|
|
%186 = xor i8 %185, -1
|
|
%187 = and i8 %186, %184
|
|
store i8 %187, i8* @uc, align 1
|
|
%188 = load i8* @uc, align 1
|
|
%189 = zext i8 %188 to i16
|
|
%190 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%191 = atomicrmw nand i16* %190, i16 %189 monotonic
|
|
%192 = xor i16 %191, -1
|
|
%193 = and i16 %192, %189
|
|
store i16 %193, i16* @ss, align 2
|
|
%194 = load i8* @uc, align 1
|
|
%195 = zext i8 %194 to i16
|
|
%196 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%197 = atomicrmw nand i16* %196, i16 %195 monotonic
|
|
%198 = xor i16 %197, -1
|
|
%199 = and i16 %198, %195
|
|
store i16 %199, i16* @us, align 2
|
|
%200 = load i8* @uc, align 1
|
|
%201 = zext i8 %200 to i32
|
|
%202 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%203 = atomicrmw nand i32* %202, i32 %201 monotonic
|
|
%204 = xor i32 %203, -1
|
|
%205 = and i32 %204, %201
|
|
store i32 %205, i32* @si, align 4
|
|
%206 = load i8* @uc, align 1
|
|
%207 = zext i8 %206 to i32
|
|
%208 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%209 = atomicrmw nand i32* %208, i32 %207 monotonic
|
|
%210 = xor i32 %209, -1
|
|
%211 = and i32 %210, %207
|
|
store i32 %211, i32* @ui, align 4
|
|
%212 = load i8* @uc, align 1
|
|
%213 = zext i8 %212 to i32
|
|
%214 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%215 = atomicrmw nand i32* %214, i32 %213 monotonic
|
|
%216 = xor i32 %215, -1
|
|
%217 = and i32 %216, %213
|
|
store i32 %217, i32* @sl, align 4
|
|
%218 = load i8* @uc, align 1
|
|
%219 = zext i8 %218 to i32
|
|
%220 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%221 = atomicrmw nand i32* %220, i32 %219 monotonic
|
|
%222 = xor i32 %221, -1
|
|
%223 = and i32 %222, %219
|
|
store i32 %223, i32* @ul, align 4
|
|
br label %return
|
|
|
|
return: ; preds = %entry
|
|
ret void
|
|
}
|
|
|
|
define void @test_compare_and_swap() nounwind {
|
|
entry:
|
|
%0 = load i8* @uc, align 1
|
|
%1 = load i8* @sc, align 1
|
|
%pair2 = cmpxchg i8* @sc, i8 %0, i8 %1 monotonic monotonic
|
|
%2 = extractvalue { i8, i1 } %pair2, 0
|
|
store i8 %2, i8* @sc, align 1
|
|
%3 = load i8* @uc, align 1
|
|
%4 = load i8* @sc, align 1
|
|
%pair5 = cmpxchg i8* @uc, i8 %3, i8 %4 monotonic monotonic
|
|
%5 = extractvalue { i8, i1 } %pair5, 0
|
|
store i8 %5, i8* @uc, align 1
|
|
%6 = load i8* @uc, align 1
|
|
%7 = zext i8 %6 to i16
|
|
%8 = load i8* @sc, align 1
|
|
%9 = sext i8 %8 to i16
|
|
%10 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%pair11 = cmpxchg i16* %10, i16 %7, i16 %9 monotonic monotonic
|
|
%11 = extractvalue { i16, i1 } %pair11, 0
|
|
store i16 %11, i16* @ss, align 2
|
|
%12 = load i8* @uc, align 1
|
|
%13 = zext i8 %12 to i16
|
|
%14 = load i8* @sc, align 1
|
|
%15 = sext i8 %14 to i16
|
|
%16 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%pair17 = cmpxchg i16* %16, i16 %13, i16 %15 monotonic monotonic
|
|
%17 = extractvalue { i16, i1 } %pair17, 0
|
|
store i16 %17, i16* @us, align 2
|
|
%18 = load i8* @uc, align 1
|
|
%19 = zext i8 %18 to i32
|
|
%20 = load i8* @sc, align 1
|
|
%21 = sext i8 %20 to i32
|
|
%22 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%pair23 = cmpxchg i32* %22, i32 %19, i32 %21 monotonic monotonic
|
|
%23 = extractvalue { i32, i1 } %pair23, 0
|
|
store i32 %23, i32* @si, align 4
|
|
%24 = load i8* @uc, align 1
|
|
%25 = zext i8 %24 to i32
|
|
%26 = load i8* @sc, align 1
|
|
%27 = sext i8 %26 to i32
|
|
%28 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%pair29 = cmpxchg i32* %28, i32 %25, i32 %27 monotonic monotonic
|
|
%29 = extractvalue { i32, i1 } %pair29, 0
|
|
store i32 %29, i32* @ui, align 4
|
|
%30 = load i8* @uc, align 1
|
|
%31 = zext i8 %30 to i32
|
|
%32 = load i8* @sc, align 1
|
|
%33 = sext i8 %32 to i32
|
|
%34 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%pair35 = cmpxchg i32* %34, i32 %31, i32 %33 monotonic monotonic
|
|
%35 = extractvalue { i32, i1 } %pair35, 0
|
|
store i32 %35, i32* @sl, align 4
|
|
%36 = load i8* @uc, align 1
|
|
%37 = zext i8 %36 to i32
|
|
%38 = load i8* @sc, align 1
|
|
%39 = sext i8 %38 to i32
|
|
%40 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%pair41 = cmpxchg i32* %40, i32 %37, i32 %39 monotonic monotonic
|
|
%41 = extractvalue { i32, i1 } %pair41, 0
|
|
store i32 %41, i32* @ul, align 4
|
|
%42 = load i8* @uc, align 1
|
|
%43 = load i8* @sc, align 1
|
|
%pair44 = cmpxchg i8* @sc, i8 %42, i8 %43 monotonic monotonic
|
|
%44 = extractvalue { i8, i1 } %pair44, 0
|
|
%45 = icmp eq i8 %44, %42
|
|
%46 = zext i1 %45 to i32
|
|
store i32 %46, i32* @ui, align 4
|
|
%47 = load i8* @uc, align 1
|
|
%48 = load i8* @sc, align 1
|
|
%pair49 = cmpxchg i8* @uc, i8 %47, i8 %48 monotonic monotonic
|
|
%49 = extractvalue { i8, i1 } %pair49, 0
|
|
%50 = icmp eq i8 %49, %47
|
|
%51 = zext i1 %50 to i32
|
|
store i32 %51, i32* @ui, align 4
|
|
%52 = load i8* @uc, align 1
|
|
%53 = zext i8 %52 to i16
|
|
%54 = load i8* @sc, align 1
|
|
%55 = sext i8 %54 to i16
|
|
%56 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%pair57 = cmpxchg i16* %56, i16 %53, i16 %55 monotonic monotonic
|
|
%57 = extractvalue { i16, i1 } %pair57, 0
|
|
%58 = icmp eq i16 %57, %53
|
|
%59 = zext i1 %58 to i32
|
|
store i32 %59, i32* @ui, align 4
|
|
%60 = load i8* @uc, align 1
|
|
%61 = zext i8 %60 to i16
|
|
%62 = load i8* @sc, align 1
|
|
%63 = sext i8 %62 to i16
|
|
%64 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%pair65 = cmpxchg i16* %64, i16 %61, i16 %63 monotonic monotonic
|
|
%65 = extractvalue { i16, i1 } %pair65, 0
|
|
%66 = icmp eq i16 %65, %61
|
|
%67 = zext i1 %66 to i32
|
|
store i32 %67, i32* @ui, align 4
|
|
%68 = load i8* @uc, align 1
|
|
%69 = zext i8 %68 to i32
|
|
%70 = load i8* @sc, align 1
|
|
%71 = sext i8 %70 to i32
|
|
%72 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%pair73 = cmpxchg i32* %72, i32 %69, i32 %71 monotonic monotonic
|
|
%73 = extractvalue { i32, i1 } %pair73, 0
|
|
%74 = icmp eq i32 %73, %69
|
|
%75 = zext i1 %74 to i32
|
|
store i32 %75, i32* @ui, align 4
|
|
%76 = load i8* @uc, align 1
|
|
%77 = zext i8 %76 to i32
|
|
%78 = load i8* @sc, align 1
|
|
%79 = sext i8 %78 to i32
|
|
%80 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%pair81 = cmpxchg i32* %80, i32 %77, i32 %79 monotonic monotonic
|
|
%81 = extractvalue { i32, i1 } %pair81, 0
|
|
%82 = icmp eq i32 %81, %77
|
|
%83 = zext i1 %82 to i32
|
|
store i32 %83, i32* @ui, align 4
|
|
%84 = load i8* @uc, align 1
|
|
%85 = zext i8 %84 to i32
|
|
%86 = load i8* @sc, align 1
|
|
%87 = sext i8 %86 to i32
|
|
%88 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%pair89 = cmpxchg i32* %88, i32 %85, i32 %87 monotonic monotonic
|
|
%89 = extractvalue { i32, i1 } %pair89, 0
|
|
%90 = icmp eq i32 %89, %85
|
|
%91 = zext i1 %90 to i32
|
|
store i32 %91, i32* @ui, align 4
|
|
%92 = load i8* @uc, align 1
|
|
%93 = zext i8 %92 to i32
|
|
%94 = load i8* @sc, align 1
|
|
%95 = sext i8 %94 to i32
|
|
%96 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%pair97 = cmpxchg i32* %96, i32 %93, i32 %95 monotonic monotonic
|
|
%97 = extractvalue { i32, i1 } %pair97, 0
|
|
%98 = icmp eq i32 %97, %93
|
|
%99 = zext i1 %98 to i32
|
|
store i32 %99, i32* @ui, align 4
|
|
br label %return
|
|
|
|
return: ; preds = %entry
|
|
ret void
|
|
}
|
|
|
|
define void @test_lock() nounwind {
|
|
entry:
|
|
%0 = atomicrmw xchg i8* @sc, i8 1 monotonic
|
|
store i8 %0, i8* @sc, align 1
|
|
%1 = atomicrmw xchg i8* @uc, i8 1 monotonic
|
|
store i8 %1, i8* @uc, align 1
|
|
%2 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
%3 = atomicrmw xchg i16* %2, i16 1 monotonic
|
|
store i16 %3, i16* @ss, align 2
|
|
%4 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
%5 = atomicrmw xchg i16* %4, i16 1 monotonic
|
|
store i16 %5, i16* @us, align 2
|
|
%6 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
%7 = atomicrmw xchg i32* %6, i32 1 monotonic
|
|
store i32 %7, i32* @si, align 4
|
|
%8 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
%9 = atomicrmw xchg i32* %8, i32 1 monotonic
|
|
store i32 %9, i32* @ui, align 4
|
|
%10 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
%11 = atomicrmw xchg i32* %10, i32 1 monotonic
|
|
store i32 %11, i32* @sl, align 4
|
|
%12 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
%13 = atomicrmw xchg i32* %12, i32 1 monotonic
|
|
store i32 %13, i32* @ul, align 4
|
|
fence seq_cst
|
|
store volatile i8 0, i8* @sc, align 1
|
|
store volatile i8 0, i8* @uc, align 1
|
|
%14 = bitcast i8* bitcast (i16* @ss to i8*) to i16*
|
|
store volatile i16 0, i16* %14, align 2
|
|
%15 = bitcast i8* bitcast (i16* @us to i8*) to i16*
|
|
store volatile i16 0, i16* %15, align 2
|
|
%16 = bitcast i8* bitcast (i32* @si to i8*) to i32*
|
|
store volatile i32 0, i32* %16, align 4
|
|
%17 = bitcast i8* bitcast (i32* @ui to i8*) to i32*
|
|
store volatile i32 0, i32* %17, align 4
|
|
%18 = bitcast i8* bitcast (i32* @sl to i8*) to i32*
|
|
store volatile i32 0, i32* %18, align 4
|
|
%19 = bitcast i8* bitcast (i32* @ul to i8*) to i32*
|
|
store volatile i32 0, i32* %19, align 4
|
|
%20 = bitcast i8* bitcast (i64* @sll to i8*) to i64*
|
|
store volatile i64 0, i64* %20, align 8
|
|
%21 = bitcast i8* bitcast (i64* @ull to i8*) to i64*
|
|
store volatile i64 0, i64* %21, align 8
|
|
br label %return
|
|
|
|
return: ; preds = %entry
|
|
ret void
|
|
}
|