|  | /* fls.S: SPARC default fls definition. | 
|  | * | 
|  | * SPARC default fls definition, which follows the same algorithm as | 
|  | * in generic fls(). This function will be boot time patched on T4 | 
|  | * and onward. | 
|  | */ | 
|  |  | 
|  | #include <linux/export.h> | 
|  | #include <linux/linkage.h> | 
|  |  | 
|  | .text | 
|  | .register	%g2, #scratch | 
|  | .register	%g3, #scratch | 
|  | ENTRY(fls) | 
|  | brz,pn	%o0, 6f | 
|  | mov	0, %o1 | 
|  | sethi	%hi(0xffff0000), %g3 | 
|  | mov	%o0, %g2 | 
|  | andcc	%o0, %g3, %g0 | 
|  | be,pt	%icc, 8f | 
|  | mov	32, %o1 | 
|  | sethi	%hi(0xff000000), %g3 | 
|  | andcc	%g2, %g3, %g0 | 
|  | bne,pt	%icc, 3f | 
|  | sethi	%hi(0xf0000000), %g3 | 
|  | sll	%o0, 8, %o0 | 
|  | 1: | 
|  | add	%o1, -8, %o1 | 
|  | sra	%o0, 0, %o0 | 
|  | mov	%o0, %g2 | 
|  | 2: | 
|  | sethi	%hi(0xf0000000), %g3 | 
|  | 3: | 
|  | andcc	%g2, %g3, %g0 | 
|  | bne,pt	%icc, 4f | 
|  | sethi	%hi(0xc0000000), %g3 | 
|  | sll	%o0, 4, %o0 | 
|  | add	%o1, -4, %o1 | 
|  | sra	%o0, 0, %o0 | 
|  | mov	%o0, %g2 | 
|  | 4: | 
|  | andcc	%g2, %g3, %g0 | 
|  | be,a,pt	%icc, 7f | 
|  | sll	%o0, 2, %o0 | 
|  | 5: | 
|  | xnor	%g0, %o0, %o0 | 
|  | srl	%o0, 31, %o0 | 
|  | sub	%o1, %o0, %o1 | 
|  | 6: | 
|  | jmp	%o7 + 8 | 
|  | sra	%o1, 0, %o0 | 
|  | 7: | 
|  | add	%o1, -2, %o1 | 
|  | ba,pt	%xcc, 5b | 
|  | sra	%o0, 0, %o0 | 
|  | 8: | 
|  | sll	%o0, 16, %o0 | 
|  | sethi	%hi(0xff000000), %g3 | 
|  | sra	%o0, 0, %o0 | 
|  | mov	%o0, %g2 | 
|  | andcc	%g2, %g3, %g0 | 
|  | bne,pt	%icc, 2b | 
|  | mov	16, %o1 | 
|  | ba,pt	%xcc, 1b | 
|  | sll	%o0, 8, %o0 | 
|  | ENDPROC(fls) | 
|  | EXPORT_SYMBOL(fls) |