| ; Test atomic double minimum. |
| ; Expect a libcall in a compare-and-swap loop. |
| ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s |
| define double @f1(ptr %src, double %b) { |
| ; CHECK: lgr [[SRC:%r[0-9]+]], %r2 |
| ; CHECK: ld [[FSRC:%f[0-9]+]], 0(%r2) |
| ; CHECK: ldr [[FB:%f[0-9]+]], %f0 |
| ; CHECK: ldr %f0, [[FSRC]] |
| ; CHECK: brasl %r14, fmin@PLT |
| ; CHECK: lgdr [[RO:%r[0-9]+]], %f0 |
| ; CHECK: lgdr [[RI:%r[0-9]+]], [[FSRC]] |
| ; CHECK: csg [[RI]], [[RO]], 0([[SRC]]) |
| ; CHECK: ldgr [[FSRC]], [[RI]] |
| ; CHECK: ldr %f0, [[FSRC]] |
| %res = atomicrmw fmin ptr %src, double %b seq_cst |