From: Tobias Klauser Date: Sun, 17 Mar 2019 21:39:42 +0000 (+0100) Subject: internal/bytealg: share code for IndexByte functions on arm X-Git-Tag: go1.13beta1~1006 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=3496ff1d1905fca857e009584f4c9a15481739d6;p=gostls13.git internal/bytealg: share code for IndexByte functions on arm Move the shared code of IndexByte and IndexByteString into indexbytebody. This will allow to implement optimizations (e.g. for #29001) in a single function. Change-Id: I1d550da8eb65f95e492a460a12058cc35b1162b6 Reviewed-on: https://go-review.googlesource.com/c/go/+/167939 Run-TryBot: Tobias Klauser TryBot-Result: Gobot Gobot Reviewed-by: Brad Fitzpatrick --- diff --git a/src/internal/bytealg/indexbyte_arm.s b/src/internal/bytealg/indexbyte_arm.s index 7d9bbb183d..faf97977a6 100644 --- a/src/internal/bytealg/indexbyte_arm.s +++ b/src/internal/bytealg/indexbyte_arm.s @@ -9,46 +9,38 @@ TEXT ·IndexByte(SB),NOSPLIT,$0-20 MOVW b_base+0(FP), R0 MOVW b_len+4(FP), R1 MOVBU c+12(FP), R2 // byte to find - MOVW R0, R4 // store base for later - ADD R0, R1 // end - -_loop: - CMP R0, R1 - B.EQ _notfound - MOVBU.P 1(R0), R3 - CMP R2, R3 - B.NE _loop - - SUB $1, R0 // R0 will be one beyond the position we want - SUB R4, R0 // remove base - MOVW R0, ret+16(FP) - RET - -_notfound: - MOVW $-1, R0 - MOVW R0, ret+16(FP) - RET + MOVW $ret+16(FP), R5 + B indexbytebody<>(SB) TEXT ·IndexByteString(SB),NOSPLIT,$0-16 MOVW s_base+0(FP), R0 MOVW s_len+4(FP), R1 MOVBU c+8(FP), R2 // byte to find + MOVW $ret+12(FP), R5 + B indexbytebody<>(SB) + +// input: +// R0: data +// R1: data length +// R2: byte to find +// R5: address to put result +TEXT indexbytebody<>(SB),NOSPLIT,$0-0 MOVW R0, R4 // store base for later ADD R0, R1 // end -_sib_loop: +loop: CMP R0, R1 - B.EQ _sib_notfound + B.EQ notfound MOVBU.P 1(R0), R3 CMP R2, R3 - B.NE _sib_loop + B.NE loop SUB $1, R0 // R0 will be one beyond the position we want SUB R4, R0 // remove base - MOVW R0, ret+12(FP) + MOVW R0, (R5) RET -_sib_notfound: +notfound: MOVW $-1, R0 - MOVW R0, ret+12(FP) + MOVW R0, (R5) RET