1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Embedded Linux system development.

Slides:



Advertisements
Similar presentations
Presented by: GREG UNGERER Lineo Inc 825 Stanley St Woolloongabba Qld 4102 Australia Ph: Building x86 Based.
Advertisements

LINUX-WINDOWS INTERACTION. One software allowing interaction between Linux and Windows is WINE. Wine allows Linux users to load Windows programs while.
1 UQC122S3 Real-Time and Embedded Systems GCC as a cross compiler.
Selecting a Cross Development Environment. Why do you need to select a CDE? Through out your career the target systems will change rapidly –Both the h/w.
1 Real-Time System Design Developing a Cross Compiler and libraries for a target system.
Cambodia-India Entrepreneurship Development Centre - : :.... :-:-
Embedded Linux Sandeep Sirpatil Graduate Student University of North Carolina Charlotte Feb 7, 2005.
1 THE ARCHITECTURE FOR THE DIGITAL WORLD TM THE ARCHITECTURE FOR THE DIGITAL WORLD Embedded Linux for ARM Architecture.
This work is licensed under the Creative Commons Attribution 4.0 International License. To view a copy of this license, visit
BUILDING & PORTING OPERATING SYSTEMS CROSS DEVELOPMENT.
Introduction to The Linaro Toolchain Embedded Processors Training Multicore Software Applications Literature Number: SPRPXXX 1.
1 Introduction to Tool chains. 2 Tool chain for the Sitara Family (but it is true for other ARM based devices as well) A tool chain is a collection of.
Building a Cross Compiler, Assembler and Linker Designed by Prof. Peng-Sheng Chen.
1 uClinux course. 2 Author: D L Johnson Overview u Day 1 +Survey of embedded operating systems - why uclinux? +The uclinux environment - the directory.
Lab 3 Department of Computer Science and Information Engineering National Taiwan University Lab3 - Cross Tools 2014/10/7/ 20 1.
Computer Organization
Introduction Purpose This training course introduces the free GNU tools that can be used for debugging embedded system application software in the Renesas.
StudioSysAdmins 2 nd Annual SIGGRAPH Birds-of-a-Feather John Hickson - 08/09/2011 StudioSysAdmins 2 nd Annual SIGGRAPH Birds-of-a-Feather John Hickson.
RTEMS overview W. Eric Norum Introduction RTEMS is a tool designed specifically for real-time embedded systems The RTEMS product is an executive.
Lab 11 Department of Computer Science and Information Engineering National Taiwan University Lab11 - Porting 2014/12/9/ 26 1.
Exploring Suitability of Linux for Embedded Vision Applications Ankit Mathur Mayank Agarwal Mini Project.
Porting Operating Systems Phan Duy Hùng (PhD) ES Lecturer – Hanoi FPT University.
Cross-Compiler Issues EPICS Meeting, May 2001 Markus Janousch (SLS)
Old Chapter 10: Programming Tools A Developer’s Candy Store.
 Overview › Requirements › Proof of Principal › Issues … › First Step – Wrap Altera NIOS2 GNU Tools › Next Step – Build RTEMS/NIOS GNU Tools › Future.
Operating System What is an Operating System? A program that acts as an intermediary between a user of a computer and the computer hardware. An operating.
Linux Overview COMS W4118 Spring Slides based on Phil Hutto, Silberschatz 2 History Linux is a modern, free operating system based on UNIX standards.
Nachos Overview Lecturer: Hao-Hua Chu TA: Chun-Po Wang (Artoo) Date: 2008/09/18 Material Provided by Yuan-Hao Chang, Yung-Feng Lu.
 Programming - the process of creating computer programs.
Implementation of Embedded OS Lab3 Porting μC/OS-II.
Chapter 1 Basic Concepts of Operating Systems Introduction Software A program is a sequence of instructions that enables the computer to carry.
Embracing Embedded Environments for Development Success By : Mark Recoskie.
This slide deck is for LPI Academy instructors to use for lectures for LPI Academy courses. ©Copyright Network Development Group Module 01 Introduction.
김민수 Cortex-M4 Processor - Getting Started with the GNU Compiler Collection(gcc)
Introduction to SimpleScalar Tool Set CPEG323 Tutorial Long Chen September, 2005.
The World Leader in High Performance Signal Processing Solutions Toolchain Basics.
Building programs LinuxChix-KE. What happens in your CPU? ● It executes a small set of instructions called "machine code" ● Each instruction is just a.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Free Electrons Introduction.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Embedded Linux system development.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com The GRUB bootloader Michael.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Free Electrons Linux kernel.
ELC-E - October crosstool-NG
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Scratchbox The Scratchbox.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Block filesystems Michael.
Developing Portable Applications ● Introduction GNU autotools – GNU toolchain ● Goals - cross-platform ● Supported platforms (POSIX compliant) ● GNU autotools.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com SSH Thomas Petazzoni Free.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Embedded Linux Training System.
(C) 2009 Yann E. MORIN1 Embedded Linux Conference / Europe - October 2009 Building our own toolchains for our embedded projects: Why, and how.
1 Buildroot. Building embedded Linux systems. Buildroot Developer Day.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com ELC 2009 System Size BOF Michael.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Block filesystems Michael.
1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com The U-boot bootloader Michael.
INTRO. To I.T Razan N. AlShihabi
Ottawa Linux Symposium 2007
Computer System Laboratory
CELF Embedded BOF - Ottawa - July 2008
Current Generation Hypervisor Type 1 Type 2.
Implementation of Embedded OS
Android.
Computer System Laboratory
History of compiler development
Penguin Weight Watchers
Embedded Linux Conference - April 2009
Uncompressed target filesystem size
Operating System Kernel Compilation
Computer Science I CSC 135.
Chapter 2: The Linux System Part 1
IS3440 Linux Security Unit 7 Securing the Linux Kernel
Outline Chapter 2 (cont) OS Design OS structure
Appendix F C Programming Environment on UNIX Systems
Presentation transcript:

1 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Embedded Linux system development Cross-compiling toolchains Thomas Petazzoni Michael Opdenacker Free Electrons © Copyright , Free Electrons. Creative Commons BY-SA 3.0 license Latest update: 9/26/2016, Document sources, updates and translations: Corrections, suggestions, contributions and translations are welcome!

2 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Definition (1) The usual development tools available on a GNU/Linux workstation is a native toolchain This toolchain runs on your workstation and generates code for your workstation, usually x86 For embedded system development, it is usually impossible or not interesting to use a native toolchain The target is too restricted in terms of storage and/or memory The target is very slow compared to your workstation You may not want to install all development tools on your target. Therefore, cross-compiling toolchains are generally used. They run on your workstation but generate code for your target.

3 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Definition (2) x86 ARM x86 Compilation machine Execution machine Source code Native toolchain Cross-compiling toolchain x86 binary ARM binary

4 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Components Binutils Kernel headers C/C++ libraries GCC compiler GDB debugger (optional)

5 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Binutils Binutils is a set of tools to generate and manipulate binaries for a given CPU architecture as, the assembler, that generates binary code from assembler source code ld, the linker ar, ranlib, to generate.a archives, used for libraries objdump, readelf, size, nm, strings, to inspect binaries. Very useful analysis tools ! strip, to strip useless parts of binaries in order to reduce their size GPL license

6 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Kernel headers (1) The C library and compiled programs needs to interact with the kernel Available system calls and their numbers Constant definitions Data structures, etc. Therefore, compiling the C library requires kernel headers, and many applications also require them. Kernel Kernel headers C Library Applications Available in and and a few other directories corresponding to the ones visible in include/ in the kernel sources

7 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Kernel headers (2) System call numbers, in Constant definitions, here in, included from, included from Data structures, here in #define __NR_exit 1 #define __NR_fork 2 #define __NR_read 3 #define O_RDWR struct stat { unsigned long st_dev; unsigned long st_ino; [...] };

8 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Kernel headers (3) The kernel-to-userspace ABI is backward compatible Binaries generated with a toolchain using kernel headers older than the running kernel will work without problem, but won't be able to use the new system calls, data structures, etc. Binaries generated with a toolchain using kernel headers newer than the running kernel might work on if they don't use the recent features, otherwise they will break Using the latest kernel headers is not necessary, unless access to the new kernel features is needed The kernel headers are extracted from the kernel sources using the headers_install kernel Makefile target.

9 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com GCC compiler GNU C Compiler, the famous free software compiler Can compile C, C++, Ada, Fortran, Java, Objective-C, Objective-C++, and generate code for a large number of CPU architectures, including ARM, AVR, Blackfin, CRIS, FRV, M32, MIPS, MN10300, PowerPC, SH, v850, i386, x86_64, IA64, Xtensa, etc. Available under the GPL license, libraries under the LGPL.

10 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com C library The C library is an essential component of a Linux system Interface between the applications and the kernel Provides the well-known standard C API to ease application development Several C libraries are available: glibc, uClibc, eglibc, dietlibc, newlib, etc. The choice of the C library must be made at the time of the cross-compiling toolchain generation, as the GCC compiler is compiled against a specific C library. Kernel C Library Applications

11 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com glibc License: LGPL C library from the GNU project Designed for performance, standards compliance and portability Found on all GNU / Linux host systems Of course, actively maintained Quite big for small embedded systems: approx 2.5 MB on arm (version libc: 1.5 MB, libm: 750 KB)

12 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com uClibc from CodePoet Consulting License: LGPL Lightweight C library for small embedded systems High configurability: many features can be enabled or disabled through a menuconfig interface Works only with Linux/uClinux, works on most embedded architectures No stable ABI, different ABI depending on the library configuration Focus on size rather than performance Small compile time

13 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com uClibc (2) Most of the applications compile with uClibc. This applies to all applications used in embedded systems. Size (arm): 4 times smaller than glibc! uClibc : approx. 600 KB (libuClibc: 460 KB, libm: 96KB) glibc 2.9: approx 2.5 MB Used on a large number of production embedded products, including consumer electronic devices Actively maintained, large developer and user base Now supported by MontaVista, TimeSys and Wind River.

14 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com uClibc (3) After compilation and installation, the following components are available Standard headers, stdio.h, stdlib.h, unistd.h and others, and Linux kernel headers, integrated with the C library headers. The libraries themselves, with mainly libuClibc, the C library itself ld-uClibc, the dynamic loader, responsible for loading the shared libraries at the beginning of a program's execution librt, the library implementing the real-time related functions libstdc++, the C++ standard library libpthread, the threads library libm, the mathematic library

15 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Honey, I shrunk the programs! Executable size comparison on ARM

16 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com eglibc « Embedded glibc », under the LGPL Variant of the GNU C Library (GLIBC) designed to work well on embedded systems Strives to be source and binary compatible with GLIBC eglibc's goals include reduced footprint, configurable components, better support for cross-compilation and cross-testing. Can be built without support for NIS, locales, IPv6, and many other features. Supported by a consortium, with Freescale, MIPS, MontaVista and Wind River as members. The Debian distribution is switching to eglibc too:

17 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Other smaller C libraries Several other smaller C libraries have been developed, but none of them have the goal of allowing the compilation of large existing applications They need specially written programs and applications Choices: Dietlibc, Approximately 70 KB. Newlib, Klibc, designed for use in an initramfs or initrd at boot time.

18 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Building a toolchain Three machines must be distinguished when discussing toolchain creation The build machine, where the toolchain is built. The host machine, where the toolchain will be executed. The target machine, where the binaries created by the toolchain will be executed. Four build types are possible

19 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Building a toolchain (2) build host target Native build used to build the normal gcc of a workstation build host target Cross build used to build a toolchain that runs on your workstation but generates binaries for the target build host target Cross-native build used to build a toolchain that runs on your target and generates binaries for the target build host target Canadian build used to build on architecture A a toolchain that runs on architecture B and generates binaries for architecture C The most common solution in embedded

20 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Building a toolchain (3) Many decisions must be made when building a toolchain Choosing the C library Choosing the version of the different components Choosing the configuration of the toolchain Which ABI should be used ? Toolchains for the ARM architecture for example, can generate binaries using the OABI (Old ABI) or the EABI (Embedded ABI), that are incompatible Should the toolchain support software floating point, or does the hardware support floating point operations ? Should the toolchain support locales, IPv6, or other specific features ?

21 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Building a toolchain (4) Crosstool build reports:

22 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Basic steps Extract and install kernel headers Extract, configure, compile and install binutils Extract, configure and compile a first version gcc that generates binaries for the target. It will be used to cross- compile the C library. Extract, configure and compile the C library using the previously generated compiler. Re-configure and compile the final gcc cross-compiler.

23 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Homebuilt toolchains Building a cross-compiling toolchain by yourself is a difficult and painful task! Can take days or weeks! Lots of details to learn. Several components to build. Lots of decisions to make (such as C library version and configuration for your platform) Need kernel headers and C library sources Need to be familiar with current gcc issues and patches on your platform Useful to be familiar with building and configuring tools can show you how fun it can be!

24 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Get a precompiled toolchain Solution that most people choose, because it is the simplest and most convenient solution First, determine what toolchain you need: CPU, endianism, C library, component versions, ABI, soft float or hard float, etc. Many pre-compiled toolchains are freely available: CodeSourcery, is a reference in that area, but they only provide glibc toolchains. Linaro will give you the most optimized toolchains on ARM: (Linaro hired CodeSourcery and added other features) See also

25 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Installing and using a precompiled toolchain Follow the installation procedure proposed by the vendor Usually, it is simply a matter of extracting a tarball at the proper place Toolchains used not to be relocatable! You must install them in the location they were built for. This is no longer true with gcc 4.x, thanks to sysroot support, but it is still more convenient to install them at the proper place. Then, add the path to toolchain binaries in your PATH: export PATH=/path/to/toolchain/bin/:$PATH

26 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Toolchain building utilities Another solution is to use utilities that automate the process of building the toolchain Same advantage as the pre-compiled toolchains: you don't need to mess up with all the details of the build process But also offers more flexibility in terms of toolchain configuration, component version selection, etc. They also usually contain several patches that fix known issues with the different components on some architectures Identical principle: shell scripts or Makefile that automatically fetch, extract, configure, compile and install the different components

27 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Crosstool The precursor, written by Dan Kegel Set of scripts and patches, glibc-only Not really maintained anymore Crosstool-ng Rewrite of Crosstool, with a menuconfig-like configuration system Feature-full: supports uClibc, glibc, eglibc, hard and soft float, many architectures Actively maintained Toolchain building utilities (2)

28 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Toolchain building utilities (3) Many root filesystem building systems also allow the construction of cross-compiling toolchain Buildroot Makefile-based, uClibc only, maintained by the community PTXdist Makefile-based, uClibc or glibc, maintained mainly by Pengutronix OpenEmbedded The feature-full, but complex building system

29 Free Electrons. Kernel, drivers and embedded Linux development, consulting, training and support. http//free-electrons.com Practical lab – Using Crosstool-NG Time to build your toolchain Configure Crosstool-NG Run it to build your own cross- compiling toolchain