Merge branch 'build_system' of https://github.com/aelmahmoudy/orbot into aelmahmoudy-build_system
This commit is contained in:
commit
4163fc14d7
|
@ -24,17 +24,37 @@ endif
|
||||||
# Android NDK setup
|
# Android NDK setup
|
||||||
NDK_BASE ?= /opt/android-ndk
|
NDK_BASE ?= /opt/android-ndk
|
||||||
NDK_PLATFORM_LEVEL ?= 16
|
NDK_PLATFORM_LEVEL ?= 16
|
||||||
NDK_ABI ?= arm
|
|
||||||
NDK_TOOLCHAIN_VERSION=4.8
|
NDK_TOOLCHAIN_VERSION=4.8
|
||||||
APP_ABI ?= armeabi
|
APP_ABI ?= armeabi
|
||||||
|
|
||||||
|
NDK_ABI := $(APP_ABI)
|
||||||
|
ifneq ($(filter arm%, $(APP_ABI)),)
|
||||||
|
NDK_ABI := arm
|
||||||
|
endif
|
||||||
|
ifneq ($(filter arm64%, $(APP_ABI)),)
|
||||||
|
NDK_ABI := arm64
|
||||||
|
endif
|
||||||
NDK_SYSROOT=$(NDK_BASE)/platforms/android-$(NDK_PLATFORM_LEVEL)/arch-$(NDK_ABI)
|
NDK_SYSROOT=$(NDK_BASE)/platforms/android-$(NDK_PLATFORM_LEVEL)/arch-$(NDK_ABI)
|
||||||
NDK_UNAME := $(shell uname -s | tr '[A-Z]' '[a-z]')
|
NDK_UNAME := $(shell uname -s | tr '[A-Z]' '[a-z]')
|
||||||
ifeq ($(NDK_ABI),x86)
|
ifneq ($(filter mips%, $(NDK_ABI)),)
|
||||||
HOST = i686-linux-android
|
HOST := $(NDK_ABI)el-linux-android
|
||||||
NDK_TOOLCHAIN = $(NDK_ABI)-$(NDK_TOOLCHAIN_VERSION)
|
endif
|
||||||
else
|
ifneq ($(filter arm64, $(NDK_ABI)),)
|
||||||
HOST = $(NDK_ABI)-linux-androideabi
|
HOST := aarch64-linux-android
|
||||||
NDK_TOOLCHAIN = $(HOST)-$(NDK_TOOLCHAIN_VERSION)
|
endif
|
||||||
|
ifneq ($(filter arm, $(NDK_ABI)),)
|
||||||
|
HOST := arm-linux-androideabi
|
||||||
|
endif
|
||||||
|
ifneq ($(filter x86, $(NDK_ABI)),)
|
||||||
|
HOST := i686-linux-android
|
||||||
|
endif
|
||||||
|
ifneq ($(filter x86_64, $(NDK_ABI)),)
|
||||||
|
HOST := x86_64-linux-android
|
||||||
|
endif
|
||||||
|
|
||||||
|
NDK_TOOLCHAIN := $(HOST)-$(NDK_TOOLCHAIN_VERSION)
|
||||||
|
ifneq ($(filter x86%, $(NDK_ABI)),)
|
||||||
|
NDK_TOOLCHAIN := $(NDK_ABI)-$(NDK_TOOLCHAIN_VERSION)
|
||||||
endif
|
endif
|
||||||
NDK_TOOLCHAIN_BASE=$(NDK_BASE)/toolchains/$(NDK_TOOLCHAIN)/prebuilt/$(NDK_UNAME)-$(NDK_PROCESSOR)
|
NDK_TOOLCHAIN_BASE=$(NDK_BASE)/toolchains/$(NDK_TOOLCHAIN)/prebuilt/$(NDK_UNAME)-$(NDK_PROCESSOR)
|
||||||
|
|
||||||
|
@ -77,16 +97,34 @@ all: assets
|
||||||
#------------------------------------------------------------------------------#
|
#------------------------------------------------------------------------------#
|
||||||
# openssl
|
# openssl
|
||||||
|
|
||||||
|
# Disable rc4 cipher for 64-bit archs, to avoid this link error for tor:
|
||||||
|
# external/lib/libcrypto.a(e_rc4_hmac_md5.o):e_rc4_hmac_md5.c:function rc4_hmac_md5_cipher: error: undefined reference to 'rc4_md5_enc'
|
||||||
|
OPENSSL_CONF_FLAG=
|
||||||
|
ifneq ($(findstring 64, $(NDK_ABI)),)
|
||||||
|
OPENSSL_CONF_FLAG+=no-rc4
|
||||||
|
endif
|
||||||
|
|
||||||
|
# OpenSSL's 'make depend' fails if _MIPS_SZLONG is not set:
|
||||||
|
ifneq ($(filter mips%, $(NDK_ABI)),)
|
||||||
|
ifneq ($(findstring 64, $(NDK_ABI)),)
|
||||||
|
OPENSSL_CONF_FLAG+=-D_MIPS_SZLONG=64
|
||||||
|
else
|
||||||
|
OPENSSL_CONF_FLAG+=-D_MIPS_SZLONG=32
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
lib/libcrypto.a:
|
lib/libcrypto.a:
|
||||||
cd openssl && \
|
cd openssl && \
|
||||||
./Configure android -DL_ENDIAN && \
|
./Configure android -DL_ENDIAN $(OPENSSL_CONF_FLAG) && \
|
||||||
|
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr depend && \
|
||||||
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr build_libs
|
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr build_libs
|
||||||
|
|
||||||
lib/libssl.a:
|
lib/libssl.a:
|
||||||
cp config.sub openssl
|
cp config.sub openssl
|
||||||
cp config.guess openssl
|
cp config.guess openssl
|
||||||
cd openssl && \
|
cd openssl && \
|
||||||
./Configure android -DL_ENDIAN && \
|
./Configure android -DL_ENDIAN $(OPENSSL_CONF_FLAG) && \
|
||||||
|
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr depend && \
|
||||||
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr build_libs
|
make CC="$(CC)" ANDROID_DEV=$(NDK_SYSROOT)/usr build_libs
|
||||||
|
|
||||||
openssl-build-stamp: lib/libcrypto.a lib/libssl.a
|
openssl-build-stamp: lib/libcrypto.a lib/libssl.a
|
||||||
|
@ -112,6 +150,9 @@ openssl-clean:
|
||||||
|
|
||||||
libevent/Makefile:
|
libevent/Makefile:
|
||||||
sed -i 's@\(SUBDIRS = . include\) sample test@\1@' libevent/Makefile.am
|
sed -i 's@\(SUBDIRS = . include\) sample test@\1@' libevent/Makefile.am
|
||||||
|
cp libevent-patch-1 libevent
|
||||||
|
-cd libevent && \
|
||||||
|
patch -N -p1 --reject-file=- < libevent-patch-1
|
||||||
##sed -i 's@\(AC_OUTPUT(Makefile include/Makefile\) test/Makefile sample/Makefile)@\1)@' libevent/configure.in
|
##sed -i 's@\(AC_OUTPUT(Makefile include/Makefile\) test/Makefile sample/Makefile)@\1)@' libevent/configure.in
|
||||||
cd libevent && ./autogen.sh
|
cd libevent && ./autogen.sh
|
||||||
cp config.sub libevent
|
cp config.sub libevent
|
||||||
|
@ -278,7 +319,7 @@ assets-clean:
|
||||||
# cleanup, cleanup, put the toys away
|
# cleanup, cleanup, put the toys away
|
||||||
|
|
||||||
##clean: openssl-clean libevent-clean tor-clean polipo-clean jtorctl-clean assets-clean
|
##clean: openssl-clean libevent-clean tor-clean polipo-clean jtorctl-clean assets-clean
|
||||||
clean: openssl-clean libevent-clean tor-clean polipo-clean jtorctl-clean assets-clean
|
clean: openssl-clean libevent-clean tor-clean polipo-clean iptables-clean jtorctl-clean assets-clean
|
||||||
|
|
||||||
#------------------------------------------------------------------------------#
|
#------------------------------------------------------------------------------#
|
||||||
# debugging stuff
|
# debugging stuff
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
For some reason arc4random_addrandom isn't present in 64-bit android archs. !
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index d42edd8..c511be7 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -290,7 +290,7 @@ AC_HEADER_TIME
|
||||||
|
|
||||||
|
dnl Checks for library functions.
|
||||||
|
AC_CHECK_FUNCS([gettimeofday vasprintf fcntl clock_gettime strtok_r strsep])
|
||||||
|
-AC_CHECK_FUNCS([getnameinfo strlcpy inet_ntop inet_pton signal sigaction strtoll inet_aton pipe eventfd sendfile mmap splice arc4random arc4random_buf issetugid geteuid getegid getprotobynumber setenv unsetenv putenv sysctl])
|
||||||
|
+AC_CHECK_FUNCS([getnameinfo strlcpy inet_ntop inet_pton signal sigaction strtoll inet_aton pipe eventfd sendfile mmap splice arc4random arc4random_buf arc4random_addrandom issetugid geteuid getegid getprotobynumber setenv unsetenv putenv sysctl])
|
||||||
|
AC_CHECK_FUNCS([umask])
|
||||||
|
|
||||||
|
AC_CACHE_CHECK(
|
||||||
|
diff --git a/evutil_rand.c b/evutil_rand.c
|
||||||
|
index 284341c..97161e4 100644
|
||||||
|
--- a/evutil_rand.c
|
||||||
|
+++ b/evutil_rand.c
|
||||||
|
@@ -174,7 +174,9 @@ evutil_secure_rng_get_bytes(void *buf, size_t n)
|
||||||
|
void
|
||||||
|
evutil_secure_rng_add_bytes(const char *buf, size_t n)
|
||||||
|
{
|
||||||
|
+#ifdef _EVENT_HAVE_ARC4RANDOM_ADDRANDOM
|
||||||
|
arc4random_addrandom((unsigned char*)buf,
|
||||||
|
n>(size_t)INT_MAX ? INT_MAX : (int)n);
|
||||||
|
+#endif
|
||||||
|
}
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 2b456034457b58454aae3998a2765b6a5b9bc837
|
Subproject commit 3df69d3aefde7671053d4e3c242b228e5d79c83f
|
Loading…
Reference in New Issue