Cranelift: pass iterators to ABIMachineSpec::compute_arg_locs (#5095)
Instead of slices. This gives us more flexibility to pass custom sequences without needing to allocate a `Vec` to hold them and pass in as a slice.
This commit is contained in:
@@ -81,13 +81,16 @@ impl ABIMachineSpec for X64ABIMachineSpec {
|
||||
16
|
||||
}
|
||||
|
||||
fn compute_arg_locs(
|
||||
fn compute_arg_locs<'a, I>(
|
||||
call_conv: isa::CallConv,
|
||||
flags: &settings::Flags,
|
||||
params: &[ir::AbiParam],
|
||||
params: I,
|
||||
args_or_rets: ArgsOrRets,
|
||||
add_ret_area_ptr: bool,
|
||||
) -> CodegenResult<(ABIArgVec, i64, Option<usize>)> {
|
||||
) -> CodegenResult<(ABIArgVec, i64, Option<usize>)>
|
||||
where
|
||||
I: IntoIterator<Item = &'a ir::AbiParam>,
|
||||
{
|
||||
let is_fastcall = call_conv.extends_windows_fastcall();
|
||||
|
||||
let mut next_gpr = 0;
|
||||
|
||||
Reference in New Issue
Block a user