#define small(x) ((x)>=1 && (x)<=8) /******************************************************************************/ /* */ /* Group 1 : Load instructions */ /* */ /******************************************************************************/ /* a6 : local base. * sp : stack pointer */ C_loc ==> "pea ($1)". C_lol ==> "move.l ($1, a6), -(sp)". C_loe.. ==> "move.l ($1+$2), -(sp)". C_lil ==> "move.l ([$1,a6]), -(sp)". C_lof ==> "move.l (sp)+, a0"; "move.l ($1,a0), -(sp)". C_lal ==> "pea ($1,a6)". C_lae.. ==> "pea ($1+$2)". C_lxl $1 == 0 ==> "move.l a6, -(sp)". $1 == 1 ==> "move.l (8, a6), -(sp)". default ==> "move.l (8, a6), a0"; "move.l #$1-2, d0"; "1: move.l (8,a0), a0"; "dbf d0, 1b"; "move.l a0, -(sp)". C_lxa $1 == 0 ==> "pea (8,a6)". $1 == 1 ==> "pea ([8,a6],8)". default ==> "move.l (8, a6), a0"; "move.l #$1-2, d0"; "1: move.l (8,a0), a0"; "dbf d0, 1b"; "pea (8,a0)". C_loi $1 == 1 ==> "move.l (sp)+, a0"; "clr.l -(sp)"; "move.b (a0), (3,sp)". $1 == 2 ==> "move.l (sp)+, a0"; "clr.l -(sp)"; "move.w (a0), (2,sp)". $1 == 4 ==> "move.l (sp)+, a0"; "move.l (a0), -(sp)". $1 == 8 ==> "move.l (sp)+, a0"; "move.l (4,a0), -(sp)"; "move.l (a0), -(sp)". $1 % 4 == 0 ==> "move.l (sp)+, a0"; "move.l #$1/4-1, d0"; "add.l #$1, a0"; "1:"; "move.l -(a0), -(sp)"; "dbf d0, 1b". default ==> arg_error( "loi", $1). C_los $1 == 4 ==> "jsr (.los)". default ==> arg_error( "los", $1). C_ldl ==> "move.l ($1+4, a6), -(sp)"; "move.l ($1, a6), -(sp)". C_lde.. ==> "move.l ($1+$2+4), -(sp)"; "move.l ($1+$2), -(sp)". C_ldf ==> "move.l (sp)+, a0"; "move.l ($1+4,a0), -(sp)"; "move.l ($1,a0), -(sp)". C_lpi ==> "pea ($1)". /******************************************************************************/ /* */ /* Group 2 : Store instructions */ /* */ /******************************************************************************/ C_stl ==> "move.l (sp)+, ($1,a6)". C_ste.. ==> "move.l (sp)+, ($1+$2)". C_sil ==> "move.l (sp)+, ([$1,a6])". C_stf ==> "move.l (sp)+, a0"; "move.l (sp)+, ($1,a0)". C_sti $1 == 1 ==> "move.l (sp)+, a0"; "move.l (sp)+, d0"; "move.b d0, (a0)". $1 == 2 ==> "move.l (sp)+, a0"; "move.l (sp)+, d0"; "move.w d0, (a0)". $1 == 4 ==> "move.l (sp)+, a0"; "move.l (sp)+, (a0)". $1 % 4 == 0 ==> "move.l (sp)+, a0"; "move.l #$1/4-1, d0"; "1:move.l (sp)+, (a0)+"; "dbf d0, 1b". default ==> arg_error( "sti", (arith) $1). C_sts ==> "jsr (.sts)". C_sdl ==> "move.l (sp)+, ($1,a6)"; "move.l (sp)+, ($1+4,a6)". C_sde.. ==> "move.l (sp)+, ($1+$2)"; "move.l (sp)+, ($1+$2+4)". C_sdf ==> "move.l (sp)+, a0"; "move.l (sp)+, ($1,a0)"; "move.l (sp)+, ($1+4,a0)". /******************************************************************************/ /* */ /* Group 3 : Integer arithmetic */ /* */ /******************************************************************************/ C_adi $1 == 4 ==> "move.l (sp)+, d0"; "add.l d0, (sp)". default ==> arg_error( "adi", $1). C_sbi $1 == 4 ==> "move.l (sp)+, d0"; "sub.l d0, (sp)". default ==> arg_error( "sbi", $1). C_mli $1 == 4 ==> "move.l (sp)+, d0"; "muls.l (sp)+, d0"; "move.l d0, -(sp)". default ==> arg_error( "mli", $1). C_dvi $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "divs.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "dvi", $1). C_rmi $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "divsl.l d0, d2:d1"; "move.l d2, -(sp)". default ==> arg_error( "rmi", $1). C_ngi $1 == 4 ==> "neg.l (sp)". default ==> arg_error( "ngi", $1). C_sli $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "asl.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "sli", $1). C_sri $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "asr.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "sri", $1). /******************************************************************************/ /* */ /* Group 4 : Unsigned arithmetic */ /* */ /******************************************************************************/ C_adu ==> C_adi( w). C_sbu ==> C_sbi( w). C_mlu $1 == 4 ==> "move.l (sp)+, d0"; "mulu.l (sp)+, d0"; "move.l d0, -(sp)". default ==> arg_error( "mlu", $1). C_dvu $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "divu.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "dvu", $1). C_rmu $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "divul.l d0, d2:d1"; "move.l d2, -(sp)". default ==> arg_error( "rmu", $1). C_slu ==> C_sli( w). C_sru $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "lsr.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "sru", $1). /******************************************************************************/ /* */ /* Group 5 : Floating point arithmetic */ /* */ /******************************************************************************/ C_adf $1 == 4 ==> "jsr (.adf4)"; "tst.l (sp)+". $1 == 8 ==> "jsr (.adf8)"; "lea (8, sp), sp". default ==> arg_error( "adf", $1). C_sbf $1 == 4 ==> "jsr (.sbf4)"; "tst.l (sp)+". $1 == 8 ==> "jsr (.sbf8)"; "lea (8, sp), sp". default ==> arg_error( "sbf", $1). C_mlf $1 == 4 ==> "jsr (.mlf4)"; "tst.l (sp)+". $1 == 8 ==> "jsr (.mlf8)"; "lea (8, sp), sp". default ==> arg_error( "mlf", $1). C_dvf $1 == 4 ==> "jsr (.dvf4)"; "tst.l (sp)+". $1 == 8 ==> "jsr (.dvf8)"; "lea (8, sp), sp". default ==> arg_error( "dvf", $1). C_ngf $1 == 4 ==> "jsr (.ngf4)". $1 == 8 ==> "jsr (.ngf8)". default ==> arg_error( "ngf", $1). C_fif $1 == 4 ==> "jsr (.fif4)". $1 == 8 ==> "jsr (.fif8)". default ==> arg_error( "fif", $1). C_fef $1 == 4 ==> C_dup( (arith) 4); "jsr (.fef4)". $1 == 8 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "move.l d0, -(sp)"; "move.l d1, -(sp)"; "move.l d0, -(sp)"; "jsr (.fef8)". default ==> arg_error( "fef", $1). /******************************************************************************/ /* */ /* Group 6 : Pointer arithmetic */ /* */ /******************************************************************************/ C_adp $1 == 0 ==> . default ==> "add.l #$1, (sp)". C_ads $1 == 4 ==> "move.l (sp)+, d0"; "add.l d0, (sp)". default ==> arg_error( "ads", $1). C_sbs $1 == 4 ==> "move.l (sp)+, d0"; "sub.l d0, (sp)". default ==> arg_error( "sbs", $1). /******************************************************************************/ /* */ /* Group 7 : Increment/decrement/zero */ /* */ /******************************************************************************/ C_inc ==> "add.l #1, (sp)". C_inl ==> "add.l #1, ($1, a6)". C_ine.. ==> "add.l #1, ($1+$2)". C_dec ==> "sub.l #1, (sp)". C_del ==> "sub.l #1, ($1, a6)". C_dee.. ==> "sub.l #1, ($1+$2)". C_zrl ==> "clr.l ($1, a6)". C_zre.. ==> "clr.l ($1+$2)". C_zrf ==> C_zer( $1). C_zer $1 == 4 ==> "clr.l -(sp)". $1 == 8 ==> "clr.l -(sp)"; "clr.l -(sp)". default ==> "move.l #$1/4-1, d0"; "1:"; "clr.l -(sp)"; "dbf d0, 1b". /******************************************************************************/ /* */ /* Group 8 : Convert */ /* */ /******************************************************************************/ C_cii ==> " move.l (sp), d0"; " move.l (4, sp), d1"; " cmp.l d1, d0"; " ble 4f"; " cmp.l #4, d1"; " bge 4f"; " move.l (8, sp), d2"; " cmp.l #1, d1"; " bne 2f"; " cmp.l #2, d0"; " bne 1f"; " ext.w d2"; " bra 3f"; "1: extl.l d2"; " bra 3f"; "2: ext.l d2"; "3: move.l d2, (8, sp)"; " move.l #4, (4, sp)"; "4: jsr (.cii)". C_cuu ==> "jsr (.cuu) ". C_ciu ==> C_cuu(). C_cui ==> C_cuu(). C_cfi ==> "jsr (.cfi)"; "move.l (4, sp), d0"; "cmp.l #4, d0"; "beq 1f"; "tst.l (sp)+"; "1:"; "lea (8, sp), sp". C_cfu ==> "jsr (.cfu)"; "move.l (4, sp), d0"; "cmp.l #4, d0"; "beq 1f"; "tst.l (sp)+"; "1:"; "lea (8, sp), sp". C_cff ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "cmp.l d0, d1"; "beq 1f"; "cmp.l #4, d0"; "bne 2f"; "jsr (.cff4)"; "add.l #4, sp"; "bra 1f"; "2:"; "move.l (sp), d0"; "clr.l (sp)"; "move.l d0,-(sp)"; "jsr (.cff8)"; "1:". C_cif ==> "move.l (sp)+, d0"; "cmp.l #4, d0"; "bne 1f"; "jsr (.cif4)"; "add.l #4, sp"; "bra 2f"; "1:"; "jsr (.cif8)"; "2:". C_cuf ==> "move.l (sp)+, d0"; "cmp.l #4, d0"; "bne 1f"; "jsr (.cuf4)"; "add.l #4, sp"; "bra 2f"; "1:"; "jsr (.cuf8)"; "2:". /******************************************************************************/ /* */ /* Group 9 : Logical */ /* */ /******************************************************************************/ C_and $1 == 4 ==> "move.l (sp)+, d0"; "and.l d0, (sp)". default ==> "move.l #$1/4-1, d0"; "lea ($1, sp), a0"; "1:"; "move.l (sp)+, d1"; "and.l d1, (a0)+"; "dbf d0, 1b". C_ior $1 == 4 ==> "move.l (sp)+, d0"; "or.l d0, (sp)". default ==> "move.l #$1/4-1, d0"; "lea ($1, sp), a0"; "1:"; "move.l (sp)+, d1"; "or.l d1, (a0)+"; "dbf d0, 1b". C_xor $1 == 4 ==> "move.l (sp)+, d0"; "eor.l d0, (sp)". default ==> "move.l #$1/4-1, d0"; "lea ($1, sp), a0"; "1:"; "move.l (sp)+, d1"; "eor.l d1, (a0)+"; "dbf d0, 1b". C_com $1 == 4 ==> "not.l (sp)". $1 == 8 ==> "not.l (sp)"; "not.l (4, sp)". default ==> "move.l #$1/4-1, d0"; "move.l sp, a0"; "1:"; "not.l (a0)+"; "dbf d0, 1b". C_rol $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "rol.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "rol", $1). C_ror $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "ror.l d0, d1"; "move.l d1, -(sp)". default ==> arg_error( "ror", $1). /******************************************************************************/ /* */ /* Group 10 : Sets */ /* */ /******************************************************************************/ C_inn $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "btst d0, d1"; "sne d1"; "and.l #1, d1"; "move.l d1, -(sp)". default ==> "move.l (sp)+, d0"; "move.l #$1, d1"; "jsr (.inn)"; "move.l d0, -(sp)". C_inn_narg ==> "move.l (sp)+, d1"; "move.l (sp)+, d0"; "jsr (.inn)"; "move.l d0, -(sp)". C_set $1 == 4 ==> "move.l (sp)+, d0"; "clr.l d1"; "bset d0, d1"; "move.l d1, -(sp)". default ==> "move.l (sp)+, d0"; "move.l #$1, d1"; "jsr (.set)". C_set_narg ==> "move.l (sp)+, d1"; "move.l (sp)+, d0"; "jsr (.set)". /******************************************************************************/ /* */ /* Group 11 : Array */ /* */ /******************************************************************************/ C_lar ==> "move.l #$1, d0"; "jsr (.lar)". C_lar_narg ==> "move.l (sp)+, d0"; "jsr (.lar)". C_sar ==> "move.l #$1, d0"; "jsr (.sar)". C_sar_narg ==> "move.l (sp)+, d0"; "jsr (.sar)". C_aar ==> "move.l #$1, d0"; "jsr (.aar)"; "move.l a0, -(sp)". C_aar_narg ==> "move.l (sp)+, d0"; "jsr (.aar)"; "move.l a0, -(sp)". /******************************************************************************/ /* */ /* Group 12 : Compare */ /* */ /******************************************************************************/ C_cmi $1 == 4 ==> "clr.l d0"; "cmp.l (sp)+, (sp)+"; "beq 2f"; "blt 1f"; "add.l #1, d0"; "bra 2f"; "1 : sub.l #1, d0"; "2 : move.l d0, -(sp)". default ==> "move.l #$1, d0"; "jsr (.cmi)"; "move.l d0, -(sp)". C_cmu $1 == 4 ==> "clr.l d0"; "cmp.l (sp)+, (sp)+"; "beq 2f"; "bcs 1f"; "add.l #1, d0"; "bra 2f"; "1 : sub.l #1, d0"; "2 : move.l d0, -(sp)". default ==> "move.l #$1, d0"; "jsr (.cmu)"; "move.l d0, -(sp)". C_cmu_narg ==> "move.l (sp)+, d0"; "jsr (.cmu)"; "move.l d0, -(sp)". C_cms ==> "move.l #$1, d0"; "jsr (.cms)"; "move.l d0, -(sp)". C_cms_narg ==> "move.l (sp)+, d0"; "jsr (.cms)"; "move.l d0, -(sp)". C_cmp ==> C_cmu( (arith)4). C_tlt ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "blt 1f"; "clr.l (sp)"; "1:". C_tle ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "ble 1f"; "clr.l (sp)"; "1:". C_teq ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "beq 1f"; "clr.l (sp)"; "1:". C_tne ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "bne 1f"; "clr.l (sp)"; "1:". C_tge ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "bge 1f"; "clr.l (sp)"; "1:". C_tgt ==> "move.l (sp)+, d0"; "move.l #1, -(sp)"; "tst.l d0"; "bgt 1f"; "clr.l (sp)"; "1:". C_cmf $1 == 4 ==> "jsr (.cmf4)"; "tst.l (sp)+"; "move.l d0,(sp)". $1 == 8 ==> "jsr (.cmf8)"; "lea (12,sp), sp"; "move.l d0,(sp)". default ==> arg_error("cmf", $1). /******************************************************************************/ /* */ /* Group 13 : Branch */ /* */ /******************************************************************************/ C_bra ==> "bra $1". C_blt ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "bgt $1". C_ble ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "bge $1". C_beq ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "beq $1". C_bne ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "bne $1". C_bge ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "ble $1". C_bgt ==> "move.l (sp)+, d0"; "cmp.l (sp)+, d0"; "blt $1". C_zlt ==> "tst.l (sp)+"; "blt $1". C_zle ==> "tst.l (sp)+"; "ble $1". C_zeq ==> "tst.l (sp)+"; "beq $1". C_zne ==> "tst.l (sp)+"; "bne $1". C_zge ==> "tst.l (sp)+"; "bge $1". C_zgt ==> "tst.l (sp)+"; "bgt $1". /******************************************************************************/ /* */ /* Group 14 : Procedure call instructions */ /* */ /******************************************************************************/ C_cai ==> "move.l (sp)+, a0"; "jsr (a0)". C_cal ==> "jsr ($1)". C_lfr $1 == 4 ==> "move.l d0, -(sp)". $1 == 8 ==> "move.l d1, -(sp)"; "move.l d0, -(sp)". default ==> arg_error( "lfr", $1). C_ret $1 == 0 ==> "unlk a6"; "rts". $1 == 4 ==> "move.l (sp)+, d0"; "unlk a6"; "rts". $1 == 8 ==> "move.l (sp)+, d0"; "move.l (sp)+, d1"; "unlk a6"; "rts". default ==> arg_error( "ret", $1). /******************************************************************************/ /* */ /* Group 15 : Miscellaneous instructions */ /* */ /******************************************************************************/ C_asp small( $1) ==> "add.l #$1, sp". default ==> "lea ($1, sp), sp". C_ass $1 == 4 ==> "add.l (sp)+, sp". default ==> arg_error( "ass", $1). C_blm $1 == 4 ==> "move.l (sp)+, a0"; "move.l (sp)+, a1"; "move.l (a1), (a0)". $1 == 8 ==> "move.l (sp)+, a0"; "move.l (sp)+, a1"; "move.l (a1), (a0)"; "move.l (4, a1), (4, a0)". default ==> "move.l (sp)+, a0"; "move.l (sp)+, a1"; "move.l #$1/4-1, d0"; "1:"; "move.l (a1)+, (a0)+"; "dbf d0, 1b". C_bls $1 == 4 ==> "move.l (sp)+, d0"; "move.l (sp)+, a0"; "move.l (sp)+, a1"; "asr.l #2, d1"; "beq 2f"; "1:"; "move.l (a1)+, (a0)+"; "dbf d0, 1b"; "2:". default ==> arg_error( "bls", $1). C_csa $1 == 4 ==> "jmp (.csa)". default ==> arg_error( "csa", $1). C_csb $1 == 4 ==> "jmp (.csb)". default ==> arg_error( "csb", $1). C_dch ==> C_loi( (arith)4). C_dup $1 == 4 ==> "move.l (sp), -(sp)". $1 == 4 ==> "move.l (4, sp), -(sp)"; "move.l (4, sp), -(sp)". default ==> "move.l #$1/4-1, d0"; "1:"; "move.l ($1-4, sp), -(sp)"; "dbf d0, 1b". C_dus $1 == 4 ==> "move.l (sp)+, d0"; "lea (0, sp, d0.l*1), a0"; "asr.l #2, d0"; "beq 2f"; "sub.l #1, d0"; "1:"; "move.l -(a0), -(sp)"; "dbf d0, 1b"; "2:". default ==> arg_error( "dus", $1). C_exg ==> "move.l #$1, d0"; "jsr (.exg)". C_fil.. ==> "move.l #$1+$2, (.filn)". C_gto.. ==> "move.l #$1+$2, a0"; "move.l (8, a0), a6"; "move.l (4, a0), sp"; "jmp ([0,a0], 0)". C_lim ==> "move.l (.trpim), -(sp)". C_lin ==> "move.l #$1, (.lino)". C_lni ==> "add.l #1, (.lino)". C_lor $1 == 0 ==> "move.l a6, -(sp)". $1 == 1 ==> "move.l sp, -(sp)". $1 == 2 ==> "move.l (.reghp), -(sp)". default ==> arg_error( "lor", $1). C_lpb ==> C_adp( (arith)8). C_mon ==> "jsr (.mon)". C_nop ==> "jsr (.nop)". C_rck $1 == 4 ==> "move.l (sp)+, a0"; "move.l (sp)+, d0"; "cmp2.l (a0), d0"; "bcc 1f"; "pea (1)"; /* push constant 1 == ERANGE */ "jsr (.trp)"; "1: move.l d0, -(sp)". default ==> arg_error( "rck", $1). C_rtt ==> C_ret( (arith)0). C_sig ==> "move.l (.trppc), a0"; "move.l (sp)+, (.trppc)"; "move.l a0, -(sp)". C_sim ==> "move.l (sp)+, (.trpim)". C_str $1 == 0 ==> "move.l (sp)+, a6". $1 == 1 ==> "move.l (sp)+, sp". $1 == 2 ==> "jsr (.strhp)". default ==> arg_error( "str", $1). C_trp ==> "jsr (.trp)". /*****************************************************************************/ ..icon $2 == 1 ==> gen1( (ONE_BYTE) atoi( $1)). $2 == 2 ==> gen2( (TWO_BYTES) atoi( $1)). $2 == 4 ==> gen4( (FOUR_BYTES) atol( $1)). default ==> arg_error( "icon", $2). ..ucon $2 == 1 ==> gen1( (ONE_BYTE) atoi( $1)). $2 == 2 ==> gen2( (TWO_BYTES) atoi( $1)). $2 == 4 ==> gen4( (FOUR_BYTES) atol( $1)). default ==> arg_error( "icon", $2). ..fcon ==> con_float($1, $2). /*****************************************************************************/ prolog ==> . jump ==> "jmp $1". locals ==> "link a6, #-$1".