summaryrefslogtreecommitdiffstats
path: root/src/internal/bytealg/equal_loong64.s
diff options
context:
space:
mode:
Diffstat (limited to 'src/internal/bytealg/equal_loong64.s')
-rw-r--r--src/internal/bytealg/equal_loong64.s68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/internal/bytealg/equal_loong64.s b/src/internal/bytealg/equal_loong64.s
new file mode 100644
index 0000000..a3ad5c1
--- /dev/null
+++ b/src/internal/bytealg/equal_loong64.s
@@ -0,0 +1,68 @@
+// Copyright 2022 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.
+
+#include "go_asm.h"
+#include "textflag.h"
+
+#define REGCTXT R29
+
+// memequal(a, b unsafe.Pointer, size uintptr) bool
+TEXT runtime·memequal<ABIInternal>(SB),NOSPLIT|NOFRAME,$0-25
+#ifndef GOEXPERIMENT_regabiargs
+ MOVV a+0(FP), R4
+ MOVV b+8(FP), R5
+ MOVV size+16(FP), R6
+#endif
+ BEQ R4, R5, eq
+ ADDV R4, R6, R7
+ PCALIGN $16
+loop:
+ BNE R4, R7, test
+ MOVV $1, R4
+#ifndef GOEXPERIMENT_regabiargs
+ MOVB R4, ret+24(FP)
+#endif
+ RET
+test:
+ MOVBU (R4), R9
+ ADDV $1, R4
+ MOVBU (R5), R10
+ ADDV $1, R5
+ BEQ R9, R10, loop
+
+ MOVB R0, R4
+#ifndef GOEXPERIMENT_regabiargs
+ MOVB R0, ret+24(FP)
+#endif
+ RET
+eq:
+ MOVV $1, R4
+#ifndef GOEXPERIMENT_regabiargs
+ MOVB R4, ret+24(FP)
+#endif
+ RET
+
+// memequal_varlen(a, b unsafe.Pointer) bool
+TEXT runtime·memequal_varlen<ABIInternal>(SB),NOSPLIT,$40-17
+#ifndef GOEXPERIMENT_regabiargs
+ MOVV a+0(FP), R4
+ MOVV b+8(FP), R5
+#endif
+ BEQ R4, R5, eq
+ MOVV 8(REGCTXT), R6 // compiler stores size at offset 8 in the closure
+ MOVV R4, 8(R3)
+ MOVV R5, 16(R3)
+ MOVV R6, 24(R3)
+ JAL runtime·memequal(SB)
+ MOVBU 32(R3), R4
+#ifndef GOEXPERIMENT_regabiargs
+ MOVB R4, ret+16(FP)
+#endif
+ RET
+eq:
+ MOVV $1, R4
+#ifndef GOEXPERIMENT_regabiargs
+ MOVB R4, ret+16(FP)
+#endif
+ RET