| OLD | NEW |
| (Empty) |
| 1 ; RUN: llc < %s | FileCheck %s | |
| 2 | |
| 3 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" | |
| 4 target triple = "asmjs-unknown-emscripten" | |
| 5 | |
| 6 ; CHECK: function _simple_integer_math( | |
| 7 ; CHECK: [[VAL_A:\$[a-z]+]] = [[VAL_A]]|0; | |
| 8 ; CHECK: [[VAL_B:\$[a-z]+]] = [[VAL_B]]|0; | |
| 9 ; CHECK: [[VAL_C:\$[a-z]+]] = (([[VAL_A]]) + ([[VAL_B]]))|0; | |
| 10 ; CHECK: [[VAL_D:\$[a-z]+]] = ([[VAL_C]]*20)|0; | |
| 11 ; CHECK: [[VAL_E:\$[a-z]+]] = (([[VAL_D]]|0) / ([[VAL_A]]|0))&-1; | |
| 12 ; CHECK: [[VAL_F:\$[a-z]+]] = (([[VAL_E]]) - 3)|0; | |
| 13 ; CHECK: return ([[VAL_F]]|0); | |
| 14 define i32 @simple_integer_math(i32 %a, i32 %b) nounwind { | |
| 15 %c = add i32 %a, %b | |
| 16 %d = mul i32 %c, 20 | |
| 17 %e = sdiv i32 %d, %a | |
| 18 %f = sub i32 %e, 3 | |
| 19 ret i32 %f | |
| 20 } | |
| 21 | |
| 22 ; CHECK: function _fneg( | |
| 23 ; CHECK: [[VAL_D:\$[a-z]+]] = +[[VAL_D]] | |
| 24 ; CHECK: [[VAL_F:\$[a-z]+]] = +0 | |
| 25 ; CHECK: [[VAL_F]] = -[[VAL_D]] | |
| 26 ; CHECK: return (+[[VAL_F]]); | |
| 27 define double @fneg(double %d) nounwind { | |
| 28 %f = fsub double -0.0, %d | |
| 29 ret double %f | |
| 30 } | |
| 31 | |
| 32 ; CHECK: function _flt_rounds( | |
| 33 ; CHECK: t = 1; | |
| 34 declare i32 @llvm.flt.rounds() | |
| 35 define i32 @flt_rounds() { | |
| 36 %t = call i32 @llvm.flt.rounds() | |
| 37 ret i32 %t | |
| 38 } | |
| OLD | NEW |