Skip to main content

luaur_code_gen/methods/
assembly_builder_a_64_ldp.rs

1use crate::enums::kind_a_64::KindA64;
2use crate::macros::codegen_assert::CODEGEN_ASSERT;
3use crate::records::address_a_64::AddressA64;
4use crate::records::assembly_builder_a_64::AssemblyBuilderA64;
5use crate::records::register_a_64::RegisterA64;
6
7impl AssemblyBuilderA64 {
8    pub fn ldp(&mut self, dst1: RegisterA64, dst2: RegisterA64, src: AddressA64) {
9        debug_assert!(dst1.kind() == KindA64::x || dst1.kind() == KindA64::w);
10        debug_assert!(dst1.kind() == dst2.kind());
11
12        let is_x = dst1.kind() == KindA64::x;
13        self.place_p(
14            b"ldp\0".as_ptr() as *const core::ffi::c_char,
15            dst1,
16            dst2,
17            src,
18            0b101_0_010_1,
19            (is_x as u8) << 1,
20            if is_x { 3 } else { 2 },
21        );
22    }
23}