summaryrefslogtreecommitdiff
path: root/cleopatre/buildroot/package/openssl/openssl.mk
diff options
context:
space:
mode:
authorlefranc2008-08-01 09:25:43 +0000
committerlefranc2008-08-01 09:25:43 +0000
commit9a2bcc0b92b392f1f21cd26927515e4d49bc128e (patch)
treed0bd193c764606c4c6e4b4568ef08d0ff3324b72 /cleopatre/buildroot/package/openssl/openssl.mk
parentd0cc0304ed6eaf72116743e13e5b3b3cbfd878bb (diff)
- import of buildroot original sources (20080729 version)
git-svn-id: svn+ssh://pessac/svn/cesar/trunk@2704 017c9cb6-072f-447c-8318-d5b54f68fe89
Diffstat (limited to 'cleopatre/buildroot/package/openssl/openssl.mk')
-rw-r--r--cleopatre/buildroot/package/openssl/openssl.mk118
1 files changed, 118 insertions, 0 deletions
diff --git a/cleopatre/buildroot/package/openssl/openssl.mk b/cleopatre/buildroot/package/openssl/openssl.mk
new file mode 100644
index 0000000000..01cddb9027
--- /dev/null
+++ b/cleopatre/buildroot/package/openssl/openssl.mk
@@ -0,0 +1,118 @@
+#############################################################
+#
+# openssl
+#
+#############################################################
+
+# TARGETS
+OPENSSL_VERSION:=0.9.7m
+OPENSSL_SITE:=http://www.openssl.org/source
+OPENSSL_SOURCE:=openssl-$(OPENSSL_VERSION).tar.gz
+OPENSSL_CAT:=$(ZCAT)
+OPENSSL_DIR:=$(BUILD_DIR)/openssl-$(OPENSSL_VERSION)
+
+OPENSSL_TARGET_ARCH:=
+ifeq ($(BR2_i386),y)
+ifneq ($(ARCH),i386)
+OPENSSL_TARGET_ARCH:=i386-$(ARCH)
+endif
+ifeq ($(ARCH),i686)
+OPENSSL_TARGET_ARCH:=i386-i686/cmov
+endif
+endif
+ifeq ($(OPENSSL_TARGET_ARCH),)
+OPENSSL_TARGET_ARCH:=$(ARCH)
+endif
+
+$(DL_DIR)/$(OPENSSL_SOURCE):
+ $(WGET) -P $(DL_DIR) $(OPENSSL_SITE)/$(OPENSSL_SOURCE)
+
+openssl-unpack: $(OPENSSL_DIR)/.unpacked
+$(OPENSSL_DIR)/.unpacked: $(DL_DIR)/$(OPENSSL_SOURCE)
+ $(OPENSSL_CAT) $(DL_DIR)/$(OPENSSL_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
+ toolchain/patch-kernel.sh $(OPENSSL_DIR) package/openssl/ openssl\*.patch
+ toolchain/patch-kernel.sh $(OPENSSL_DIR) package/openssl/ openssl\*.patch.$(ARCH)
+ # sigh... we have to resort to this just to set a gcc flag.
+ # grumble.. and of course make sure to escape any '/' in CFLAGS
+ifeq ($(BR2_avr32),)
+ $(SED) 's,/CFLAG=,/CFLAG= $(TARGET_SOFT_FLOAT) ,g' \
+ $(OPENSSL_DIR)/Configure
+endif
+ $(SED) '/CFLAG=/s,/;, $(shell echo '$(TARGET_CFLAGS)' | sed -e 's/\//\\\\\//g')/;,' \
+ $(OPENSSL_DIR)/Configure
+ touch $@
+
+$(OPENSSL_DIR)/Makefile: $(OPENSSL_DIR)/.unpacked
+ (cd $(OPENSSL_DIR); \
+ CFLAGS="-DOPENSSL_NO_KRB5 -DOPENSSL_NO_IDEA -DOPENSSL_NO_MDC2 -DOPENSSL_NO_RC5 $(TARGET_CFLAGS)" \
+ PATH=$(TARGET_PATH) \
+ ./Configure linux-$(OPENSSL_TARGET_ARCH) --prefix=/ \
+ --openssldir=/lib/ssl -L$(STAGING_DIR)/lib -ldl \
+ -I$(STAGING_DIR)/usr/include $(OPENSSL_OPTS) threads \
+ shared no-idea no-mdc2 no-rc5)
+
+# --openssldir=/usr/lib/ssl results in files in /usr/usr/lib...
+
+$(OPENSSL_DIR)/apps/openssl: $(OPENSSL_DIR)/Makefile
+ $(MAKE1) CC=$(TARGET_CC) -C $(OPENSSL_DIR) all build-shared
+ # Work around openssl build bug to link libssl.so with libcrypto.so.
+ -rm $(OPENSSL_DIR)/libssl.so.*.*.*
+ $(MAKE1) CC=$(TARGET_CC) -C $(OPENSSL_DIR) do_linux-shared
+
+$(STAGING_DIR)/usr/lib/libcrypto.a: $(OPENSSL_DIR)/apps/openssl
+ $(MAKE) CC=$(TARGET_CC) INSTALL_PREFIX=$(STAGING_DIR)/usr -C $(OPENSSL_DIR) install
+ cp -fa $(OPENSSL_DIR)/libcrypto.so* $(STAGING_DIR)/usr/lib/
+ chmod a-x $(STAGING_DIR)/usr/lib/libcrypto.so.0.9.7
+ (cd $(STAGING_DIR)/usr/lib; \
+ ln -fs libcrypto.so.0.9.7 libcrypto.so; \
+ ln -fs libcrypto.so.0.9.7 libcrypto.so.0; \
+ )
+ cp -fa $(OPENSSL_DIR)/libssl.so* $(STAGING_DIR)/usr/lib/
+ chmod a-x $(STAGING_DIR)/usr/lib/libssl.so.0.9.7
+ (cd $(STAGING_DIR)/usr/lib; \
+ ln -fs libssl.so.0.9.7 libssl.so; \
+ ln -fs libssl.so.0.9.7 libssl.so.0; \
+ )
+ touch -c $@
+
+$(TARGET_DIR)/usr/lib/libcrypto.so.0.9.7: $(STAGING_DIR)/usr/lib/libcrypto.a
+ mkdir -p $(TARGET_DIR)/usr/lib
+ cp -fa $(STAGING_DIR)/usr/lib/libcrypto.so* $(TARGET_DIR)/usr/lib/
+ cp -fa $(STAGING_DIR)/usr/lib/libssl.so* $(TARGET_DIR)/usr/lib/
+ #cp -fa $(STAGING_DIR)/bin/openssl $(TARGET_DIR)/bin/
+ -$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libssl.so.0.9.7
+ -$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libcrypto.so.0.9.7
+
+$(TARGET_DIR)/usr/lib/libssl.a: $(STAGING_DIR)/usr/lib/libcrypto.a
+ mkdir -p $(TARGET_DIR)/usr/include
+ cp -a $(STAGING_DIR)/usr/include/openssl $(TARGET_DIR)/usr/include/
+ cp -dpf $(STAGING_DIR)/usr/lib/libssl.a $(TARGET_DIR)/usr/lib/
+ cp -dpf $(STAGING_DIR)/usr/lib/libcrypto.a $(TARGET_DIR)/usr/lib/
+ touch -c $@
+
+openssl-headers: $(TARGET_DIR)/usr/lib/libssl.a
+
+openssl: uclibc $(TARGET_DIR)/usr/lib/libcrypto.so.0.9.7
+
+openssl-source: $(DL_DIR)/$(OPENSSL_SOURCE)
+
+openssl-clean:
+ -$(MAKE) -C $(OPENSSL_DIR) clean
+ rm -f $(STAGING_DIR)/usr/bin/openssl $(TARGET_DIR)/usr/bin/openssl
+ -rm -f $(STAGING_DIR)/usr/lib/libcrypto.so* $(TARGET_DIR)/usr/lib/libcrypto.so*
+ -rm -f $(STAGING_DIR)/usr/lib/libssl.so* $(TARGET_DIR)/usr/lib/libssl.so*
+ rm -rf $(STAGING_DIR)/usr/include/openssl $(TARGET_DIR)/usr/include/openssl
+
+openssl-dirclean:
+ rm -rf $(OPENSSL_DIR)
+#############################################################
+#
+# Toplevel Makefile options
+#
+#############################################################
+ifeq ($(strip $(BR2_PACKAGE_OPENSSL)),y)
+TARGETS+=openssl
+endif
+ifeq ($(strip $(BR2_PACKAGE_OPENSSL_TARGET_HEADERS)),y)
+TARGETS+=openssl-headers
+endif