factor/library/compiler/amd64/architecture.factor

28 lines
584 B
Factor
Raw Normal View History

2005-12-02 01:23:09 -05:00
IN: compiler-backend
USING: assembler compiler-backend kernel sequences ;
! AMD64 register assignments
! RAX RCX RDX RSI RDI R8 R9 R10 R11 vregs
2005-12-04 02:30:19 -05:00
! R14 datastack
! R15 callstack
: ds-reg R14 ; inline
: cs-reg R15 ; inline
2005-12-02 01:23:09 -05:00
: fixnum-imm? ( -- ? )
#! Can fixnum operations take immediate operands?
t ; inline
: vregs ( -- n )
#! Number of vregs
3 ; inline
M: vreg v>operand 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 ;