X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=blobdiff_plain;f=test%2FCodeGen%2FWebAssembly%2Fi64.ll;h=272f152ae728783b1d358acd843a4e22a748dd02;hp=65a4137984ad0844bafdacd681296e4c8262cdd1;hb=2d3e3ef1c769aad95d6cf9f04d24cebea1c0be1c;hpb=fce2219764f00e1b6de75bca08d9b10a212165b5 diff --git a/test/CodeGen/WebAssembly/i64.ll b/test/CodeGen/WebAssembly/i64.ll index 65a4137984a..272f152ae72 100644 --- a/test/CodeGen/WebAssembly/i64.ll +++ b/test/CodeGen/WebAssembly/i64.ll @@ -9,194 +9,274 @@ declare i64 @llvm.ctlz.i64(i64, i1) declare i64 @llvm.cttz.i64(i64, i1) declare i64 @llvm.ctpop.i64(i64) -; CHECK-LABEL: (func $add64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (add @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: add64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: add @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @add64(i64 %x, i64 %y) { %a = add i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $sub64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (sub @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: sub64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: sub @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @sub64(i64 %x, i64 %y) { %a = sub i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $mul64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (mul @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: mul64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: mul @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @mul64(i64 %x, i64 %y) { %a = mul i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $sdiv64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (sdiv @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: sdiv64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: sdiv @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @sdiv64(i64 %x, i64 %y) { %a = sdiv i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $udiv64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (udiv @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: udiv64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: udiv @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @udiv64(i64 %x, i64 %y) { %a = udiv i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $srem64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (srem @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: srem64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: srem @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @srem64(i64 %x, i64 %y) { %a = srem i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $urem64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (urem @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: urem64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: urem @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @urem64(i64 %x, i64 %y) { %a = urem i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $and64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (and @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: and64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: and @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @and64(i64 %x, i64 %y) { %a = and i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $ior64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (ior @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: ior64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: ior @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @ior64(i64 %x, i64 %y) { %a = or i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $xor64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (xor @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: xor64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: xor @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @xor64(i64 %x, i64 %y) { %a = xor i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $shl64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (shl @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: shl64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: shl @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @shl64(i64 %x, i64 %y) { %a = shl i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $shr64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (shr_u @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: shr64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: shr_u @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @shr64(i64 %x, i64 %y) { %a = lshr i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $sar64 -; CHECK-NEXT: (param i64) (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 1)) -; CHECK-NEXT: (set_local @1 (argument 0)) -; CHECK-NEXT: (set_local @2 (shr_s @1 @0)) -; CHECK-NEXT: (return @2) +; CHECK-LABEL: sar64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @3, pop{{$}} +; CHECK-NEXT: shr_s @3, @2{{$}} +; CHECK-NEXT: set_local @4, pop{{$}} +; CHECK-NEXT: return @4{{$}} define i64 @sar64(i64 %x, i64 %y) { %a = ashr i64 %x, %y ret i64 %a } -; CHECK-LABEL: (func $clz64 -; CHECK-NEXT: (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (clz @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: clz64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: clz @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @clz64(i64 %x) { %a = call i64 @llvm.ctlz.i64(i64 %x, i1 false) ret i64 %a } -; CHECK-LABEL: (func $clz64_zero_undef -; CHECK-NEXT: (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (clz @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: clz64_zero_undef: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: clz @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @clz64_zero_undef(i64 %x) { %a = call i64 @llvm.ctlz.i64(i64 %x, i1 true) ret i64 %a } -; CHECK-LABEL: (func $ctz64 -; CHECK-NEXT: (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (ctz @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: ctz64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: ctz @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @ctz64(i64 %x) { %a = call i64 @llvm.cttz.i64(i64 %x, i1 false) ret i64 %a } -; CHECK-LABEL: (func $ctz64_zero_undef -; CHECK-NEXT: (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (ctz @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: ctz64_zero_undef: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: ctz @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @ctz64_zero_undef(i64 %x) { %a = call i64 @llvm.cttz.i64(i64 %x, i1 true) ret i64 %a } -; CHECK-LABEL: (func $popcnt64 -; CHECK-NEXT: (param i64) (result i64) -; CHECK-NEXT: (set_local @0 (argument 0)) -; CHECK-NEXT: (set_local @1 (popcnt @0)) -; CHECK-NEXT: (return @1) +; CHECK-LABEL: popcnt64: +; CHECK-NEXT: .param i64{{$}} +; CHECK-NEXT: .result i64{{$}} +; CHECK-NEXT: @0{{$}} +; CHECK-NEXT: set_local @1, pop{{$}} +; CHECK-NEXT: popcnt @1{{$}} +; CHECK-NEXT: set_local @2, pop{{$}} +; CHECK-NEXT: return @2{{$}} define i64 @popcnt64(i64 %x) { %a = call i64 @llvm.ctpop.i64(i64 %x) ret i64 %a