- 1 Intro
- 2 Goal
- 3 The shortcut
- 4 Paparazzi-dev packages
- 5 Installing the Cross compiler toolchain
- 6 Rest of code needed
- 7 LPC21ISP
- 8 IVY
- 9 Paparazzi Main sourcecode
- 10 The depriciated -mapcs-32 option
- 11 Useful links
Users of recent Debian/Ubuntu distributions are advised to use the binary packages as described in Installation/Linux.
WARNING! This page is not quite up-to-date. Only use if you are proficient in working with Linux!
As with all Wiki pages, also this page is a work in progress. try to be a big help to the Paparazzi project and improve this page whenever you can. If you have a distribution different from Ubuntu which doesn't satisfy any other dependency and have instructions about compiling it, packaging it, feel free to add any reference on how to do that on this wikipage.
The goal of this page is to clarify about which version of each piece of software has to be compiled, where to find that software, patches needed to make it compile on Linux. In our case 64bit Linux. This includes compiling all paparazzi-dev, paparazzi-arm-multilib software on your machine, running an Ubuntu Lucid Lynx or later Linux distribution or maybe even FreeBSD, or OSX.
Maybe you are no so interested in the details at this moment and just want to quickly install. That's fine, for that we are working on a script and you only need to run one line to get everything installed. For this to work out you do need a working internet connection, but since you can read this text, that will probably not pose a problem.
$ cd ~ && wget http://openuas.org/pub/paparazzifromscratch.sh (still not ready and a work in progress)
If you used the line above, and it all worked out you can stop reading now since everything is installed and compiled, ready for you to use.
For Ubuntu users, you can install the following packages from standard repository. You can just copy the line(s) and paste into your terminal. But do not copy the $ sign, this symbol is just added on this page to show that it is to be pasted at a normal terminal prompt.
Whole lot in one
sudo apt-get install ocaml libcamlimages-ocaml liblablgtk2-ocaml-dev liblablgtk2-gl-ocaml-dev \ liblablgtk2-gnome-ocaml-dev libxml-light-ocaml-dev libocamlnet-ocaml-dev libpcre-ocaml \ libpcre-ocaml-dev libgnomecanvas2-0 libgnomecanvas2-dev libglade2-0 libglade2-dev make build-essential \ git-core gnuplot boa m4 libtool libftdi-dev libmpfr-dev tcl8.5-dev xutils-dev tkdiff
Ocaml and libraries
Ocaml, short for Objective Caml is the most popular variant of the Caml language. The Paparazzi Ground Control Station (GCS) and some of it's tools are crafted in this language.
- ocaml, ocaml-camlimages-devel, ocaml-lablgtk2-devel, ocaml-xml-light-devel, ocamlnet-ocaml-devel
$ sudo apt-get install ocaml libcamlimages-ocaml liblablgtk2-ocaml-dev liblablgtk2-gl-ocaml-dev \ liblablgtk2-gnome-ocaml-dev libxml-light-ocaml-dev libocamlnet-ocaml-dev
Gnome canvas Library
The GnomeCanvas is an engine for structured graphics that offers a rich imaging model, high performance rendering, and a powerful, high level API. This widget can be used for flexible display of graphics and for creating interactive user interface elements.
$ sudo apt-get install libgnomecanvas2-0 libgnomecanvas2-dev
The libusb project aims to create a library for use by user level applications to access USB devices regardless of OS. http://www.libusb.org
$ sudo apt-get install libusb-dev
This OCaml-library interfaces the PCRE (Perl-compatibility regular expressions) C library. it can be used for matching regular expressions which are written in Perl style.
$ sudo apt-get install libpcre-ocaml libpcre-ocaml-dev
Libglade is a library that performs a similar job to the C source output routines in the GLADE user interface builder. Whereas GLADE's output routines create C source code that must be compiled, libglade builds the interface from an XML file (GLADE's save format) at runtime. This can allow modifying the user interface without recompiling.
$ sudo apt-get install libglade2-0 libglade2-dev
$ sudo apt-get install tcl8.5-dev
Also the some utils are required to compile and install Ivy.
$ sudo apt-get install xutils-dev
GNU Make is an utility which controls the generation of executables and other target files of a program from the program's source files.
$ sudo apt-get install make
$ sudo apt-get install build-essential
GNU libtool is a generic library support script. Libtool hides the complexity of using shared libraries behind a consistent, portable interface. Creating the files for Paparazzi software building becomes less cumbersome by using this tool.
$ sudo apt-get install libtool
Git is a version control system. Version control systems allow many individuals to collaborate on the Paparazzi source code. This is needed to retrieve the latest sourcecode from various packages and Paparazzi sourcecode itself.
$ sudo apt-get install git-core
A command-line driven interactive plotting program. Unknow if it is used
$ sudo apt-get install gnuplot
TKDiff is a graphical front end to the diff program. It provides a side-by-side view of the differences between two files. It is used by the Paparazzi Center when configuration changes are not yet saved and the option comes along where one either can keep or view changes made in aircraft- and other configuration files.
$ sudo apt-get install tkdiff
libftdi is a library that talks to FTDI's 232 type chips, including the popular bitbang mode, using libusb. A library to be able to use with a debugging Autopilot hardware boards.
$ sudo apt-get install libftdi-dev
The MPFR library is a C library for multiple-precision floating-point computations with correct rounding. MPFR is based on the GMP multiple-precision library. The main goal of MPFR is to provide a library for multiple-precision floating-point computation which is both efficient and has a well-defined semantics.
$ sudo apt-get install libmpfr-dev
ImageMagick is a software suite to create, edit, and compose bitmap images. It can read, convert and write images in a variety of formats. Use ImageMagick to translate, flip, mirror, rotate, scale, shear and transform images, adjust image colors, apply various special effects, or draw text, lines, polygons, ellipses and Bézier curves. Being able to modify image based map pictures is a feature that may come in handy one time.
$ sudo apt-get install imagemagick
Optional on an older OS
If you have an older OS distribution it never hurts to install the following...
$ sudo apt-get install libx11-6 libx11-dev texinfo libncurses5 libncursesw5 libncursesw5-dev zlibc
Installing the Cross compiler toolchain
The gcc-arm-embedded toolchain is recommended, this also supports the STM32F4 with FPU (hardware floating point).</br> You can just download the tarball, unpack it and add it to your PATH:
cd ~ wget https://launchpad.net/gcc-arm-embedded/4.7/4.7-2013-q3-update/+download/gcc-arm-none-eabi-4_7-2013q3-20130916-linux.tar.bz2 tar -vjxf gcc-arm-none-eabi-4_7-2013q3-20130916-linux.tar.bz2 exportline="export PATH=$HOME/gcc-arm-none-eabi-4_7-2013q3/bin:\$PATH" if grep -Fxq "$exportline" ~/.profile; then echo nothing to do ; else echo $exportline >> ~/.profile; fi . ~/.profile
The file .profile will be sourced in every bash after logging out and in again. Until then,
can be used for every bash individually.
Rest of code needed
To install the rest we make a special directory "develop". You can give it another name ofcourse.
$ mkdir ~/develop
To get the software onto the main autopilot board a special tool is needed. We will use the great open-source LPC21ISP application. LPC21ISP is an in-circuit programming (ISP) tool for the microcontroller used on the Paparazzi autopilot boards. The lpc21isp project is hosted on sourceforge and one can find the source packages and information at http://sourceforge.net/projects/lpc21isp/
Get the SVN version via
$ mkdir -p ~/develop/lpc21isp $ cd ~/develop/lpc21isp $ svn co https://lpc21isp.svn.sourceforge.net/svnroot/lpc21isp lpc21
To compile go into the source directory and then do
$ cd lpc21 $ make -f Makefile clean all
$ sudo cp lpc21isp /usr/bin/
IVY is a simple protocol and a set of open-source libraries and programs that allows applications to broadcast information through text messages, with a subscription mechanism based on regular expressions. The project can be found at: http://www.eei.cena.fr/products/ivy/
In the paparazzi project, Ivy is used to send telemetry data to where ever you want.
NOTE: Do not confuse this IVY with the Apache Ivy project.
The ivy-python package makes it possible to use the IVY libraries from within the Python programming language. The ivy-python package is architecture independent, so it can be downloaded from the Ubuntu or Debian paparazzi repository. However since this is the from scratch page we will download it from the official source repository via
$ mkdir -p ~/develop/ivy-python/ $ cd ~/develop/ivy-python/ $ svn co https://svn.tls.cena.fr/svn/ivy/ivy-python/trunk
Now we can build and install /!\ Only works with Python 2 /!\
$ cd ~/develop/ivy-python/trunk $ sudo ./setup.py install
To be able to use IVY-c, the libraries need to be installed. Source packages of ivy-c can be downloaded via:
$ mkdir -p ~/develop/ivy-c $ cd ~/develop/ivy-c $ svn co https://svn.tls.cena.fr/svn/ivy/ivy-c/trunk
$ cd ~/develop/ivy-c/trunk/src $ make
It is possible you get errors of the test module when compiling, just ignore the messages, it is not important for the Paparazzi project. Contact the IVY team to help them also to resolve also the testing makefile issue.
Now install the compiled libraries
$ sudo make install
If you have a 64bit system your ivy libs were probably installed to /usr/local/lib64 and you have to make symbolic links so that they will be found:
$ sudo ln -s /usr/local/lib64/libivy.so /usr/local/lib64/libivy.so.3 /usr/lib
$ sudo ln -s /usr/local/lib64/libivy.so /usr/local/lib64/libivy.so.3 /usr/local/lib
If you get an error relating to ivytestready.c, make the following changes:
$ mkdir ~/develop/ivy-c/trunk/tools/Ivy $ cd ~/develop/ivy-c/trunk/tools/Ivy $ cp ../../src/ivy.h . $ cp ../../src/ivyloop.h . $ cp ../../src/ivysocket.h . $ cp ../../src/timer.h . $ cd ~/develop/ivy-c/trunk/src $ make
This copies files from the src directory to the Ivy folder in tools which did not appear after running svn above.
The Ivy-ocaml is a Library that make it possible to use Ivy via the Ocaml language.
$ mkdir -p ~/develop/ivy-ocaml $ cd ~/develop/ivy-ocaml/ $ svn co https://svn.tls.cena.fr/svn/ivy/ivy-ocaml/trunk
Now we need to compile the source via
$ cd ~/develop/ivy-ocaml/trunk $ make $ sudo make install
NOTE: If the above SVN repository does not work due to API incompatibilities get the ivy-ocaml source via
If you are running Ubuntu use the wget method listed above. Then run
$ tar -zxvf ivy-ocaml_1.1-12.tar.gz $ cd ivy $ make $ sudo make install
Paparazzi Main sourcecode
See the main installation page
TIP: If you get the File "pprz.mli", line 149, characters 78-89: Error: Unbound type constructor Ivy.binding ...this happens when IVY libraries are not yet installed. How to do this, read the part on installing IVY on this page
The depriciated -mapcs-32 option
The option "-mapcs-32" is only available with very old tool chain versions e.g. GCC-3.3.x. More recent tool chains will either require "-mabi=apcs-gnu" (non-EABI-compliant) or "-mabi=aapcs-linux" (EABI-compliant). To have an overview of all flags go here
By changing -mapcs-32 with -Wa,-mapcs-32 compilation will work with more recent compilers and we have backward compatibility with the old flag for older compilers. The option -Wa,-mapcs-32 is doing the following: -Wa,option : Pass option as an option to the assembler. If option contains commas, it is split into multiple options at the commas.
The -mapcs-32 option generates code for a processor running with a 32-bit program counter and conforming to the function calling standards for the APCS 32-bit option. If interested in depth what APCS is read the following: http://www.openuas.org/site/APCS.txt
The gcc flag -mapcs-32 was deprecated since gcc-3.4.0 and finally removed in gcc-4.0.0 which unconditionally generates 32bit ARM code. You should not need to pass this flag to the assembler either but it might not hurt for backwards compatibility with older compilers, so it's best to leave it in with the -Wa, option metho