mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-31 12:39:23 +00:00 
			
		
		
		
	 3b041227f7
			
		
	
	
		3b041227f7
		
	
	
	
	
		
			
			We chan't share code for udivsi3 and udivsi3_i4, because they have a different clobber list. Copy udivsi3 from gcc-4.1.2. As shown in arch/sh/lib/udivsi3.S (and -Os.S), .global __udivsi3_i4i .global __udivsi3_i4 .global __udivsi3 __udivsi3_i4i: ... Three symbols are sharing one code, which is actually udivsi3_i4i. But, this results unwanted code with gcc 4.1. In gcc, these three are treated as pseudo instructions that have their own clobber list apart from the usual calling convention. According to sh's machine description. The clobber list is as follows: - udivsi3_i4i : t,r1,pr,mach,macl - udivsi3_i4 : t,r0,r1,r4,r5,pr,dr0,dr2,dr4 - udivsi3 : t,r4,pr The caller of udivsi3 will be left with a broken r1 and mac*. gcc-4.1.x and older(at least to 3.4) generate udivsi3. ST's gcc-4.1.1 seems to be OK because it has _i4i. Signed-off-by: Takashi YOSHII <yoshii.takashi@renesas.com> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
		
			
				
	
	
		
			31 lines
		
	
	
		
			707 B
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			707 B
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| #
 | |
| # Makefile for SuperH-specific library files..
 | |
| #
 | |
| 
 | |
| lib-y  = delay.o memset.o memmove.o memchr.o \
 | |
| 	 checksum.o strlen.o div64.o div64-generic.o
 | |
| 
 | |
| # Extracted from libgcc
 | |
| lib-y += movmem.o ashldi3.o ashrdi3.o lshrdi3.o \
 | |
| 	 ashlsi3.o ashrsi3.o ashiftrt.o lshrsi3.o \
 | |
| 	 udiv_qrnnd.o
 | |
| 
 | |
| udivsi3-y			:= udivsi3_i4i-Os.o
 | |
| 
 | |
| ifneq ($(CONFIG_CC_OPTIMIZE_FOR_SIZE),y)
 | |
| udivsi3-$(CONFIG_CPU_SH3)	:= udivsi3_i4i.o
 | |
| udivsi3-$(CONFIG_CPU_SH4)	:= udivsi3_i4i.o
 | |
| endif
 | |
| udivsi3-y			+= udivsi3.o
 | |
| 
 | |
| obj-y				+= io.o
 | |
| 
 | |
| memcpy-y			:= memcpy.o
 | |
| memcpy-$(CONFIG_CPU_SH4)	:= memcpy-sh4.o
 | |
| 
 | |
| lib-$(CONFIG_MMU)		+= copy_page.o clear_page.o
 | |
| lib-$(CONFIG_FUNCTION_TRACER)	+= mcount.o
 | |
| lib-y				+= $(memcpy-y) $(udivsi3-y)
 | |
| 
 | |
| EXTRA_CFLAGS += -Werror
 |