use crate::enums::kind_a_64::KindA64;
use crate::macros::codegen_assert::CODEGEN_ASSERT;
use crate::records::assembly_builder_a_64::AssemblyBuilderA64;
use crate::records::register_a_64::RegisterA64;
impl AssemblyBuilderA64 {
pub fn place_sr_3(
&mut self,
name: *const core::ffi::c_char,
dst: RegisterA64,
src1: RegisterA64,
src2: RegisterA64,
op: u8,
shift: i32,
n: i32,
) {
if self.log_text {
self.log_c_char_register_a_64_register_a_64_register_a_64_i32(
name, dst, src1, src2, shift,
);
}
debug_assert!(dst.kind() == KindA64::w || dst.kind() == KindA64::x);
debug_assert!(dst.kind() == src1.kind() && dst.kind() == src2.kind());
debug_assert!(shift >= -63 && shift <= 63);
let sf = if dst.kind() == KindA64::x {
0x80000000
} else {
0
};
let shift_abs = if shift < 0 { -shift } else { shift };
self.place(
dst.index() as u32
| (src1.index() as u32) << 5
| (shift_abs as u32) << 10
| (src2.index() as u32) << 16
| ((n as u32) << 21)
| ((shift < 0) as u32) << 22
| (op as u32) << 24
| sf,
);
self.commit();
}
}