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