#![no_std] #![feature(error_in_core)] extern crate alloc; pub mod text; mod macros; use {alloc::vec::Vec, hashbrown::HashSet}; #[derive(Default)] pub struct Assembler { pub buf: Vec, sub: HashSet, } impl Assembler { macros::impl_asm!( bbbb(p0: u8, p1: u8, p2: u8, p3: u8) => [DIR, DIRF, FMAF], bbb(p0: u8, p1: u8, p2: u8) => [ADD, SUB, MUL, AND, OR, XOR, SL, SR, SRS, CMP, CMPU, BRC, ADDF, SUBF, MULF], bbdh(p0: u8, p1: u8, p2: impl Imm, p3: u16) => [LD, ST], bbd(p0: u8, p1: u8, p2: impl Imm) => [ADDI, MULI, ANDI, ORI, XORI, SLI, SRI, SRSI, CMPI, CMPUI, BMC, JEQ, JNE, JLT, JGT, JLTU, JGTU, ADDFI, MULFI], bb(p0: u8, p1: u8) => [NEG, NOT, CP, SWA, NEGF, ITF, FTI], bd(p0: u8, p1: impl Imm) => [LI, JMP], n() => [NOP, ECALL], ); } pub trait Imm { fn insert(&self, asm: &mut Assembler); } macro_rules! impl_imm_le_bytes { ($($ty:ty),* $(,)?) => { $( impl Imm for $ty { #[inline(always)] fn insert(&self, asm: &mut Assembler) { asm.buf.extend(self.to_le_bytes()); } } )* }; } impl_imm_le_bytes!(u64, i64, f64); #[derive(Clone, Copy, Debug, PartialEq, Eq)] pub struct Symbol(pub u64); impl Imm for Symbol { #[inline(always)] fn insert(&self, asm: &mut Assembler) { asm.sub.insert(asm.buf.len()); asm.buf.extend(self.0.to_le_bytes()); } }