summaryrefslogtreecommitdiff
path: root/contrib/cross.sh
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/cross.sh')
-rw-r--r--contrib/cross.sh167
1 files changed, 167 insertions, 0 deletions
diff --git a/contrib/cross.sh b/contrib/cross.sh
new file mode 100644
index 0000000000..09d5af70e3
--- /dev/null
+++ b/contrib/cross.sh
@@ -0,0 +1,167 @@
+#!/bin/bash
+# $Id$
+# Copyright 2006 Michael Mohr
+# See LICENSE for licensing information.
+
+#######################################################################
+# Tor-cross: a tool to help cross-compile Tor
+#
+# mailto:tor-assistants@freehaven.net
+#
+# The purpose of a cross-compiler is to produce an executable for
+# one system (CPU) on another. This is useful, for example, when
+# the target system does not have a native compiler available.
+# You might, for example, wish to cross-compile a program on your
+# host (the computer you're working on now) for a target such as
+# a router or handheld computer.
+#
+# This script automatically patches two files in the Tor source:
+# configure.in : remove test programs
+# compat.h : remove check for NULL==0
+#
+# A number of environment variables must be set in order for this
+# script to work:
+# $PREFIX, $CROSSPATH, $ARCH_PREFIX, $HOST,
+# and (optionally) $BUILD
+# Please run the script for a description of each one. If automated
+# builds are desired, the above variables can be exported at the top
+# of this script.
+#
+# Recent releases of Tor include test programs in configure. Normally
+# this is a good thing, since it catches a number of problems.
+# However, this also presents a problem when cross compiling, since
+# you can't run binary images for the target system on the host.
+#
+# Tor-cross assumes that you know what you're doing and removes a
+# number of checks known to cause problems with this process.
+# Note that this does not guarantee that the program will run or
+# even compile; it simply allows configure to generate the Makefiles.
+#
+# Stripping the binaries should almost always be done for an
+# embedded environment where space is at an exacting premium.
+# However, the default is NOT to strip them since they are useful for
+# debugging. If you do not plan to do any debugging and you
+# don't care about the debugging symbols, set $STRIP to "yes" before
+# running this script.
+#
+# Tor-cross was written by Michael Mohr. He can be contacted at
+# m(dot)mohr(at)laposte(dot)net. Comments are appreciated, but
+# flames go to /dev/null.
+#
+# The target with which this script is tested is little-endian
+# MIPS Linux, built on an Athlon-based Linux desktop.
+#
+#######################################################################
+
+# disable some show-stopping bugs (see cross.patch for more)
+export CROSS_COMPILE=yes
+
+if [ ! -f configure.in ]
+then
+ echo "Please run this script from the root of the Tor distribution."
+ exit -1
+fi
+
+if [ -z $PREFIX ]
+then
+ echo "You must define \$PREFIX since you are cross-compiling."
+ echo "Select a non-system location (i.e. /tmp/tor-cross):"
+ echo " export PREFIX=/tmp/tor-cross"
+ exit -1
+fi
+
+if [ -z $CROSSPATH ]
+then
+ echo "You must define the location of your cross-compiler's"
+ echo "directory using \$CROSSPATH; for example,"
+ echo " export CROSSPATH=/opt/cross/staging_dir_mipsel/bin"
+ exit -1
+fi
+
+if [ -z $ARCH_PREFIX ]
+then
+ echo "You must define \$ARCH_PREFIX to continue. For example,"
+ echo "if you normally cross-compile applications using"
+ echo "mipsel-linux-uclibc-gcc, you would set \$ARCH_PREFIX like so:"
+ echo " export ARCH_PREFIX=mipsel-linux-uclibc-"
+ exit -1
+fi
+
+if [ -z $HOST ]
+then
+ echo "You must specify a target processor with \$HOST; for example:"
+ echo " export HOST=mipsel-unknown-elf"
+ exit -1
+fi
+
+if [ -z $BUILD ]
+then
+ echo "You should specify the host machine's type with \$BUILD; for example:"
+ echo " export BUILD=i686-pc-linux-gnu"
+ echo "If you wish to let configure autodetect the host, set \$BUILD to 'auto':"
+ echo " export BUILD=auto"
+ exit -1
+fi
+
+# clean up any existing object files
+if [ -f src/or/tor ]
+then
+ make clean
+fi
+
+# check if the source has already been patched
+patch -f -p1 -R --dry-run < contrib/cross.patch > /dev/null 2>&1
+# if it hasn't, rerun the autotools
+if [ $? -ne 0 ]
+then
+ patch -p1 < contrib/cross.patch
+ aclocal
+ autoconf
+ autoheader
+ automake --add-missing
+fi
+
+# Set up the buld environment and try to run configure
+export PATH=$PATH:$CROSSPATH
+export RANLIB=${ARCH_PREFIX}ranlib
+export CC=${ARCH_PREFIX}gcc
+
+if [ $BUILD == "auto" ]
+then
+ ./configure \
+ --prefix=$PREFIX \
+ --host=$HOST
+else
+ ./configure \
+ --prefix=$PREFIX \
+ --host=$HOST \
+ --build=$BUILD
+fi
+
+# has a problem occurred?
+if [ $? -ne 0 ]
+then
+ echo ""
+ echo "A problem has been detected with configure."
+ echo "Please check the output above and rerun cross.sh"
+ echo ""
+ exit -1
+fi
+
+# Now we're cookin'
+
+make
+
+# if $STRIP has length (i.e. STRIP=yes), strip the binaries
+if [ ! -z $STRIP ]
+then
+${ARCH_PREFIX}strip \
+ src/or/tor \
+ src/or/test \
+ src/tools/tor-resolve
+fi
+
+echo ""
+echo "Tor should be compiled at this point. Now run 'make install' to"
+echo "install to $PREFIX"
+echo ""