1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
// 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.
//go:build mips64 || mips64le
#include "textflag.h"
// See memmove Go doc for important implementation constraints.
// func memmove(to, from unsafe.Pointer, n uintptr)
TEXT runtime·memmove(SB), NOSPLIT|NOFRAME, $0-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
|