1*2fe8fb19SBen Gras/* $NetBSD: bcmp.S,v 1.9 2009/12/14 01:07:42 matt Exp $ */ 2*2fe8fb19SBen Gras 3*2fe8fb19SBen Gras/*- 4*2fe8fb19SBen Gras * Copyright (c) 1991, 1993 5*2fe8fb19SBen Gras * The Regents of the University of California. All rights reserved. 6*2fe8fb19SBen Gras * 7*2fe8fb19SBen Gras * This code is derived from software contributed to Berkeley by 8*2fe8fb19SBen Gras * Ralph Campbell. 9*2fe8fb19SBen Gras * 10*2fe8fb19SBen Gras * Redistribution and use in source and binary forms, with or without 11*2fe8fb19SBen Gras * modification, are permitted provided that the following conditions 12*2fe8fb19SBen Gras * are met: 13*2fe8fb19SBen Gras * 1. Redistributions of source code must retain the above copyright 14*2fe8fb19SBen Gras * notice, this list of conditions and the following disclaimer. 15*2fe8fb19SBen Gras * 2. Redistributions in binary form must reproduce the above copyright 16*2fe8fb19SBen Gras * notice, this list of conditions and the following disclaimer in the 17*2fe8fb19SBen Gras * documentation and/or other materials provided with the distribution. 18*2fe8fb19SBen Gras * 3. Neither the name of the University nor the names of its contributors 19*2fe8fb19SBen Gras * may be used to endorse or promote products derived from this software 20*2fe8fb19SBen Gras * without specific prior written permission. 21*2fe8fb19SBen Gras * 22*2fe8fb19SBen Gras * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 23*2fe8fb19SBen Gras * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24*2fe8fb19SBen Gras * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25*2fe8fb19SBen Gras * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 26*2fe8fb19SBen Gras * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27*2fe8fb19SBen Gras * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28*2fe8fb19SBen Gras * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29*2fe8fb19SBen Gras * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30*2fe8fb19SBen Gras * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31*2fe8fb19SBen Gras * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32*2fe8fb19SBen Gras * SUCH DAMAGE. 33*2fe8fb19SBen Gras */ 34*2fe8fb19SBen Gras 35*2fe8fb19SBen Gras#include <mips/asm.h> 36*2fe8fb19SBen Gras#define _LOCORE /* XXX not really, just assembly-code source */ 37*2fe8fb19SBen Gras#include <machine/endian.h> /* LWLO/LWHI, SWLO/SWHI */ 38*2fe8fb19SBen Gras 39*2fe8fb19SBen Gras#if defined(LIBC_SCCS) && !defined(lint) 40*2fe8fb19SBen Gras#if 0 41*2fe8fb19SBen Gras RCSID("from: @(#)bcmp.s 8.1 (Berkeley) 6/4/93") 42*2fe8fb19SBen Gras#else 43*2fe8fb19SBen Gras RCSID("$NetBSD: bcmp.S,v 1.9 2009/12/14 01:07:42 matt Exp $") 44*2fe8fb19SBen Gras#endif 45*2fe8fb19SBen Gras#endif /* LIBC_SCCS and not lint */ 46*2fe8fb19SBen Gras 47*2fe8fb19SBen Gras/* bcmp(s1, s2, n) */ 48*2fe8fb19SBen Gras 49*2fe8fb19SBen Gras 50*2fe8fb19SBen GrasLEAF(bcmp) 51*2fe8fb19SBen Gras .set noreorder 52*2fe8fb19SBen Gras blt a2, 16, small # is it worth any trouble? 53*2fe8fb19SBen Gras xor v0, a0, a1 # compare low two bits of addresses 54*2fe8fb19SBen Gras and v0, v0, 3 55*2fe8fb19SBen Gras PTR_SUBU a3, zero, a1 # compute # bytes to word align address 56*2fe8fb19SBen Gras bne v0, zero, unaligned # not possible to align addresses 57*2fe8fb19SBen Gras and a3, a3, 3 58*2fe8fb19SBen Gras 59*2fe8fb19SBen Gras beq a3, zero, 1f 60*2fe8fb19SBen Gras PTR_SUBU a2, a2, a3 # subtract from remaining count 61*2fe8fb19SBen Gras move v0, v1 # init v0,v1 so unmodified bytes match 62*2fe8fb19SBen Gras LWHI v0, 0(a0) # read 1, 2, or 3 bytes 63*2fe8fb19SBen Gras LWHI v1, 0(a1) 64*2fe8fb19SBen Gras PTR_ADDU a1, a1, a3 65*2fe8fb19SBen Gras bne v0, v1, nomatch 66*2fe8fb19SBen Gras PTR_ADDU a0, a0, a3 67*2fe8fb19SBen Gras1: 68*2fe8fb19SBen Gras and a3, a2, ~3 # compute number of whole words left 69*2fe8fb19SBen Gras PTR_SUBU a2, a2, a3 # which has to be >= (16-3) & ~3 70*2fe8fb19SBen Gras PTR_ADDU a3, a3, a0 # compute ending address 71*2fe8fb19SBen Gras2: 72*2fe8fb19SBen Gras lw v0, 0(a0) # compare words 73*2fe8fb19SBen Gras lw v1, 0(a1) 74*2fe8fb19SBen Gras PTR_ADDU a0, a0, 4 75*2fe8fb19SBen Gras bne v0, v1, nomatch 76*2fe8fb19SBen Gras PTR_ADDU a1, a1, 4 77*2fe8fb19SBen Gras bne a0, a3, 2b 78*2fe8fb19SBen Gras nop 79*2fe8fb19SBen Gras b small # finish remainder 80*2fe8fb19SBen Gras nop 81*2fe8fb19SBen Grasunaligned: 82*2fe8fb19SBen Gras beq a3, zero, 2f 83*2fe8fb19SBen Gras PTR_SUBU a2, a2, a3 # subtract from remaining count 84*2fe8fb19SBen Gras PTR_ADDU a3, a3, a0 # compute ending address 85*2fe8fb19SBen Gras1: 86*2fe8fb19SBen Gras lbu v0, 0(a0) # compare bytes until a1 word aligned 87*2fe8fb19SBen Gras lbu v1, 0(a1) 88*2fe8fb19SBen Gras PTR_ADDU a0, a0, 1 89*2fe8fb19SBen Gras bne v0, v1, nomatch 90*2fe8fb19SBen Gras PTR_ADDU a1, a1, 1 91*2fe8fb19SBen Gras bne a0, a3, 1b 92*2fe8fb19SBen Gras nop 93*2fe8fb19SBen Gras2: 94*2fe8fb19SBen Gras and a3, a2, ~3 # compute number of whole words left 95*2fe8fb19SBen Gras PTR_SUBU a2, a2, a3 # which has to be >= (16-3) & ~3 96*2fe8fb19SBen Gras PTR_ADDU a3, a3, a0 # compute ending address 97*2fe8fb19SBen Gras3: 98*2fe8fb19SBen Gras LWHI v0, 0(a0) # compare words a0 unaligned, a1 aligned 99*2fe8fb19SBen Gras LWLO v0, 3(a0) 100*2fe8fb19SBen Gras lw v1, 0(a1) 101*2fe8fb19SBen Gras PTR_ADDU a0, a0, 4 102*2fe8fb19SBen Gras bne v0, v1, nomatch 103*2fe8fb19SBen Gras PTR_ADDU a1, a1, 4 104*2fe8fb19SBen Gras bne a0, a3, 3b 105*2fe8fb19SBen Gras nop 106*2fe8fb19SBen Grassmall: 107*2fe8fb19SBen Gras ble a2, zero, match 108*2fe8fb19SBen Gras PTR_ADDU a3, a2, a0 # compute ending address 109*2fe8fb19SBen Gras1: 110*2fe8fb19SBen Gras lbu v0, 0(a0) 111*2fe8fb19SBen Gras lbu v1, 0(a1) 112*2fe8fb19SBen Gras PTR_ADDU a0, a0, 1 113*2fe8fb19SBen Gras bne v0, v1, nomatch 114*2fe8fb19SBen Gras PTR_ADDU a1, a1, 1 115*2fe8fb19SBen Gras bne a0, a3, 1b 116*2fe8fb19SBen Gras nop 117*2fe8fb19SBen Grasmatch: 118*2fe8fb19SBen Gras j ra 119*2fe8fb19SBen Gras move v0, zero 120*2fe8fb19SBen Grasnomatch: 121*2fe8fb19SBen Gras j ra 122*2fe8fb19SBen Gras li v0, 1 123*2fe8fb19SBen Gras .set reorder 124*2fe8fb19SBen GrasEND(bcmp) 125