|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | #include <linux/linkage.h> | 
|  | #include <asm/export.h> | 
|  |  | 
|  | .register	%g2,#scratch | 
|  |  | 
|  | .text | 
|  | .align	32 | 
|  |  | 
|  | ENTRY(ffs) | 
|  | brnz,pt	%o0, 1f | 
|  | mov	1, %o1 | 
|  | retl | 
|  | clr	%o0 | 
|  | nop | 
|  | nop | 
|  | ENTRY(__ffs) | 
|  | sllx	%o0, 32, %g1		/* 1  */ | 
|  | srlx	%o0, 32, %g2 | 
|  |  | 
|  | clr	%o1			/* 2  */ | 
|  | movrz	%g1, %g2, %o0 | 
|  |  | 
|  | movrz	%g1, 32, %o1		/* 3  */ | 
|  | 1:	clr	%o2 | 
|  |  | 
|  | sllx	%o0, (64 - 16), %g1	/* 4  */ | 
|  | srlx	%o0, 16, %g2 | 
|  |  | 
|  | movrz	%g1, %g2, %o0		/* 5  */ | 
|  | clr	%o3 | 
|  |  | 
|  | movrz	%g1, 16, %o2		/* 6  */ | 
|  | clr	%o4 | 
|  |  | 
|  | and	%o0, 0xff, %g1		/* 7  */ | 
|  | srlx	%o0, 8, %g2 | 
|  |  | 
|  | movrz	%g1, %g2, %o0		/* 8  */ | 
|  | clr	%o5 | 
|  |  | 
|  | movrz	%g1, 8, %o3		/* 9  */ | 
|  | add	%o2, %o1, %o2 | 
|  |  | 
|  | and	%o0, 0xf, %g1		/* 10 */ | 
|  | srlx	%o0, 4, %g2 | 
|  |  | 
|  | movrz	%g1, %g2, %o0		/* 11 */ | 
|  | add	%o2, %o3, %o2 | 
|  |  | 
|  | movrz	%g1, 4, %o4		/* 12 */ | 
|  |  | 
|  | and	%o0, 0x3, %g1		/* 13 */ | 
|  | srlx	%o0, 2, %g2 | 
|  |  | 
|  | movrz	%g1, %g2, %o0		/* 14 */ | 
|  | add	%o2, %o4, %o2 | 
|  |  | 
|  | movrz	%g1, 2, %o5		/* 15 */ | 
|  |  | 
|  | and	%o0, 0x1, %g1		/* 16 */ | 
|  |  | 
|  | add	%o2, %o5, %o2		/* 17 */ | 
|  | xor	%g1, 0x1, %g1 | 
|  |  | 
|  | retl				/* 18 */ | 
|  | add	%o2, %g1, %o0 | 
|  | ENDPROC(ffs) | 
|  | ENDPROC(__ffs) | 
|  | EXPORT_SYMBOL(__ffs) | 
|  | EXPORT_SYMBOL(ffs) | 
|  |  | 
|  | .section	.popc_6insn_patch, "ax" | 
|  | .word		ffs | 
|  | brz,pn	%o0, 98f | 
|  | neg	%o0, %g1 | 
|  | xnor	%o0, %g1, %o1 | 
|  | popc	%o1, %o0 | 
|  | 98:	retl | 
|  | nop | 
|  | .word		__ffs | 
|  | neg	%o0, %g1 | 
|  | xnor	%o0, %g1, %o1 | 
|  | popc	%o1, %o0 | 
|  | retl | 
|  | sub	%o0, 1, %o0 | 
|  | nop | 
|  | .previous |