1
0
mirror of https://github.com/golang/go synced 2024-11-19 15:54:46 -07:00
go/src/runtime/memmove_mips64x.s
Yao Zhang 424738e43e runtime: added assembly part of linux/mips64{,le} support
Change-Id: I9e94027ef66c88007107de2b2b75c3d7cf1352af
Reviewed-on: https://go-review.googlesource.com/14467
Reviewed-by: Minux Ma <minux@golang.org>
2015-11-12 04:46:17 +00:00

106 lines
1.7 KiB
ArmAsm

// Copyright 2015 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// +build mips64 mips64le
#include "textflag.h"
// void runtime·memmove(void*, void*, uintptr)
TEXT runtime·memmove(SB), NOSPLIT, $-8-24
MOVV to+0(FP), R1
MOVV from+8(FP), R2
MOVV n+16(FP), R3
BNE R3, check
RET
check:
SGTU R1, R2, R4
BNE R4, backward
ADDV R1, R3, R6 // end pointer
// if the two pointers are not of same alignments, do byte copying
SUBVU R2, R1, R4
AND $7, R4
BNE R4, out
// if less than 8 bytes, do byte copying
SGTU $8, R3, R4
BNE R4, out
// do one byte at a time until 8-aligned
AND $7, R1, R5
BEQ R5, words
MOVB (R2), R4
ADDV $1, R2
MOVB R4, (R1)
ADDV $1, R1
JMP -6(PC)
words:
// do 8 bytes at a time if there is room
ADDV $-7, R6, R3 // R3 is end pointer-7
SGTU R3, R1, R5
BEQ R5, out
MOVV (R2), R4
ADDV $8, R2
MOVV R4, (R1)
ADDV $8, R1
JMP -6(PC)
out:
BEQ R1, R6, done
MOVB (R2), R4
ADDV $1, R2
MOVB R4, (R1)
ADDV $1, R1
JMP -5(PC)
done:
RET
backward:
ADDV R3, R2 // from-end pointer
ADDV R1, R3, R6 // to-end pointer
// if the two pointers are not of same alignments, do byte copying
SUBVU R6, R2, R4
AND $7, R4
BNE R4, out1
// if less than 8 bytes, do byte copying
SGTU $8, R3, R4
BNE R4, out1
// do one byte at a time until 8-aligned
AND $7, R6, R5
BEQ R5, words1
ADDV $-1, R2
MOVB (R2), R4
ADDV $-1, R6
MOVB R4, (R6)
JMP -6(PC)
words1:
// do 8 bytes at a time if there is room
ADDV $7, R1, R3 // R3 is start pointer+7
SGTU R6, R3, R5
BEQ R5, out1
ADDV $-8, R2
MOVV (R2), R4
ADDV $-8, R6
MOVV R4, (R6)
JMP -6(PC)
out1:
BEQ R1, R6, done1
ADDV $-1, R2
MOVB (R2), R4
ADDV $-1, R6
MOVB R4, (R6)
JMP -5(PC)
done1:
RET