[ORC-RT][LoongArch] Add initial support for loongarch64 in ELFNixPlatform (#123575)
[llvm-project.git] / llvm / test / tools / llvm-reduce / reduce-volatile.ll
blob2f09cbc38ccd6b5ce1dfb557367a8ee91496a1a4
1 ; RUN: llvm-reduce --abort-on-invalid-reduction --delta-passes=volatile --test FileCheck --test-arg --check-prefixes=INTERESTING,CHECK --test-arg %s --test-arg --input-file %s -o %t
2 ; RUN: FileCheck -check-prefixes=RESULT,CHECK %s < %t
4 ; CHECK-LABEL: @load_volatile_keep(
5 ; INTERESTING: load volatile
6 ; RESULT: %op = load volatile i32,
7 define i32 @load_volatile_keep(ptr %ptr) {
8   %op = load volatile i32, ptr %ptr
9   ret i32 %op
12 ; CHECK-LABEL: @load_volatile_drop(
13 ; INTERESTING: load
14 ; RESULT: %op = load i32,
15 define i32 @load_volatile_drop(ptr %ptr) {
16   %op = load volatile i32, ptr %ptr
17   ret i32 %op
20 ; CHECK-LABEL: @store_volatile_keep(
21 ; INTERESTING: store volatile
22 ; RESULT: store volatile i32 0,
23 define void @store_volatile_keep(ptr %ptr) {
24   store volatile i32 0, ptr %ptr
25   ret void
28 ; CHECK-LABEL: @store_volatile_drop(
29 ; INTERESTING: store
30 ; RESULT: store i32 0,
31 define void @store_volatile_drop(ptr %ptr) {
32   store volatile i32 0, ptr %ptr
33   ret void
36 ; CHECK-LABEL: @atomicrmw_volatile_keep(
37 ; INTERESTING: atomicrmw volatile
38 ; RESULT: atomicrmw volatile add ptr %ptr
39 define i32 @atomicrmw_volatile_keep(ptr %ptr) {
40   %val = atomicrmw volatile add ptr %ptr, i32 3 seq_cst
41   ret i32 %val
44 ; CHECK-LABEL: @atomicrmw_volatile_drop(
45 ; INTERESTING: atomicrmw
46 ; RESULT: atomicrmw add ptr %ptr
47 define i32 @atomicrmw_volatile_drop(ptr %ptr) {
48   %val = atomicrmw volatile add ptr %ptr, i32 3 seq_cst
49   ret i32 %val
52 ; CHECK-LABEL: @cmpxchg_volatile_keep(
53 ; INTERESTING: cmpxchg volatile
54 ; RESULT: cmpxchg volatile ptr %ptr, i32 %old, i32 %in seq_cst seq_cst
55 define { i32, i1 } @cmpxchg_volatile_keep(ptr %ptr, i32 %old, i32 %in) {
56   %val = cmpxchg volatile ptr %ptr, i32 %old, i32 %in seq_cst seq_cst
57   ret { i32, i1 } %val
60 ; CHECK-LABEL: @cmpxchg_volatile_drop(
61 ; INTERESTING: cmpxchg
62 ; RESULT: cmpxchg ptr %ptr, i32 %old, i32 %in seq_cst seq_cst
63 define { i32, i1 } @cmpxchg_volatile_drop(ptr %ptr, i32 %old, i32 %in) {
64   %val = cmpxchg volatile ptr %ptr, i32 %old, i32 %in seq_cst seq_cst
65   ret { i32, i1 } %val
68 ; CHECK-LABEL: @memcpy_volatile_keep(
69 ; INTERESTING: i1 true
70 ; RESULT: call void @llvm.memcpy.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 true)
71 define void @memcpy_volatile_keep(ptr %dst, ptr %src, i64 %size) {
72   call void @llvm.memcpy.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 true)
73   ret void
76 ; CHECK-LABEL: @memcpy_volatile_drop(
77 ; INTERESTING: llvm.memcpy
78 ; RESULT: call void @llvm.memcpy.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 false)
79 define void @memcpy_volatile_drop(ptr %dst, ptr %src, i64 %size) {
80   call void @llvm.memcpy.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 true)
81   ret void
84 ; CHECK-LABEL: @memcpy_inline_volatile_keep(
85 ; INTERESTING: i1 true
86 ; RESULT: call void @llvm.memcpy.inline.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 true)
87 define void @memcpy_inline_volatile_keep(ptr %dst, ptr %src) {
88   call void @llvm.memcpy.inline.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 true)
89   ret void
92 ; CHECK-LABEL: @memcpy_inline_volatile_drop(
93 ; INTERESTING: llvm.memcpy
94 ; RESULT: call void @llvm.memcpy.inline.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 false)
95 define void @memcpy_inline_volatile_drop(ptr %dst, ptr %src) {
96   call void @llvm.memcpy.inline.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 true)
97   ret void
100 ; CHECK-LABEL: @memmove_volatile_keep(
101 ; INTERESTING: i1 true
102 ; RESULT: call void @llvm.memmove.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 true)
103 define void @memmove_volatile_keep(ptr %dst, ptr %src) {
104   call void @llvm.memmove.p0.p0.i64(ptr %dst, ptr %src, i64 256, i1 true)
105   ret void
108 ; CHECK-LABEL: @memmove_volatile_drop(
109 ; INTERESTING: llvm.memmove
110 ; RESULT: call void @llvm.memmove.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 false)
111 define void @memmove_volatile_drop(ptr %dst, ptr %src, i64 %size) {
112   call void @llvm.memmove.p0.p0.i64(ptr %dst, ptr %src, i64 %size, i1 true)
113   ret void
116 ; CHECK-LABEL: @memset_volatile_keep(
117 ; INTERESTING: i1 true
118 ; RESULT: call void @llvm.memset.p0.i64(ptr %ptr, i8 %val, i64 %size, i1 true)
119 define void @memset_volatile_keep(ptr %ptr, i8 %val, i64 %size) {
120   call void @llvm.memset.p0.i64(ptr %ptr, i8 %val, i64 %size, i1 true)
121   ret void
124 ; CHECK-LABEL: @memset_volatile_drop(
125 ; INTERESTING: llvm.memset
126 ; RESULT: call void @llvm.memset.p0.i64(ptr %ptr, i8 %val, i64 %size, i1 false)
127 define void @memset_volatile_drop(ptr %ptr, i8 %val, i64 %size) {
128   call void @llvm.memset.p0.i64(ptr %ptr, i8 %val, i64 %size, i1 true)
129   ret void
132 declare void @llvm.memcpy.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64, i1 immarg)
133 declare void @llvm.memmove.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64, i1 immarg)
134 declare void @llvm.memcpy.inline.p0.p0.i64(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i64 immarg, i1 immarg)
135 declare void @llvm.memset.p0.i64(ptr noalias nocapture readonly, i8, i64, i1 immarg)