diff options
-rw-r--r-- | sys/lib/libkern/arch/mips/bcmp.S | 14 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/bcopy.S | 22 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/bzero.S | 4 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/ffs.S | 2 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/htonl.S | 4 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/htons.S | 2 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/strcmp.S | 2 | ||||
-rw-r--r-- | sys/lib/libkern/arch/mips/strlen.S | 2 |
8 files changed, 24 insertions, 28 deletions
diff --git a/sys/lib/libkern/arch/mips/bcmp.S b/sys/lib/libkern/arch/mips/bcmp.S index 409c821aeb5..0a18dadd12b 100644 --- a/sys/lib/libkern/arch/mips/bcmp.S +++ b/sys/lib/libkern/arch/mips/bcmp.S @@ -1,11 +1,11 @@ #include "DEFS.h" - .set noreorder /* * bcmp(s1, s2, n) */ LEAF(bcmp) + .set noreorder blt a2, 16, smallcmp # is it worth any trouble? xor v0, a0, a1 # compare low two bits of addresses and v0, v0, 3 @@ -16,9 +16,8 @@ LEAF(bcmp) beq a3, zero, 1f subu a2, a2, a3 # subtract from remaining count move v0, v1 # init v0,v1 so unmodified bytes match -/*XXX FIXME Endian dependent */ - LWLO v0, 0(a0) # read 1, 2, or 3 bytes - LWLO v1, 0(a1) + LWHI v0, 0(a0) # read 1, 2, or 3 bytes + LWHI v1, 0(a1) addu a1, a1, a3 bne v0, v1, nomatch addu a0, a0, a3 @@ -53,9 +52,8 @@ unalignedcmp: subu a2, a2, a3 # which has to be >= (16-3) & ~3 addu a3, a3, a0 # compute ending address 3: -/*XXX FIXME Endian dependent */ - LWLO v0, 0(a0) # compare words a0 unaligned, a1 aligned - LWHI v0, 3(a0) + LWHI v0, 0(a0) # compare words a0 unaligned, a1 aligned + LWLO v0, 3(a0) lw v1, 0(a1) addu a0, a0, 4 bne v0, v1, nomatch @@ -78,5 +76,5 @@ match: move v0, zero nomatch: j ra - li v0, 1 + li v0, 1 END(bcmp) diff --git a/sys/lib/libkern/arch/mips/bcopy.S b/sys/lib/libkern/arch/mips/bcopy.S index 50937442a9e..3936fb8b2ed 100644 --- a/sys/lib/libkern/arch/mips/bcopy.S +++ b/sys/lib/libkern/arch/mips/bcopy.S @@ -1,17 +1,18 @@ #include "DEFS.h" - .set noreorder /* * memcpy(to, from, len) * {ov}bcopy(from, to, len) */ LEAF(memcpy) + .set noreorder move v0, a0 # swap from and to move a0, a1 move a1, v0 ALEAF(bcopy) ALEAF(ovbcopy) + .set noreorder addu t0, a0, a2 # t0 = end of s1 region sltu t1, a1, t0 sltu t2, a0, a1 @@ -40,11 +41,10 @@ forward: beq a3, zero, 1f subu a2, a2, a3 # subtract from remaining count -/*XXX FIXME Endian dependent */ - LWLO v1, 0(a0) # get next 4 bytes (unaligned) - LWHI v1, 3(a0) + LWHI v1, 0(a0) # get next 4 bytes (unaligned) + LWLO v1, 3(a0) addu a0, a0, a3 - SWLO v1, 0(a1) # store 1, 2, or 3 bytes to align a1 + SWHI v1, 0(a1) # store 1, 2, or 3 bytes to align a1 addu a1, a1, a3 1: and v1, a2, 3 # compute number of words left @@ -52,9 +52,8 @@ forward: move a2, v1 addu a3, a3, a0 # compute ending address 2: -/*XXX FIXME Endian dependent */ - LWLO v1, 0(a0) # copy words a0 unaligned, a1 aligned - LWHI v1, 3(a0) + LWHI v1, 0(a0) # copy words a0 unaligned, a1 aligned + LWLO v1, 3(a0) addu a0, a0, 4 sw v1, 0(a1) addu a1, a1, 4 @@ -65,9 +64,9 @@ forward: aligned: beq a3, zero, 1f subu a2, a2, a3 # subtract from remaining count - LWLO v1, 0(a0) # copy 1, 2, or 3 bytes to align + LWHI v1, 0(a0) # copy 1, 2, or 3 bytes to align addu a0, a0, a3 - SWLO v1, 0(a1) + SWHI v1, 0(a1) addu a1, a1, a3 1: and v1, a2, 3 # compute number of whole words left @@ -87,9 +86,8 @@ smallcpy: lbu v1, 0(a0) # copy bytes addu a0, a0, 1 sb v1, 0(a1) - addu a1, a1, 1 bne a0, a3, 1b - nop # MMU BUG ? can't do -1(a1) at 0x80000000!! + addu a1, a1, 1 # MMU BUG ? can't do -1(a1) at 0x80000000!! 2: j ra nop diff --git a/sys/lib/libkern/arch/mips/bzero.S b/sys/lib/libkern/arch/mips/bzero.S index 77b12f6b5b4..4ff16b0a93b 100644 --- a/sys/lib/libkern/arch/mips/bzero.S +++ b/sys/lib/libkern/arch/mips/bzero.S @@ -1,18 +1,18 @@ #include "DEFS.h" - .set noreorder /* * bzero(s1, n) */ LEAF(bzero) ALEAF(blkclr) + .set noreorder blt a1, 12, smallclr # small amount to clear? subu a3, zero, a0 # compute # bytes to word align address and a3, a3, 3 beq a3, zero, 1f # skip if word aligned subu a1, a1, a3 # subtract from remaining count - SWLO zero, 0(a0) # clear 1, 2, or 3 bytes to align + SWHI zero, 0(a0) # clear 1, 2, or 3 bytes to align addu a0, a0, a3 1: and v0, a1, 3 # compute number of words left diff --git a/sys/lib/libkern/arch/mips/ffs.S b/sys/lib/libkern/arch/mips/ffs.S index fdc8c0bd3ee..f84c947105d 100644 --- a/sys/lib/libkern/arch/mips/ffs.S +++ b/sys/lib/libkern/arch/mips/ffs.S @@ -1,11 +1,11 @@ #include "DEFS.h" - .set noreorder /* * bit = ffs(value) */ LEAF(ffs) + .set noreorder beq a0, zero, 2f move v0, zero 1: diff --git a/sys/lib/libkern/arch/mips/htonl.S b/sys/lib/libkern/arch/mips/htonl.S index 24046d252e0..85576cde536 100644 --- a/sys/lib/libkern/arch/mips/htonl.S +++ b/sys/lib/libkern/arch/mips/htonl.S @@ -1,6 +1,5 @@ #include "DEFS.h" - .set noreorder /* * netorder = htonl(hostorder) @@ -8,6 +7,7 @@ */ LEAF(htonl) # a0 = 0x11223344, return 0x44332211 ALEAF(ntohl) + .set noreorder srl v1, a0, 24 # v1 = 0x00000011 sll v0, a0, 24 # v0 = 0x44000000 or v0, v0, v1 @@ -17,5 +17,5 @@ ALEAF(ntohl) srl v1, a0, 8 and v1, v1, 0xff00 # v1 = 0x00002200 j ra - or v0, v0, v1 + or v0, v0, v1 END(htonl) diff --git a/sys/lib/libkern/arch/mips/htons.S b/sys/lib/libkern/arch/mips/htons.S index 2ac256aa271..f425144c094 100644 --- a/sys/lib/libkern/arch/mips/htons.S +++ b/sys/lib/libkern/arch/mips/htons.S @@ -1,6 +1,5 @@ #include "DEFS.h" - .set noreorder /* * netorder = htons(hostorder) @@ -8,6 +7,7 @@ */ LEAF(htons) ALEAF(ntohs) + .set noreorder srl v0, a0, 8 and v0, v0, 0xff sll v1, a0, 8 diff --git a/sys/lib/libkern/arch/mips/strcmp.S b/sys/lib/libkern/arch/mips/strcmp.S index 02b661e11d7..6c6b7a503c5 100644 --- a/sys/lib/libkern/arch/mips/strcmp.S +++ b/sys/lib/libkern/arch/mips/strcmp.S @@ -1,11 +1,11 @@ #include "DEFS.h" - .set noreorder /* * NOTE: this version assumes unsigned chars in order to be "8 bit clean". */ LEAF(strcmp) + .set noreorder 1: lbu t0, 0(a0) # get two bytes and compare them lbu t1, 0(a1) diff --git a/sys/lib/libkern/arch/mips/strlen.S b/sys/lib/libkern/arch/mips/strlen.S index 95d6696429d..4f9288eb537 100644 --- a/sys/lib/libkern/arch/mips/strlen.S +++ b/sys/lib/libkern/arch/mips/strlen.S @@ -1,11 +1,11 @@ #include "DEFS.h" - .set noreorder /* * strlen(str) */ LEAF(strlen) + .set noreorder addu v1, a0, 1 1: lb v0, 0(a0) # get byte from string |