[BACK]Return to memcmp.S CVS log [TXT][DIR] Up to [local] / sys / lib / libkern / arch / amd64

Annotation of sys/lib/libkern/arch/amd64/memcmp.S, Revision 1.1

1.1     ! nbrk        1: /*
        !             2:  * Written by J.T. Conklin <jtc@netbsd.org>.
        !             3:  * Public domain.
        !             4:  * Adapted for NetBSD/x86_64 by Frank van der Linden <fvdl@wasabisystems.com>
        !             5:  */
        !             6:
        !             7: #include <machine/asm.h>
        !             8:
        !             9: #if defined(LIBC_SCCS)
        !            10:        RCSID("$NetBSD: memcmp.S,v 1.1 2001/06/19 00:22:46 fvdl Exp $")
        !            11: #endif
        !            12:
        !            13: ENTRY(memcmp)
        !            14:        cld                             /* set compare direction forward */
        !            15:        movq    %rdx,%rcx               /* compare by longs */
        !            16:        shrq    $3,%rcx
        !            17:        repe
        !            18:        cmpsq
        !            19:        jne     L5                      /* do we match so far? */
        !            20:
        !            21:        movq    %rdx,%rcx               /* compare remainder by bytes */
        !            22:        andq    $7,%rcx
        !            23:        repe
        !            24:        cmpsb
        !            25:        jne     L6                      /* do we match? */
        !            26:
        !            27:        xorl    %eax,%eax               /* we match, return zero        */
        !            28:        ret
        !            29:
        !            30: L5:    movl    $8,%ecx                 /* We know that one of the next */
        !            31:        subq    %rcx,%rdi               /* eight pairs of bytes do not  */
        !            32:        subq    %rcx,%rsi               /* match.                       */
        !            33:        repe
        !            34:        cmpsb
        !            35: L6:    xorl    %eax,%eax               /* Perform unsigned comparison  */
        !            36:        movb    -1(%rdi),%al
        !            37:        xorl    %edx,%edx
        !            38:        movb    -1(%rsi),%dl
        !            39:        subl    %edx,%eax
        !            40:        ret

CVSweb