diff --git a/README.md b/README.md index b22308b..42a5707 100644 --- a/README.md +++ b/README.md @@ -23,6 +23,7 @@ If you have problems building for arm64 please uninstall MacPorts (see #28). * ## Changelog +* 2015-11-16: tvOS support * 2015-10-25: Xcode 7.1 support * 2015-08-06: iOS 9.0 support, Bitcode support * 2015-07-09: OpenSSL 1.0.2d, iOS 8.4 diff --git a/build-libssl.sh b/build-libssl.sh index 9024a2b..f0550e8 100755 --- a/build-libssl.sh +++ b/build-libssl.sh @@ -1,6 +1,6 @@ #!/bin/sh -# Automatic build script for libssl and libcrypto +# Automatic build script for libssl and libcrypto # for iPhoneOS and iPhoneSimulator # # Created by Felix Schulze on 16.12.10. @@ -20,9 +20,10 @@ # ########################################################################### # Change values here # -# +# VERSION="1.0.2d" # -SDKVERSION=`xcrun -sdk iphoneos --show-sdk-version` # +IOS_SDKVERSION=`xcrun -sdk iphoneos --show-sdk-version` +TVOS_SDKVERSION=`xcrun -sdk appletvos --show-sdk-version` # CONFIG_OPTIONS="" CURL_OPTIONS="" @@ -37,12 +38,13 @@ ENABLE_EC_NISTP_64_GCC_128="" CURRENTPATH=`pwd` -ARCHS="i386 x86_64 armv7 armv7s arm64" +ARCHS="i386 x86_64 armv7 armv7s arm64 tv_x86_64 tv_arm64" DEVELOPER=`xcode-select -print-path` -MIN_SDK_VERSION="7.0" +IOS_MIN_SDK_VERSION="7.0" +TVOS_MIN_SDK_VERSION="9.0" if [ ! -d "$DEVELOPER" ]; then - echo "xcode path is not set correctly $DEVELOPER does not exist (most likely because of xcode > 4.3)" + echo "xcode path is not set correctly $DEVELOPER does not exist" echo "run" echo "sudo xcode-select -switch " echo "for default installation:" @@ -50,14 +52,14 @@ if [ ! -d "$DEVELOPER" ]; then exit 1 fi -case $DEVELOPER in +case $DEVELOPER in *\ * ) echo "Your Xcode path contains whitespaces, which is not supported." exit 1 ;; esac -case $CURRENTPATH in +case $CURRENTPATH in *\ * ) echo "Your path contains whitespaces, which is not supported by 'make install'." exit 1 @@ -82,14 +84,32 @@ cd "${CURRENTPATH}/src/openssl-${VERSION}" for ARCH in ${ARCHS} do - if [[ "${ARCH}" == "i386" || "${ARCH}" == "x86_64" ]]; - then + if [[ "$ARCH" == tv* ]]; then + SDKVERSION=$TVOS_SDKVERSION + MIN_SDK_VERSION=$TVOS_MIN_SDK_VERSION + LC_ALL=C sed -i -- 's/define HAVE_FORK 1/define HAVE_FORK 0/' "./apps/speed.c" + LC_ALL=C sed -i -- 's/D\_REENTRANT\:iOS/D\_REENTRANT\:tvOS/' "./Configure" + chmod u+x ./Configure + else + SDKVERSION=$IOS_SDKVERSION + MIN_SDK_VERSION=$IOS_MIN_SDK_VERSION + fi + + if [[ "${ARCH}" == "i386" || "${ARCH}" == "x86_64" ]]; then PLATFORM="iPhoneSimulator" + elif [ "${ARCH}" == "tv_x86_64" ]; then + ARCH="x86_64" + PLATFORM="AppleTVSimulator" + elif [ "${ARCH}" == "tv_arm64" ]; then + ARCH="arm64" + sed -ie "s!static volatile sig_atomic_t intr_signal;!static volatile intr_signal;!" "crypto/ui/ui_openssl.c" + PLATFORM="AppleTVOS" else sed -ie "s!static volatile sig_atomic_t intr_signal;!static volatile intr_signal;!" "crypto/ui/ui_openssl.c" - PLATFORM="iPhoneOS" + PLATFORM="iPhoneOS" fi - + + export $PLATFORM export CROSS_TOP="${DEVELOPER}/Platforms/${PLATFORM}.platform/Developer" export CROSS_SDK="${PLATFORM}${SDKVERSION}.sdk" export BUILD_TOOLS="${DEVELOPER}" @@ -121,18 +141,20 @@ do else ./Configure iphoneos-cross --openssldir="${CURRENTPATH}/bin/${PLATFORM}${SDKVERSION}-${ARCH}.sdk" ${LOCAL_CONFIG_OPTIONS} > "${LOG}" 2>&1 fi - - if [ $? != 0 ]; - then - echo "Problem while configure - Please check ${LOG}" - exit 1 - fi - # add -isysroot to CC= - sed -ie "s!^CFLAG=!CFLAG=-isysroot ${CROSS_TOP}/SDKs/${CROSS_SDK} -miphoneos-version-min=${MIN_SDK_VERSION} !" "Makefile" + if [ $? != 0 ]; then + echo "Problem while configure - Please check ${LOG}" + exit 1 + fi - if [ "$1" == "verbose" ]; - then + # add -isysroot to CC= + if [[ "${PLATFORM}" == "AppleTVSimulator" || "${PLATFORM}" == "AppleTVOS" ]]; then + sed -ie "s!^CFLAG=!CFLAG=-isysroot ${CROSS_TOP}/SDKs/${CROSS_SDK} -mtvos-version-min=${TVOS_MIN_SDK_VERSION} !" "Makefile" + else + sed -ie "s!^CFLAG=!CFLAG=-isysroot ${CROSS_TOP}/SDKs/${CROSS_SDK} -miphoneos-version-min=${MIN_SDK_VERSION} !" "Makefile" + fi + + if [ "$1" == "verbose" ]; then if [[ ! -z $CONFIG_OPTIONS ]]; then make depend fi @@ -143,22 +165,24 @@ do fi make >> "${LOG}" 2>&1 fi - - if [ $? != 0 ]; - then - echo "Problem while make - Please check ${LOG}" - exit 1 - fi - - set -e + + if [ $? != 0 ]; then + echo "Problem while make - Please check ${LOG}" + exit 1 + fi + + set -e make install_sw >> "${LOG}" 2>&1 make clean >> "${LOG}" 2>&1 done -echo "Build library..." -lipo -create ${CURRENTPATH}/bin/iPhoneSimulator${SDKVERSION}-i386.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneSimulator${SDKVERSION}-x86_64.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-armv7.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-armv7s.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-arm64.sdk/lib/libssl.a -output ${CURRENTPATH}/lib/libssl.a +echo "Build library for iOS..." +lipo -create ${CURRENTPATH}/bin/iPhoneSimulator${IOS_SDKVERSION}-i386.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneSimulator${IOS_SDKVERSION}-x86_64.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-armv7.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-armv7s.sdk/lib/libssl.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-arm64.sdk/lib/libssl.a -output ${CURRENTPATH}/lib/libssl.a +lipo -create ${CURRENTPATH}/bin/iPhoneSimulator${IOS_SDKVERSION}-i386.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneSimulator${IOS_SDKVERSION}-x86_64.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-armv7.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-armv7s.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${IOS_SDKVERSION}-arm64.sdk/lib/libcrypto.a -output ${CURRENTPATH}/lib/libcrypto.a -lipo -create ${CURRENTPATH}/bin/iPhoneSimulator${SDKVERSION}-i386.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneSimulator${SDKVERSION}-x86_64.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-armv7.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-armv7s.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/iPhoneOS${SDKVERSION}-arm64.sdk/lib/libcrypto.a -output ${CURRENTPATH}/lib/libcrypto.a +echo "Build library for tvOS..." +lipo -create ${CURRENTPATH}/bin/AppleTVSimulator${TVOS_SDKVERSION}-x86_64.sdk/lib/libssl.a ${CURRENTPATH}/bin/AppleTVOS${TVOS_SDKVERSION}-arm64.sdk/lib/libssl.a -output ${CURRENTPATH}/lib/libssl-tvOS.a +lipo -create ${CURRENTPATH}/bin/AppleTVSimulator${TVOS_SDKVERSION}-x86_64.sdk/lib/libcrypto.a ${CURRENTPATH}/bin/AppleTVOS${TVOS_SDKVERSION}-arm64.sdk/lib/libcrypto.a -output ${CURRENTPATH}/lib/libcrypto-tvOS.a mkdir -p ${CURRENTPATH}/include cp -R ${CURRENTPATH}/bin/iPhoneSimulator${SDKVERSION}-i386.sdk/include/openssl ${CURRENTPATH}/include/