X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=Makefile;h=683850d30078075a71741a3895ed8df7705acbb4;hp=b419554463259fd5a84ea5dd1069d23b12705861;hb=0d4d1a96e4fd827267250e469affc7ebfc44324f;hpb=d86d2829abc116c3e8741aa92727a5c55023088a diff --git a/Makefile b/Makefile index b4195544..683850d3 100644 --- a/Makefile +++ b/Makefile @@ -20,11 +20,20 @@ SRCS = $(sort $(wildcard src/*/*.c)) OBJS = $(SRCS:.c=.o) LOBJS = $(OBJS:.o=.lo) GENH = include/bits/alltypes.h +IMPH = src/internal/stdio_impl.h src/internal/pthread_impl.h src/internal/libc.h + +LDFLAGS = +LIBCC = -lgcc +CPPFLAGS = +CFLAGS = -Os -pipe +CFLAGS_C99FSE = -std=c99 -ffreestanding -nostdinc + +CFLAGS_ALL = $(CFLAGS_C99FSE) +CFLAGS_ALL += -D_XOPEN_SOURCE=700 -I./arch/$(ARCH) -I./src/internal -I./include +CFLAGS_ALL += $(CPPFLAGS) $(CFLAGS) +CFLAGS_ALL_STATIC = $(CFLAGS_ALL) +CFLAGS_ALL_SHARED = $(CFLAGS_ALL) -fPIC -DSHARED -O3 -CFLAGS = -Os -nostdinc -ffreestanding -std=c99 -D_XOPEN_SOURCE=700 -pipe -LDFLAGS = -nostdlib -shared -fPIC -Wl,-e,_start -Wl,-Bsymbolic-functions -INC = -I./src/internal -I./include -I./arch/$(ARCH) -PIC = -fPIC -O3 AR = $(CROSS_COMPILE)ar RANLIB = $(CROSS_COMPILE)ranlib @@ -32,11 +41,11 @@ ALL_INCLUDES = $(sort $(wildcard include/*.h include/*/*.h) $(GENH)) EMPTY_LIB_NAMES = m rt pthread crypt util xnet resolv dl EMPTY_LIBS = $(EMPTY_LIB_NAMES:%=lib/lib%.a) -CRT_LIBS = lib/crt1.o lib/crti.o lib/crtn.o -STATIC_LIBS = lib/libc.a $(EMPTY_LIBS) +CRT_LIBS = lib/crt1.o lib/Scrt1.o lib/crti.o lib/crtn.o +STATIC_LIBS = lib/libc.a SHARED_LIBS = lib/libc.so TOOL_LIBS = lib/musl-gcc.specs -ALL_LIBS = $(CRT_LIBS) $(STATIC_LIBS) $(SHARED_LIBS) $(TOOL_LIBS) +ALL_LIBS = $(CRT_LIBS) $(STATIC_LIBS) $(SHARED_LIBS) $(EMPTY_LIBS) $(TOOL_LIBS) ALL_TOOLS = tools/musl-gcc LDSO_PATHNAME = $(syslibdir)/ld-musl-$(ARCH).so.1 @@ -56,6 +65,9 @@ clean: rm -f $(GENH) rm -f include/bits +distclean: clean + rm -f config.mak + include/bits: @test "$(ARCH)" || { echo "Please set ARCH in config.mak before running make." ; exit 1 ; } ln -sf ../arch/$(ARCH)/bits $@ @@ -65,20 +77,24 @@ include/bits/alltypes.h.sh: include/bits include/bits/alltypes.h: include/bits/alltypes.h.sh sh $< > $@ +src/ldso/dynlink.lo: arch/$(ARCH)/reloc.h + %.o: $(ARCH)/%.s - $(CC) $(CFLAGS) $(INC) -c -o $@ $< + $(CC) $(CFLAGS_ALL_STATIC) -c -o $@ $< -%.o: %.c $(GENH) - $(CC) $(CFLAGS) $(INC) -c -o $@ $< +%.o: %.c $(GENH) $(IMPH) + $(CC) $(CFLAGS_ALL_STATIC) -c -o $@ $< %.lo: $(ARCH)/%.s - $(CC) $(CFLAGS) $(INC) $(PIC) -c -o $@ $< + $(CC) $(CFLAGS_ALL_SHARED) -c -o $@ $< -%.lo: %.c $(GENH) - $(CC) $(CFLAGS) $(INC) $(PIC) -c -o $@ $< +%.lo: %.c $(GENH) $(IMPH) + $(CC) $(CFLAGS_ALL_SHARED) -c -o $@ $< lib/libc.so: $(LOBJS) - $(CC) $(LDFLAGS) -Wl,-soname=libc.so -o $@ $(LOBJS) -lgcc + $(CC) $(CFLAGS_ALL_SHARED) $(LDFLAGS) -nostdlib -shared \ + -Wl,-e,_start -Wl,-Bsymbolic-functions \ + -Wl,-soname=libc.so -o $@ $(LOBJS) $(LIBCC) lib/libc.a: $(OBJS) rm -f $@ @@ -111,10 +127,12 @@ $(DESTDIR)$(libdir)/%: lib/% $(DESTDIR)$(includedir)/%: include/% install -D -m 644 $< $@ -$(DESTDIR)$(LDSO_PATHNAME): lib/libc.so - install -d -m 755 $(DESTDIR)$(syslibdir) || true +$(DESTDIR)$(LDSO_PATHNAME): $(DESTDIR)$(syslibdir) ln -sf $(libdir)/libc.so $@ || true +$(DESTDIR)$(syslibdir): + install -d -m 755 $(DESTDIR)$(syslibdir) + .PRECIOUS: $(CRT_LIBS:lib/%=crt/%) .PHONY: all clean install