mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-28 06:03:35 +00:00
[WebAssembly] Fix lowering of calls with more than one argument.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@247118 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7e657c85c6
commit
307756e77e
@ -228,16 +228,19 @@ WebAssemblyTargetLowering::LowerCall(CallLoweringInfo &CLI,
|
||||
|
||||
SmallVectorImpl<ISD::OutputArg> &Outs = CLI.Outs;
|
||||
SmallVectorImpl<SDValue> &OutVals = CLI.OutVals;
|
||||
|
||||
bool IsStructRet = (Outs.empty()) ? false : Outs[0].Flags.isSRet();
|
||||
if (IsStructRet)
|
||||
fail(DL, DAG, "WebAssembly doesn't support struct return yet");
|
||||
if (Outs.size() > 1)
|
||||
fail(DL, DAG, "WebAssembly doesn't support more than 1 returned value yet");
|
||||
|
||||
SmallVectorImpl<ISD::InputArg> &Ins = CLI.Ins;
|
||||
if (Ins.size() > 1)
|
||||
fail(DL, DAG, "WebAssembly doesn't support more than 1 returned value yet");
|
||||
|
||||
bool IsVarArg = CLI.IsVarArg;
|
||||
if (IsVarArg)
|
||||
fail(DL, DAG, "WebAssembly doesn't support varargs yet");
|
||||
|
||||
// Analyze operands of the call, assigning locations to each operand.
|
||||
SmallVector<CCValAssign, 16> ArgLocs;
|
||||
CCState CCInfo(CallConv, IsVarArg, MF, ArgLocs, *DAG.getContext());
|
||||
|
@ -7,6 +7,7 @@ target triple = "wasm32-unknown-unknown"
|
||||
|
||||
declare i32 @i32_nullary()
|
||||
declare i32 @i32_unary(i32)
|
||||
declare i32 @i32_binary(i32, i32)
|
||||
declare i64 @i64_nullary()
|
||||
declare float @float_nullary()
|
||||
declare double @double_nullary()
|
||||
@ -62,6 +63,18 @@ define i32 @call_i32_unary(i32 %a) {
|
||||
ret i32 %r
|
||||
}
|
||||
|
||||
; CHECK-LABEL: (func $call_i32_binary
|
||||
; CHECK-NEXT: (param i32) (param i32) (result i32)
|
||||
; CHECK-NEXT: (setlocal @0 (argument 1))
|
||||
; CHECK-NEXT: (setlocal @1 (argument 0))
|
||||
; CHECK-NEXT: (setlocal @2 (global $i32_binary))
|
||||
; CHECK-NEXT: (setlocal @3 (call @2 @1 @0))
|
||||
; CHECK-NEXT: (return @3)
|
||||
define i32 @call_i32_binary(i32 %a, i32 %b) {
|
||||
%r = call i32 @i32_binary(i32 %a, i32 %b)
|
||||
ret i32 %r
|
||||
}
|
||||
|
||||
; FIXME test the following:
|
||||
; - Functions without return.
|
||||
; - More argument combinations.
|
||||
|
Loading…
x
Reference in New Issue
Block a user