xref: /llvm-project/llvm/test/CodeGen/SystemZ/atomicrmw-fmin-02.ll (revision 03934e70ef1cf86a6ebd1a56e0b5b46f4fec8e13)
1; Test atomic double minimum.
2; Expect a libcall in a compare-and-swap loop.
3;
4; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
5
6define double @f1(ptr %src, double %b) {
7; CHECK-LABEL: f1:
8; CHECK: lgr [[SRC:%r[0-9]+]], %r2
9; CHECK: ld [[FSRC:%f[0-9]+]], 0(%r2)
10; CHECK: ldr [[FB:%f[0-9]+]], %f0
11; CHECK: [[L:\.L.+]]:
12; CHECK: ldr %f0, [[FSRC]]
13; CHECK: ldr %f2, [[FB]]
14; CHECK: brasl %r14, fmin@PLT
15; CHECK: lgdr [[RO:%r[0-9]+]], %f0
16; CHECK: lgdr [[RI:%r[0-9]+]], [[FSRC]]
17; CHECK: csg [[RI]], [[RO]], 0([[SRC]])
18; CHECK: ldgr [[FSRC]], [[RI]]
19; CHECK: jl [[L]]
20; CHECK: ldr %f0, [[FSRC]]
21; CHECK: br %r14
22  %res = atomicrmw fmin ptr %src, double %b seq_cst
23  ret double %res
24}
25