shithub: riscv

ref: 6184a4ef2eba1d49f0386e9ce94f4877d3d9edb2
dir: /sys/src/libc/amd64/strchr.s/

View raw version
	TEXT	strchr(SB), $0

	MOVQ	RARG, DI
	MOVB	c+8(FP), AX
	CMPB	AX, $0
	JEQ	l2	/**/

/*
 * char is not null
 */
l1:
	MOVB	(DI), BX
	CMPB	BX, $0
	JEQ	ret0
	ADDQ	$1, DI
	CMPB	AX, BX
	JNE	l1

	MOVQ	DI, AX
	SUBQ	$1, AX
	RET

/*
 * char is null
 */
l2:
	MOVQ	$-1, CX
	CLD

	REPN;	SCASB

	MOVQ	DI, AX
	SUBQ	$1, AX
	RET

ret0:
	MOVQ	$0, AX
	RET