github.com/SandwichDev/go-internals@v0.0.0-20210605002614-12311ac6b2c5/bytealg/indexbyte_mipsx.s (about)

     1  // Copyright 2018 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  // +build mips mipsle
     6  
     7  #include "go_asm.h"
     8  #include "textflag.h"
     9  
    10  TEXT ·IndexByte(SB),NOSPLIT,$0-20
    11  	MOVW	b_base+0(FP), R1
    12  	MOVW	b_len+4(FP), R2
    13  	MOVBU	c+12(FP), R3	// byte to find
    14  	ADDU	$1, R1, R4	// store base+1 for later
    15  	ADDU	R1, R2	// end
    16  
    17  loop:
    18  	BEQ	R1, R2, notfound
    19  	MOVBU	(R1), R5
    20  	ADDU	$1, R1
    21  	BNE	R3, R5, loop
    22  
    23  	SUBU	R4, R1	// R1 will be one beyond the position we want so remove (base+1)
    24  	MOVW	R1, ret+16(FP)
    25  	RET
    26  
    27  notfound:
    28  	MOVW	$-1, R1
    29  	MOVW	R1, ret+16(FP)
    30  	RET
    31  
    32  TEXT ·IndexByteString(SB),NOSPLIT,$0-16
    33  	MOVW	s_base+0(FP), R1
    34  	MOVW	s_len+4(FP), R2
    35  	MOVBU	c+8(FP), R3	// byte to find
    36  	ADDU	$1, R1, R4	// store base+1 for later
    37  	ADDU	R1, R2	// end
    38  
    39  loop:
    40  	BEQ	R1, R2, notfound
    41  	MOVBU	(R1), R5
    42  	ADDU	$1, R1
    43  	BNE	R3, R5, loop
    44  
    45  	SUBU	R4, R1	// remove (base+1)
    46  	MOVW	R1, ret+12(FP)
    47  	RET
    48  
    49  notfound:
    50  	MOVW	$-1, R1
    51  	MOVW	R1, ret+12(FP)
    52  	RET