diff options
| author | Ralf Jung <post@ralfj.de> | 2017-08-23 18:09:13 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-08-23 18:09:13 +0200 |
| commit | ae10b23a7c59ad28d5eceb8df042f38802064da0 (patch) | |
| tree | 9c4f29a5b4cd3ca3b4edd7481a009f321b75a5f9 | |
| parent | 1f20b7d77412aec1b654b9fd2b6dfffdd3bf0a81 (diff) | |
| parent | 66108be99d6736d63e47c2f7f5b75ab703822557 (diff) | |
| download | rust-ae10b23a7c59ad28d5eceb8df042f38802064da0.tar.gz rust-ae10b23a7c59ad28d5eceb8df042f38802064da0.zip | |
Merge branch 'master' into mir-validate
| -rw-r--r-- | src/librustc_mir/interpret/eval_context.rs | 6 | ||||
| -rw-r--r-- | src/librustc_mir/interpret/terminator/mod.rs | 46 | ||||
| -rwxr-xr-x | xargo/build.sh | 1 |
3 files changed, 12 insertions, 41 deletions
diff --git a/src/librustc_mir/interpret/eval_context.rs b/src/librustc_mir/interpret/eval_context.rs index a5f5072dc29..d4b7761567d 100644 --- a/src/librustc_mir/interpret/eval_context.rs +++ b/src/librustc_mir/interpret/eval_context.rs @@ -2270,6 +2270,12 @@ fn resolve_associated_item<'a, 'tcx>( substs: rcvr_substs, } } + ::rustc::traits::VtableBuiltin(..) if Some(trait_id) == tcx.lang_items.clone_trait() => { + ty::Instance { + def: ty::InstanceDef::CloneShim(def_id, trait_ref.self_ty()), + substs: rcvr_substs + } + } _ => bug!("static call to invalid vtable: {:?}", vtbl), } } diff --git a/src/librustc_mir/interpret/terminator/mod.rs b/src/librustc_mir/interpret/terminator/mod.rs index dde541ed5f7..d8a432cfa48 100644 --- a/src/librustc_mir/interpret/terminator/mod.rs +++ b/src/librustc_mir/interpret/terminator/mod.rs @@ -256,6 +256,7 @@ impl<'a, 'tcx, M: Machine<'tcx>> EvalContext<'a, 'tcx, M> { self.dump_local(ret); Ok(()) } + // FIXME: figure out why we can't just go through the shim ty::InstanceDef::ClosureOnceShim { .. } => { let mut args = Vec::new(); for arg in arg_operands { @@ -297,6 +298,9 @@ impl<'a, 'tcx, M: Machine<'tcx>> EvalContext<'a, 'tcx, M> { } Ok(()) } + ty::InstanceDef::FnPtrShim(..) | + ty::InstanceDef::DropGlue(..) | + ty::InstanceDef::CloneShim(..) | ty::InstanceDef::Item(_) => { let mut args = Vec::new(); for arg in arg_operands { @@ -394,47 +398,7 @@ impl<'a, 'tcx, M: Machine<'tcx>> EvalContext<'a, 'tcx, M> { } Ok(()) } - ty::InstanceDef::DropGlue(..) => { - assert_eq!(arg_operands.len(), 1); - assert_eq!(sig.abi, Abi::Rust); - let val = self.eval_operand(&arg_operands[0])?; - let ty = self.operand_ty(&arg_operands[0]); - let (_, target) = destination.expect("diverging drop glue"); - self.goto_block(target); - // FIXME: deduplicate these matches - let pointee_type = match ty.sty { - ty::TyRawPtr(ref tam) | - ty::TyRef(_, ref tam) => tam.ty, - ty::TyAdt(def, _) if def.is_box() => ty.boxed_ty(), - _ => bug!("can only deref pointer types"), - }; - self.drop(val, instance, pointee_type, span) - } - ty::InstanceDef::FnPtrShim(..) => { - trace!("ABI: {}", sig.abi); - let mut args = Vec::new(); - for arg in arg_operands { - let arg_val = self.eval_operand(arg)?; - let arg_ty = self.operand_ty(arg); - args.push((arg_val, arg_ty)); - } - if M::eval_fn_call(self, instance, destination, arg_operands, span, sig)? { - return Ok(()); - } - let arg_locals = self.frame().mir.args_iter(); - match sig.abi { - Abi::Rust => { - args.remove(0); - } - Abi::RustCall => {} - _ => unimplemented!(), - }; - for (arg_local, (arg_val, arg_ty)) in arg_locals.zip(args) { - let dest = self.eval_lvalue(&mir::Lvalue::Local(arg_local))?; - self.write_value(arg_val, dest, arg_ty)?; - } - Ok(()) - } + // cannot use the shim here, because that will only result in infinite recursion ty::InstanceDef::Virtual(_, idx) => { let ptr_size = self.memory.pointer_size(); let (_, vtable) = self.eval_operand(&arg_operands[0])?.into_ptr_vtable_pair( diff --git a/xargo/build.sh b/xargo/build.sh index 15a7c770910..b842c04ae09 100755 --- a/xargo/build.sh +++ b/xargo/build.sh @@ -1,3 +1,4 @@ #!/bin/sh cd "$(dirname "$0")" +sed 's/gcc = "0\.3\.50"/gcc = "=0\.3\.50"/' -i ~/.rustup/toolchains/*/lib/rustlib/src/rust/src/libstd/Cargo.toml RUSTFLAGS='-Zalways-encode-mir -Zmir-emit-validate=1' xargo build |
