Annotation of MiNT/src/asm/quickmov.s, revision 1.1

1.1     ! root        1: ;
        !             2: 
        !             3: ; quickmove(char *dst, char *src, long nbytes):
        !             4: 
        !             5: ; quickly copy "nbytes" bytes from src to dst. Assumes that both
        !             6: 
        !             7: ; src and dst are word aligned.
        !             8: 
        !             9: ;
        !            10: 
        !            11:        SECTION TEXT
        !            12: 
        !            13: 
        !            14: 
        !            15:        XDEF    _quickmove
        !            16: 
        !            17: 
        !            18: 
        !            19: _quickmove:
        !            20: 
        !            21:        move.l  4(sp),a0                ; get dst
        !            22: 
        !            23:        move.l  8(sp),a1                ; get src
        !            24: 
        !            25:        move.l  12(sp),d0               ; get nbytes
        !            26: 
        !            27:        lsr.l   #8,d0                   ; 
        !            28: 
        !            29:        lsr.l   #1,d0                   ; d0 = nbytes / 512
        !            30: 
        !            31:        subq.l  #1,d0                   ; prepare for dbra loop
        !            32: 
        !            33:        bmi     Leftover                ; if < 0, skip
        !            34: 
        !            35:        movem.l d1-d7/a2-a6,-(sp)       ; save regs
        !            36: 
        !            37: L1:
        !            38: 
        !            39:        movem.l (a1)+,d1-d7/a2-a6       ; read 12*4 = 48 bytes
        !            40: 
        !            41:        movem.l d1-d7/a2-a6,(a0)        ;
        !            42: 
        !            43:        movem.l (a1)+,d1-d7/a2-a6       ; 2nd read
        !            44: 
        !            45:        movem.l d1-d7/a2-a6,48(a0)      ;
        !            46: 
        !            47:        movem.l (a1)+,d1-d7/a2-a6       ; 3rd read
        !            48: 
        !            49:        movem.l d1-d7/a2-a6,96(a0)      ;
        !            50: 
        !            51:        movem.l (a1)+,d1-d7/a2-a6       ; 4th read
        !            52: 
        !            53:        movem.l d1-d7/a2-a6,144(a0)     ;
        !            54: 
        !            55:        movem.l (a1)+,d1-d7/a2-a6       ; 5th
        !            56: 
        !            57:        movem.l d1-d7/a2-a6,192(a0)     ;
        !            58: 
        !            59:        movem.l (a1)+,d1-d7/a2-a6       ; 6th
        !            60: 
        !            61:        movem.l d1-d7/a2-a6,240(a0)     ;
        !            62: 
        !            63:        movem.l (a1)+,d1-d7/a2-a6       ; 7th
        !            64: 
        !            65:        movem.l d1-d7/a2-a6,288(a0)     ;
        !            66: 
        !            67:        movem.l (a1)+,d1-d7/a2-a6       ; 8th
        !            68: 
        !            69:        movem.l d1-d7/a2-a6,336(a0)     ;
        !            70: 
        !            71:        movem.l (a1)+,d1-d7/a2-a6       ; 9th
        !            72: 
        !            73:        movem.l d1-d7/a2-a6,384(a0)     ;
        !            74: 
        !            75:        movem.l (a1)+,d1-d7/a2-a6       ; 10th
        !            76: 
        !            77:        movem.l d1-d7/a2-a6,432(a0)     ; At this point, 480 bytes done
        !            78: 
        !            79:        movem.l (a1)+,d1-d7/a2          ; Only do 32 more bytes
        !            80: 
        !            81:        movem.l d1-d7/a2,480(a0)        ; for a total of 512
        !            82: 
        !            83: 
        !            84: 
        !            85:        lea     512(a0),a0
        !            86: 
        !            87:        subq.l  #1,d0
        !            88: 
        !            89:        bge.s   L1
        !            90: 
        !            91: 
        !            92: 
        !            93:        movem.l (sp)+,d1-d7/a2-a6       ; pop registers
        !            94: 
        !            95: 
        !            96: 
        !            97: Leftover:                              ; do the remaining bytes
        !            98: 
        !            99:        move.l  12(sp),d1
        !           100: 
        !           101:        and.l   #$01ff,d1               ; d1 = nbytes % 512
        !           102: 
        !           103:        subq.l  #1,d1                   ; prepare for dbra loop
        !           104: 
        !           105:        bmi.s   Ldone
        !           106: 
        !           107: L2:
        !           108: 
        !           109:        move.b  (a1)+,(a0)+
        !           110: 
        !           111:        dbra    d1,L2
        !           112: 
        !           113: Ldone:
        !           114: 
        !           115:        rts                             ; return
        !           116: 
        !           117:        END
        !           118: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.