diff options
| author | Eric Andersen <andersen@codepoet.org> | 2002-12-12 10:14:19 +0000 | 
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2002-12-12 10:14:19 +0000 | 
| commit | 3628edc05e5b439aad08191ab220360f9d9f54bd (patch) | |
| tree | ff8aaa7216e50019a7852d367bae3bae34fdb92d /libc/sysdeps/linux/mips | |
| parent | f329b6fe2f16e16000bb648aa678c2a947258e87 (diff) | |
Based on discussions with Stefan Allius, change it so that we always
build a crt0.o and a crt1.o.  crt1.o will support ctors and dtors if
such support is enabled.  One more gratuitous toolchain support issue
is thereby removed...
 -Erik
Diffstat (limited to 'libc/sysdeps/linux/mips')
| -rw-r--r-- | libc/sysdeps/linux/mips/Makefile | 11 | ||||
| -rw-r--r-- | libc/sysdeps/linux/mips/crt0.S | 2 | 
2 files changed, 5 insertions, 8 deletions
| diff --git a/libc/sysdeps/linux/mips/Makefile b/libc/sysdeps/linux/mips/Makefile index 080f04394..1fba4ef74 100644 --- a/libc/sysdeps/linux/mips/Makefile +++ b/libc/sysdeps/linux/mips/Makefile @@ -25,10 +25,8 @@ TOPDIR=../../../../  include $(TOPDIR)Rules.mak  ASFLAGS=$(CFLAGS) -TARGET_MACHINE_TYPE=$(shell $(CC) -dumpmachine) - -CRT0=crt0.S -CRT0_OBJ=$(patsubst %.S,%.o, $(CRT0)) +CRT0_SRC = crt0.S +CRT0_OBJ = crt0.o crt1.o  SSRC=bsd-_setjmp.S bsd-setjmp.S setjmp.S clone.S fork.S syscall.S  SOBJS=$(patsubst %.S,%.o, $(SSRC)) @@ -47,9 +45,8 @@ ar-target: $(OBJS) $(CRT0_OBJ)  	$(AR) $(ARFLAGS) $(LIBC) $(OBJS)  	cp $(CRT0_OBJ) $(TOPDIR)lib/ - -$(CRT0_OBJ): %.o : %.S -	$(CC) $(CFLAGS) -c $< -o $@ +$(CRT0_OBJ): $(CRT0_SRC) +	$(CC) $(CFLAGS) -DL_$* $< -c -o $*.o  	$(STRIPTOOL) -x -R .note -R .comment $*.o  $(SOBJS): %.o : %.S diff --git a/libc/sysdeps/linux/mips/crt0.S b/libc/sysdeps/linux/mips/crt0.S index 052229819..fdb997b73 100644 --- a/libc/sysdeps/linux/mips/crt0.S +++ b/libc/sysdeps/linux/mips/crt0.S @@ -30,7 +30,7 @@ __start:  	addu a2, a0, 1	    /* argv[0] program name (ordinal->cardinal) */          sll  a2, a2, 2	    /* multiple by 4 */  	add  a2, a2, a1	    /* a2 now points to start of envp */ -#ifdef __UCLIBC_CTOR_DTOR__ +#if defined L_crt1 && defined __UCLIBC_CTOR_DTOR__  	la   a3, _init	    /* a3 is address of _init */  	addiu sp, sp, -24   /* 16 + 4 rounded up to multiple of 8 */  			    /* multiple of 8 for longlong/double support */ | 
