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