# In this section, we need .config
-include .config.cmd
-shared:
+shared: subdirs
ifeq ($(strip $(HAVE_SHARED)),y)
+ $(SECHO)
+ $(SECHO) Building shared libraries ...
+ $(SECHO)
@$(MAKE) -C libc shared
@$(MAKE) -C ldso shared
@$(MAKE) -C libcrypt shared
@$(MAKE) -C libintl shared
endif
else
- @echo
- @echo Not building shared libraries...
- @echo
+ $(SECHO)
+ $(SECHO) Not building shared libraries ...
+ $(SECHO)
endif
-
finished: shared
- @echo
- @echo Finally finished compiling...
- @echo
+ $(SECHO)
+ $(SECHO) Finally finished compiling ...
+ $(SECHO)
include/bits/uClibc_config.h: .config
@if [ ! -x ./extra/config/conf ] ; then \
$(INSTALL) -d include/bits
@./extra/config/conf -o extra/Configs/Config.in
-headers: include/bits/uClibc_config.h
+# For the moment, we have to keep re-running this target
+# because the fix includes scripts rely on pre-processers
+# in order to generate the headers correctly :(. That
+# means we can't use the $(HOSTCC) in order to get the
+# correct output.
ifeq ($(strip $(ARCH_HAS_MMU)),y)
- @set -x; ./extra/scripts/fix_includes.sh -k $(KERNEL_SOURCE) -t $(TARGET_ARCH)
+export header_extra_args =
else
- @set -x; ./extra/scripts/fix_includes.sh -k $(KERNEL_SOURCE) -t $(TARGET_ARCH) -n
+export header_extra_args = -n
endif
+headers: include/bits/uClibc_config.h
+ @$(SHELL_SET_X); \
+ ./extra/scripts/fix_includes.sh \
+ -k $(KERNEL_SOURCE) -t $(TARGET_ARCH) \
+ $(header_extra_args)
@cd include/bits; \
set -e; \
for i in `ls ../../libc/sysdeps/linux/common/bits/*.h` ; do \
done; \
fi
@cd $(TOPDIR); \
- set -x -e; \
+ set -e; \
+ $(SHELL_SET_X); \
TOPDIR=. CC="$(CC)" /bin/sh extra/scripts/gen_bits_syscall_h.sh > include/bits/sysnum.h.new; \
if cmp include/bits/sysnum.h include/bits/sysnum.h.new >/dev/null 2>&1; then \
$(RM) include/bits/sysnum.h.new; \
else \
mv -f include/bits/sysnum.h.new include/bits/sysnum.h; \
fi
+ $(MAKE) -C libpthread headers
$(MAKE) -C libc/sysdeps/linux/common headers
$(MAKE) -C libc/sysdeps/linux/$(TARGET_ARCH) headers
subdirs: $(patsubst %, _dir_%, $(DIRS))
-
-$(patsubst %, _dir_%, $(DIRS)) : dummy
+$(patsubst %, _dir_%, $(DIRS)): headers
$(MAKE) -C $(patsubst _dir_%, %, $@)
tags:
$(INSTALL) -d $(PREFIX)$(DEVEL_PREFIX)lib
$(INSTALL) -d $(PREFIX)$(DEVEL_PREFIX)include
-$(INSTALL) -m 644 lib/*.[ao] $(PREFIX)$(DEVEL_PREFIX)lib/
- tar -chf - include | tar -xf - -C $(PREFIX)$(DEVEL_PREFIX);
+ if [ "$(KERNEL_SOURCE)" == "$(DEVEL_PREFIX)" ] ; then \
+ extra_exclude="--exclude include/linux --exclude include/asm'*'" ; \
+ else \
+ extra_exclude="" ; \
+ fi ; \
+ tar -chf - include --exclude .svn --exclude CVS $$extra_exclude \
+ | tar -xf - -C $(PREFIX)$(DEVEL_PREFIX)
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/libc-internal.h
ifneq ($(strip $(UCLIBC_HAS_FLOATS)),y)
# Remove floating point related headers since float support is disabled.
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/complex.h
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/ieee754.h
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/math.h
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/tgmath.h
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/bits/uClibc_fpmax.h
endif
ifneq ($(strip $(UCLIBC_HAS_WCHAR)),y)
# Remove wide char headers since wide char support is disabled.
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/getopt.h
endif
ifneq ($(strip $(HAS_SHADOW)),y)
- # Remove getopt header since shadow password support is disabled.
+ # Remove shadow header since shadow password support is disabled.
$(RM) $(PREFIX)$(DEVEL_PREFIX)include/shadow.h
endif
+ifneq ($(strip $(PTHREADS_DEBUG_SUPPORT)),y)
+ # Remove thread_db header since thread debug support is disabled.
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/thread_db.h
+endif
+ifneq ($(strip $(UCLIBC_HAS_THREADS)),y)
+ # Remove pthread headers since thread support is disabled.
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/*thread*.h
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/semaphore.h
+ $(RM) $(PREFIX)$(DEVEL_PREFIX)include/bits/*thread*.h
+endif
-@for i in `find $(PREFIX)$(DEVEL_PREFIX) -type d` ; do \
chmod 755 $$i; chmod 644 $$i/*.h > /dev/null 2>&1; \
done;
- -find $(PREFIX)$(DEVEL_PREFIX) -name CVS | xargs $(RM) -r;
- -chown -R `id | sed 's/^uid=\([0-9]*\).*gid=\([0-9]*\).*$$/\1.\2/'` $(PREFIX)$(DEVEL_PREFIX)
+ -find $(PREFIX)$(DEVEL_PREFIX) -name .svn | xargs $(RM) -r;
+ -chown -R `id | sed 's/^uid=\([0-9]*\).*gid=\([0-9]*\).*$$/\1:\2/'` $(PREFIX)$(DEVEL_PREFIX)
ifeq ($(strip $(HAVE_SHARED)),y)
for i in `find lib/ -type l -name 'lib[a-zA-Z]*.so' | \
sed -e 's/lib\///'` ; do \
$(PREFIX)$(DEVEL_PREFIX)lib/$$i; \
done;
ifeq ($(strip $(PTHREADS_DEBUG_SUPPORT)),y)
- ln -sf $(RUNTIME_PREFIX_LIB_FROM_DEVEL_PREFIX_LIB)libthread_db.so.1 \
+ $(LN) -sf $(RUNTIME_PREFIX_LIB_FROM_DEVEL_PREFIX_LIB)libthread_db.so.1 \
$(PREFIX)$(DEVEL_PREFIX)lib/libthread_db.so
endif
# # If we build shared libraries then the static libs are PIC...
$(LN) -sf $$i $(PREFIX)$(DEVEL_PREFIX)lib/`echo $$i \
| sed -e 's/\.a$$/_pic.a/'`; \
done;
+ # Ugh!!! Remember that libdl.a and libdl_pic.a are different. Since
+ # libdl is pretty small, and not likely to benefit from mklibs.py and
+ # similar, lets just remove libdl_pic.a and avoid the issue
+ rm -f $(PREFIX)$(DEVEL_PREFIX)lib/libdl_pic.a
endif
$(INSTALL) -d $(PREFIX)$(RUNTIME_PREFIX)lib
$(INSTALL) -m 644 lib/lib*-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so \
$(PREFIX)$(RUNTIME_PREFIX)lib
- cp -PRf lib/*.so.* $(PREFIX)$(RUNTIME_PREFIX)lib
+ cp -dRf lib/*.so.* $(PREFIX)$(RUNTIME_PREFIX)lib
@if [ -x lib/ld-uClibc-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so ] ; then \
- set -x -e; \
+ set -e; \
+ $(SHELL_SET_X); \
$(INSTALL) -m 755 lib/ld-uClibc-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so \
$(PREFIX)$(RUNTIME_PREFIX)lib; \
fi;
endif
.PHONY: utils
-ifeq ($(strip $(HAVE_SHARED)),y)
utils:
- $(MAKE) CROSS=$(CROSS) CC=$(CC) -C utils
-else
-utils: dummy
-endif
+ $(MAKE) CROSS="$(CROSS)" CC="$(CC)" -C utils
# Installs helper applications, such as 'ldd' and 'ldconfig'
install_utils: utils
- $(MAKE) CROSS=$(CROSS) CC=$(CC) -C utils install
-#ifeq ($(strip $(UCLIBC_HAS_LOCALE)),y)
-# @$(MAKE) -C libc/misc/wchar iconv.target
-# $(INSTALL) -d $(PREFIX)$(RUNTIME_PREFIX)/usr/bin;
-# $(INSTALL) -m 755 libc/misc/wchar/iconv.target $(PREFIX)$(RUNTIME_PREFIX)/usr/bin/iconv
-#endif
+ $(MAKE) CROSS="$(CROSS)" CC="$(CC)" -C utils install
finished2:
- @echo
- @echo Finished installing...
- @echo
+ $(SECHO)
+ $(SECHO) Finished installing ...
+ $(SECHO)
else # ifeq ($(strip $(HAVE_DOT_CONFIG)),y)
$(INSTALL) -d include/bits
@./extra/config/conf -d extra/Configs/Config.in
-
clean:
- find . \( -name \*.o -o -name \*.a -o -name \*.so -o -name core -o -name .\#\* \) -exec $(RM) {} \;
@$(RM) -r tmp lib include/bits libc/tmp _install
+ $(RM) libc/obj.* headers
$(MAKE) -C test clean
$(MAKE) -C ldso clean
$(MAKE) -C libc/misc/internals clean
$(MAKE) -C libc/unistd clean
$(MAKE) -C libc/sysdeps/linux/common clean
$(MAKE) -C extra/locale clean
+ $(MAKE) -C utils clean
+ $(MAKE) -C libpthread clean
@set -e; \
for i in `(cd $(TOPDIR)/libc/sysdeps/linux/common/sys; ls *.h)` ; do \
$(RM) include/sys/$$i; \
release: distclean
cd ..; \
$(RM) -r uClibc-$(VERSION); \
- cp -PRf uClibc uClibc-$(VERSION); \
+ cp -dRf uClibc uClibc-$(VERSION); \
find uClibc-$(VERSION)/ -type f \
-name .\#* -exec $(RM) -r {} \; ; \
find uClibc-$(VERSION)/ -type d \
- -name CVS -exec $(RM) -r {} \; ; \
+ -name .svn -exec $(RM) -r {} \; ; \
\
tar -cvzf uClibc-$(VERSION).tar.gz uClibc-$(VERSION)/;
endif # ifeq ($(strip $(HAVE_DOT_CONFIG)),y)
-.PHONY: dummy subdirs release distclean clean config oldconfig menuconfig
-
+check:
+ $(MAKE) -C test
+.PHONY: dummy subdirs release distclean clean config oldconfig menuconfig