fix ICE in ConstProp
This commit is contained in:
parent
dfd243e27c
commit
a73e2557c7
3 changed files with 31 additions and 8 deletions
|
@ -10,7 +10,7 @@ use rustc_middle::mir;
|
||||||
use rustc_middle::ty::{self, Ty, TyCtxt};
|
use rustc_middle::ty::{self, Ty, TyCtxt};
|
||||||
use rustc_span::def_id::DefId;
|
use rustc_span::def_id::DefId;
|
||||||
use rustc_target::abi::Size;
|
use rustc_target::abi::Size;
|
||||||
use rustc_target::spec::abi::Abi;
|
use rustc_target::spec::abi::Abi as FnAbi;
|
||||||
|
|
||||||
use super::{
|
use super::{
|
||||||
AllocId, AllocRange, Allocation, ConstAllocation, Frame, ImmTy, InterpCx, InterpResult,
|
AllocId, AllocRange, Allocation, ConstAllocation, Frame, ImmTy, InterpCx, InterpResult,
|
||||||
|
@ -139,7 +139,7 @@ pub trait Machine<'mir, 'tcx>: Sized {
|
||||||
/// Whether to enforce integers and floats not having provenance.
|
/// Whether to enforce integers and floats not having provenance.
|
||||||
fn enforce_number_no_provenance(ecx: &InterpCx<'mir, 'tcx, Self>) -> bool;
|
fn enforce_number_no_provenance(ecx: &InterpCx<'mir, 'tcx, Self>) -> bool;
|
||||||
|
|
||||||
/// Whether function calls should be [ABI](Abi)-checked.
|
/// Whether function calls should be [ABI](FnAbi)-checked.
|
||||||
fn enforce_abi(_ecx: &InterpCx<'mir, 'tcx, Self>) -> bool {
|
fn enforce_abi(_ecx: &InterpCx<'mir, 'tcx, Self>) -> bool {
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
@ -170,7 +170,7 @@ pub trait Machine<'mir, 'tcx>: Sized {
|
||||||
fn find_mir_or_eval_fn(
|
fn find_mir_or_eval_fn(
|
||||||
ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
||||||
instance: ty::Instance<'tcx>,
|
instance: ty::Instance<'tcx>,
|
||||||
abi: Abi,
|
abi: FnAbi,
|
||||||
args: &[OpTy<'tcx, Self::PointerTag>],
|
args: &[OpTy<'tcx, Self::PointerTag>],
|
||||||
destination: &PlaceTy<'tcx, Self::PointerTag>,
|
destination: &PlaceTy<'tcx, Self::PointerTag>,
|
||||||
target: Option<mir::BasicBlock>,
|
target: Option<mir::BasicBlock>,
|
||||||
|
@ -182,7 +182,7 @@ pub trait Machine<'mir, 'tcx>: Sized {
|
||||||
fn call_extra_fn(
|
fn call_extra_fn(
|
||||||
ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
||||||
fn_val: Self::ExtraFnVal,
|
fn_val: Self::ExtraFnVal,
|
||||||
abi: Abi,
|
abi: FnAbi,
|
||||||
args: &[OpTy<'tcx, Self::PointerTag>],
|
args: &[OpTy<'tcx, Self::PointerTag>],
|
||||||
destination: &PlaceTy<'tcx, Self::PointerTag>,
|
destination: &PlaceTy<'tcx, Self::PointerTag>,
|
||||||
target: Option<mir::BasicBlock>,
|
target: Option<mir::BasicBlock>,
|
||||||
|
@ -480,7 +480,7 @@ pub macro compile_time_machine(<$mir: lifetime, $tcx: lifetime>) {
|
||||||
fn call_extra_fn(
|
fn call_extra_fn(
|
||||||
_ecx: &mut InterpCx<$mir, $tcx, Self>,
|
_ecx: &mut InterpCx<$mir, $tcx, Self>,
|
||||||
fn_val: !,
|
fn_val: !,
|
||||||
_abi: Abi,
|
_abi: FnAbi,
|
||||||
_args: &[OpTy<$tcx>],
|
_args: &[OpTy<$tcx>],
|
||||||
_destination: &PlaceTy<$tcx, Self::PointerTag>,
|
_destination: &PlaceTy<$tcx, Self::PointerTag>,
|
||||||
_target: Option<mir::BasicBlock>,
|
_target: Option<mir::BasicBlock>,
|
||||||
|
|
|
@ -22,8 +22,8 @@ use rustc_middle::ty::{
|
||||||
self, ConstKind, EarlyBinder, Instance, ParamEnv, Ty, TyCtxt, TypeVisitable,
|
self, ConstKind, EarlyBinder, Instance, ParamEnv, Ty, TyCtxt, TypeVisitable,
|
||||||
};
|
};
|
||||||
use rustc_span::{def_id::DefId, Span};
|
use rustc_span::{def_id::DefId, Span};
|
||||||
use rustc_target::abi::{HasDataLayout, Size, TargetDataLayout};
|
use rustc_target::abi::{self, HasDataLayout, Size, TargetDataLayout};
|
||||||
use rustc_target::spec::abi::Abi;
|
use rustc_target::spec::abi::Abi as FnAbi;
|
||||||
use rustc_trait_selection::traits;
|
use rustc_trait_selection::traits;
|
||||||
|
|
||||||
use crate::MirPass;
|
use crate::MirPass;
|
||||||
|
@ -199,7 +199,7 @@ impl<'mir, 'tcx> interpret::Machine<'mir, 'tcx> for ConstPropMachine<'mir, 'tcx>
|
||||||
fn find_mir_or_eval_fn(
|
fn find_mir_or_eval_fn(
|
||||||
_ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
_ecx: &mut InterpCx<'mir, 'tcx, Self>,
|
||||||
_instance: ty::Instance<'tcx>,
|
_instance: ty::Instance<'tcx>,
|
||||||
_abi: Abi,
|
_abi: FnAbi,
|
||||||
_args: &[OpTy<'tcx>],
|
_args: &[OpTy<'tcx>],
|
||||||
_destination: &PlaceTy<'tcx>,
|
_destination: &PlaceTy<'tcx>,
|
||||||
_target: Option<BasicBlock>,
|
_target: Option<BasicBlock>,
|
||||||
|
@ -654,6 +654,11 @@ impl<'mir, 'tcx> ConstPropagator<'mir, 'tcx> {
|
||||||
(Ok(_), Ok(_)) => return this.ecx.eval_rvalue_into_place(rvalue, place),
|
(Ok(_), Ok(_)) => return this.ecx.eval_rvalue_into_place(rvalue, place),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if !matches!(const_arg.layout.abi, abi::Abi::Scalar(..)) {
|
||||||
|
// We cannot handle Scalar Pair stuff.
|
||||||
|
return this.ecx.eval_rvalue_into_place(rvalue, place);
|
||||||
|
}
|
||||||
|
|
||||||
let arg_value = const_arg.to_scalar()?.to_bits(const_arg.layout.size)?;
|
let arg_value = const_arg.to_scalar()?.to_bits(const_arg.layout.size)?;
|
||||||
let dest = this.ecx.eval_place(place)?;
|
let dest = this.ecx.eval_place(place)?;
|
||||||
|
|
||||||
|
|
18
src/test/ui/consts/issue-96169.rs
Normal file
18
src/test/ui/consts/issue-96169.rs
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
// check-pass
|
||||||
|
// compile-flags: -Zmir-opt-level=4 --emit=mir
|
||||||
|
#![allow(unused)]
|
||||||
|
fn a() -> usize { 0 }
|
||||||
|
|
||||||
|
fn bar(_: u32) {}
|
||||||
|
|
||||||
|
fn baz() -> *const dyn Fn(u32) { unimplemented!() }
|
||||||
|
|
||||||
|
fn foo() {
|
||||||
|
match () {
|
||||||
|
_ if baz() == &bar as &dyn Fn(u32) => (),
|
||||||
|
() => (),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue