[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / X86 / volatile.ll
blob50c023446e2eda825c2ce719c2e691963b66a9d3
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-- -mattr=sse2 | FileCheck %s --check-prefixes=ALL,OPT
3 ; RUN: llc < %s -mtriple=i686-- -mattr=sse2 -O0 | FileCheck %s --check-prefixes=ALL,NOOPT
5 @x = external dso_local global double
7 define void @foo() nounwind  {
8 ; OPT-LABEL: foo:
9 ; OPT:       # %bb.0:
10 ; OPT-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
11 ; OPT-NEXT:    xorps %xmm0, %xmm0
12 ; OPT-NEXT:    movsd %xmm0, x
13 ; OPT-NEXT:    movsd %xmm0, x
14 ; OPT-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
15 ; OPT-NEXT:    retl
17 ; NOOPT-LABEL: foo:
18 ; NOOPT:       # %bb.0:
19 ; NOOPT-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
20 ; NOOPT-NEXT:    xorps %xmm0, %xmm0
21 ; NOOPT-NEXT:    movsd %xmm0, x
22 ; NOOPT-NEXT:    xorps %xmm0, %xmm0
23 ; NOOPT-NEXT:    movsd %xmm0, x
24 ; NOOPT-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
25 ; NOOPT-NEXT:    retl
26   %a = load volatile double, double* @x
27   store volatile double 0.0, double* @x
28   store volatile double 0.0, double* @x
29   %b = load volatile double, double* @x
30   ret void
33 define void @bar() nounwind  {
34 ; ALL-LABEL: bar:
35 ; ALL:       # %bb.0:
36 ; ALL-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
37 ; ALL-NEXT:    retl
38   %c = load volatile double, double* @x
39   ret void