ref: ced38bc6ee1cacf6aea23d114ca45d4a48fbb5a5
dir: /test/link/all-instructions.asm/
SECTION "All instructions", ROM0[0]
    ; 8-bit Arithmetic and Logic Instructions
alu_instruction_list : MACRO
    \1 a,a
    \1 a,b
    \1 a,c
    \1 a,d
    \1 a,$DB
    \1 a,e
    \1 a,h
    \1 a,[hl]
    \1 a,l
ENDM
    alu_instruction_list adc
    alu_instruction_list add
    alu_instruction_list and
    alu_instruction_list cp
    alu_instruction_list or
    alu_instruction_list sbc
    alu_instruction_list sub
    alu_instruction_list xor
incdec_8bit_instruction_list : MACRO
    \1 a
    \1 b
    \1 c
    \1 d
    \1 e
    \1 h
    \1 [hl]
    \1 l
ENDM
    incdec_8bit_instruction_list inc
    incdec_8bit_instruction_list dec
    ; 16-bit Arithmetic Instructions
    add hl,bc
    add hl,de
    add hl,hl
    add hl,sp
    inc bc
    inc de
    inc hl
    inc sp
    dec bc
    dec de
    dec hl
    dec sp
    ; Bit Operations Instructions
bitop_u3_instruction_list : MACRO
NBIT SET 0
    REPT 8
        \1 NBIT,a
        \1 NBIT,b
        \1 NBIT,c
        \1 NBIT,d
        \1 NBIT,e
        \1 NBIT,h
        \1 NBIT,[hl]
        \1 NBIT,l
NBIT SET NBIT + 1
    ENDR
ENDM
    bitop_u3_instruction_list bit
    bitop_u3_instruction_list res
    bitop_u3_instruction_list set
bitop_noarg_instruction_list : MACRO
    \1 a
    \1 b
    \1 c
    \1 d
    \1 e
    \1 h
    \1 [hl]
    \1 l
ENDM
    bitop_noarg_instruction_list swap
    ; Bit Shift Instructions
    rla
    rlca
    rra
    rrca
    bitop_noarg_instruction_list rl
    bitop_noarg_instruction_list rlc
    bitop_noarg_instruction_list rr
    bitop_noarg_instruction_list rrc
    bitop_noarg_instruction_list sla
    bitop_noarg_instruction_list sra
    bitop_noarg_instruction_list srl
    ; Load Instructions
ld_r8_x_instruction_list : MACRO
    ld \1,a
    ld \1,b
    ld \1,c
    ld \1,d
    ld \1,$DB
    ld \1,e
    ld \1,h
    ld \1,l
ENDM
    ld_r8_x_instruction_list a
    ld_r8_x_instruction_list b
    ld_r8_x_instruction_list c
    ld_r8_x_instruction_list d
    ld_r8_x_instruction_list e
    ld_r8_x_instruction_list h
    ld_r8_x_instruction_list [hl]
    ld_r8_x_instruction_list l
ld_x_r8_instruction_list : MACRO
    ld a,\1
    ld b,\1
    ld c,\1
    ld d,\1
    ld e,\1
    ld h,\1
    ld l,\1
ENDM
    ld_x_r8_instruction_list a
    ld_x_r8_instruction_list b
    ld_x_r8_instruction_list c
    ld_x_r8_instruction_list d
    ld_x_r8_instruction_list e
    ld_x_r8_instruction_list h
    ld_x_r8_instruction_list [hl]
    ld_x_r8_instruction_list l
    ld  bc,$ABCD
    ld  de,$ABCD
    ld  hl,$ABCD
    ld  sp,$ABCD
    ld  [bc],a
    ld  [de],a
    ld  [hl],a
    ld  [$ABCD],a
    ldh [$ff00+$DB],a
    ld  [$ff00+c],a
    ld  a,[bc]
    ld  a,[de]
    ld  a,[hl]
    ld  a,[$ABCD]
    ldh a,[$ff00+$DB]
    ld  a,[$ff00+c]
    ld  [hl+],a
    ld  [hl-],a
    ld  a,[hl+]
    ld  a,[hl-]
    ; Jumps and Subroutines
    call $ABCD
    call z,$ABCD
    call nz,$ABCD
    call c,$ABCD
    call nc,$ABCD
    jp hl
    jp $ABCD
    jp z,$ABCD
    jp nz,$ABCD
    jp c,$ABCD
    jp nc,$ABCD
jrlabel:
    jr jrlabel
    jr z,jrlabel
    jr nz,jrlabel
    jr c,jrlabel
    jr nc,jrlabel
    ret
    ret z
    ret nz
    ret c
    ret nc
    reti
    rst $00
    rst $08
    rst $10
    rst $18
    rst $20
    rst $28
    rst $30
    rst $38
    ; Stack Operations Instructions
    add sp,$DB
    ld  [$ABCD],sp
    ld  hl,sp+$DB
    ld  sp,hl
    pop af
    pop bc
    pop de
    pop hl
    push af
    push bc
    push de
    push hl
    ; Miscellaneous Instructions
    ccf
    cpl
    daa
    di
    ei
    halt
    nop
    scf
    stop
BYTE = 0
REPT 256
    stop BYTE
BYTE = BYTE + 1
ENDR