2019-05-26 03:55:50 -05:00
|
|
|
use crate::util::expand_aggregate;
|
2020-12-31 18:53:25 -06:00
|
|
|
use crate::MirPass;
|
2020-03-29 09:41:09 -05:00
|
|
|
use rustc_middle::mir::*;
|
|
|
|
use rustc_middle::ty::TyCtxt;
|
2016-07-27 19:46:54 -05:00
|
|
|
|
|
|
|
pub struct Deaggregator;
|
|
|
|
|
2019-08-04 15:20:00 -05:00
|
|
|
impl<'tcx> MirPass<'tcx> for Deaggregator {
|
2020-10-04 13:01:38 -05:00
|
|
|
fn run_pass(&self, tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) {
|
2022-07-03 19:00:00 -05:00
|
|
|
let basic_blocks = body.basic_blocks.as_mut_preserves_cfg();
|
2018-02-07 07:27:00 -06:00
|
|
|
for bb in basic_blocks {
|
2018-02-16 11:20:18 -06:00
|
|
|
bb.expand_statements(|stmt| {
|
|
|
|
// FIXME(eddyb) don't match twice on `stmt.kind` (post-NLL).
|
2020-08-13 16:59:47 -05:00
|
|
|
match stmt.kind {
|
|
|
|
// FIXME(#48193) Deaggregate arrays when it's cheaper to do so.
|
|
|
|
StatementKind::Assign(box (
|
|
|
|
_,
|
|
|
|
Rvalue::Aggregate(box AggregateKind::Array(_), _),
|
|
|
|
)) => {
|
2018-02-16 11:20:18 -06:00
|
|
|
return None;
|
|
|
|
}
|
2020-08-13 16:59:47 -05:00
|
|
|
StatementKind::Assign(box (_, Rvalue::Aggregate(_, _))) => {}
|
|
|
|
_ => return None,
|
2018-02-16 11:20:18 -06:00
|
|
|
}
|
2018-02-07 07:27:00 -06:00
|
|
|
|
2018-02-16 11:20:18 -06:00
|
|
|
let stmt = stmt.replace_nop();
|
|
|
|
let source_info = stmt.source_info;
|
2022-02-18 17:48:49 -06:00
|
|
|
let StatementKind::Assign(box (lhs, Rvalue::Aggregate(kind, operands))) = stmt.kind else {
|
|
|
|
bug!();
|
2016-08-02 12:46:26 -05:00
|
|
|
};
|
2018-02-07 07:27:00 -06:00
|
|
|
|
2019-05-26 03:55:50 -05:00
|
|
|
Some(expand_aggregate(
|
|
|
|
lhs,
|
|
|
|
operands.into_iter().map(|op| {
|
2022-07-03 19:00:00 -05:00
|
|
|
let ty = op.ty(&body.local_decls, tcx);
|
2019-05-26 03:55:50 -05:00
|
|
|
(op, ty)
|
|
|
|
}),
|
|
|
|
*kind,
|
|
|
|
source_info,
|
2019-10-20 15:11:04 -05:00
|
|
|
tcx,
|
2019-05-26 03:55:50 -05:00
|
|
|
))
|
2018-02-16 11:20:18 -06:00
|
|
|
});
|
2016-07-27 19:46:54 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|