1; Test conversion of floating-point values to unsigned i32s (z10 only). 2; 3; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z10 | FileCheck %s 4 5; z10 doesn't have native support for unsigned fp-to-i32 conversions; 6; they were added in z196 as the Convert to Logical family of instructions. 7; Promoting to i64 doesn't generate an inexact condition for values that are 8; outside the i32 range but in the i64 range, so use the default expansion. 9 10; Test f32->i32. 11define i32 @f1(float %f) { 12; CHECK-LABEL: f1: 13; CHECK: cebr 14; CHECK: sebr 15; CHECK: cfebr 16; CHECK: xilf 17; CHECK: br %r14 18 %conv = fptoui float %f to i32 19 ret i32 %conv 20} 21 22; Test f64->i32. 23define i32 @f2(double %f) { 24; CHECK-LABEL: f2: 25; CHECK: cdbr 26; CHECK: sdbr 27; CHECK: cfdbr 28; CHECK: xilf 29; CHECK: br %r14 30 %conv = fptoui double %f to i32 31 ret i32 %conv 32} 33 34; Test f128->i32. 35define i32 @f3(fp128 *%src) { 36; CHECK-LABEL: f3: 37; CHECK: cxbr 38; CHECK: sxbr 39; CHECK: cfxbr 40; CHECK: xilf 41; CHECK: br %r14 42 %f = load fp128, fp128 *%src 43 %conv = fptoui fp128 %f to i32 44 ret i32 %conv 45} 46