IN: compiler-backend USING: assembler compiler-backend kernel sequences ; ! AMD64 register assignments ! RAX RCX RDX RSI RDI R8 R9 R10 R11 vregs ! R14 datastack ! R15 callstack : ds-reg R14 ; inline : cs-reg R15 ; inline : fixnum-imm? ( -- ? ) #! Can fixnum operations take immediate operands? f ; inline : vregs ( -- n ) #! Number of vregs 3 ; inline M: vreg v>operand ( vreg -- reg ) vreg-n { RAX RCX RDX RSI RDI R8 R9 R10 R11 } nth ; ! FIXME M: int-regs fastcall-regs drop 0 ; M: int-regs reg-class-size drop 4 ; M: float-regs fastcall-regs drop 0 ; : dual-fp/int-regs? f ;