Skip to main content

luaur_code_gen/methods/
assembly_builder_a_64_place_r_3.rs

1use 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        // Avoid CODEGEN_ASSERT! macro invocation here: it currently expands to luaur_common::assert_call_handler
20        // which expects *const i8 parameters and may type-mismatch at call sites elsewhere.
21        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}