Home | History | Annotate | Download | only in Verifier
      1 ; RUN: not llvm-as < %s 2>&1 | FileCheck %s
      2 
      3 define void @fpmath1(i32 %i, float %f, <2 x float> %g) {
      4   %s = add i32 %i, %i, !fpmath !0
      5 ; CHECK: fpmath requires a floating point result!
      6   %t = fadd float %f, %f, !fpmath !1
      7 ; CHECK: fpmath takes one operand!
      8   %u = fadd float %f, %f, !fpmath !2
      9 ; CHECK: fpmath takes one operand!
     10   %v = fadd float %f, %f, !fpmath !3
     11 ; CHECK: invalid fpmath accuracy!
     12   %w = fadd float %f, %f, !fpmath !0
     13 ; Above line is correct.
     14   %w2 = fadd <2 x float> %g, %g, !fpmath !0
     15 ; Above line is correct.
     16   %x = fadd float %f, %f, !fpmath !4
     17 ; CHECK: fpmath accuracy not a positive number!
     18   %y = fadd float %f, %f, !fpmath !5
     19 ; CHECK: fpmath accuracy not a positive number!
     20   %z = fadd float %f, %f, !fpmath !6
     21 ; CHECK: fpmath accuracy not a positive number!
     22   %double.fpmath = fadd float %f, %f, !fpmath !7
     23 ; CHECK: fpmath accuracy must have float type
     24   ret void
     25 }
     26 
     27 !0 = !{ float 1.0 }
     28 !1 = !{ }
     29 !2 = !{ float 1.0, float 1.0 }
     30 !3 = !{ i32 1 }
     31 !4 = !{ float -1.0 }
     32 !5 = !{ float 0.0 }
     33 !6 = !{ float 0x7FFFFFFF00000000 }
     34 !7 = !{ double 1.0 }
     35