cranelift: Rework pinned register lowering (#5249)
Rework pinned register lowering to avoid the use of pinned virtual registers, instead using the MovFromPReg and MovToPReg pseudo instructions.
This commit is contained in:
@@ -698,9 +698,9 @@ pub(crate) fn emit(
|
||||
);
|
||||
}
|
||||
|
||||
Inst::MovPReg { src, dst } => {
|
||||
Inst::MovFromPReg { src, dst } => {
|
||||
let src: Reg = (*src).into();
|
||||
debug_assert!([regs::rsp(), regs::rbp()].contains(&src));
|
||||
debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&src));
|
||||
let src = Gpr::new(src).unwrap();
|
||||
let size = OperandSize::Size64;
|
||||
let dst = allocs.next(dst.to_reg().to_reg());
|
||||
@@ -708,6 +708,16 @@ pub(crate) fn emit(
|
||||
Inst::MovRR { size, src, dst }.emit(&[], sink, info, state);
|
||||
}
|
||||
|
||||
Inst::MovToPReg { src, dst } => {
|
||||
let src = allocs.next(src.to_reg());
|
||||
let src = Gpr::new(src).unwrap();
|
||||
let dst: Reg = (*dst).into();
|
||||
debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&dst));
|
||||
let dst = WritableGpr::from_writable_reg(Writable::from_reg(dst)).unwrap();
|
||||
let size = OperandSize::Size64;
|
||||
Inst::MovRR { size, src, dst }.emit(&[], sink, info, state);
|
||||
}
|
||||
|
||||
Inst::MovzxRmR { ext_mode, src, dst } => {
|
||||
let dst = allocs.next(dst.to_reg().to_reg());
|
||||
let (opcodes, num_opcodes, mut rex_flags) = match ext_mode {
|
||||
|
||||
@@ -92,7 +92,8 @@ impl Inst {
|
||||
| Inst::Mov64MR { .. }
|
||||
| Inst::MovRM { .. }
|
||||
| Inst::MovRR { .. }
|
||||
| Inst::MovPReg { .. }
|
||||
| Inst::MovFromPReg { .. }
|
||||
| Inst::MovToPReg { .. }
|
||||
| Inst::MovsxRmR { .. }
|
||||
| Inst::MovzxRmR { .. }
|
||||
| Inst::MulHi { .. }
|
||||
@@ -1233,13 +1234,20 @@ impl PrettyPrint for Inst {
|
||||
)
|
||||
}
|
||||
|
||||
Inst::MovPReg { src, dst } => {
|
||||
Inst::MovFromPReg { src, dst } => {
|
||||
let src: Reg = (*src).into();
|
||||
let src = regs::show_ireg_sized(src, 8);
|
||||
let dst = pretty_print_reg(dst.to_reg().to_reg(), 8, allocs);
|
||||
format!("{} {}, {}", ljustify("movq".to_string()), src, dst)
|
||||
}
|
||||
|
||||
Inst::MovToPReg { src, dst } => {
|
||||
let src = pretty_print_reg(src.to_reg(), 8, allocs);
|
||||
let dst: Reg = (*dst).into();
|
||||
let dst = regs::show_ireg_sized(dst, 8);
|
||||
format!("{} {}, {}", ljustify("movq".to_string()), src, dst)
|
||||
}
|
||||
|
||||
Inst::MovzxRmR {
|
||||
ext_mode, src, dst, ..
|
||||
} => {
|
||||
@@ -1877,11 +1885,16 @@ fn x64_get_operands<F: Fn(VReg) -> VReg>(inst: &Inst, collector: &mut OperandCol
|
||||
collector.reg_use(src.to_reg());
|
||||
collector.reg_def(dst.to_writable_reg());
|
||||
}
|
||||
Inst::MovPReg { dst, src } => {
|
||||
debug_assert!([regs::rsp(), regs::rbp()].contains(&(*src).into()));
|
||||
Inst::MovFromPReg { dst, src } => {
|
||||
debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&(*src).into()));
|
||||
debug_assert!(dst.to_reg().to_reg().is_virtual());
|
||||
collector.reg_def(dst.to_writable_reg());
|
||||
}
|
||||
Inst::MovToPReg { dst, src } => {
|
||||
debug_assert!(src.to_reg().is_virtual());
|
||||
debug_assert!([regs::rsp(), regs::rbp(), regs::pinned_reg()].contains(&(*dst).into()));
|
||||
collector.reg_use(src.to_reg());
|
||||
}
|
||||
Inst::XmmToGpr { src, dst, .. } => {
|
||||
collector.reg_use(src.to_reg());
|
||||
collector.reg_def(dst.to_writable_reg());
|
||||
|
||||
Reference in New Issue
Block a user