use crate::records::assembly_builder_a_64::AssemblyBuilderA64;
use crate::records::label::Label;
use crate::records::register_a_64::RegisterA64;
impl AssemblyBuilderA64 {
pub fn place_bcr(
&mut self,
name: *const core::ffi::c_char,
label: &mut Label,
op: u8,
cond: RegisterA64,
) {
assert!(
cond.kind() == crate::enums::kind_a_64::KindA64::w
|| cond.kind() == crate::enums::kind_a_64::KindA64::x
);
let sf = if cond.kind() == crate::enums::kind_a_64::KindA64::x {
0x8000_0000
} else {
0
};
self.place(cond.index() as u32 | ((op as u32) << 24) | sf);
self.commit();
self.patch_label(label, crate::enums::kind::Kind::Imm19);
if self.log_text {
self.log_c_char_register_a_64_label_i32(name, cond, *label, -1);
}
}
}