diff --git a/android/Android_Readme.md b/android/Android_Readme.md new file mode 100644 index 000000000..0316894de --- /dev/null +++ b/android/Android_Readme.md @@ -0,0 +1,40 @@ +## Quick Android Environment setup instructions + +- Download NDK command line toolkit from http://developer.android.com/ndk/downloads/index.html +- Extract the archive or execute the binary to extract the files. +- Rename the extracted directory to "ndk" +- cd ndk +- Execute following command to create a standalone NDK Toolchain, which will be used to compile iguana for Android. MAKE SURE TO CHANGE VALUE OF "--install-dir". + +build/tools/make-standalone-toolchain.sh --toolchain=arm-linux-androideabi-4.9 --platform=android-21 --install-dir=/home/user/ndkTC + +- Copy "curl" and "openssl" directory from "/android/include/" to NDK Standalone Toolchain directory's library includes directory. (eg. /home/user/ndkTC/sysroot/usr/include/) +- Copy all files from "/android/lib/" to NDK Standalone Toolchain directory's "lib" files directory. (eg. /home/user/ndkTC/sysroot/usr/lib/) + +- Now edit the "set_android_env.sh" file's 'BASIC' section with correct path of 'NDK' and 'NDKTC'. +- Make sure "set_android_env.sh" file is executable. set it to executable with command 'chmod 755 set_android_env.sh' + +- Once done execute the 'set_android_env.sh' to set the Android Development Environment for that terminal window using following command: + +source set_android_env.sh + +- Check if you get output of following commands: + +echo $CC +echo $CC2 +echo $AR + +- If getting output your Android NDK developement environment is set temporarily in terminal window in which you executed the set_android_env.sh script. + + +## Compile iguana for android + +- Once you have the Android NDK environment set, execute the following commands: + +./m_onetime_android +./m_android + + +NOTE: This build of iguan will only work with Android version 5.x. Tested with Android 6.0 gave errors related to libssl functions. If you want to compile iguana for Android 6.0, you either need to compile static 'libssl.a' or NDK 'Platform 23' directory. + +More detailed instructions you may visit the developer wiki at https://phabricator.supernet.org/w/iguana/development/android/ \ No newline at end of file diff --git a/arm/include/curl/Makefile b/android/include/curl/Makefile similarity index 100% rename from arm/include/curl/Makefile rename to android/include/curl/Makefile diff --git a/arm/include/curl/Makefile.am b/android/include/curl/Makefile.am similarity index 100% rename from arm/include/curl/Makefile.am rename to android/include/curl/Makefile.am diff --git a/arm/include/curl/Makefile.in b/android/include/curl/Makefile.in similarity index 100% rename from arm/include/curl/Makefile.in rename to android/include/curl/Makefile.in diff --git a/arm/include/curl/curl.h b/android/include/curl/curl.h similarity index 100% rename from arm/include/curl/curl.h rename to android/include/curl/curl.h diff --git a/arm/include/curl/curlbuild.h b/android/include/curl/curlbuild.h similarity index 100% rename from arm/include/curl/curlbuild.h rename to android/include/curl/curlbuild.h diff --git a/arm/include/curl/curlbuild.h.cmake b/android/include/curl/curlbuild.h.cmake similarity index 100% rename from arm/include/curl/curlbuild.h.cmake rename to android/include/curl/curlbuild.h.cmake diff --git a/arm/include/curl/curlbuild.h.in b/android/include/curl/curlbuild.h.in similarity index 100% rename from arm/include/curl/curlbuild.h.in rename to android/include/curl/curlbuild.h.in diff --git a/arm/include/curl/curlrules.h b/android/include/curl/curlrules.h similarity index 100% rename from arm/include/curl/curlrules.h rename to android/include/curl/curlrules.h diff --git a/arm/include/curl/curlver.h b/android/include/curl/curlver.h similarity index 100% rename from arm/include/curl/curlver.h rename to android/include/curl/curlver.h diff --git a/arm/include/curl/easy.h b/android/include/curl/easy.h similarity index 100% rename from arm/include/curl/easy.h rename to android/include/curl/easy.h diff --git a/arm/include/curl/mprintf.h b/android/include/curl/mprintf.h similarity index 100% rename from arm/include/curl/mprintf.h rename to android/include/curl/mprintf.h diff --git a/arm/include/curl/multi.h b/android/include/curl/multi.h similarity index 100% rename from arm/include/curl/multi.h rename to android/include/curl/multi.h diff --git a/arm/include/curl/stamp-h2 b/android/include/curl/stamp-h2 similarity index 100% rename from arm/include/curl/stamp-h2 rename to android/include/curl/stamp-h2 diff --git a/arm/include/curl/stdcheaders.h b/android/include/curl/stdcheaders.h similarity index 100% rename from arm/include/curl/stdcheaders.h rename to android/include/curl/stdcheaders.h diff --git a/arm/include/curl/typecheck-gcc.h b/android/include/curl/typecheck-gcc.h similarity index 100% rename from arm/include/curl/typecheck-gcc.h rename to android/include/curl/typecheck-gcc.h diff --git a/arm/include/openssl/aes.h b/android/include/openssl/aes.h similarity index 100% rename from arm/include/openssl/aes.h rename to android/include/openssl/aes.h diff --git a/arm/include/openssl/asn1.h b/android/include/openssl/asn1.h similarity index 100% rename from arm/include/openssl/asn1.h rename to android/include/openssl/asn1.h diff --git a/arm/include/openssl/asn1_mac.h b/android/include/openssl/asn1_mac.h similarity index 100% rename from arm/include/openssl/asn1_mac.h rename to android/include/openssl/asn1_mac.h diff --git a/arm/include/openssl/asn1t.h b/android/include/openssl/asn1t.h similarity index 100% rename from arm/include/openssl/asn1t.h rename to android/include/openssl/asn1t.h diff --git a/arm/include/openssl/bio.h b/android/include/openssl/bio.h similarity index 100% rename from arm/include/openssl/bio.h rename to android/include/openssl/bio.h diff --git a/arm/include/openssl/blowfish.h b/android/include/openssl/blowfish.h similarity index 100% rename from arm/include/openssl/blowfish.h rename to android/include/openssl/blowfish.h diff --git a/arm/include/openssl/bn.h b/android/include/openssl/bn.h similarity index 100% rename from arm/include/openssl/bn.h rename to android/include/openssl/bn.h diff --git a/arm/include/openssl/buffer.h b/android/include/openssl/buffer.h similarity index 100% rename from arm/include/openssl/buffer.h rename to android/include/openssl/buffer.h diff --git a/arm/include/openssl/camellia.h b/android/include/openssl/camellia.h similarity index 100% rename from arm/include/openssl/camellia.h rename to android/include/openssl/camellia.h diff --git a/arm/include/openssl/cast.h b/android/include/openssl/cast.h similarity index 100% rename from arm/include/openssl/cast.h rename to android/include/openssl/cast.h diff --git a/arm/include/openssl/cmac.h b/android/include/openssl/cmac.h similarity index 100% rename from arm/include/openssl/cmac.h rename to android/include/openssl/cmac.h diff --git a/arm/include/openssl/cms.h b/android/include/openssl/cms.h similarity index 100% rename from arm/include/openssl/cms.h rename to android/include/openssl/cms.h diff --git a/arm/include/openssl/comp.h b/android/include/openssl/comp.h similarity index 100% rename from arm/include/openssl/comp.h rename to android/include/openssl/comp.h diff --git a/arm/include/openssl/conf.h b/android/include/openssl/conf.h similarity index 100% rename from arm/include/openssl/conf.h rename to android/include/openssl/conf.h diff --git a/arm/include/openssl/conf_api.h b/android/include/openssl/conf_api.h similarity index 100% rename from arm/include/openssl/conf_api.h rename to android/include/openssl/conf_api.h diff --git a/arm/include/openssl/cryptlib.h b/android/include/openssl/cryptlib.h similarity index 100% rename from arm/include/openssl/cryptlib.h rename to android/include/openssl/cryptlib.h diff --git a/arm/include/openssl/crypto.h b/android/include/openssl/crypto.h similarity index 100% rename from arm/include/openssl/crypto.h rename to android/include/openssl/crypto.h diff --git a/arm/include/openssl/curl.h b/android/include/openssl/curl.h similarity index 100% rename from arm/include/openssl/curl.h rename to android/include/openssl/curl.h diff --git a/arm/include/openssl/curlbuild.h b/android/include/openssl/curlbuild.h similarity index 100% rename from arm/include/openssl/curlbuild.h rename to android/include/openssl/curlbuild.h diff --git a/arm/include/openssl/curlrules.h b/android/include/openssl/curlrules.h similarity index 100% rename from arm/include/openssl/curlrules.h rename to android/include/openssl/curlrules.h diff --git a/arm/include/openssl/curlver.h b/android/include/openssl/curlver.h similarity index 100% rename from arm/include/openssl/curlver.h rename to android/include/openssl/curlver.h diff --git a/arm/include/openssl/des.h b/android/include/openssl/des.h similarity index 100% rename from arm/include/openssl/des.h rename to android/include/openssl/des.h diff --git a/arm/include/openssl/des_old.h b/android/include/openssl/des_old.h similarity index 100% rename from arm/include/openssl/des_old.h rename to android/include/openssl/des_old.h diff --git a/arm/include/openssl/dh.h b/android/include/openssl/dh.h similarity index 100% rename from arm/include/openssl/dh.h rename to android/include/openssl/dh.h diff --git a/arm/include/openssl/dsa.h b/android/include/openssl/dsa.h similarity index 100% rename from arm/include/openssl/dsa.h rename to android/include/openssl/dsa.h diff --git a/arm/include/openssl/dso.h b/android/include/openssl/dso.h similarity index 100% rename from arm/include/openssl/dso.h rename to android/include/openssl/dso.h diff --git a/arm/include/openssl/dtls1.h b/android/include/openssl/dtls1.h similarity index 100% rename from arm/include/openssl/dtls1.h rename to android/include/openssl/dtls1.h diff --git a/arm/include/openssl/e_os.h b/android/include/openssl/e_os.h similarity index 100% rename from arm/include/openssl/e_os.h rename to android/include/openssl/e_os.h diff --git a/arm/include/openssl/e_os2.h b/android/include/openssl/e_os2.h similarity index 100% rename from arm/include/openssl/e_os2.h rename to android/include/openssl/e_os2.h diff --git a/arm/include/openssl/easy.h b/android/include/openssl/easy.h similarity index 100% rename from arm/include/openssl/easy.h rename to android/include/openssl/easy.h diff --git a/arm/include/openssl/ebcdic.h b/android/include/openssl/ebcdic.h similarity index 100% rename from arm/include/openssl/ebcdic.h rename to android/include/openssl/ebcdic.h diff --git a/arm/include/openssl/ec.h b/android/include/openssl/ec.h similarity index 100% rename from arm/include/openssl/ec.h rename to android/include/openssl/ec.h diff --git a/arm/include/openssl/ecdh.h b/android/include/openssl/ecdh.h similarity index 100% rename from arm/include/openssl/ecdh.h rename to android/include/openssl/ecdh.h diff --git a/arm/include/openssl/ecdsa.h b/android/include/openssl/ecdsa.h similarity index 100% rename from arm/include/openssl/ecdsa.h rename to android/include/openssl/ecdsa.h diff --git a/arm/include/openssl/engine.h b/android/include/openssl/engine.h similarity index 100% rename from arm/include/openssl/engine.h rename to android/include/openssl/engine.h diff --git a/arm/include/openssl/err.h b/android/include/openssl/err.h similarity index 100% rename from arm/include/openssl/err.h rename to android/include/openssl/err.h diff --git a/arm/include/openssl/evp.h b/android/include/openssl/evp.h similarity index 100% rename from arm/include/openssl/evp.h rename to android/include/openssl/evp.h diff --git a/arm/include/openssl/fips_err.h b/android/include/openssl/fips_err.h similarity index 100% rename from arm/include/openssl/fips_err.h rename to android/include/openssl/fips_err.h diff --git a/arm/include/openssl/hmac.h b/android/include/openssl/hmac.h similarity index 100% rename from arm/include/openssl/hmac.h rename to android/include/openssl/hmac.h diff --git a/arm/include/openssl/idea.h b/android/include/openssl/idea.h similarity index 100% rename from arm/include/openssl/idea.h rename to android/include/openssl/idea.h diff --git a/arm/include/openssl/krb5_asn.h b/android/include/openssl/krb5_asn.h similarity index 100% rename from arm/include/openssl/krb5_asn.h rename to android/include/openssl/krb5_asn.h diff --git a/arm/include/openssl/kssl.h b/android/include/openssl/kssl.h similarity index 100% rename from arm/include/openssl/kssl.h rename to android/include/openssl/kssl.h diff --git a/arm/include/openssl/lhash.h b/android/include/openssl/lhash.h similarity index 100% rename from arm/include/openssl/lhash.h rename to android/include/openssl/lhash.h diff --git a/arm/include/openssl/md32_common.h b/android/include/openssl/md32_common.h similarity index 100% rename from arm/include/openssl/md32_common.h rename to android/include/openssl/md32_common.h diff --git a/arm/include/openssl/md4.h b/android/include/openssl/md4.h similarity index 100% rename from arm/include/openssl/md4.h rename to android/include/openssl/md4.h diff --git a/arm/include/openssl/md5.h b/android/include/openssl/md5.h similarity index 100% rename from arm/include/openssl/md5.h rename to android/include/openssl/md5.h diff --git a/arm/include/openssl/mdc2.h b/android/include/openssl/mdc2.h similarity index 100% rename from arm/include/openssl/mdc2.h rename to android/include/openssl/mdc2.h diff --git a/arm/include/openssl/modes.h b/android/include/openssl/modes.h similarity index 100% rename from arm/include/openssl/modes.h rename to android/include/openssl/modes.h diff --git a/arm/include/openssl/mprintf.h b/android/include/openssl/mprintf.h similarity index 100% rename from arm/include/openssl/mprintf.h rename to android/include/openssl/mprintf.h diff --git a/arm/include/openssl/multi.h b/android/include/openssl/multi.h similarity index 100% rename from arm/include/openssl/multi.h rename to android/include/openssl/multi.h diff --git a/arm/include/openssl/o_dir.h b/android/include/openssl/o_dir.h similarity index 100% rename from arm/include/openssl/o_dir.h rename to android/include/openssl/o_dir.h diff --git a/arm/include/openssl/o_str.h b/android/include/openssl/o_str.h similarity index 100% rename from arm/include/openssl/o_str.h rename to android/include/openssl/o_str.h diff --git a/arm/include/openssl/o_time.h b/android/include/openssl/o_time.h similarity index 100% rename from arm/include/openssl/o_time.h rename to android/include/openssl/o_time.h diff --git a/arm/include/openssl/obj_mac.h b/android/include/openssl/obj_mac.h similarity index 100% rename from arm/include/openssl/obj_mac.h rename to android/include/openssl/obj_mac.h diff --git a/arm/include/openssl/objects.h b/android/include/openssl/objects.h similarity index 100% rename from arm/include/openssl/objects.h rename to android/include/openssl/objects.h diff --git a/arm/include/openssl/ocsp.h b/android/include/openssl/ocsp.h similarity index 100% rename from arm/include/openssl/ocsp.h rename to android/include/openssl/ocsp.h diff --git a/arm/include/openssl/opensslconf.h b/android/include/openssl/opensslconf.h similarity index 100% rename from arm/include/openssl/opensslconf.h rename to android/include/openssl/opensslconf.h diff --git a/arm/include/openssl/opensslv.h b/android/include/openssl/opensslv.h similarity index 100% rename from arm/include/openssl/opensslv.h rename to android/include/openssl/opensslv.h diff --git a/arm/include/openssl/ossl_typ.h b/android/include/openssl/ossl_typ.h similarity index 100% rename from arm/include/openssl/ossl_typ.h rename to android/include/openssl/ossl_typ.h diff --git a/arm/include/openssl/pem.h b/android/include/openssl/pem.h similarity index 100% rename from arm/include/openssl/pem.h rename to android/include/openssl/pem.h diff --git a/arm/include/openssl/pem2.h b/android/include/openssl/pem2.h similarity index 100% rename from arm/include/openssl/pem2.h rename to android/include/openssl/pem2.h diff --git a/arm/include/openssl/pkcs12.h b/android/include/openssl/pkcs12.h similarity index 100% rename from arm/include/openssl/pkcs12.h rename to android/include/openssl/pkcs12.h diff --git a/arm/include/openssl/pkcs7.h b/android/include/openssl/pkcs7.h similarity index 100% rename from arm/include/openssl/pkcs7.h rename to android/include/openssl/pkcs7.h diff --git a/arm/include/openssl/pqueue.h b/android/include/openssl/pqueue.h similarity index 100% rename from arm/include/openssl/pqueue.h rename to android/include/openssl/pqueue.h diff --git a/arm/include/openssl/rand.h b/android/include/openssl/rand.h similarity index 100% rename from arm/include/openssl/rand.h rename to android/include/openssl/rand.h diff --git a/arm/include/openssl/rc2.h b/android/include/openssl/rc2.h similarity index 100% rename from arm/include/openssl/rc2.h rename to android/include/openssl/rc2.h diff --git a/arm/include/openssl/rc4.h b/android/include/openssl/rc4.h similarity index 100% rename from arm/include/openssl/rc4.h rename to android/include/openssl/rc4.h diff --git a/arm/include/openssl/ripemd.h b/android/include/openssl/ripemd.h similarity index 100% rename from arm/include/openssl/ripemd.h rename to android/include/openssl/ripemd.h diff --git a/arm/include/openssl/rsa.h b/android/include/openssl/rsa.h similarity index 100% rename from arm/include/openssl/rsa.h rename to android/include/openssl/rsa.h diff --git a/arm/include/openssl/safestack.h b/android/include/openssl/safestack.h similarity index 100% rename from arm/include/openssl/safestack.h rename to android/include/openssl/safestack.h diff --git a/arm/include/openssl/seed.h b/android/include/openssl/seed.h similarity index 100% rename from arm/include/openssl/seed.h rename to android/include/openssl/seed.h diff --git a/arm/include/openssl/sha.h b/android/include/openssl/sha.h similarity index 100% rename from arm/include/openssl/sha.h rename to android/include/openssl/sha.h diff --git a/arm/include/openssl/srp.h b/android/include/openssl/srp.h similarity index 100% rename from arm/include/openssl/srp.h rename to android/include/openssl/srp.h diff --git a/arm/include/openssl/srtp.h b/android/include/openssl/srtp.h similarity index 100% rename from arm/include/openssl/srtp.h rename to android/include/openssl/srtp.h diff --git a/arm/include/openssl/ssl.h b/android/include/openssl/ssl.h similarity index 100% rename from arm/include/openssl/ssl.h rename to android/include/openssl/ssl.h diff --git a/arm/include/openssl/ssl2.h b/android/include/openssl/ssl2.h similarity index 100% rename from arm/include/openssl/ssl2.h rename to android/include/openssl/ssl2.h diff --git a/arm/include/openssl/ssl23.h b/android/include/openssl/ssl23.h similarity index 100% rename from arm/include/openssl/ssl23.h rename to android/include/openssl/ssl23.h diff --git a/arm/include/openssl/ssl3.h b/android/include/openssl/ssl3.h similarity index 100% rename from arm/include/openssl/ssl3.h rename to android/include/openssl/ssl3.h diff --git a/arm/include/openssl/stack.h b/android/include/openssl/stack.h similarity index 100% rename from arm/include/openssl/stack.h rename to android/include/openssl/stack.h diff --git a/arm/include/openssl/stdcheaders.h b/android/include/openssl/stdcheaders.h similarity index 100% rename from arm/include/openssl/stdcheaders.h rename to android/include/openssl/stdcheaders.h diff --git a/arm/include/openssl/symhacks.h b/android/include/openssl/symhacks.h similarity index 100% rename from arm/include/openssl/symhacks.h rename to android/include/openssl/symhacks.h diff --git a/arm/include/openssl/tls1.h b/android/include/openssl/tls1.h similarity index 100% rename from arm/include/openssl/tls1.h rename to android/include/openssl/tls1.h diff --git a/arm/include/openssl/ts.h b/android/include/openssl/ts.h similarity index 100% rename from arm/include/openssl/ts.h rename to android/include/openssl/ts.h diff --git a/arm/include/openssl/txt_db.h b/android/include/openssl/txt_db.h similarity index 100% rename from arm/include/openssl/txt_db.h rename to android/include/openssl/txt_db.h diff --git a/arm/include/openssl/typecheck-gcc.h b/android/include/openssl/typecheck-gcc.h similarity index 100% rename from arm/include/openssl/typecheck-gcc.h rename to android/include/openssl/typecheck-gcc.h diff --git a/arm/include/openssl/ui.h b/android/include/openssl/ui.h similarity index 100% rename from arm/include/openssl/ui.h rename to android/include/openssl/ui.h diff --git a/arm/include/openssl/ui_compat.h b/android/include/openssl/ui_compat.h similarity index 100% rename from arm/include/openssl/ui_compat.h rename to android/include/openssl/ui_compat.h diff --git a/arm/include/openssl/vms_rms.h b/android/include/openssl/vms_rms.h similarity index 100% rename from arm/include/openssl/vms_rms.h rename to android/include/openssl/vms_rms.h diff --git a/arm/include/openssl/whrlpool.h b/android/include/openssl/whrlpool.h similarity index 100% rename from arm/include/openssl/whrlpool.h rename to android/include/openssl/whrlpool.h diff --git a/arm/include/openssl/x509.h b/android/include/openssl/x509.h similarity index 100% rename from arm/include/openssl/x509.h rename to android/include/openssl/x509.h diff --git a/arm/include/openssl/x509_vfy.h b/android/include/openssl/x509_vfy.h similarity index 100% rename from arm/include/openssl/x509_vfy.h rename to android/include/openssl/x509_vfy.h diff --git a/arm/include/openssl/x509v3.h b/android/include/openssl/x509v3.h similarity index 100% rename from arm/include/openssl/x509v3.h rename to android/include/openssl/x509v3.h diff --git a/arm/include/openssl/zconf.h b/android/include/openssl/zconf.h similarity index 100% rename from arm/include/openssl/zconf.h rename to android/include/openssl/zconf.h diff --git a/arm/include/openssl/zlib.h b/android/include/openssl/zlib.h similarity index 100% rename from arm/include/openssl/zlib.h rename to android/include/openssl/zlib.h diff --git a/arm/libcrypto.so b/android/lib/libcrypto.so similarity index 100% rename from arm/libcrypto.so rename to android/lib/libcrypto.so diff --git a/arm/libcurl.a b/android/lib/libcurl.a similarity index 100% rename from arm/libcurl.a rename to android/lib/libcurl.a diff --git a/arm/libssl.so b/android/lib/libssl.so similarity index 100% rename from arm/libssl.so rename to android/lib/libssl.so diff --git a/android/set_android_env.sh b/android/set_android_env.sh new file mode 100755 index 000000000..275627d67 --- /dev/null +++ b/android/set_android_env.sh @@ -0,0 +1,209 @@ +#!/bin/bash + +# _ _ _ _ _ +# | |_ _ ___| |_ / \ _ __ ___| |__ (_) +# _ | | | | / __| __| / _ \ | '__/ __| '_ \| | +# | |_| | |_| \__ \ |_ / ___ \| | | (__| | | | | +# \___/ \__,_|___/\__/_/ \_\_| \___|_| |_|_| +# +# Copyright 2014-2015 Ɓukasz "JustArchi" Domeradzki +# Contact: JustArchi@JustArchi.net +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +############# +### BASIC ### +############# + +# Root of NDK, the one which contains $NDK/ndk-build binary +NDK="/home/user/ndk" + +# Example command to build standalone toolchain: +# user@machine:ndk# build/tools/make-standalone-toolchain.sh --toolchain=arm-linux-androideabi-4.9 --platform=android-21 --install-dir=/home/user/ndkTC +# Root of NDK toolchain, the one used in --install-dir from $NDK/build/tools/make-standalone-toolchain.sh. Make sure it contains $NDKTC/bin directory with $CROSS_COMPILE binaries +NDKTC="/home/user/ndkTC" + +# Optional, may help NDK in some cases +export NDK_TOOLCHAIN_VERSION=4.9 +export SYSROOT="$NDKTC/sysroot" + +# This flag turns on ADVANCED section below, you should use "0" if you want easy compiling for generic targets, or "1" if you want to get best optimized results for specific targets +# In general it's strongly suggested to leave it turned on, but if you're using makefiles, which already specify optimization level and everything else, then of course you may want to turn it off +ADVANCED="1" + +################ +### ADVANCED ### +################ + +# Defaults +MARCH="armv7-a" +MFPU="neon" +MFLOATABI="hard" + +FLTO=1 + +for ARG in "$@"; do + case "$ARG" in + --march=*) MARCH="$(echo "$ARG" | cut -d '=' -f 2-)" ;; + --mfpu=*) MFPU="$(echo "$ARG" | cut -d '=' -f 2-)" ;; + --mfloat-abi=*) MFLOATABI="$(echo "$ARG" | cut -d '=' -f 2-)" ;; + --no-flto) FLTO=0 ;; + esac +done + +# Device CFLAGS, these should be taken from TARGET_GLOBAL_CFLAGS property of BoardCommonConfig.mk of your device, eventually leave them empty for generic non-device-optimized build +# Please notice that -march flag comes from TARGET_ARCH_VARIANT +DEVICECFLAGS="-march=$MARCH -mfpu=$MFPU -mfloat-abi=$MFLOATABI" + +# This specifies optimization level used during compilation. Usually it's a good idea to keep it on "-O2" for best results, but you may want to experiment with "-Os", "-O3" or "-Ofast" +OLEVEL="-O3" + +# This specifies extra optimization flags, which are not selected by any of optimization levels chosen above +# Please notice that they're pretty EXPERIMENTAL, and if you get any compilation errors, the first step is experimenting with them or disabling them completely, you may also want to try different O level + +# Main ArchiDroid Optimizations flags +OPTICFLAGS="-fgcse-las -fgcse-sm -fipa-pta -fivopts -fomit-frame-pointer -frename-registers -fsection-anchors -ftracer -ftree-loop-im -ftree-loop-ivcanon -funsafe-loop-optimizations -funswitch-loops -fweb" + +# Graphgite ArchiDroid Optimization flags +OPTICFLAGS+=" -fgraphite -fgraphite-identity" + +# Extra ArchiDroid ICE flags +OPTICFLAGS+=" -floop-block -floop-interchange -floop-nest-optimize -floop-parallelize-all -floop-strip-mine -fmodulo-sched -fmodulo-sched-allow-regmoves" + +# Extra Android flags +OPTICFLAGS+=" -ffunction-sections -fdata-sections -fvisibility=hidden -s" + +# This specifies extra linker optimizations. Same as above, in case of problems this is second step for finding out the culprit +LDFLAGS="-llog -Wl,-O3 -Wl,--as-needed -Wl,--relax -Wl,--sort-common -Wl,--gc-sections" + +# This specifies additional sections to strip, for extra savings on size +STRIPFLAGS="-s -R .note -R .comment -R .gnu.version -R .gnu.version_r" + +# Additional definitions, which may help some binaries to work with android +DEFFLAGS="-fPIC -fPIE -pie -DNDEBUG -D__ANDROID__ -DANDROID" + +if [[ "$FLTO" -eq 1 ]]; then + OPTICFLAGS+=" -flto" + LDFLAGS+=" -Wl,-flto" +fi + +############## +### EXPERT ### +############## + +# This specifies host (target) for makefiles. In some rare scenarios you may also try "--host=arm-linux-androideabi" +# In general you shouldn't change that, as you're compiling binaries for low-level ARM-EABI and not Android itself +CONFIGANDROID="--host=arm-linux-eabi --with-sysroot=$SYSROOT" + +# This specifies the CROSS_COMPILE variable, again, in some rare scenarios you may also try "arm-eabi-" +# But beware, NDK doesn't even offer anything apart from arm-linux-androideabi one, however custom toolchains such as Linaro offer arm-eabi as well +CROSS_COMPILE="arm-linux-androideabi-" + +# This specifies if we should also override our native toolchain in the PATH in addition to overriding makefile commands such as CC +# You should NOT enable it, unless your makefile calls "gcc" instead of "$CC" and you want to point "gcc" (and similar) to NDKTC +# However, in such case, you should either fix makefile yourself or not use it at all +# You've been warned, this is not a good idea +TCOVERRIDE="0" + +# Workaround for some broken compilers with malloc problems (undefined reference to rpl_malloc and similar errors during compiling), don't uncomment unless you need it +#export ac_cv_func_malloc_0_nonnull=yes + +############ +### CORE ### +############ + +# You shouldn't edit anything from now on +export CROSS_COMPILE="$CROSS_COMPILE" # All makefiles depend on CROSS_COMPILE variable, this is important to set" + +if [[ "$ADVANCED" -ne 0 ]]; then # If advanced is specified, we override flags used by makefiles with our optimized ones, of course if makefile allows that + CFLAGS="$OLEVEL $DEVICECFLAGS $OPTICFLAGS $DEFFLAGS --sysroot=$SYSROOT" + CXXFLAGS="$CFLAGS" # We use same flags for CXX as well + CPPFLAGS="$CPPFLAGS" # Yes, CPP is the same as CXX, because they're both used in different makefiles/compilers, unfortunately + + export CFLAGS="$CFLAGS" + export LOCAL_CFLAGS="$CFLAGS" + export CXXFLAGS="$CFLAGS" # We use same flags for CXX as well + export LOCAL_CXXFLAGS="$CXXFLAGS" + export CPPFLAGS="$CPPFLAGS" # Yes, CPP is the same as CXX, because they're both used in different makefiles/compilers, unfortunately + export LOCAL_CPPFLAGS="$CPPFLAGS" + export LDFLAGS="$LDFLAGS" + export LOCAL_LDFLAGS="$LDFLAGS" +else + unset CFLAGS + unset CXXFLAGS + unset CPPFLAGS + unset LDFLAGS +fi + +if [[ -n "$NDK" && -d "$NDK" ]] && ! echo "$PATH" | grep -q "$NDK"; then # If NDK doesn't exist in the path (yet), prepend it + export PATH="$NDK:$PATH" +fi + +if [[ -n "$NDKTC" && -d "$NDKTC" ]] && ! echo "$PATH" | grep -q "$NDKTC"; then # If NDKTC doesn't exist in the path (yet), prepend it + export PATH="$NDKTC/bin:$PATH" +fi + +# Set some common makefile references +export AS=${CROSS_COMPILE}as +export AR=${CROSS_COMPILE}ar +export CC=${CROSS_COMPILE}gcc +export CXX=${CROSS_COMPILE}g++ +export CPP=${CROSS_COMPILE}cpp +export LD=${CROSS_COMPILE}ld +export NM=${CROSS_COMPILE}nm +export OBJCOPY=${CROSS_COMPILE}objcopy +export OBJDUMP=${CROSS_COMPILE}objdump +export READELF=${CROSS_COMPILE}readelf +export RANLIB=${CROSS_COMPILE}ranlib +export SIZE=${CROSS_COMPILE}size +export STRINGS=${CROSS_COMPILE}strings +export STRIP=${CROSS_COMPILE}strip + +if [[ "$TCOVERRIDE" -eq 1 ]]; then # This is not a a good idea... + alias as="$AS" + alias ar="$AR" + alias gcc="$CC" + alias g++="$CXX" + alias cpp="$CPP" + alias ld="$LD" + alias nm="$NM" + alias objcopy="$OBJCOPY" + alias objdump="$OBJDUMP" + alias readelf="$READELF" + alias ranlib="$RANLIB" + alias size="$SIZE" + alias strings="$STRINGS" + alias strip="$STRIP" +fi + +export CONFIGANDROID="$CONFIGANDROID" +export CC2="$CC -fPIC -fPIE -pie" +export CCC="$CC $CFLAGS $LDFLAGS" +export CXX="$CXX $CXXFLAGS $LDFLAGS" +export SSTRIP="$STRIP $STRIPFLAGS" + +echo "Done setting your environment" +echo +echo "CFLAGS: $CFLAGS" +echo "LDFLAGS: $LDFLAGS" +echo "CC points to $CC and this points to $(which "$CC")" +echo +echo "Use \"\$CC\" command for calling gcc and \"\$CCC\" command for calling our optimized CC" +echo "Use \"\$CXX\" command for calling g++ and \"\$CCXX\" for calling our optimized CXX" +echo "Use \"\$STRIP\" command for calling strip and \"\$SSTRIP\" command for calling our optimized STRIP" +echo +echo "Example: \"\$CCC myprogram.c -o mybinary && \$SSTRIP mybinary \"" +echo +echo "When using makefiles with configure options, always use \"./configure \$CONFIGANDROID\" instead of using \"./configure\" itself" +echo "Please notice that makefiles may, or may not, borrow our CFLAGS and LFLAGS, so I suggest to double-check them and eventually append them to makefile itself" +echo "Pro tip: Makefiles with configure options always borrow CC, CFLAGS and LDFLAGS, so if you're using ./configure, probably you don't need to do anything else" diff --git a/crypto777/m_android b/crypto777/m_android new file mode 100755 index 000000000..159c9fc6c --- /dev/null +++ b/crypto777/m_android @@ -0,0 +1,2 @@ +$CC -c -O2 *.c jpeg/*.c jpeg/unix/*.c +rm -f ../agents/libcrypto777.a; $AR rcu ../agents/libcrypto777.a *.o diff --git a/iguana/m_android b/iguana/m_android new file mode 100755 index 000000000..4e9bf6b6e --- /dev/null +++ b/iguana/m_android @@ -0,0 +1 @@ +$CC2 -o ../agents/iguana -O2 *.c ../agents/libcrypto777.a ../android/lib/libcurl.a -lssl -lcrypto -lm -lc diff --git a/m_android b/m_android new file mode 100755 index 000000000..b84f37742 --- /dev/null +++ b/m_android @@ -0,0 +1,2 @@ +git pull +cd iguana; ./m_android; cd .. diff --git a/m_onetime_android b/m_onetime_android new file mode 100755 index 000000000..b4f1aa383 --- /dev/null +++ b/m_onetime_android @@ -0,0 +1,4 @@ +git pull +cd crypto777 +./m_android +cd ..