diff options
author | Dan Gohman <dan433584@gmail.com> | 2015-10-06 00:27:55 +0000 |
---|---|---|
committer | Dan Gohman <dan433584@gmail.com> | 2015-10-06 00:27:55 +0000 |
commit | e51c058ecc2d06b329e176a78487144828a7ae51 (patch) | |
tree | ccbaecac243b7f16d7683c0bdc128ad892e7810f /llvm/test/CodeGen/WebAssembly/conv.ll | |
parent | d77e802f0772e3f0fe53027a9e09de3dae46b911 (diff) | |
download | bcm5719-llvm-e51c058ecc2d06b329e176a78487144828a7ae51.tar.gz bcm5719-llvm-e51c058ecc2d06b329e176a78487144828a7ae51.zip |
[WebAssembly] Switch to a more traditional assembly syntax
This new syntax is built around putting each instruction on its own line
in a "mnemonic op, op, op" like syntax. It also uses conventional data
section directives like ".byte" and so on rather than requiring everything
to be in hierarchical S-expression format. This is a more natural syntax
for a ".s" file format from the perspective of LLVM MC and related tools,
while remaining easy to translate into other forms as needed.
llvm-svn: 249364
Diffstat (limited to 'llvm/test/CodeGen/WebAssembly/conv.ll')
-rw-r--r-- | llvm/test/CodeGen/WebAssembly/conv.ll | 273 |
1 files changed, 168 insertions, 105 deletions
diff --git a/llvm/test/CodeGen/WebAssembly/conv.ll b/llvm/test/CodeGen/WebAssembly/conv.ll index 0b45cbe204a..0742c55bb7a 100644 --- a/llvm/test/CodeGen/WebAssembly/conv.ll +++ b/llvm/test/CodeGen/WebAssembly/conv.ll @@ -5,211 +5,274 @@ target datalayout = "e-p:32:32-i64:64-n32:64-S128" target triple = "wasm32-unknown-unknown" -; CHECK-LABEL: $i32_wrap_i64 -; CHECK-NEXT: (param i64) (result i32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i32_wrap @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i32_wrap_i64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i32{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i32_wrap @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i32 @i32_wrap_i64(i64 %x) { %a = trunc i64 %x to i32 ret i32 %a } -; CHECK-LABEL: $i64_extend_s_i32 -; CHECK-NEXT: (param i32) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_extend_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_extend_s_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_extend_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_extend_s_i32(i32 %x) { %a = sext i32 %x to i64 ret i64 %a } -; CHECK-LABEL: $i64_extend_u_i32 -; CHECK-NEXT: (param i32) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_extend_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_extend_u_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_extend_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_extend_u_i32(i32 %x) { %a = zext i32 %x to i64 ret i64 %a } -; CHECK-LABEL: $i32_trunc_s_f32 -; CHECK-NEXT: (param f32) (result i32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i32_trunc_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i32_trunc_s_f32: +; CHECK-NEXT: .param f32 +; CHECK-NEXT: .result i32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i32_trunc_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i32 @i32_trunc_s_f32(float %x) { %a = fptosi float %x to i32 ret i32 %a } -; CHECK-LABEL: $i32_trunc_u_f32 -; CHECK-NEXT: (param f32) (result i32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i32_trunc_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i32_trunc_u_f32: +; CHECK-NEXT: .param f32 +; CHECK-NEXT: .result i32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i32_trunc_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i32 @i32_trunc_u_f32(float %x) { %a = fptoui float %x to i32 ret i32 %a } -; CHECK-LABEL: $i32_trunc_s_f64 -; CHECK-NEXT: (param f64) (result i32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i32_trunc_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i32_trunc_s_f64: +; CHECK-NEXT: .param f64 +; CHECK-NEXT: .result i32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i32_trunc_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i32 @i32_trunc_s_f64(double %x) { %a = fptosi double %x to i32 ret i32 %a } -; CHECK-LABEL: $i32_trunc_u_f64 -; CHECK-NEXT: (param f64) (result i32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i32_trunc_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i32_trunc_u_f64: +; CHECK-NEXT: .param f64 +; CHECK-NEXT: .result i32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i32_trunc_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i32 @i32_trunc_u_f64(double %x) { %a = fptoui double %x to i32 ret i32 %a } -; CHECK-LABEL: $i64_trunc_s_f32 -; CHECK-NEXT: (param f32) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_trunc_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_trunc_s_f32: +; CHECK-NEXT: .param f32 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_trunc_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_trunc_s_f32(float %x) { %a = fptosi float %x to i64 ret i64 %a } -; CHECK-LABEL: $i64_trunc_u_f32 -; CHECK-NEXT: (param f32) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_trunc_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_trunc_u_f32: +; CHECK-NEXT: .param f32 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_trunc_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_trunc_u_f32(float %x) { %a = fptoui float %x to i64 ret i64 %a } -; CHECK-LABEL: $i64_trunc_s_f64 -; CHECK-NEXT: (param f64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_trunc_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_trunc_s_f64: +; CHECK-NEXT: .param f64 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_trunc_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_trunc_s_f64(double %x) { %a = fptosi double %x to i64 ret i64 %a } -; CHECK-LABEL: $i64_trunc_u_f64 -; CHECK-NEXT: (param f64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (i64_trunc_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: i64_trunc_u_f64: +; CHECK-NEXT: .param f64 +; CHECK-NEXT: .result i64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: i64_trunc_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @i64_trunc_u_f64(double %x) { %a = fptoui double %x to i64 ret i64 %a } -; CHECK-LABEL: $f32_convert_s_i32 -; CHECK-NEXT: (param i32) (result f32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f32_convert_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f32_convert_s_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result f32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f32_convert_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define float @f32_convert_s_i32(i32 %x) { %a = sitofp i32 %x to float ret float %a } -; CHECK-LABEL: $f32_convert_u_i32 -; CHECK-NEXT: (param i32) (result f32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f32_convert_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f32_convert_u_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result f32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f32_convert_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define float @f32_convert_u_i32(i32 %x) { %a = uitofp i32 %x to float ret float %a } -; CHECK-LABEL: $f64_convert_s_i32 -; CHECK-NEXT: (param i32) (result f64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f64_convert_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f64_convert_s_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result f64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f64_convert_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define double @f64_convert_s_i32(i32 %x) { %a = sitofp i32 %x to double ret double %a } -; CHECK-LABEL: $f64_convert_u_i32 -; CHECK-NEXT: (param i32) (result f64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f64_convert_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f64_convert_u_i32: +; CHECK-NEXT: .param i32 +; CHECK-NEXT: .result f64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f64_convert_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define double @f64_convert_u_i32(i32 %x) { %a = uitofp i32 %x to double ret double %a } -; CHECK-LABEL: $f32_convert_s_i64 -; CHECK-NEXT: (param i64) (result f32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f32_convert_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f32_convert_s_i64: +; CHECK-NEXT: .param i64 +; CHECK-NEXT: .result f32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f32_convert_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define float @f32_convert_s_i64(i64 %x) { %a = sitofp i64 %x to float ret float %a } -; CHECK-LABEL: $f32_convert_u_i64 -; CHECK-NEXT: (param i64) (result f32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f32_convert_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f32_convert_u_i64: +; CHECK-NEXT: .param i64 +; CHECK-NEXT: .result f32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f32_convert_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define float @f32_convert_u_i64(i64 %x) { %a = uitofp i64 %x to float ret float %a } -; CHECK-LABEL: $f64_convert_s_i64 -; CHECK-NEXT: (param i64) (result f64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f64_convert_s @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f64_convert_s_i64: +; CHECK-NEXT: .param i64 +; CHECK-NEXT: .result f64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f64_convert_s @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define double @f64_convert_s_i64(i64 %x) { %a = sitofp i64 %x to double ret double %a } -; CHECK-LABEL: $f64_convert_u_i64 -; CHECK-NEXT: (param i64) (result f64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f64_convert_u @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f64_convert_u_i64: +; CHECK-NEXT: .param i64 +; CHECK-NEXT: .result f64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f64_convert_u @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define double @f64_convert_u_i64(i64 %x) { %a = uitofp i64 %x to double ret double %a } -; CHECK-LABEL: $f64_promote_f32 -; CHECK-NEXT: (param f32) (result f64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f64_promote @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f64_promote_f32: +; CHECK-NEXT: .param f32 +; CHECK-NEXT: .result f64 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f64_promote @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define double @f64_promote_f32(float %x) { %a = fpext float %x to double ret double %a } -; CHECK-LABEL: $f32_demote_f64 -; CHECK-NEXT: (param f64) (result f32) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (f32_demote @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: f32_demote_f64: +; CHECK-NEXT: .param f64 +; CHECK-NEXT: .result f32 +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: f32_demote @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define float @f32_demote_f64(double %x) { %a = fptrunc double %x to float ret float %a |