Miguel Freitas
11 years ago
14 changed files with 3925 additions and 6 deletions
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,22 @@
@@ -0,0 +1,22 @@
|
||||
export PATH=/home/miguel/android/android-ndk-r8b/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86/bin/:$PATH |
||||
export NDK=/home/miguel/android/android-ndk-r8b |
||||
export NDK_BASE=$NDK |
||||
export SYSROOT=$NDK/platforms/android-9/arch-arm |
||||
export BOOSTDIR=/home/miguel/android/Boost-for-Android/build/ |
||||
|
||||
if [ $1 == "configure" ]; then |
||||
./configure --host=arm-linux-androideabi --enable-shared=no --enable-static=yes \ |
||||
--enable-debug \ |
||||
CPPFLAGS="-I$SYSROOT/usr/include/ -I$BOOSTDIR/include \ |
||||
-I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/include \ |
||||
-I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/include \ |
||||
-fexceptions -frtti" \ |
||||
LDFLAGS="-Wl,-rpath-link=$SYSROOT/usr/lib/ -L$SYSROOT/usr/lib/ -L$BOOSTDIR/lib \ |
||||
$BOOSTDIR/lib/libboost_system-gcc-mt-1_49.a $BOOSTDIR/lib/libboost_thread-gcc-mt-1_49.a \ |
||||
$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/libgnustl_static.a" \ |
||||
LIBS="-lc" CFLAGS="-nostdlib" --prefix="$SYSROOT/usr" \ |
||||
--with-boost=$BOOSTDIR --with-boost-libdir=$BOOSTDIR/lib && make -j2 |
||||
fi |
||||
|
||||
make -j2 |
||||
|
@ -0,0 +1,227 @@
@@ -0,0 +1,227 @@
|
||||
# Copyright (c) 2009-2010 Satoshi Nakamoto |
||||
# Distributed under the MIT/X11 software license, see the accompanying |
||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php. |
||||
|
||||
# :=0 --> UPnP support turned off by default at runtime |
||||
# :=1 --> UPnP support turned on by default at runtime |
||||
# :=- --> No UPnP support - miniupnp not required |
||||
USE_UPNP:=- |
||||
|
||||
# :=1 --> Enable IPv6 support |
||||
# :=0 --> Disable IPv6 support |
||||
USE_IPV6:=0 |
||||
|
||||
LINK:=$(CXX) |
||||
|
||||
DEFS=-DBOOST_SPIRIT_THREADSAFE -D_FILE_OFFSET_BITS=64 -DBOOST_THREAD_USE_LIB |
||||
|
||||
DEFS += $(addprefix -I,$(CURDIR) $(CURDIR)/obj $(BOOST_INCLUDE_PATH) $(BDB_INCLUDE_PATH) $(OPENSSL_INCLUDE_PATH)) |
||||
LIBS = $(addprefix -L,$(BOOST_LIB_PATH) $(BDB_LIB_PATH) $(OPENSSL_LIB_PATH)) |
||||
|
||||
TESTDEFS = -DTEST_DATA_DIR=$(abspath test/data) |
||||
|
||||
LMODE = static |
||||
LMODE2 = dynamic |
||||
ifdef STATIC |
||||
LMODE = static |
||||
ifeq (${STATIC}, all) |
||||
LMODE2 = static |
||||
endif |
||||
else |
||||
TESTDEFS += -DBOOST_TEST_DYN_LINK |
||||
endif |
||||
|
||||
|
||||
TESTLIBS += \ |
||||
-Wl,-B$(LMODE) \ |
||||
-l boost_unit_test_framework$(BOOST_LIB_SUFFIX) |
||||
|
||||
ifndef USE_UPNP |
||||
override USE_UPNP = - |
||||
endif |
||||
ifneq (${USE_UPNP}, -) |
||||
LIBS += -l miniupnpc |
||||
DEFS += -DUSE_UPNP=$(USE_UPNP) |
||||
endif |
||||
|
||||
ifneq (${USE_IPV6}, -) |
||||
DEFS += -DUSE_IPV6=$(USE_IPV6) |
||||
endif |
||||
|
||||
|
||||
|
||||
# Hardening |
||||
# Make some classes of vulnerabilities unexploitable in case one is discovered. |
||||
# |
||||
# This is a workaround for Ubuntu bug #691722, the default -fstack-protector causes |
||||
# -fstack-protector-all to be ignored unless -fno-stack-protector is used first. |
||||
# see: https://bugs.launchpad.net/ubuntu/+source/gcc-4.5/+bug/691722 |
||||
HARDENING=-fno-stack-protector |
||||
|
||||
# Stack Canaries |
||||
# Put numbers at the beginning of each stack frame and check that they are the same. |
||||
# If a stack buffer if overflowed, it writes over the canary number and then on return |
||||
# when that number is checked, it won't be the same and the program will exit with |
||||
# a "Stack smashing detected" error instead of being exploited. |
||||
#HARDENING+=-fstack-protector-all -Wstack-protector |
||||
|
||||
# Make some important things such as the global offset table read only as soon as |
||||
# the dynamic linker is finished building it. This will prevent overwriting of addresses |
||||
# which would later be jumped to. |
||||
LDHARDENING+=-Wl,-z,relro -Wl,-z,now |
||||
|
||||
# Build position independent code to take advantage of Address Space Layout Randomization |
||||
# offered by some kernels. |
||||
# see doc/build-unix.txt for more information. |
||||
ifdef PIE |
||||
HARDENING+=-fPIE |
||||
LDHARDENING+=-pie |
||||
endif |
||||
|
||||
# -D_FORTIFY_SOURCE=2 does some checking for potentially exploitable code patterns in |
||||
# the source such overflowing a statically defined buffer. |
||||
HARDENING+=-D_FORTIFY_SOURCE=2 |
||||
# |
||||
|
||||
|
||||
DEBUGFLAGS=-g |
||||
|
||||
# CXXFLAGS can be specified on the make command line, so we use xCXXFLAGS that only |
||||
# adds some defaults in front. Unfortunately, CXXFLAGS=... $(CXXFLAGS) does not work. |
||||
xCXXFLAGS=-O2 -pthread -Wall -Wextra -Wformat -Wformat-security -Wno-unused-parameter \ |
||||
$(DEBUGFLAGS) $(DEFS) $(HARDENING) $(CXXFLAGS) |
||||
|
||||
# LDFLAGS can be specified on the make command line, so we use xLDFLAGS that only |
||||
# adds some defaults in front. Unfortunately, LDFLAGS=... $(LDFLAGS) does not work. |
||||
xLDFLAGS=$(LDHARDENING) $(LDFLAGS) |
||||
|
||||
OBJS= \ |
||||
leveldb/libleveldb.a \ |
||||
../libtorrent/src/.libs/libtorrent-rasterbar.a \ |
||||
obj/alert.o \ |
||||
obj/version.o \ |
||||
obj/checkpoints.o \ |
||||
obj/netbase.o \ |
||||
obj/addrman.o \ |
||||
obj/crypter.o \ |
||||
obj/key.o \ |
||||
obj/db.o \ |
||||
obj/init.o \ |
||||
obj/bitcoind.o \ |
||||
obj/keystore.o \ |
||||
obj/core.o \ |
||||
obj/main.o \ |
||||
obj/net.o \ |
||||
obj/protocol.o \ |
||||
obj/bitcoinrpc.o \ |
||||
obj/rpcdump.o \ |
||||
obj/rpcnet.o \ |
||||
obj/rpcmining.o \ |
||||
obj/rpcwallet.o \ |
||||
obj/rpcblockchain.o \ |
||||
obj/rpcrawtransaction.o \ |
||||
obj/script.o \ |
||||
obj/sync.o \ |
||||
obj/util.o \ |
||||
obj/wallet.o \ |
||||
obj/walletdb.o \ |
||||
obj/hash.o \ |
||||
obj/bloom.o \ |
||||
obj/noui.o \ |
||||
obj/leveldb.o \ |
||||
obj/txdb.o \ |
||||
obj/chainparams.o \ |
||||
obj/twister.o \ |
||||
obj/twister_utils.o |
||||
|
||||
|
||||
all: twisterd |
||||
|
||||
test check: test_bitcoin FORCE |
||||
./test_bitcoin |
||||
|
||||
# |
||||
# LevelDB support |
||||
# |
||||
MAKEOVERRIDES = |
||||
LIBS += $(CURDIR)/leveldb/libleveldb.a $(CURDIR)/leveldb/libmemenv.a |
||||
DEFS += $(addprefix -I,$(CURDIR)/leveldb/include) |
||||
DEFS += $(addprefix -I,$(CURDIR)/leveldb/helpers) |
||||
leveldb/libleveldb.a: |
||||
@echo "Building LevelDB ..." && cd leveldb && $(MAKE) CC=$(CC) CXX=$(CXX) OPT="$(xCXXFLAGS)" libleveldb.a libmemenv.a && cd .. |
||||
|
||||
# |
||||
# libtorrent hack |
||||
# |
||||
MAKEOVERRIDES = |
||||
LIBS += $(CURDIR)/../libtorrent/src/.libs/libtorrent-rasterbar.a |
||||
DEFS += $(addprefix -I,$(CURDIR)/../libtorrent/include) |
||||
DEFS += -DTORRENT_DEBUG |
||||
DEFS += -DBOOST_ASIO_SEPARATE_COMPILATION |
||||
#DEFS += -DBOOST_ASIO_DYN_LINK |
||||
../libtorrent/src/.libs/libtorrent-rasterbar.a: |
||||
@echo "Building libtorrent ..." && cd ../libtorrent && $(MAKE) CC=$(CC) CXX=$(CXX) OPT="$(xCXXFLAGS)" && cd ../src |
||||
|
||||
|
||||
# for boost 1.37, add -mt to the boost libraries |
||||
LIBS += \ |
||||
-Wl,-B$(LMODE) \ |
||||
-Wl,-rpath-link=$(SYSROOT)/usr/lib/ -L$(SYSROOT)/usr/lib/ \ |
||||
-L$(BOOSTDIR)/lib \ |
||||
-l boost_system$(BOOST_LIB_SUFFIX) \ |
||||
-l boost_filesystem$(BOOST_LIB_SUFFIX) \ |
||||
-l boost_program_options$(BOOST_LIB_SUFFIX) \ |
||||
-l boost_thread$(BOOST_LIB_SUFFIX) \ |
||||
-l db_cxx$(BDB_LIB_SUFFIX) \ |
||||
-L$(NDK_BASE)/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/ -lgnustl_static |
||||
#-l ssl_static -l crypto_static |
||||
|
||||
LIBS+= \ |
||||
-Wl,-B$(LMODE2) \ |
||||
-Wl,-rpath-link=$(SYSROOT)/usr/lib/ -L$(SYSROOT)/usr/lib/ \ |
||||
-lssl -lcrypto -lstdc++ -lm -lgcc -nostdlib -lc \ |
||||
$(NDK_BASE)/platforms/android-9/arch-arm/usr/lib/crtbegin_dynamic.o \ |
||||
$(NDK_BASE)/platforms/android-9/arch-arm/usr/lib/crtend_android.o |
||||
|
||||
# auto-generated dependencies: |
||||
-include obj/*.P |
||||
-include obj-test/*.P |
||||
|
||||
obj/build.h: FORCE |
||||
/bin/sh ../share/genbuild.sh obj/build.h |
||||
version.cpp: obj/build.h |
||||
DEFS += -DHAVE_BUILD_INFO |
||||
|
||||
obj/%.o: %.cpp |
||||
$(CXX) -c $(xCXXFLAGS) -MMD -MF $(@:%.o=%.d) -o $@ $< |
||||
@cp $(@:%.o=%.d) $(@:%.o=%.P); \ |
||||
sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' \ |
||||
-e '/^$$/ d' -e 's/$$/ :/' < $(@:%.o=%.d) >> $(@:%.o=%.P); \ |
||||
rm -f $(@:%.o=%.d) |
||||
|
||||
twisterd: $(OBJS:obj/%=obj/%) |
||||
$(LINK) $(xCXXFLAGS) -o $@ $^ $(xLDFLAGS) $(LIBS) |
||||
arm-linux-androideabi-strip -g $@ |
||||
|
||||
TESTOBJS := $(patsubst test/%.cpp,obj-test/%.o,$(wildcard test/*.cpp)) |
||||
|
||||
obj-test/%.o: test/%.cpp |
||||
$(CXX) -c $(TESTDEFS) $(xCXXFLAGS) -MMD -MF $(@:%.o=%.d) -o $@ $< |
||||
@cp $(@:%.o=%.d) $(@:%.o=%.P); \ |
||||
sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' \ |
||||
-e '/^$$/ d' -e 's/$$/ :/' < $(@:%.o=%.d) >> $(@:%.o=%.P); \ |
||||
rm -f $(@:%.o=%.d) |
||||
|
||||
test_bitcoin: $(TESTOBJS) $(filter-out obj/init.o obj/bitcoind.o,$(OBJS:obj/%=obj/%)) |
||||
$(LINK) $(xCXXFLAGS) -o $@ $(LIBPATHS) $^ $(TESTLIBS) $(xLDFLAGS) $(LIBS) |
||||
|
||||
clean: |
||||
-rm -f twisterd test_bitcoin |
||||
-rm -f obj/*.o |
||||
-rm -f obj-test/*.o |
||||
-rm -f obj/*.P |
||||
-rm -f obj-test/*.P |
||||
-rm -f obj/build.h |
||||
-cd leveldb && $(MAKE) clean || true |
||||
|
||||
FORCE: |
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
export PATH=/home/miguel/android/android-ndk-r8b/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86/bin/:$PATH |
||||
export NDK=/home/miguel/android/android-ndk-r8b |
||||
export NDK_BASE=$NDK |
||||
export SYSROOT=$NDK/platforms/android-9/arch-arm |
||||
export BOOSTDIR=/home/miguel/android/Boost-for-Android/build/ |
||||
export TARGET_OS=OS_ANDROID_CROSSCOMPILE |
||||
|
||||
export CXX=arm-linux-androideabi-gcc |
||||
export CXXFLAGS="-I$SYSROOT/usr/include/ -I$BOOSTDIR/include/boost-1_49 \ |
||||
-I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/include \ |
||||
-I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/include \ |
||||
-fexceptions -frtti -DHAVE_CXX_STDHEADERS -DANDROID -nostdlib" |
||||
export BOOST_LIB_SUFFIX=-gcc-mt-1_49 |
||||
export BDB_LIB_SUFFIX=-4.8 |
||||
|
||||
make -f makefile.android -j2 |
||||
#make -j2 |
||||
#exit |
||||
|
||||
#./configure --host=arm-linux-androideabi --enable-shared=no --enable-static=yes\ |
||||
# CPPFLAGS="-I$SYSROOT/usr/include/ -I$BOOSTDIR/include \ |
||||
# -I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/include \ |
||||
# -I$NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/include \ |
||||
# -fexceptions -frtti" \ |
||||
# LDFLAGS="-Wl,-rpath-link=$SYSROOT/usr/lib/ -L$SYSROOT/usr/lib/ -L$BOOSTDIR/lib \ |
||||
# $BOOSTDIR/lib/libboost_system-gcc-mt-1_49.a $BOOSTDIR/lib/libboost_thread-gcc-mt-1_49.a \ |
||||
# $NDK_BASE/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi/libgnustl_static.a" \ |
||||
# LIBS="-lc" CFLAGS="-nostdlib" --prefix="$SYSROOT/usr" \ |
||||
# --with-boost=$BOOSTDIR --with-boost-libdir=$BOOSTDIR/lib && make -j2 |
Loading…
Reference in new issue