diff options
| author | Graydon Hoare <[email protected]> | 2010-11-14 13:41:10 -0800 |
|---|---|---|
| committer | Graydon Hoare <[email protected]> | 2010-11-14 13:41:10 -0800 |
| commit | a352efadad7271798848c6ef4a22d8de7c8eba3a (patch) | |
| tree | 13e38ac987a13c1b5cf27d1c949275af68808c36 /src/comp/lib | |
| parent | Remove outptr from module-internal calls; use standard ABI returns. (diff) | |
| download | rust-a352efadad7271798848c6ef4a22d8de7c8eba3a.tar.xz rust-a352efadad7271798848c6ef4a22d8de7c8eba3a.zip | |
Switch upcall glues to fastcall as well.
Diffstat (limited to 'src/comp/lib')
| -rw-r--r-- | src/comp/lib/llvm.rs | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/comp/lib/llvm.rs b/src/comp/lib/llvm.rs index 0cd177a4..da48c6b5 100644 --- a/src/comp/lib/llvm.rs +++ b/src/comp/lib/llvm.rs @@ -1026,6 +1026,15 @@ obj builder(BuilderRef B) { _str.buf("")); } + fn FastCall(ValueRef Fn, vec[ValueRef] Args) -> ValueRef { + auto v = llvm.LLVMBuildCall(B, Fn, + _vec.buf[ValueRef](Args), + _vec.len[ValueRef](Args), + _str.buf("")); + llvm.LLVMSetInstructionCallConv(v, LLVMFastCallConv); + ret v; + } + fn Select(ValueRef If, ValueRef Then, ValueRef Else) -> ValueRef { ret llvm.LLVMBuildSelect(B, If, Then, Else, _str.buf("")); } |