diff options
author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-04-25 22:59:52 +0000 |
---|---|---|
committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2005-04-25 22:59:52 +0000 |
commit | 58065e3715b7d2684df76d2f125da422d6dcf2b2 (patch) | |
tree | 3decd478f120e5adeac01030489f76d339cf530b /openwrt/package/uclibc++/Makefile | |
parent | d29d31cfa836fac8e2131ea00c17bd264489db63 (diff) |
add uclibc++
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@717 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'openwrt/package/uclibc++/Makefile')
-rw-r--r-- | openwrt/package/uclibc++/Makefile | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/openwrt/package/uclibc++/Makefile b/openwrt/package/uclibc++/Makefile new file mode 100644 index 000000000..6cc0ceb59 --- /dev/null +++ b/openwrt/package/uclibc++/Makefile @@ -0,0 +1,77 @@ +# $Id$ + +include $(TOPDIR)/rules.mk + +PKG_NAME:=uClibc++ +PKG_VERSION:=0.1.9 +PKG_RELEASE:=1 +PKG_MD5SUM:=ebf58e04d72eab5c131c2c9118737024 + +PKG_SOURCE_URL:=http://cxx.uclibc.org/src/ +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tbz2 +PKG_CAT:=bzcat + +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME) + +IPKG_LIBCXX:=$(PACKAGE_DIR)/$(PKG_NAME)_$(PKG_VERSION)-$(PKG_RELEASE)_$(ARCH).ipk +IDIR_LIBCXX:=$(PKG_BUILD_DIR)/ipkg/$(PKG_NAME) +INFO_LIBCXX:=$(IPKG_STATE_DIR)/info/$(PKG_NAME).list + +UCLIBC_TARGET_ARCH:=$(shell echo $(ARCH) | sed -e s'/-.*//' \ + -e 's/i.86/i386/' \ + -e 's/sparc.*/sparc/' \ + -e 's/arm.*/arm/g' \ + -e 's/m68k.*/m68k/' \ + -e 's/ppc/powerpc/g' \ + -e 's/v850.*/v850/g' \ + -e 's/sh64/sh/' \ + -e 's/sh[234].*/sh/' \ + -e 's/mips.*/mips/' \ + -e 's/mipsel.*/mips/' \ + -e 's/cris.*/cris/' \ +) + + +$(DL_DIR)/$(PKG_SOURCE): + $(SCRIPT_DIR)/download.pl $(DL_DIR) $(PKG_SOURCE) $(PKG_MD5SUM) $(PKG_SOURCE_URL) + +$(PKG_BUILD_DIR)/.prepared: $(DL_DIR)/$(PKG_SOURCE) + $(PKG_CAT) $(DL_DIR)/$(PKG_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + $(PATCH) $(PKG_BUILD_DIR) ./patches + touch $(PKG_BUILD_DIR)/.prepared + +$(PKG_BUILD_DIR)/.config: $(PKG_BUILD_DIR)/.prepared + cp ./uclibc++.config $(PKG_BUILD_DIR)/.config + $(SED) 's,^.*TARGET_ARCH.*,TARGET_ARCH="$(UCLIBC_TARGET_ARCH)",g' $(PKG_BUILD_DIR)/.config + $(SED) 's,^.*ARCH_CFLAGS.*,ARCH_CFLAGS="-mno-split-addresses $(TARGET_CFLAGS)",g' $(PKG_BUILD_DIR)/.config + + +$(PKG_BUILD_DIR)/.built: $(PKG_BUILD_DIR)/.config + $(MAKE) -C $(PKG_BUILD_DIR) \ + $(TARGET_CONFIGURE_OPTS) + touch $(PKG_BUILD_DIR)/.built + +$(STAGING_DIR)/lib/libuClibc++.so: $(PKG_BUILD_DIR)/.built + $(MAKE) -C $(PKG_BUILD_DIR) \ + DESTDIR="$(STAGING_DIR)" \ + install + +$(IPKG_LIBCXX): $(STAGING_DIR)/lib/libuClibc++.so + $(SCRIPT_DIR)/make-ipkg-dir.sh $(IDIR_LIBCXX) ./$(PKG_NAME).control $(PKG_VERSION)-$(PKG_RELEASE) $(ARCH) + mkdir -p $(IDIR_LIBCXX)/usr/lib + cp -fpR $(STAGING_DIR)/lib/libuClibc++.so* $(IDIR_LIBCXX)/usr/lib/ + $(STRIP) $(IDIR_LIBCXX)/usr/lib/*.so* + mkdir -p $(PACKAGE_DIR) + $(IPKG_BUILD) $(IDIR_LIBCXX) $(PACKAGE_DIR) + +$(INFO_LIBCXX): $(IPKG_LIBCXX) + $(IPKG) install $(IPKG_LIBCXX) + +source: $(DL_DIR)/$(PKG_SOURCE) +prepare: $(PKG_BUILD_DIR)/.prepared +compile: $(IPKG_LIBCXX) +install: $(INFO_LIBCXX) + +clean: + rm -rf $(PKG_BUILD_DIR) $(IPKG_LIBCXX) + rm -f $(STAGING_DIR)/lib/libuClibc++.so* |