Login

Subversion Repositories NedoOS

Rev

Blame | Last modification | View Log | Download | RSS feed

    OPT push reset --syntax=abfw

    MACRO negR16toR16 fromR16?, toR16?
        ; 6B 24T, uses A
        xor     a
        sub     low fromR16?
        ld      low toR16?,a    ; low = 0 - low
        sbc     a,a
        sub     high fromR16?
        ld      high toR16?,a   ; high = 0 - high - borrow
    ENDM

    MACRO negR16 r16?
        ; 6B 24T, uses A
        negR16toR16 r16?, r16?
    ENDM

    MACRO negHLuseDE            ; 6B 38T
        ; HL = -HL, DE = HL (preserves A)
        ex  de,hl
        or  a
        sbc hl,hl               ; HL = 0
        sbc hl,de               ; HL = 0 - HL
    ENDM

    MACRO negDEuseHL            ; 6B 38T
        ; DE = -DE, HL = DE (preserves A)
        or  a
        sbc hl,hl
        sbc hl,de
        ex  de,hl
    ENDM

    MACRO alignHl alignValue?
        ASSERT 2 <= (alignValue?)
        ASSERT 0 == ((alignValue?) & ((alignValue?)-1)) ; make sure it's power of two
        push    af
        IF (alignValue?) == 256
            xor     a
            cp      l           ; Fc=1 when 0 < L
            ld      l,a         ; L = 0
            adc     a,h
            ld      h,a
                ; 20T 5B
        ELSE : IF (alignValue?) == 2
            inc     hl
            res     0,l
                ; 14T 3B
        ELSE : IF (alignValue?) < 256
            ld      a,(alignValue?)-1
            IFNDEF SJ_LIBRARY_USE_Z80N
                add     a,l
                rra             ; preserve carry flag for increment of H
                and     -((alignValue?)>>1)     ; clear bottom bits, Fc=0
                rla             ; restore add-carry and fix position of L bits
                ld      l,a
                adc     a,h     ; A = L + H + add-carry
                sub     l       ; A = H + add-carry (new H)
                ld      h,a
                    ; 42T 11B
            ELSE
                add     hl,a    ; add align-1 to HL
                cpl             ; bits to keep in L (and clear bottom bits)
                and     l
                ld      l,a
                    ; 27T 7B
            ENDIF
        ELSE : ASSERT 256 < (alignValue?)
            xor     a
            cp      l
            ld      l,a
            adc     a,h     ; if 0 < L, then ++H here in every case
            add     a,((alignValue?)-1)>>8
            and     -((alignValue?)>>8)
            ld      h,a
                ; 34T 9B
        ENDIF : ENDIF : ENDIF
        pop     af
    ENDM

    OPT pop