Skip to content

Cross compile for raspberry PI

Sébastien Gallou edited this page Mar 10, 2017 · 32 revisions

This page explain how to cross compile Yadoms on a linux computer for the RaspberryPI target. This wiki page has been tested with :

  • Ubuntu 14.04 (64 bits)

Before starting

  • RaspberryPI and Ubuntu are connected to network
  • SSH is activated on the RaspberryPI

We assume user knows :

  • RaspberryPI ip address
  • RaspberryPI sudoer account (login and password); i.e. : pi / raspberry

Install cross compiler

Before you start, you need to make sure the following is installed on the linux machine :

        sudo apt-get install git cmake libssl-dev libgnutls-dev libopencv-gpu-dev autoconf automake libtool curl make g++ unzip

Start with making a folder in your home directory called 'raspberry'. Go into this folder and pull down the ENTIRE tools folder :

        git clone --depth=1 git://github.com/raspberrypi/tools.git

The tools repository contains many toolchains. Go into your home directory , edit the file ~/.bashrc and add the following file at end:

        export PATH=$PATH:$HOME/raspberry/tools/arm-bcm2708/arm-rpi-4.9.3-linux-gnueabihf/bin

Now you can either log out and log back in (i.e. restart your terminal session), or run . ~/.bashrc in your terminal to pick up the PATH addition in your current terminal session. Now, verify that you can access the compiler arm-linux-gnueabihf-gcc. You should get something like this :

        arm-linux-gnueabihf-gcc --version
arm-linux-gnueabihf-gcc (crosstool-NG linaro-1.13.1-4.8-2014.01 - Linaro GCC 2013.11) 4.8.3 20140106 (prerelease)
Copyright © 2013 Free Software Foundation, Inc.
Ce logiciel est libre; voir les sources pour les conditions de copie.  Il n'y a PAS
GARANTIE; ni implicite pour le MARCHANDAGE ou pour un BUT PARTICULIER.

Boost 1.63

Boost must be cross-compiled because the apt-get do not provide all requested libraries.

Download boost and extract it

        wget https://sourceforge.net/projects/boost/files/boost/1.63.0/boost_1_63_0.tar.bz2
	tar xjf boost_1_63_0.tar.bz2

Create bootstrap

	cd boost_1_63_0
	./bootstrap.sh

Create the user-config.jam in the user directory (cd ~)

	nano ~/user-config.jam
        using gcc : arm : arm-linux-gnueabihf-g++ ;

Cross compile boost (only useful libraries)

        ./b2 --with-atomic --with-chrono --with-date_time --with-filesystem --with-regex --with-serialization --with-thread --with-system --no-samples --no-tests toolset=gcc-arm link=static cxxflags=-fPIC

Remove user-config.jam

	rm ~/user-config.jam

Cross compile OpenSSL

Download OpenSSL and extract it

Version 1.0.x is working.

Version 1.1.x is not working well

        wget https://www.openssl.org/source/openssl-1.0.2k.tar.gz
	tar xzf openssl-1.0.2k.tar.gz

Build OpenSSL

        cd openssl-1.0.2k
        ./Configure os/compiler:arm-linux-gnueabihf
        make CC="arm-linux-gnueabihf-gcc" AR="arm-linux-gnueabihf-ar r" RANLIB="arm-linux-gnueabihf-ranlib"

Cross compile POCO

Download POCO and extract it

	wget http://pocoproject.org/releases/poco-1.7.7/poco-1.7.7-all.tar.gz
	tar xzf poco-1.7.7-all.tar.gz

In order to make it cross-compile, we need to define the RaspberryPI platform :

	cd poco-1.7.7-all
	echo 'TOOL               = arm-linux-gnueabihf' > build/config/RaspberryPI
	cat build/config/ARM-Linux >> build/config/RaspberryPI
	echo 'STATICOPT_CC = -fPIC' >> build/config/RaspberryPI
	echo 'STATICOPT_CXX = -fPIC' >> build/config/RaspberryPI

Configure and build POCO :

	./configure --static --config=RaspberryPI --no-samples --no-tests --omit=CppUnit,CppUnit/WinTestRunner,Data,Data/SQLite,Data/ODBCData/MySQL,MongoDB,PageCompiler,PageCompiler/File2Page --include-path=$HOME/raspberry/openssl-1.0.2k/include --library-path=$HOME/raspberry/depsBuild/openssl-1.0.2k
	make

Protobuf

Protobuf is divided in two parts :

  • The protoc compiler, used to generate C++ code from proto file : must be build for the host machine
  • The protobuf library, which C++ generated code will link against : must be built for the target

For host

	wget https://github.com/google/protobuf/releases/download/v3.2.0/protobuf-cpp-3.2.0.tar.gz
	tar -vxzf ./protobuf-cpp-3.2.0.tar.gz
        mv protobuf-3.2.0 protobuf-3.2.0-host
	cd protobuf-3.2.0-host
	mkdir build
	cd build
	cmake ../cmake
	cmake --build .
	sudo make install
	sudo ldconfig
	cd ..

For target

	wget https://github.com/google/protobuf/releases/download/v3.2.0/protobuf-cpp-3.2.0.tar.gz
	tar -vxzf ./protobuf-cpp-3.2.0.tar.gz
	cd protobuf-3.2.0
	./autogen.sh
	./configure --enable-shared=no --host=arm-linux CC=arm-linux-gnueabihf-gcc CXX=arm-linux-gnueabihf-g++ AR=arm-linux-gnueabihf-ar STRIP=arm-linux-gnueabihf-strip RANLIB=arm-linux-gnueabihf-ranlib --with-protoc=protoc --with-pic
	make
	cd ..

SWIG

To install swig 3 (apt-get give swig 2); you must install prerequisites.

PCRE

	sudo apt-get install libpcre3 libpcre3-dev

SWIG

Download swig source tarball from http://www.swig.org/download.html

	tar xzf swig-3.0.7.tar.gz
	cd swig-3.0.7
	./configure
	make
	sudo make install

Python

Python must be build in 2 phases :

  • Build of PGen
  • Cross-compiled for the target

PGen

	sudo apt-get install python-dev
	wget https://www.python.org/ftp/python/2.7.13/Python-2.7.13.tgz
	tar xzf Python-2.7.13.tgz
	mv Python-2.7.13 Python-2.7.13-host
	cd Python-2.7.13-host
	./configure
	make python Parser/pgen
	sudo make install

Cross-compilation

	sudo apt-get install python-dev
	wget https://www.python.org/ftp/python/2.7.13/Python-2.7.13.tgz
	tar xzf Python-2.7.13.tgz
	cd Python-2.7.13
	CC=arm-linux-gnueabihf-gcc CXX=arm-linux-gnueabihf-g++ AR=arm-linux-gnueabihf-ar RANLIB=arm-linux-gnueabihf-ranlib ./configure --host=arm-linux-gnueabihf --target=arm-linux-gnueabihf --build=x86_64-linux-gnu --disable-ipv6 ac_cv_file__dev_ptmx=no ac_cv_file__dev_ptc=no ac_cv_have_long_long_format=yes --enable-shared
	make HOSTPYTHON=$HOME/raspberry/Python-2.7.13-host/python HOSTPGEN=$HOME/raspberry/Python-2.7.13-host/Parser/pgen BLDSHARED="arm-linux-gnueabihf-cc -shared" CROSS-COMPILE=arm-linux-gnueabihf- CROSS_COMPILE_TARGET=yes HOSTARCH=arm-linux BUILDARCH=arm-linux-gnueabihf

Postgresql (optional)

	wget https://ftp.postgresql.org/pub/source/v9.6.2/postgresql-9.6.2.tar.bz2
	tar xjf postgresql-9.6.2.tar.bz2
	cd postgresql-9.6.2
	CC=arm-linux-gnueabihf-gcc CXX=arm-linux-gnueabihf-g++ AR=arm-linux-gnueabihf-ar RANLIB=arm-linux-gnueabihf-ranlib ./configure --host=arm-linux --build=arm-linux-gnueabihf --without-readline --without-zlib --disable-spinlocks
	cd src/interfaces/libpq
	make
	cd ../../../..

CMake

	sudo apt-get install cmake

Yadoms

Clone sources

	git clone https://github.com/Yadoms/yadoms.git

Configure repo

Create the sources/CMakeListsUserConfig.txt (from the .sample.txt) ans edit the boost root configuration (don't forget to remove #)

set(BOOST_ROOT "/path/to/raspberry/boost/boost_1_58_0")
set(POCO_ROOT "/path/to/poco-1.6.0")

To cross compile for Raspberry PI, set the three defines

SET(CC_RPI_GCC arm-linux-gnueabihf-gcc)
SET(CC_RPI_GXX arm-linux-gnueabihf-g++)
SET(CC_RPI_LIBS /path/to/raspberry/git/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian-x64/arm-linux-gnueabihf/libc/usr/lib/arm-linux-gnueabihf/)

If something fails, try to specify full path for CC_RPI_GCC and CC_RPI_GXX

Generate makefile

	cd yadoms
	sh cmake_raspberry.sh c

Build Yadoms

To make using standard makefile:

	cd projects
	make

To make using "cotired" makefile (really much faster):

	cd projects
	make all_unity

Deploy Yadoms to Raspberry PI

Assume you know : pi_login : for this example : pi pi_address: 192.168.0.7

Create these directories on target where to copy files:

        ssh pi_login@pi_address
        mkdir /home/pi/dev/ccyadoms
        mkdir /home/pi/dev/ccyadoms/www
        mkdir /home/pi/lib_tmp
        exit

First step : copy yadoms executable

        cd yadoms
        cd build
        scp -r * pi_login@pi_address:/home/pi/dev/ccyadoms

Second step : copy shared files to target

As /usr/local/lib needs root rights, use the lib_tmp folder in home

        scp plugins/libyadoms-shared.so pi_login@pi_address:/home/pi/lib_tmp
        scp path/to/poco-1.6.0/lib/Linux/ARM/* pi_login@pi_address:/home/pi/lib_tmp
        scp path/to/boost_1_58_0/stage/lib/* pi_login@pi_address:/home/pi/lib_tmp

Third step : copy web site files to target

        scp -r www/* pi_login@pi_address:/home/pi/dev/ccyadoms/www

Endly, go to the target to move shared files to /usr/local/lib

        ssh pi_login@pi_address
        sudo mv lib_tmp /usr/local/lib
        rmdir lib_tmp
        exit

On the target, do a ldconfig to update available libraries

ssh pi_login@pi_address
sudo ldconfig

Workaround for a known bug (will be fixed) : make logs directory

mkdir logs

Run yadoms

./yadoms
Clone this wiki locally