Development boards and associated software project examples provided by microcontroller manufacturers are often of great help to engineers when starting a new design. However, after the early stages of a design project are completed, the software provided by the manufacturer may cause some problems when designing further.
There are also many challenges for the design of using a real-time operating system as a platform for application code. For example, there are issues such as how to effectively allocate functions to different parallel tasks, how to design reliable inter-process communication, and how to test the entire software package on hardware.
More and more OEM manufacturers have found that the best way to avoid the above problems is to start new designs using a Linux operating system based on open source, proven, scalable, and able to run on various hardware platforms. The number of Linux operating system transplants on various computer hardware platforms is also second to none.
Linux derivatives are already used in a wide variety of embedded systems, including network routers, mobile phones, building automation controls, televisions, and video game consoles.
Although Linux is widely used and successful, this does not mean that it is easy to use. Linux contains over a million lines of code and operates in a distinctly "Linux way" that may take some getting used to for beginners.
Therefore, the purpose of this article is to help start a new design project using the Linux embedded operating system version-μClinux. This guide will be broken down into five steps. To illustrate the guide, a μClinux project implemented on STMicroelectronics' STM32F429 microcontroller, which uses an ARM Cortex-M4 core with a maximum frequency of 180MHz and uses Emcraft's STM32F429 Discovery Linux Board Support Package (BSP ).
Every embedded software design starts with choosing the right tools.
The tool chain is a set of software development tools that are connected (or linked) together. It includes tools such as the GNU Compiler Collection (GCC), binutils (a set of linkers, assemblers, and other tools for object files and archives). development tools) and glibc (a C function library that provides system calls and basic functions); in some cases, other tools such as compilers and debuggers may also be included.
The tool chain used for embedded development is a cross tool chain, more commonly known as a cross compiler.
GNUBinutils is the first component of the embedded Linux tool chain. GNUBinutils contains two important tools:
●"as", assembler, converts assembly code (generated by GCC) into binary code
●"ld", connector, connects discrete target code segments to libraries or form executable files
The compiler is the second important component of the tool chain. In Embedded Linux, it is called GCC and supports many kinds of microcontroller and processor architectures.
Next is the C function library. It implements Linux's traditional POSIX application programming interface (API), which can be used to develop user-space applications. It interfaces with the kernel through system calls and provides high-level services.
Engineers have several C function library options:
●glibc is an available C function library provided by the open source GNU project. The library is full-featured, portable and compliant with Linux standards.
●Embedded GLIBC (EGLIBC) is a derivative version optimized for embedded systems. Its code is streamlined, supports cross-compilation and cross-testing, and its source code and binary code are compatible with GLIBC.
●uClibc is another C function library that can be used when flash space is limited and/or the memory footprint must be minimal.
The debugger is usually also part of the tool chain, because when debugging the application running on the target machine, a cross-debugger is required. In the field of embedded Linux, GDB is a commonly used debugger.
The above tools are so indispensable, but when they work independently, it will take too long to compile the Linux source code and integrate it into the final image (image). Fortunately, Buildroot automates the process of building a complete embedded system and simplifies cross-compilation by generating any or all of the following tasks:
●Cross-compilation tool chain
●Root file system
●Kernel image
●Boot image
For embedded system designers, it is also convenient to use a tool (utility) aggregation tool, such as BusyBox, which integrates the tools that are usually most needed. According to BusyBox's information page, "It combines tiny versions of many common UNIX tools into a small executable. It provides an alternative to most of the tools you would typically see in tools like GNU fileutils and shellutils. BusyBox The tools in BusyBox are generally less selective than their full-featured GNU counterparts; but the included options provide expected functionality and behavior that is almost identical to that provided by the GNU counterpart. For any small or embedded system, BusyBox provides The environment is quite complete.”
The last important tool is a BSP, which is specially made for the motherboard equipped with the project target MCU or processor.
The BSP includes pre-configured tools, as well as a bootloader to load the operating system onto the motherboard. It also provides source code for the kernel and device drivers (see Figure 1).
The typical embedded Linux startup sequence is as follows:
1) The bootloader firmware (U-Boot in the example project) runs in the target MCU's built-in flash memory (no external memory required), and after power-on/reset, performs all necessary initialization work, including setting up the serial port and using Memory controller for external memory (RAM) access.
2) U-Boot can transfer the Linux image from external Flash to external RAM and transfer control to the kernel entry point in RAM. Linux images can be compressed to save flash space at the expense of decompression time at boot time.
3) Linux boots and installs a RAM-based file system (initramfs) as the root file system. When the project is built, the Initramfs is populated with the required files and directories and then simply linked to the kernel.
4) Under the Linux kernel, execute /sbin/init. The /sbin/init program initializes the system according to the description of the configuration file in /etc/inittab.
5) Once the initialization process completes run-level execution and commands in /sbin/init, it starts a login process.
6) The execution of the shell initialization file /etc/profile marks the completion of the startup process.
You can significantly shorten startup time and improve overall performance by enabling in-place execution (ExecuteInPlace—XIP), which is a method of executing code from flash memory. Typically, Linux code is loaded from flash memory to external memory and then executed from the external memory. By executing from flash memory, less memory is required because this copying step is no longer required, and read-only memory no longer takes up program space.
The above is the detailed content of Several steps for embedded Linux project development. For more information, please follow other related articles on the PHP Chinese website!