Prefix fixed_results/fixed_value_arguments with num to indicate they return a usize;
This commit is contained in:
committed by
Dan Gohman
parent
e13b0886dc
commit
f896bfb946
@@ -430,26 +430,38 @@ impl DataFlowGraph {
|
|||||||
|
|
||||||
/// Get the fixed value arguments on `inst` as a slice.
|
/// Get the fixed value arguments on `inst` as a slice.
|
||||||
pub fn inst_fixed_args(&self, inst: Inst) -> &[Value] {
|
pub fn inst_fixed_args(&self, inst: Inst) -> &[Value] {
|
||||||
let fixed_args = self[inst].opcode().constraints().fixed_value_arguments();
|
let num_fixed_args = self[inst]
|
||||||
&self.inst_args(inst)[..fixed_args]
|
.opcode()
|
||||||
|
.constraints()
|
||||||
|
.num_fixed_value_arguments();
|
||||||
|
&self.inst_args(inst)[..num_fixed_args]
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the fixed value arguments on `inst` as a mutable slice.
|
/// Get the fixed value arguments on `inst` as a mutable slice.
|
||||||
pub fn inst_fixed_args_mut(&mut self, inst: Inst) -> &mut [Value] {
|
pub fn inst_fixed_args_mut(&mut self, inst: Inst) -> &mut [Value] {
|
||||||
let fixed_args = self[inst].opcode().constraints().fixed_value_arguments();
|
let num_fixed_args = self[inst]
|
||||||
&mut self.inst_args_mut(inst)[..fixed_args]
|
.opcode()
|
||||||
|
.constraints()
|
||||||
|
.num_fixed_value_arguments();
|
||||||
|
&mut self.inst_args_mut(inst)[..num_fixed_args]
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the variable value arguments on `inst` as a slice.
|
/// Get the variable value arguments on `inst` as a slice.
|
||||||
pub fn inst_variable_args(&self, inst: Inst) -> &[Value] {
|
pub fn inst_variable_args(&self, inst: Inst) -> &[Value] {
|
||||||
let fixed_args = self[inst].opcode().constraints().fixed_value_arguments();
|
let num_fixed_args = self[inst]
|
||||||
&self.inst_args(inst)[fixed_args..]
|
.opcode()
|
||||||
|
.constraints()
|
||||||
|
.num_fixed_value_arguments();
|
||||||
|
&self.inst_args(inst)[num_fixed_args..]
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the variable value arguments on `inst` as a mutable slice.
|
/// Get the variable value arguments on `inst` as a mutable slice.
|
||||||
pub fn inst_variable_args_mut(&mut self, inst: Inst) -> &mut [Value] {
|
pub fn inst_variable_args_mut(&mut self, inst: Inst) -> &mut [Value] {
|
||||||
let fixed_args = self[inst].opcode().constraints().fixed_value_arguments();
|
let num_fixed_args = self[inst]
|
||||||
&mut self.inst_args_mut(inst)[fixed_args..]
|
.opcode()
|
||||||
|
.constraints()
|
||||||
|
.num_fixed_value_arguments();
|
||||||
|
&mut self.inst_args_mut(inst)[num_fixed_args..]
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Create result values for an instruction that produces multiple results.
|
/// Create result values for an instruction that produces multiple results.
|
||||||
@@ -489,7 +501,10 @@ impl DataFlowGraph {
|
|||||||
// Get the call signature if this is a function call.
|
// Get the call signature if this is a function call.
|
||||||
if let Some(sig) = self.call_signature(inst) {
|
if let Some(sig) = self.call_signature(inst) {
|
||||||
// Create result values corresponding to the call return types.
|
// Create result values corresponding to the call return types.
|
||||||
debug_assert_eq!(self.insts[inst].opcode().constraints().fixed_results(), 0);
|
debug_assert_eq!(
|
||||||
|
self.insts[inst].opcode().constraints().num_fixed_results(),
|
||||||
|
0
|
||||||
|
);
|
||||||
let num_results = self.signatures[sig].returns.len();
|
let num_results = self.signatures[sig].returns.len();
|
||||||
for res_idx in 0..num_results {
|
for res_idx in 0..num_results {
|
||||||
let ty = self.signatures[sig].returns[res_idx].value_type;
|
let ty = self.signatures[sig].returns[res_idx].value_type;
|
||||||
@@ -504,7 +519,7 @@ impl DataFlowGraph {
|
|||||||
} else {
|
} else {
|
||||||
// Create result values corresponding to the opcode's constraints.
|
// Create result values corresponding to the opcode's constraints.
|
||||||
let constraints = self.insts[inst].opcode().constraints();
|
let constraints = self.insts[inst].opcode().constraints();
|
||||||
let num_results = constraints.fixed_results();
|
let num_results = constraints.num_fixed_results();
|
||||||
for res_idx in 0..num_results {
|
for res_idx in 0..num_results {
|
||||||
let ty = constraints.result_type(res_idx, ctrl_typevar);
|
let ty = constraints.result_type(res_idx, ctrl_typevar);
|
||||||
if let Some(Some(v)) = reuse.next() {
|
if let Some(Some(v)) = reuse.next() {
|
||||||
@@ -662,9 +677,9 @@ impl DataFlowGraph {
|
|||||||
ctrl_typevar: Type,
|
ctrl_typevar: Type,
|
||||||
) -> Option<Type> {
|
) -> Option<Type> {
|
||||||
let constraints = self.insts[inst].opcode().constraints();
|
let constraints = self.insts[inst].opcode().constraints();
|
||||||
let fixed_results = constraints.fixed_results();
|
let num_fixed_results = constraints.num_fixed_results();
|
||||||
|
|
||||||
if result_idx < fixed_results {
|
if result_idx < num_fixed_results {
|
||||||
return Some(constraints.result_type(result_idx, ctrl_typevar));
|
return Some(constraints.result_type(result_idx, ctrl_typevar));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -672,7 +687,7 @@ impl DataFlowGraph {
|
|||||||
self.call_signature(inst).and_then(|sigref| {
|
self.call_signature(inst).and_then(|sigref| {
|
||||||
self.signatures[sigref]
|
self.signatures[sigref]
|
||||||
.returns
|
.returns
|
||||||
.get(result_idx - fixed_results)
|
.get(result_idx - num_fixed_results)
|
||||||
.map(|&arg| arg.value_type)
|
.map(|&arg| arg.value_type)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@@ -934,7 +949,10 @@ impl DataFlowGraph {
|
|||||||
) -> usize {
|
) -> usize {
|
||||||
// Get the call signature if this is a function call.
|
// Get the call signature if this is a function call.
|
||||||
if let Some(sig) = self.call_signature(inst) {
|
if let Some(sig) = self.call_signature(inst) {
|
||||||
assert_eq!(self.insts[inst].opcode().constraints().fixed_results(), 0);
|
assert_eq!(
|
||||||
|
self.insts[inst].opcode().constraints().num_fixed_results(),
|
||||||
|
0
|
||||||
|
);
|
||||||
for res_idx in 0..self.signatures[sig].returns.len() {
|
for res_idx in 0..self.signatures[sig].returns.len() {
|
||||||
let ty = self.signatures[sig].returns[res_idx].value_type;
|
let ty = self.signatures[sig].returns[res_idx].value_type;
|
||||||
if let Some(v) = reuse.get(res_idx) {
|
if let Some(v) = reuse.get(res_idx) {
|
||||||
@@ -943,7 +961,7 @@ impl DataFlowGraph {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let constraints = self.insts[inst].opcode().constraints();
|
let constraints = self.insts[inst].opcode().constraints();
|
||||||
for res_idx in 0..constraints.fixed_results() {
|
for res_idx in 0..constraints.num_fixed_results() {
|
||||||
let ty = constraints.result_type(res_idx, ctrl_typevar);
|
let ty = constraints.result_type(res_idx, ctrl_typevar);
|
||||||
if let Some(v) = reuse.get(res_idx) {
|
if let Some(v) = reuse.get(res_idx) {
|
||||||
self.set_value_type_for_parser(*v, ty);
|
self.set_value_type_for_parser(*v, ty);
|
||||||
|
|||||||
@@ -335,8 +335,8 @@ pub struct OpcodeConstraints {
|
|||||||
typeset_offset: u8,
|
typeset_offset: u8,
|
||||||
|
|
||||||
/// Offset into `OPERAND_CONSTRAINT` table of the descriptors for this opcode. The first
|
/// Offset into `OPERAND_CONSTRAINT` table of the descriptors for this opcode. The first
|
||||||
/// `fixed_results()` entries describe the result constraints, then follows constraints for the
|
/// `num_fixed_results()` entries describe the result constraints, then follows constraints for the
|
||||||
/// fixed `Value` input operands. (`fixed_value_arguments()` of them).
|
/// fixed `Value` input operands. (`num_fixed_value_arguments()` of them).
|
||||||
constraint_offset: u16,
|
constraint_offset: u16,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -360,7 +360,7 @@ impl OpcodeConstraints {
|
|||||||
|
|
||||||
/// Get the number of *fixed* result values produced by this opcode.
|
/// Get the number of *fixed* result values produced by this opcode.
|
||||||
/// This does not include `variable_args` produced by calls.
|
/// This does not include `variable_args` produced by calls.
|
||||||
pub fn fixed_results(self) -> usize {
|
pub fn num_fixed_results(self) -> usize {
|
||||||
(self.flags & 0x7) as usize
|
(self.flags & 0x7) as usize
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -371,7 +371,7 @@ impl OpcodeConstraints {
|
|||||||
/// The number of fixed input values is usually implied by the instruction format, but
|
/// The number of fixed input values is usually implied by the instruction format, but
|
||||||
/// instruction formats that use a `ValueList` put both fixed and variable arguments in the
|
/// instruction formats that use a `ValueList` put both fixed and variable arguments in the
|
||||||
/// list. This method returns the *minimum* number of values required in the value list.
|
/// list. This method returns the *minimum* number of values required in the value list.
|
||||||
pub fn fixed_value_arguments(self) -> usize {
|
pub fn num_fixed_value_arguments(self) -> usize {
|
||||||
((self.flags >> 5) & 0x7) as usize
|
((self.flags >> 5) & 0x7) as usize
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -394,7 +394,7 @@ impl OpcodeConstraints {
|
|||||||
/// Get the value type of result number `n`, having resolved the controlling type variable to
|
/// Get the value type of result number `n`, having resolved the controlling type variable to
|
||||||
/// `ctrl_type`.
|
/// `ctrl_type`.
|
||||||
pub fn result_type(self, n: usize, ctrl_type: Type) -> Type {
|
pub fn result_type(self, n: usize, ctrl_type: Type) -> Type {
|
||||||
debug_assert!(n < self.fixed_results(), "Invalid result index");
|
debug_assert!(n < self.num_fixed_results(), "Invalid result index");
|
||||||
if let ResolvedConstraint::Bound(t) =
|
if let ResolvedConstraint::Bound(t) =
|
||||||
OPERAND_CONSTRAINTS[self.constraint_offset() + n].resolve(ctrl_type)
|
OPERAND_CONSTRAINTS[self.constraint_offset() + n].resolve(ctrl_type)
|
||||||
{
|
{
|
||||||
@@ -411,10 +411,10 @@ impl OpcodeConstraints {
|
|||||||
/// `ValueTypeSet`. This is represented with the `ArgumentConstraint::Free` variant.
|
/// `ValueTypeSet`. This is represented with the `ArgumentConstraint::Free` variant.
|
||||||
pub fn value_argument_constraint(self, n: usize, ctrl_type: Type) -> ResolvedConstraint {
|
pub fn value_argument_constraint(self, n: usize, ctrl_type: Type) -> ResolvedConstraint {
|
||||||
debug_assert!(
|
debug_assert!(
|
||||||
n < self.fixed_value_arguments(),
|
n < self.num_fixed_value_arguments(),
|
||||||
"Invalid value argument index"
|
"Invalid value argument index"
|
||||||
);
|
);
|
||||||
let offset = self.constraint_offset() + self.fixed_results();
|
let offset = self.constraint_offset() + self.num_fixed_results();
|
||||||
OPERAND_CONSTRAINTS[offset + n].resolve(ctrl_type)
|
OPERAND_CONSTRAINTS[offset + n].resolve(ctrl_type)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -603,8 +603,8 @@ mod tests {
|
|||||||
let a = Opcode::Iadd.constraints();
|
let a = Opcode::Iadd.constraints();
|
||||||
assert!(a.use_typevar_operand());
|
assert!(a.use_typevar_operand());
|
||||||
assert!(!a.requires_typevar_operand());
|
assert!(!a.requires_typevar_operand());
|
||||||
assert_eq!(a.fixed_results(), 1);
|
assert_eq!(a.num_fixed_results(), 1);
|
||||||
assert_eq!(a.fixed_value_arguments(), 2);
|
assert_eq!(a.num_fixed_value_arguments(), 2);
|
||||||
assert_eq!(a.result_type(0, types::I32), types::I32);
|
assert_eq!(a.result_type(0, types::I32), types::I32);
|
||||||
assert_eq!(a.result_type(0, types::I8), types::I8);
|
assert_eq!(a.result_type(0, types::I8), types::I8);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
@@ -619,8 +619,8 @@ mod tests {
|
|||||||
let b = Opcode::Bitcast.constraints();
|
let b = Opcode::Bitcast.constraints();
|
||||||
assert!(!b.use_typevar_operand());
|
assert!(!b.use_typevar_operand());
|
||||||
assert!(!b.requires_typevar_operand());
|
assert!(!b.requires_typevar_operand());
|
||||||
assert_eq!(b.fixed_results(), 1);
|
assert_eq!(b.num_fixed_results(), 1);
|
||||||
assert_eq!(b.fixed_value_arguments(), 1);
|
assert_eq!(b.num_fixed_value_arguments(), 1);
|
||||||
assert_eq!(b.result_type(0, types::I32), types::I32);
|
assert_eq!(b.result_type(0, types::I32), types::I32);
|
||||||
assert_eq!(b.result_type(0, types::I8), types::I8);
|
assert_eq!(b.result_type(0, types::I8), types::I8);
|
||||||
match b.value_argument_constraint(0, types::I32) {
|
match b.value_argument_constraint(0, types::I32) {
|
||||||
@@ -629,18 +629,18 @@ mod tests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let c = Opcode::Call.constraints();
|
let c = Opcode::Call.constraints();
|
||||||
assert_eq!(c.fixed_results(), 0);
|
assert_eq!(c.num_fixed_results(), 0);
|
||||||
assert_eq!(c.fixed_value_arguments(), 0);
|
assert_eq!(c.num_fixed_value_arguments(), 0);
|
||||||
|
|
||||||
let i = Opcode::CallIndirect.constraints();
|
let i = Opcode::CallIndirect.constraints();
|
||||||
assert_eq!(i.fixed_results(), 0);
|
assert_eq!(i.num_fixed_results(), 0);
|
||||||
assert_eq!(i.fixed_value_arguments(), 1);
|
assert_eq!(i.num_fixed_value_arguments(), 1);
|
||||||
|
|
||||||
let cmp = Opcode::Icmp.constraints();
|
let cmp = Opcode::Icmp.constraints();
|
||||||
assert!(cmp.use_typevar_operand());
|
assert!(cmp.use_typevar_operand());
|
||||||
assert!(cmp.requires_typevar_operand());
|
assert!(cmp.requires_typevar_operand());
|
||||||
assert_eq!(cmp.fixed_results(), 1);
|
assert_eq!(cmp.num_fixed_results(), 1);
|
||||||
assert_eq!(cmp.fixed_value_arguments(), 2);
|
assert_eq!(cmp.num_fixed_value_arguments(), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|||||||
@@ -201,8 +201,14 @@ where
|
|||||||
|
|
||||||
// We theoretically allow for call instructions that return a number of fixed results before
|
// We theoretically allow for call instructions that return a number of fixed results before
|
||||||
// the call return values. In practice, it doesn't happen.
|
// the call return values. In practice, it doesn't happen.
|
||||||
let fixed_results = pos.func.dfg[call].opcode().constraints().fixed_results();
|
debug_assert_eq!(
|
||||||
debug_assert_eq!(fixed_results, 0, "Fixed results on calls not supported");
|
pos.func.dfg[call]
|
||||||
|
.opcode()
|
||||||
|
.constraints()
|
||||||
|
.num_fixed_results(),
|
||||||
|
0,
|
||||||
|
"Fixed results on calls not supported"
|
||||||
|
);
|
||||||
|
|
||||||
let results = pos.func.dfg.detach_results(call);
|
let results = pos.func.dfg.detach_results(call);
|
||||||
let mut next_res = 0;
|
let mut next_res = 0;
|
||||||
@@ -440,11 +446,11 @@ fn legalize_inst_arguments<ArgType>(
|
|||||||
// The value list contains all arguments to the instruction, including the callee on an
|
// The value list contains all arguments to the instruction, including the callee on an
|
||||||
// indirect call which isn't part of the call arguments that must match the ABI signature.
|
// indirect call which isn't part of the call arguments that must match the ABI signature.
|
||||||
// Figure out how many fixed values are at the front of the list. We won't touch those.
|
// Figure out how many fixed values are at the front of the list. We won't touch those.
|
||||||
let fixed_values = pos.func.dfg[inst]
|
let num_fixed_values = pos.func.dfg[inst]
|
||||||
.opcode()
|
.opcode()
|
||||||
.constraints()
|
.constraints()
|
||||||
.fixed_value_arguments();
|
.num_fixed_value_arguments();
|
||||||
let have_args = vlist.len(&pos.func.dfg.value_lists) - fixed_values;
|
let have_args = vlist.len(&pos.func.dfg.value_lists) - num_fixed_values;
|
||||||
|
|
||||||
// Grow the value list to the right size and shift all the existing arguments to the right.
|
// Grow the value list to the right size and shift all the existing arguments to the right.
|
||||||
// This lets us write the new argument values into the list without overwriting the old
|
// This lets us write the new argument values into the list without overwriting the old
|
||||||
@@ -472,11 +478,11 @@ fn legalize_inst_arguments<ArgType>(
|
|||||||
// [FFFFNNNNNNNNNNNNNNNNNNNN]
|
// [FFFFNNNNNNNNNNNNNNNNNNNN]
|
||||||
//
|
//
|
||||||
vlist.grow_at(
|
vlist.grow_at(
|
||||||
fixed_values,
|
num_fixed_values,
|
||||||
abi_args - have_args,
|
abi_args - have_args,
|
||||||
&mut pos.func.dfg.value_lists,
|
&mut pos.func.dfg.value_lists,
|
||||||
);
|
);
|
||||||
let old_arg_offset = fixed_values + abi_args - have_args;
|
let old_arg_offset = num_fixed_values + abi_args - have_args;
|
||||||
|
|
||||||
let mut abi_arg = 0;
|
let mut abi_arg = 0;
|
||||||
for old_arg in 0..have_args {
|
for old_arg in 0..have_args {
|
||||||
@@ -487,7 +493,7 @@ fn legalize_inst_arguments<ArgType>(
|
|||||||
let abi_type = get_abi_type(func, abi_arg);
|
let abi_type = get_abi_type(func, abi_arg);
|
||||||
if func.dfg.value_type(arg) == abi_type.value_type {
|
if func.dfg.value_type(arg) == abi_type.value_type {
|
||||||
// This is the argument type we need.
|
// This is the argument type we need.
|
||||||
vlist.as_mut_slice(&mut func.dfg.value_lists)[fixed_values + abi_arg] = arg;
|
vlist.as_mut_slice(&mut func.dfg.value_lists)[num_fixed_values + abi_arg] = arg;
|
||||||
abi_arg += 1;
|
abi_arg += 1;
|
||||||
Ok(())
|
Ok(())
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -133,14 +133,14 @@ fn split_any(
|
|||||||
"Predecessor not a branch: {}",
|
"Predecessor not a branch: {}",
|
||||||
pos.func.dfg.display_inst(inst, None)
|
pos.func.dfg.display_inst(inst, None)
|
||||||
);
|
);
|
||||||
let fixed_args = branch_opc.constraints().fixed_value_arguments();
|
let num_fixed_args = branch_opc.constraints().num_fixed_value_arguments();
|
||||||
let mut args = pos.func.dfg[inst]
|
let mut args = pos.func.dfg[inst]
|
||||||
.take_value_list()
|
.take_value_list()
|
||||||
.expect("Branches must have value lists.");
|
.expect("Branches must have value lists.");
|
||||||
let num_args = args.len(&pos.func.dfg.value_lists);
|
let num_args = args.len(&pos.func.dfg.value_lists);
|
||||||
// Get the old value passed to the EBB argument we're repairing.
|
// Get the old value passed to the EBB argument we're repairing.
|
||||||
let old_arg = args
|
let old_arg = args
|
||||||
.get(fixed_args + repair.num, &pos.func.dfg.value_lists)
|
.get(num_fixed_args + repair.num, &pos.func.dfg.value_lists)
|
||||||
.expect("Too few branch arguments");
|
.expect("Too few branch arguments");
|
||||||
|
|
||||||
// It's possible that the CFG's predecessor list has duplicates. Detect them here.
|
// It's possible that the CFG's predecessor list has duplicates. Detect them here.
|
||||||
@@ -155,21 +155,23 @@ fn split_any(
|
|||||||
|
|
||||||
// The `lo` part replaces the original argument.
|
// The `lo` part replaces the original argument.
|
||||||
*args
|
*args
|
||||||
.get_mut(fixed_args + repair.num, &mut pos.func.dfg.value_lists)
|
.get_mut(num_fixed_args + repair.num, &mut pos.func.dfg.value_lists)
|
||||||
.unwrap() = lo;
|
.unwrap() = lo;
|
||||||
|
|
||||||
// The `hi` part goes at the end. Since multiple repairs may have been scheduled to the
|
// The `hi` part goes at the end. Since multiple repairs may have been scheduled to the
|
||||||
// same EBB, there could be multiple arguments missing.
|
// same EBB, there could be multiple arguments missing.
|
||||||
if num_args > fixed_args + repair.hi_num {
|
if num_args > num_fixed_args + repair.hi_num {
|
||||||
*args
|
*args
|
||||||
.get_mut(fixed_args + repair.hi_num, &mut pos.func.dfg.value_lists)
|
.get_mut(
|
||||||
.unwrap() = hi;
|
num_fixed_args + repair.hi_num,
|
||||||
|
&mut pos.func.dfg.value_lists,
|
||||||
|
).unwrap() = hi;
|
||||||
} else {
|
} else {
|
||||||
// We need to append one or more arguments. If we're adding more than one argument,
|
// We need to append one or more arguments. If we're adding more than one argument,
|
||||||
// there must be pending repairs on the stack that will fill in the correct values
|
// there must be pending repairs on the stack that will fill in the correct values
|
||||||
// instead of `hi`.
|
// instead of `hi`.
|
||||||
args.extend(
|
args.extend(
|
||||||
iter::repeat(hi).take(1 + fixed_args + repair.hi_num - num_args),
|
iter::repeat(hi).take(1 + num_fixed_args + repair.hi_num - num_args),
|
||||||
&mut pos.func.dfg.value_lists,
|
&mut pos.func.dfg.value_lists,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -266,7 +266,7 @@ impl<'a> Context<'a> {
|
|||||||
let retvals = &defs[self.cur.func.dfg[inst]
|
let retvals = &defs[self.cur.func.dfg[inst]
|
||||||
.opcode()
|
.opcode()
|
||||||
.constraints()
|
.constraints()
|
||||||
.fixed_results()..];
|
.num_fixed_results()..];
|
||||||
if !retvals.is_empty() {
|
if !retvals.is_empty() {
|
||||||
let sig = self
|
let sig = self
|
||||||
.cur
|
.cur
|
||||||
@@ -367,7 +367,7 @@ impl<'a> Context<'a> {
|
|||||||
let offset = self.cur.func.dfg[inst]
|
let offset = self.cur.func.dfg[inst]
|
||||||
.opcode()
|
.opcode()
|
||||||
.constraints()
|
.constraints()
|
||||||
.fixed_value_arguments();
|
.num_fixed_value_arguments();
|
||||||
if args.len() == offset {
|
if args.len() == offset {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -376,10 +376,10 @@ impl<'a> Context<'a> {
|
|||||||
|
|
||||||
// Collect register uses from the ABI input constraints.
|
// Collect register uses from the ABI input constraints.
|
||||||
fn collect_abi_reg_uses(&mut self, inst: Inst, sig: SigRef) {
|
fn collect_abi_reg_uses(&mut self, inst: Inst, sig: SigRef) {
|
||||||
let fixed_args = self.cur.func.dfg[inst]
|
let num_fixed_args = self.cur.func.dfg[inst]
|
||||||
.opcode()
|
.opcode()
|
||||||
.constraints()
|
.constraints()
|
||||||
.fixed_value_arguments();
|
.num_fixed_value_arguments();
|
||||||
let args = self.cur.func.dfg.inst_variable_args(inst);
|
let args = self.cur.func.dfg.inst_variable_args(inst);
|
||||||
for (idx, (abi, &arg)) in self.cur.func.dfg.signatures[sig]
|
for (idx, (abi, &arg)) in self.cur.func.dfg.signatures[sig]
|
||||||
.params
|
.params
|
||||||
@@ -396,7 +396,7 @@ impl<'a> Context<'a> {
|
|||||||
),
|
),
|
||||||
Affinity::Unassigned => panic!("Missing affinity for {}", arg),
|
Affinity::Unassigned => panic!("Missing affinity for {}", arg),
|
||||||
};
|
};
|
||||||
let mut reguse = RegUse::new(arg, fixed_args + idx, rci);
|
let mut reguse = RegUse::new(arg, num_fixed_args + idx, rci);
|
||||||
reguse.fixed = true;
|
reguse.fixed = true;
|
||||||
reguse.spilled = spilled;
|
reguse.spilled = spilled;
|
||||||
self.reg_uses.push(reguse);
|
self.reg_uses.push(reguse);
|
||||||
|
|||||||
@@ -524,12 +524,12 @@ impl<'a> Verifier<'a> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
let fixed_results = inst_data.opcode().constraints().fixed_results();
|
let num_fixed_results = inst_data.opcode().constraints().num_fixed_results();
|
||||||
// var_results is 0 if we aren't a call instruction
|
// var_results is 0 if we aren't a call instruction
|
||||||
let var_results = dfg
|
let var_results = dfg
|
||||||
.call_signature(inst)
|
.call_signature(inst)
|
||||||
.map_or(0, |sig| dfg.signatures[sig].returns.len());
|
.map_or(0, |sig| dfg.signatures[sig].returns.len());
|
||||||
let total_results = fixed_results + var_results;
|
let total_results = num_fixed_results + var_results;
|
||||||
|
|
||||||
// All result values for multi-valued instructions are created
|
// All result values for multi-valued instructions are created
|
||||||
let got_results = dfg.inst_results(inst).len();
|
let got_results = dfg.inst_results(inst).len();
|
||||||
|
|||||||
Reference in New Issue
Block a user