Browse Source

Begin converting the client utils

Eric Andersen 20 years ago
parent
commit
e556691e4f
12 changed files with 102 additions and 129 deletions
  1. 5 34
      Makefile
  2. 2 5
      ldso/Makefile
  3. 0 87
      ldso/util/Makefile
  4. 0 2
      utils/.cvsignore
  5. 95 0
      utils/Makefile
  6. 0 0
      utils/bswap.h
  7. 0 1
      utils/ldconfig.c
  8. 0 0
      utils/ldd.c
  9. 0 0
      utils/readelf.c
  10. 0 0
      utils/readsoname.c
  11. 0 0
      utils/readsoname.h
  12. 0 0
      utils/readsoname2.c

+ 5 - 34
Makefile

@@ -35,7 +35,7 @@ endif
 
 ifeq ($(strip $(HAVE_DOT_CONFIG)),y)
 
-all: headers pregen subdirs shared utils finished
+all: headers pregen subdirs shared finished
 
 # In this section, we need .config
 -include .config.cmd
@@ -271,8 +271,8 @@ ifeq ($(strip $(HAVE_SHARED)),y)
 endif
 
 ifeq ($(strip $(HAVE_SHARED)),y)
-utils: $(TOPDIR)ldso/util/ldd
-	$(MAKE) -C ldso utils
+utils: $(TOPDIR)utils/ldd
+	$(MAKE) -C utils
 else
 utils: dummy
 endif
@@ -290,39 +290,10 @@ ifeq ($(strip $(HAVE_SHARED)),y)
 	#$(INSTALL) -m 755 ldso/util/readelf \
 	#	$(PREFIX)$(RUNTIME_PREFIX)usr/bin/readelf
 endif
-
-# Installs run-time libraries and helper apps in preparation for
-# deploying onto a target system, but installed below wherever
-# $PREFIX is set to, allowing you to package up the result for
-# deployment onto your target system.
-install_target:
-ifeq ($(strip $(HAVE_SHARED)),y)
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/lib
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/usr/bin
-	$(INSTALL) -m 644 lib/lib*-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so \
-		$(PREFIX)$(TARGET_PREFIX)/lib
-	cp -fa lib/*.so.* $(PREFIX)$(TARGET_PREFIX)/lib
-	@if [ -x lib/ld-uClibc-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so ] ; then \
-	    set -x -e; \
-	    $(INSTALL) -m 755 lib/ld-uClibc-$(MAJOR_VERSION).$(MINOR_VERSION).$(SUBLEVEL).so \
-	    		$(PREFIX)$(TARGET_PREFIX)/lib; \
-	fi;
-endif
-
-install_target_utils:
-ifeq ($(strip $(HAVE_SHARED)),y)
-	@$(MAKE) -C ldso/util ldd.target ldconfig.target #readelf.target
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/etc;
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/sbin;
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/usr/bin;
-	$(INSTALL) -m 755 ldso/util/ldd.target $(PREFIX)$(TARGET_PREFIX)/usr/bin/ldd
-	$(INSTALL) -m 755 ldso/util/ldconfig.target $(PREFIX)$(TARGET_PREFIX)/sbin/ldconfig;
-	#$(INSTALL) -m 755 ldso/util/readelf.target $(PREFIX)$(TARGET_PREFIX)/usr/bin/readelf;
-endif
 ifeq ($(strip $(UCLIBC_HAS_LOCALE)),y)
 	@$(MAKE) -C libc/misc/wchar iconv.target
-	$(INSTALL) -d $(PREFIX)$(TARGET_PREFIX)/usr/bin;
-	$(INSTALL) -m 755 libc/misc/wchar/iconv.target $(PREFIX)$(TARGET_PREFIX)/usr/bin/iconv
+	$(INSTALL) -d $(PREFIX)$(RUNTIME_PREFIX)/usr/bin;
+	$(INSTALL) -m 755 libc/misc/wchar/iconv.target $(PREFIX)$(RUNTIME_PREFIX)/usr/bin/iconv
 endif
 
 finished2:

+ 2 - 5
ldso/Makefile

@@ -23,7 +23,7 @@
 TOPDIR=../
 include $(TOPDIR)Rules.mak
 
-ALL_SUBDIRS = ldso libdl util
+ALL_SUBDIRS = ldso libdl
 
 
 all: headers
@@ -33,16 +33,13 @@ else
 	echo "Not building ld-uClibc"
 endif
 
-shared: utils
+shared:
 ifeq ($(strip $(BUILD_UCLIBC_LDSO)),y)
 	$(MAKE) -C libdl;
 else
 	echo "Not building libdl"
 endif
 
-utils:
-	$(MAKE) -C util;
-
 headers:
 	$(LN) -fs $(TOPDIR)../include/elf.h include/
 	$(LN) -fs ../ldso/$(TARGET_ARCH)/boot1_arch.h include/

+ 0 - 87
ldso/util/Makefile

@@ -1,87 +0,0 @@
-# Makefile for uClibc
-#
-# Copyright (C) 2000,2001 Erik Andersen <andersen@uclibc.org>
-#
-# This program is free software; you can redistribute it and/or modify it under
-# the terms of the GNU Library General Public License as published by the Free
-# Software Foundation; either version 2 of the License, or (at your option) any
-# later version.
-#
-# This program 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 Library General Public License for more
-# details.
-#
-# You should have received a copy of the GNU Library General Public License
-# along with this program; if not, write to the Free Software Foundation, Inc.,
-# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-#
-# Derived in part from the Linux-8086 C library, the GNU C Library, and several
-# other sundry sources.  Files within this library are copyright by their
-# respective copyright holders.
-
-TOPDIR=../../
-include $(TOPDIR)Rules.mak
-TARGET_CC = $(TOPDIR)extra/gcc-uClibc/$(TARGET_ARCH)-uclibc-gcc
-
-TARGETS = ldd ldconfig
-ifeq ($(OSTYPE),linux)
-TARGETS += readelf
-endif
-#ifneq ($(strip $(LIBRARY_CACHE)),)
-#TARGETS += ldconfig
-#endif
-
-ifeq ($(strip $(LDSO_LDD_SUPPORT)),y)
-XXFLAGS = -D__LDSO_LDD_SUPPORT
-endif
-
-all:	$(TARGETS)
-
-headers:
-	$(LN) -fs $(TOPDIR)include/elf.h
-
-readelf:	readelf.c
-	$(HOSTCC) $(HOSTCFLAGS) -I. -I../include $^ -o $@
-	strip -x -R .note -R .comment $@
-
-readelf.target: readelf.c
-	$(TARGET_CC) $(CFLAGS) -Wl,-s $^ -o $@ $(LDADD_LIBFLOAT)
-	$(STRIPTOOL) -x -R .note -R .comment $@
-
-readsoname.o:	readsoname.c readsoname2.c
-	$(HOSTCC) $(HOSTCFLAGS) -I. -I../include -c $< -o $@
-	strip -x -R .note -R .comment $*.o
-
-ldconfig:	ldconfig.c readsoname.c
-	$(HOSTCC) $(HOSTCFLAGS) $(XXFLAGS) \
-		-DUCLIBC_RUNTIME_PREFIX=\"$(RUNTIME_PREFIX)\" \
-		-DUCLIBC_LDSO=\"$(UCLIBC_LDSO)\" -I. -I../include \
-		$^ -o $@
-	strip -x -R .note -R .comment $@
-
-ldconfig.target:	ldconfig.c readsoname.c
-	$(TARGET_CC) $(CFLAGS) $(XXFLAGS) -Wl,-s \
-		-DUCLIBC_RUNTIME_PREFIX=\"$(RUNTIME_PREFIX)\" \
-		-DUCLIBC_LDSO=\"$(UCLIBC_LDSO)\" -I. -I../include \
-		$^ -o $@ $(LDADD_LIBFLOAT)
-	$(STRIPTOOL) -x -R .note -R .comment $@
-
-ldd:	ldd.c
-	$(HOSTCC) $(HOSTCFLAGS) $(XXFLAGS) \
-		-DUCLIBC_RUNTIME_PREFIX=\"$(RUNTIME_PREFIX)\" \
-		-DUCLIBC_LDSO=\"$(UCLIBC_LDSO)\" -I. -I../include \
-		$^ -o $@
-	strip -x -R .note -R .comment $@
-
-ldd.target:	ldd.c
-	$(TARGET_CC) $(CFLAGS) $(XXFLAGS) -Wl,-s \
-		-DUCLIBC_RUNTIME_PREFIX=\"$(RUNTIME_PREFIX)\" \
-		-DUCLIBC_LDSO=\"$(UCLIBC_LDSO)\" \
-		$^ -o $@ $(LDADD_LIBFLOAT)
-	$(STRIPTOOL) -x -R .note -R .comment $@
-
-clean:
-	$(RM) $(TARGETS) *.o *~ core *.target elf.h
-
-readelf.c readsoname.c ldconfig.c ldd.c:	headers

+ 0 - 2
ldso/util/.cvsignore → utils/.cvsignore

@@ -1,6 +1,4 @@
 ldd
-ldd.target
 readelf
-readelf.target
 ldconfig
 elf.h

+ 95 - 0
utils/Makefile

@@ -0,0 +1,95 @@
+# Makefile for uClibc
+#
+# Copyright (C) 2000-2003 Erik Andersen <andersen@uclibc.org>
+#
+# This program is free software; you can redistribute it and/or modify it under
+# the terms of the GNU Library General Public License as published by the Free
+# Software Foundation; either version 2 of the License, or (at your option) any
+# later version.
+#
+# This program 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 Library General Public License for more
+# details.
+#
+# You should have received a copy of the GNU Library General Public License
+# along with this program; if not, write to the Free Software Foundation, Inc.,
+# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+# Pull in the user's uClibc configuration, but do not
+# include Rules.mak.....
+TOPDIR=../
+include $(TOPDIR).config
+
+# A nifty macro to make testing gcc features easier
+check_gcc=$(shell if $(CC) $(1) -S -o /dev/null -xc /dev/null > /dev/null 2>&1; \
+	then echo "$(1)"; else echo "$(2)"; fi)
+
+# use '-Os' optimization if available, else use -O2, allow Config to override
+OPTIMIZATION+=$(call check_gcc,-Os,-O2)
+XWARNINGS=$(subst ",, $(strip $(WARNINGS))) -Wstrict-prototypes -Wno-trigraphs -fno-strict-aliasing
+
+MAJOR_VERSION:=0
+UCLIBC_LDSO:=ld-uClibc.so.$(MAJOR_VERSION)
+
+ifndef CROSS
+CROSS=
+endif
+CC= $(CROSS)gcc
+AR= $(CROSS)ar
+LD= $(CROSS)ld
+NM= $(CROSS)nm
+STRIP= $(CROSS)strip
+LN=ln
+
+ifeq ($(DODEBUG),y)
+    CFLAGS = $(XWARNINGS) -O0 -g3
+    LDFLAGS =
+else
+    CFLAGS=$(XWARNINGS) $(OPTIMIZATION)
+    LDFLAGS = -s
+endif
+
+# Make certain these contain a final "/", but no "//"s.
+RUNTIME_PREFIX:=$(strip $(subst //,/, $(subst ,/, $(subst ",, $(strip $(RUNTIME_PREFIX))))))
+DEVEL_PREFIX:=$(strip $(subst //,/, $(subst ,/, $(subst ",, $(strip $(DEVEL_PREFIX))))))
+export RUNTIME_PREFIX DEVEL_PREFIX
+
+
+TARGETS = ldd ldconfig readelf
+
+ifeq ($(strip $(LDSO_LDD_SUPPORT)),y)
+XXFLAGS = -D__LDSO_LDD_SUPPORT
+endif
+
+ifeq ($(strip $(HAVE_SHARED)),y)
+all:	$(TARGETS)
+else
+all:
+endif
+
+headers:
+	$(LN) -fs $(TOPDIR)include/elf.h
+
+readelf: readelf.c
+	$(CC) $(CFLAGS) -Wl,-s $^ -o $@ $(LDADD_LIBFLOAT)
+	$(STRIP) -x -R .note -R .comment $@
+
+ldconfig:	ldconfig.c readsoname.c
+	$(CC) $(CFLAGS) $(XXFLAGS) -Wl,-s \
+		-DUCLIBC_RUNTIME_PREFIX=$(R_PREFIX) \
+		-DUCLIBC_LDSO=$(UCLIBC_LDSO) -I. -I../ldso/include \
+		$^ -o $@ $(LDADD_LIBFLOAT)
+	$(STRIP) -x -R .note -R .comment $@
+
+ldd:	ldd.c
+	$(CC) $(CFLAGS) $(XXFLAGS) -Wl,-s \
+		-DUCLIBC_RUNTIME_PREFIX=$(R_PREFIX) \
+		-DUCLIBC_LDSO=$(UCLIBC_LDSO) \
+		$^ -o $@ $(LDADD_LIBFLOAT)
+	$(STRIP) -x -R .note -R .comment $@
+
+clean:
+	$(RM) $(TARGETS) *.o *~ core *.target elf.h
+
+readelf.c readsoname.c ldconfig.c ldd.c:	headers

+ 0 - 0
ldso/util/bswap.h → utils/bswap.h


+ 0 - 1
ldso/util/ldconfig.c → utils/ldconfig.c

@@ -34,7 +34,6 @@
 #include <unistd.h>
 #include <link.h>
 #include <fcntl.h>
-//#include <err.h>
 #include <errno.h>
 #include <sys/stat.h>
 #include <sys/mman.h>

+ 0 - 0
ldso/util/ldd.c → utils/ldd.c


+ 0 - 0
ldso/util/readelf.c → utils/readelf.c


+ 0 - 0
ldso/util/readsoname.c → utils/readsoname.c


+ 0 - 0
ldso/util/readsoname.h → utils/readsoname.h


+ 0 - 0
ldso/util/readsoname2.c → utils/readsoname2.c