arc: Fix strcmp for big endian without barrel shifter
strcmp.S contained invalid guard for code that used barrel-shifter optional instruction - it was checking for !ARC601 instead of whether barrel shifter is present. While it is true that ARC601 doesn't have barrel shifter, so does some other ARC EM configurations. 2016-07-21 Anton Kolesov <Anton.Kolesov@synopsys.com> * libc/machine/arc/strcmp.S: Fix big endian without barrel shifter. Signed-off-by: Anton Kolesov <Anton.Kolesov@synopsys.com>
This commit is contained in:
		
				
					committed by
					
						 Corinna Vinschen
						Corinna Vinschen
					
				
			
			
				
	
			
			
			
						parent
						
							1baa8bb843
						
					
				
				
					commit
					668033eb9f
				
			| @@ -97,7 +97,7 @@ ENTRY (strcmp) | ||||
| 	   when bit 7 is cleared.  */ | ||||
| 	.balign	4 | ||||
| .Lfound0: | ||||
| #ifndef __ARC601__ | ||||
| #ifdef __ARC_BARREL_SHIFTER__ | ||||
| 	lsr	r0,r4,8 | ||||
| 	lsr_s	r1,r2 | ||||
| 	bic_s	r2,r2,r0	; get low estimate for r2 and get ... | ||||
| @@ -110,11 +110,11 @@ ENTRY (strcmp) | ||||
| 	cmp_s	r2,r3 | ||||
| 	j_s.d	[blink] | ||||
| 	bset.lo	r0,r0,31 | ||||
| #else /* __ARC601__ */ | ||||
| #else /* __ARC_BARREL_SHIFTER__ */ | ||||
| 	/* Fall through to .Lcharloop.  */ | ||||
| 	sub_s	r0,r0,4 | ||||
| 	sub_s	r1,r1,4 | ||||
| #endif /* __ARC601__ */ | ||||
| #endif /* __ARC_BARREL_SHIFTER__ */ | ||||
| #endif /* ENDIAN */ | ||||
|  | ||||
| 	.balign	4 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user