toolarge.ll 524 B

12345678910111213141516
  1. ; RUN: opt < %s -float2int -float2int-max-integer-bw=256 -S | FileCheck %s
  2. ; CHECK-LABEL: @neg_toolarge
  3. ; CHECK: %1 = uitofp i80 %a to fp128
  4. ; CHECK: %2 = fadd fp128 %1, %1
  5. ; CHECK: %3 = fptoui fp128 %2 to i80
  6. ; CHECK: ret i80 %3
  7. ; fp128 has a 112-bit mantissa, which can hold an i80. But we only support
  8. ; up to i64, so it should fail (even though the max integer bitwidth is 256).
  9. define i80 @neg_toolarge(i80 %a) {
  10. %1 = uitofp i80 %a to fp128
  11. %2 = fadd fp128 %1, %1
  12. %3 = fptoui fp128 %2 to i80
  13. ret i80 %3
  14. }