luaur_code_gen/methods/
assembly_builder_a_64_place_r_3.rs1use crate::enums::kind_a_64::KindA64;
2use crate::records::assembly_builder_a_64::AssemblyBuilderA64;
3use crate::records::register_a_64::RegisterA64;
4
5impl AssemblyBuilderA64 {
6 pub fn place_r_3(
7 &mut self,
8 name: *const core::ffi::c_char,
9 dst: RegisterA64,
10 src1: RegisterA64,
11 src2: RegisterA64,
12 op: u8,
13 op2: u8,
14 ) {
15 if self.log_text {
16 self.log_c_char_register_a_64_register_a_64_register_a_64_i32(name, dst, src1, src2, 0);
17 }
18
19 assert!(
22 dst.kind() == KindA64::w
23 || dst.kind() == KindA64::x
24 || dst.kind() == KindA64::d
25 || dst.kind() == KindA64::s
26 );
27 assert!(dst.kind() == src1.kind() && dst.kind() == src2.kind());
28
29 let sf = if dst.kind() == KindA64::x {
30 0x80000000
31 } else {
32 0
33 };
34
35 self.place(
36 (dst.index() as u32)
37 | ((src1.index() as u32) << 5)
38 | ((op2 as u32) << 10)
39 | ((src2.index() as u32) << 16)
40 | ((op as u32) << 21)
41 | sf,
42 );
43 self.commit();
44 }
45}