Improve abi ir comments a bit

This commit is contained in:
bjorn3 2019-08-30 15:07:15 +02:00
parent d731c4a6a7
commit 76d2e085db
4 changed files with 23 additions and 20 deletions

View File

@ -5,20 +5,19 @@ use rustc::mir;
use crate::prelude::*; use crate::prelude::*;
use crate::abi::pass_mode::*; use crate::abi::pass_mode::*;
pub fn add_local_header_comment(fx: &mut FunctionCx<impl Backend>) { pub fn add_args_header_comment(fx: &mut FunctionCx<impl Backend>) {
fx.add_global_comment(format!( fx.add_global_comment(format!(
"msg loc.idx param pass mode ssa flags ty" "kind loc.idx param pass mode ty"
)); ));
} }
pub fn add_arg_comment<'tcx>( pub fn add_arg_comment<'tcx>(
fx: &mut FunctionCx<'_, 'tcx, impl Backend>, fx: &mut FunctionCx<'_, 'tcx, impl Backend>,
msg: &str, kind: &str,
local: mir::Local, local: mir::Local,
local_field: Option<usize>, local_field: Option<usize>,
params: EmptySinglePair<Value>, params: EmptySinglePair<Value>,
pass_mode: PassMode, pass_mode: PassMode,
ssa: crate::analyze::Flags,
ty: Ty<'tcx>, ty: Ty<'tcx>,
) { ) {
let local_field = if let Some(local_field) = local_field { let local_field = if let Some(local_field) = local_field {
@ -33,17 +32,23 @@ pub fn add_arg_comment<'tcx>(
}; };
let pass_mode = format!("{:?}", pass_mode); let pass_mode = format!("{:?}", pass_mode);
fx.add_global_comment(format!( fx.add_global_comment(format!(
"{msg:5}{local:>3}{local_field:<5} {params:10} {pass_mode:36} {ssa:10} {ty:?}", "{kind:5}{local:>3}{local_field:<5} {params:10} {pass_mode:36} {ty:?}",
msg = msg, kind = kind,
local = format!("{:?}", local), local = format!("{:?}", local),
local_field = local_field, local_field = local_field,
params = params, params = params,
pass_mode = pass_mode, pass_mode = pass_mode,
ssa = format!("{:?}", ssa),
ty = ty, ty = ty,
)); ));
} }
pub fn add_locals_header_comment(fx: &mut FunctionCx<impl Backend>) {
fx.add_global_comment(String::new());
fx.add_global_comment(format!(
"kind local ty size align (abi,pref)"
));
}
pub fn add_local_place_comments<'tcx>( pub fn add_local_place_comments<'tcx>(
fx: &mut FunctionCx<'_, 'tcx, impl Backend>, fx: &mut FunctionCx<'_, 'tcx, impl Backend>,
place: CPlace<'tcx>, place: CPlace<'tcx>,
@ -62,9 +67,9 @@ pub fn add_local_place_comments<'tcx>(
CPlaceInner::Var(var) => { CPlaceInner::Var(var) => {
assert_eq!(local, var); assert_eq!(local, var);
fx.add_global_comment(format!( fx.add_global_comment(format!(
"ssa {:?}: {:?} size={} align={}, {}", "ssa {:5} {:20} {:4}b {}, {}",
local, format!("{:?}", local),
ty, format!("{:?}", ty),
size.bytes(), size.bytes(),
align.abi.bytes(), align.abi.bytes(),
align.pref.bytes(), align.pref.bytes(),
@ -82,9 +87,9 @@ pub fn add_local_place_comments<'tcx>(
), ),
), ),
CPlaceInner::NoPlace => fx.add_global_comment(format!( CPlaceInner::NoPlace => fx.add_global_comment(format!(
"zst {:?}: {:?} size={} align={}, {}", "zst {:5} {:20} {:4}b {}, {}",
local, format!("{:?}", local),
ty, format!("{:?}", ty),
size.bytes(), size.bytes(),
align.abi.bytes(), align.abi.bytes(),
align.pref.bytes(), align.pref.bytes(),

View File

@ -220,11 +220,10 @@ pub fn codegen_fn_prelude(
let ssa_analyzed = crate::analyze::analyze(fx); let ssa_analyzed = crate::analyze::analyze(fx);
#[cfg(debug_assertions)] #[cfg(debug_assertions)]
self::comments::add_local_header_comment(fx); self::comments::add_args_header_comment(fx);
self::returning::codegen_return_param(fx, &ssa_analyzed, start_ebb); self::returning::codegen_return_param(fx, &ssa_analyzed, start_ebb);
// None means pass_mode == NoPass // None means pass_mode == NoPass
enum ArgKind<'tcx> { enum ArgKind<'tcx> {
Normal(Option<CValue<'tcx>>), Normal(Option<CValue<'tcx>>),
@ -257,7 +256,6 @@ pub fn codegen_fn_prelude(
local, local,
Some(i), Some(i),
arg_ty, arg_ty,
ssa_analyzed[&local],
); );
params.push(param); params.push(param);
} }
@ -265,7 +263,7 @@ pub fn codegen_fn_prelude(
(local, ArgKind::Spread(params), arg_ty) (local, ArgKind::Spread(params), arg_ty)
} else { } else {
let param = let param =
cvalue_for_param(fx, start_ebb, local, None, arg_ty, ssa_analyzed[&local]); cvalue_for_param(fx, start_ebb, local, None, arg_ty);
(local, ArgKind::Normal(param), arg_ty) (local, ArgKind::Normal(param), arg_ty)
} }
}) })
@ -273,6 +271,9 @@ pub fn codegen_fn_prelude(
fx.bcx.switch_to_block(start_ebb); fx.bcx.switch_to_block(start_ebb);
#[cfg(debug_assertions)]
self::comments::add_locals_header_comment(fx);
for (local, arg_kind, ty) in func_params { for (local, arg_kind, ty) in func_params {
let layout = fx.layout_of(ty); let layout = fx.layout_of(ty);

View File

@ -132,7 +132,6 @@ pub fn cvalue_for_param<'tcx>(
local: mir::Local, local: mir::Local,
local_field: Option<usize>, local_field: Option<usize>,
arg_ty: Ty<'tcx>, arg_ty: Ty<'tcx>,
ssa_flags: crate::analyze::Flags,
) -> Option<CValue<'tcx>> { ) -> Option<CValue<'tcx>> {
let layout = fx.layout_of(arg_ty); let layout = fx.layout_of(arg_ty);
let pass_mode = get_pass_mode(fx.tcx, fx.layout_of(arg_ty)); let pass_mode = get_pass_mode(fx.tcx, fx.layout_of(arg_ty));
@ -152,7 +151,6 @@ pub fn cvalue_for_param<'tcx>(
local_field, local_field,
ebb_params, ebb_params,
pass_mode, pass_mode,
ssa_flags,
arg_ty, arg_ty,
); );

View File

@ -44,7 +44,6 @@ pub fn codegen_return_param(
None, None,
ret_param, ret_param,
output_pass_mode, output_pass_mode,
ssa_analyzed[&RETURN_PLACE],
ret_layout.ty, ret_layout.ty,
); );
} }