Skip to content

Commit 5230750

Browse files
committed
---
yaml --- r: 93775 b: refs/heads/try c: 5b534e4 h: refs/heads/master i: 93773: 6fae327 93771: fc22685 93767: de046ce 93759: 7b39f12 v: v3
1 parent 34e4aaa commit 5230750

File tree

2 files changed

+10
-2
lines changed

2 files changed

+10
-2
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: 0da105a8b7b6b1e0568e8ff20f6ff4b13cc7ecc2
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: a6d3e57dca68fde4effdda3e4ae2887aa535fcd6
5-
refs/heads/try: 50fb4be1cce008ef8c0b4b40e70460c1be1d795a
5+
refs/heads/try: 5b534e4a22d914e284c650f4504789c2678961bd
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
88
refs/heads/try2: 147ecfdd8221e4a4d4e090486829a06da1e0ca3c

branches/try/src/librustc/middle/trans/foreign.rs

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -399,11 +399,19 @@ pub fn register_rust_fn_with_foreign_abi(ccx: @mut CrateContext,
399399

400400
let tys = foreign_types_for_id(ccx, node_id);
401401
let llfn_ty = lltype_for_fn_from_foreign_types(&tys);
402+
let t = ty::node_id_to_type(ccx.tcx, node_id);
403+
let cconv = match ty::get(t).sty {
404+
ty::ty_bare_fn(ref fn_ty) => {
405+
let c = llvm_calling_convention(ccx, fn_ty.abis);
406+
c.unwrap_or(lib::llvm::CCallConv)
407+
}
408+
_ => lib::llvm::CCallConv
409+
};
402410
let llfn = base::register_fn_llvmty(ccx,
403411
sp,
404412
sym,
405413
node_id,
406-
lib::llvm::CCallConv,
414+
cconv,
407415
llfn_ty);
408416
add_argument_attributes(&tys, llfn);
409417
debug!("register_rust_fn_with_foreign_abi(node_id={:?}, llfn_ty={}, llfn={})",

0 commit comments

Comments
 (0)