| ; RUN: llc < %s | FileCheck %s |
| |
| target datalayout = "e-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-p:32:32:32-v128:32:128-n32-S128" |
| target triple = "asmjs-unknown-emscripten" |
| |
| ; CHECK: function _simple_integer_math( |
| ; CHECK: [[VAL_A:\$[a-z]+]] = [[VAL_A]]|0; |
| ; CHECK: [[VAL_B:\$[a-z]+]] = [[VAL_B]]|0; |
| ; CHECK: [[VAL_C:\$[a-z]+]] = (([[VAL_A]]) + ([[VAL_B]]))|0; |
| ; CHECK: [[VAL_D:\$[a-z]+]] = ([[VAL_C]]*20)|0; |
| ; CHECK: [[VAL_E:\$[a-z]+]] = (([[VAL_D]]|0) / ([[VAL_A]]|0))&-1; |
| ; CHECK: [[VAL_F:\$[a-z]+]] = (([[VAL_E]]) - 3)|0; |
| ; CHECK: return ([[VAL_F]]|0); |
| define i32 @simple_integer_math(i32 %a, i32 %b) nounwind { |
| %c = add i32 %a, %b |
| %d = mul i32 %c, 20 |
| %e = sdiv i32 %d, %a |
| %f = sub i32 %e, 3 |
| ret i32 %f |
| } |
| |
| ; CHECK: function _fneg( |
| ; CHECK: [[VAL_D:\$[a-z]+]] = +[[VAL_D]] |
| ; CHECK: [[VAL_F:\$[a-z]+]] = +0 |
| ; CHECK: [[VAL_F]] = -[[VAL_D]] |
| ; CHECK: return (+[[VAL_F]]); |
| define double @fneg(double %d) nounwind { |
| %f = fsub double -0.0, %d |
| ret double %f |
| } |
| |
| ; CHECK: function _flt_rounds( |
| ; CHECK: t = 1; |
| declare i32 @llvm.flt.rounds() |
| define i32 @flt_rounds() { |
| %t = call i32 @llvm.flt.rounds() |
| ret i32 %t |
| } |