return call ref

This commit is contained in:
Graham Kelly 2024-06-02 19:33:57 -04:00
parent b29a983ab9
commit 36e3059be7
5 changed files with 64 additions and 1 deletions

View file

@ -214,6 +214,12 @@ impl<'a> WasmFuncBackend<'a> {
table: table.index() as u32, table: table.index() as u32,
}); });
} }
WasmBlock::ReturnCallRef { sig, values } => {
for &value in &values[..] {
self.lower_value(value, func);
}
func.instruction(&wasm_encoder::Instruction::ReturnCallRef(sig.index() as u32));
}
WasmBlock::Unreachable => { WasmBlock::Unreachable => {
func.instruction(&wasm_encoder::Instruction::Unreachable); func.instruction(&wasm_encoder::Instruction::Unreachable);
} }

View file

@ -61,6 +61,12 @@ pub enum WasmBlock<'a> {
table: Table, table: Table,
values: &'a [Value], values: &'a [Value],
}, },
/// A function refernce tail call instruction
ReturnCallRef {
sig: Signature,
// table: Table,
values: &'a [Value],
},
/// An unreachable instruction. /// An unreachable instruction.
Unreachable, Unreachable,
} }
@ -465,6 +471,15 @@ impl<'a, 'b> Context<'a, 'b> {
table, table,
values: args, values: args,
}), }),
&Terminator::ReturnCallRef {
sig,
// table,
ref args,
} => into.push(WasmBlock::ReturnCallRef {
sig,
// table,
values: args,
}),
} }
} }
} }

View file

@ -1531,7 +1531,22 @@ impl<'a, 'b> FunctionBodyBuilder<'a, 'b> {
}); });
self.reachable = false; self.reachable = false;
} }
wasmparser::Operator::ReturnCallRef {
type_index,
// table_index,
} => {
let retvals = self.pop_n(
self.module.signatures[Signature::new(*type_index as usize)]
.params
.len(),
);
self.emit_term(Terminator::ReturnCallRef {
sig: Signature::new(*type_index as usize),
// table: Table::new(*table_index as usize),
args: retvals,
});
self.reachable = false;
}
_ => bail!(FrontendError::UnsupportedFeature(format!( _ => bail!(FrontendError::UnsupportedFeature(format!(
"Unsupported operator: {:?}", "Unsupported operator: {:?}",
op op

View file

@ -325,6 +325,7 @@ impl InterpContext {
log::trace!("returning from {}: {:?}", func, values); log::trace!("returning from {}: {:?}", func, values);
return InterpResult::Ok(values); return InterpResult::Ok(values);
} }
Terminator::ReturnCallRef { sig, args } => todo!(),
} }
} }
} }

View file

@ -545,6 +545,10 @@ pub enum Terminator {
table: Table, table: Table,
args: Vec<Value>, args: Vec<Value>,
}, },
ReturnCallRef {
sig: Signature,
args: Vec<Value>,
},
Unreachable, Unreachable,
None, None,
} }
@ -609,6 +613,16 @@ impl std::fmt::Display for Terminator {
.collect::<Vec<_>>() .collect::<Vec<_>>()
.join(", ") .join(", ")
)?, )?,
Terminator::ReturnCallRef { sig, args } =>write!(
f,
"return_call_ref ({})({})",
sig,
// table,
args.iter()
.map(|val| format!("{}", val))
.collect::<Vec<_>>()
.join(", ")
)?,
} }
Ok(()) Ok(())
} }
@ -641,6 +655,7 @@ impl Terminator {
Terminator::Unreachable => {} Terminator::Unreachable => {}
Terminator::ReturnCall { func, args } => {} Terminator::ReturnCall { func, args } => {}
Terminator::ReturnCallIndirect { sig, table, args } => {} Terminator::ReturnCallIndirect { sig, table, args } => {}
Terminator::ReturnCallRef { sig, args } => {},
} }
} }
@ -670,6 +685,9 @@ impl Terminator {
Terminator::Unreachable => {} Terminator::Unreachable => {}
Terminator::ReturnCall { func, args } => {} Terminator::ReturnCall { func, args } => {}
Terminator::ReturnCallIndirect { sig, table, args } => {} Terminator::ReturnCallIndirect { sig, table, args } => {}
Terminator::ReturnCallRef { sig, args } => {
},
} }
} }
@ -787,6 +805,14 @@ impl Terminator {
f(value); f(value);
} }
} }
&mut Terminator::ReturnCallRef {
sig,
ref mut args,
} => {
for value in args {
f(value);
}
}
_ => {} _ => {}
} }
} }