Skip to content

Commit 9c42ed1

Browse files
committed
[X86] Add x86-atomic-double.c double test coverage
1 parent 4bb6974 commit 9c42ed1

File tree

1 file changed

+104
-0
lines changed

1 file changed

+104
-0
lines changed
Lines changed: 104 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,104 @@
1+
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 4
2+
// RUN: %clang_cc1 -triple x86_64-linux-gnu -target-cpu core2 %s -emit-llvm -o - | FileCheck -check-prefixes=X64 %s
3+
// RUN: %clang_cc1 -triple i686-linux-gnu -target-cpu core2 %s -emit-llvm -o - | FileCheck -check-prefixes=X86 %s
4+
5+
6+
// X64-LABEL: define dso_local double @test_double_post_inc(
7+
// X64-SAME: ) #[[ATTR0:[0-9]+]] {
8+
// X64-NEXT: entry:
9+
// X64-NEXT: [[RETVAL:%.*]] = alloca double, align 8
10+
// X64-NEXT: [[TMP0:%.*]] = atomicrmw fadd ptr @test_double_post_inc.n, float 1.000000e+00 seq_cst, align 8
11+
// X64-NEXT: store float [[TMP0]], ptr [[RETVAL]], align 8
12+
// X64-NEXT: [[TMP1:%.*]] = load double, ptr [[RETVAL]], align 8
13+
// X64-NEXT: ret double [[TMP1]]
14+
//
15+
// X86-LABEL: define dso_local double @test_double_post_inc(
16+
// X86-SAME: ) #[[ATTR0:[0-9]+]] {
17+
// X86-NEXT: entry:
18+
// X86-NEXT: [[RETVAL:%.*]] = alloca double, align 4
19+
// X86-NEXT: [[TMP0:%.*]] = atomicrmw fadd ptr @test_double_post_inc.n, float 1.000000e+00 seq_cst, align 8
20+
// X86-NEXT: store float [[TMP0]], ptr [[RETVAL]], align 4
21+
// X86-NEXT: [[TMP1:%.*]] = load double, ptr [[RETVAL]], align 4
22+
// X86-NEXT: ret double [[TMP1]]
23+
//
24+
double test_double_post_inc()
25+
{
26+
static _Atomic double n;
27+
return n++;
28+
}
29+
30+
// X64-LABEL: define dso_local double @test_double_post_dc(
31+
// X64-SAME: ) #[[ATTR0]] {
32+
// X64-NEXT: entry:
33+
// X64-NEXT: [[RETVAL:%.*]] = alloca double, align 8
34+
// X64-NEXT: [[TMP0:%.*]] = atomicrmw fsub ptr @test_double_post_dc.n, float 1.000000e+00 seq_cst, align 8
35+
// X64-NEXT: store float [[TMP0]], ptr [[RETVAL]], align 8
36+
// X64-NEXT: [[TMP1:%.*]] = load double, ptr [[RETVAL]], align 8
37+
// X64-NEXT: ret double [[TMP1]]
38+
//
39+
// X86-LABEL: define dso_local double @test_double_post_dc(
40+
// X86-SAME: ) #[[ATTR0]] {
41+
// X86-NEXT: entry:
42+
// X86-NEXT: [[RETVAL:%.*]] = alloca double, align 4
43+
// X86-NEXT: [[TMP0:%.*]] = atomicrmw fsub ptr @test_double_post_dc.n, float 1.000000e+00 seq_cst, align 8
44+
// X86-NEXT: store float [[TMP0]], ptr [[RETVAL]], align 4
45+
// X86-NEXT: [[TMP1:%.*]] = load double, ptr [[RETVAL]], align 4
46+
// X86-NEXT: ret double [[TMP1]]
47+
//
48+
double test_double_post_dc()
49+
{
50+
static _Atomic double n;
51+
return n--;
52+
}
53+
54+
// X64-LABEL: define dso_local double @test_double_pre_dc(
55+
// X64-SAME: ) #[[ATTR0]] {
56+
// X64-NEXT: entry:
57+
// X64-NEXT: [[RETVAL:%.*]] = alloca double, align 8
58+
// X64-NEXT: [[TMP0:%.*]] = atomicrmw fsub ptr @test_double_pre_dc.n, float 1.000000e+00 seq_cst, align 8
59+
// X64-NEXT: [[TMP1:%.*]] = fsub float [[TMP0]], 1.000000e+00
60+
// X64-NEXT: store float [[TMP1]], ptr [[RETVAL]], align 8
61+
// X64-NEXT: [[TMP2:%.*]] = load double, ptr [[RETVAL]], align 8
62+
// X64-NEXT: ret double [[TMP2]]
63+
//
64+
// X86-LABEL: define dso_local double @test_double_pre_dc(
65+
// X86-SAME: ) #[[ATTR0]] {
66+
// X86-NEXT: entry:
67+
// X86-NEXT: [[RETVAL:%.*]] = alloca double, align 4
68+
// X86-NEXT: [[TMP0:%.*]] = atomicrmw fsub ptr @test_double_pre_dc.n, float 1.000000e+00 seq_cst, align 8
69+
// X86-NEXT: [[TMP1:%.*]] = fsub float [[TMP0]], 1.000000e+00
70+
// X86-NEXT: store float [[TMP1]], ptr [[RETVAL]], align 4
71+
// X86-NEXT: [[TMP2:%.*]] = load double, ptr [[RETVAL]], align 4
72+
// X86-NEXT: ret double [[TMP2]]
73+
//
74+
double test_double_pre_dc()
75+
{
76+
static _Atomic double n;
77+
return --n;
78+
}
79+
80+
// X64-LABEL: define dso_local double @test_double_pre_inc(
81+
// X64-SAME: ) #[[ATTR0]] {
82+
// X64-NEXT: entry:
83+
// X64-NEXT: [[RETVAL:%.*]] = alloca double, align 8
84+
// X64-NEXT: [[TMP0:%.*]] = atomicrmw fadd ptr @test_double_pre_inc.n, float 1.000000e+00 seq_cst, align 8
85+
// X64-NEXT: [[TMP1:%.*]] = fadd float [[TMP0]], 1.000000e+00
86+
// X64-NEXT: store float [[TMP1]], ptr [[RETVAL]], align 8
87+
// X64-NEXT: [[TMP2:%.*]] = load double, ptr [[RETVAL]], align 8
88+
// X64-NEXT: ret double [[TMP2]]
89+
//
90+
// X86-LABEL: define dso_local double @test_double_pre_inc(
91+
// X86-SAME: ) #[[ATTR0]] {
92+
// X86-NEXT: entry:
93+
// X86-NEXT: [[RETVAL:%.*]] = alloca double, align 4
94+
// X86-NEXT: [[TMP0:%.*]] = atomicrmw fadd ptr @test_double_pre_inc.n, float 1.000000e+00 seq_cst, align 8
95+
// X86-NEXT: [[TMP1:%.*]] = fadd float [[TMP0]], 1.000000e+00
96+
// X86-NEXT: store float [[TMP1]], ptr [[RETVAL]], align 4
97+
// X86-NEXT: [[TMP2:%.*]] = load double, ptr [[RETVAL]], align 4
98+
// X86-NEXT: ret double [[TMP2]]
99+
//
100+
double test_double_pre_inc()
101+
{
102+
static _Atomic double n;
103+
return ++n;
104+
}

0 commit comments

Comments
 (0)