mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-24 13:33:08 +03:00 
			
		
		
		
	* sysdeps/i386/addmul_1.S: Likewise. * sysdeps/i386/bsd-setjmp.S: Likewise. * sysdeps/i386/lshift.S: Likewise. * sysdeps/i386/memchr.S: Likewise. * sysdeps/i386/memcmp.S: Likewise. * sysdeps/i386/mul_1.S: Likewise. * sysdeps/i386/rawmemchr.S: Likewise. * sysdeps/i386/rshift.S: Likewise. * sysdeps/i386/stpncpy.S: Likewise. * sysdeps/i386/strchr.S: Likewise. * sysdeps/i386/strchrnul.S: Likewise. * sysdeps/i386/strcspn.S: Likewise. * sysdeps/i386/strpbrk.S: Likewise. * sysdeps/i386/strrchr.S: Likewise. * sysdeps/i386/strspn.S: Likewise. * sysdeps/i386/strtok.S: Likewise. * sysdeps/i386/sub_n.S: Likewise. * sysdeps/i386/submul_1.S: Likewise. * sysdeps/i386/elf/bsd-setjmp.S: Likewise. * sysdeps/i386/i486/strcat.S: Likewise. * sysdeps/i386/i586/add_n.S: Likewise. * sysdeps/i386/i586/addmul_1.S: Likewise. * sysdeps/i386/i586/lshift.S: Likewise. * sysdeps/i386/i586/memcpy.S: Likewise. * sysdeps/i386/i586/memset.S: Likewise. * sysdeps/i386/i586/mul_1.S: Likewise. * sysdeps/i386/i586/rshift.S: Likewise. * sysdeps/i386/i586/strchr.S: Likewise. * sysdeps/i386/i586/strcpy.S: Likewise. * sysdeps/i386/i586/sub_n.S: Likewise. * sysdeps/i386/i586/submul_1.S: Likewise. * sysdeps/i386/i686/add_n.S: Likewise. * sysdeps/i386/i686/memcmp.S: Likewise. * sysdeps/i386/i686/memmove.S: Likewise. * sysdeps/i386/i686/mempcpy.S: Likewise. * sysdeps/i386/i686/memset.S: Likewise. * sysdeps/i386/i686/strtok.S: Likewise. * sysdeps/unix/sysv/linux/i386/clone.S: Likewise. * sysdeps/unix/sysv/linux/i386/mmap.S: Likewise. * sysdeps/unix/sysv/linux/i386/mmap64.S: Likewise. * sysdeps/unix/sysv/linux/i386/posix_fadvise64.S: Likewise. * sysdeps/unix/sysv/linux/i386/semtimedop.S: Likewise. * sysdeps/unix/sysv/linux/i386/setcontext.S: Likewise. * sysdeps/i386/fpu/libm-test-ulps: Adjust for gcc 4.
		
			
				
	
	
		
			114 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* i80386 __mpn_lshift --
 | |
|    Copyright (C) 1992, 1994, 1997-2000, 2005 Free Software Foundation, Inc.
 | |
|    This file is part of the GNU MP Library.
 | |
| 
 | |
|    The GNU MP Library is free software; you can redistribute it and/or modify
 | |
|    it under the terms of the GNU Lesser General Public License as published by
 | |
|    the Free Software Foundation; either version 2.1 of the License, or (at your
 | |
|    option) any later version.
 | |
| 
 | |
|    The GNU MP Library is distributed in the hope that it will be useful, but
 | |
|    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 | |
|    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
 | |
|    License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU Lesser General Public License
 | |
|    along with the GNU MP Library; see the file COPYING.LIB.  If not, write to
 | |
|    the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
 | |
|    MA 02111-1307, USA. */
 | |
| 
 | |
| #include "sysdep.h"
 | |
| #include "asm-syntax.h"
 | |
| #include "bp-sym.h"
 | |
| #include "bp-asm.h"
 | |
| 
 | |
| #define PARMS	LINKAGE+12		/* space for 3 saved regs */
 | |
| #define RES	PARMS
 | |
| #define S	RES+PTR_SIZE
 | |
| #define SIZE	S+PTR_SIZE
 | |
| #define CNT	SIZE+4
 | |
| 
 | |
| 	.text
 | |
| ENTRY (BP_SYM (__mpn_lshift))
 | |
| 	ENTER
 | |
| 
 | |
| 	pushl	%edi
 | |
| 	cfi_adjust_cfa_offset (4)
 | |
| 	pushl	%esi
 | |
| 	cfi_adjust_cfa_offset (4)
 | |
| 	pushl	%ebx
 | |
| 	cfi_adjust_cfa_offset (4)
 | |
| 
 | |
| 	movl	RES(%esp),%edi
 | |
| 	cfi_rel_offset (edi, 8)
 | |
| 	movl	S(%esp),%esi
 | |
| 	cfi_rel_offset (esi, 4)
 | |
| 	movl	SIZE(%esp),%edx
 | |
| 	movl	CNT(%esp),%ecx
 | |
| #if __BOUNDED_POINTERS__
 | |
| 	shll	$2, %edx		/* convert limbs to bytes */
 | |
| 	CHECK_BOUNDS_BOTH_WIDE (%edi, RES(%esp), %edx)
 | |
| 	CHECK_BOUNDS_BOTH_WIDE (%esi, S(%esp), %edx)
 | |
| 	shrl	$2, %edx
 | |
| #endif
 | |
| 	subl	$4,%esi			/* adjust s_ptr */
 | |
| 
 | |
| 	movl	(%esi,%edx,4),%ebx	/* read most significant limb */
 | |
| 	cfi_rel_offset (ebx, 0)
 | |
| 	xorl	%eax,%eax
 | |
| 	shldl	%cl,%ebx,%eax		/* compute carry limb */
 | |
| 	decl	%edx
 | |
| 	jz	L(end)
 | |
| 	pushl	%eax			/* push carry limb onto stack */
 | |
| 	cfi_adjust_cfa_offset (4)
 | |
| 	testb	$1,%dl
 | |
| 	jnz	L(1)			/* enter loop in the middle */
 | |
| 	movl	%ebx,%eax
 | |
| 
 | |
| 	ALIGN (3)
 | |
| L(oop):	movl	(%esi,%edx,4),%ebx	/* load next lower limb */
 | |
| 	shldl	%cl,%ebx,%eax		/* compute result limb */
 | |
| 	movl	%eax,(%edi,%edx,4)	/* store it */
 | |
| 	decl	%edx
 | |
| L(1):	movl	(%esi,%edx,4),%eax
 | |
| 	shldl	%cl,%eax,%ebx
 | |
| 	movl	%ebx,(%edi,%edx,4)
 | |
| 	decl	%edx
 | |
| 	jnz	L(oop)
 | |
| 
 | |
| 	shll	%cl,%eax		/* compute least significant limb */
 | |
| 	movl	%eax,(%edi)		/* store it */
 | |
| 
 | |
| 	popl	%eax			/* pop carry limb */
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 
 | |
| 	popl	%ebx
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (ebx)
 | |
| 	popl	%esi
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (esi)
 | |
| 	popl	%edi
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (edi)
 | |
| 
 | |
| 	LEAVE
 | |
| 	ret
 | |
| 
 | |
| L(end):	shll	%cl,%ebx		/* compute least significant limb */
 | |
| 	movl	%ebx,(%edi)		/* store it */
 | |
| 
 | |
| 	popl	%ebx
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (ebx)
 | |
| 	popl	%esi
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (esi)
 | |
| 	popl	%edi
 | |
| 	cfi_adjust_cfa_offset (-4)
 | |
| 	cfi_restore (edi)
 | |
| 
 | |
| 	LEAVE
 | |
| 	ret
 | |
| END (BP_SYM (__mpn_lshift))
 |