


In Linux, cross-compilation is a compilation program that runs in a computer environment and can compile code that runs in another environment; the cross-compiled program can be run in various target environments. Resources are relatively limited, so it is difficult to perform direct local compilation. Sometimes it is because the target platform does not allow or cannot install the compiler we need, and we need certain features of this compiler, so we need to use cross Compile.
#The operating environment of this tutorial: linux7.3 system, Dell G3 computer.
What is the use of linux cross compilation
What is cross compilation
Local compilation
Before explaining what cross-compilation is, we must first understand a concept: local compilation
Our common software development before was all local compilation: under the current PC, under the x86 CPU, directly The compiled program is a program (or library file) that can be run, which can be run directly in the current environment, that is, under the x86 CPU, in the current computer.
The compilation at this time can be called: local compilation, that is, under the current target platform, the compiled program can be run just under the current platform.
Cross-compilation
Cross-compilation is a concept corresponding to local compilation.
The so-called cross-compilation means: when compiled on one platform, the compiled program will be run on another platform, that is, the compiled environment. It is different from the running environment and is cross-compiled. , this is called cross.
Cross-compilation, this concept, is mainly related to embedded development.
For example: Compile on x86 platform and run on ARM platform.
One of the most common examples is:
When you are doing embedded development, you have an embedded development board. The CPU is arm and you develop it on an x86 platform, such as Ubuntu. Linux, or Win 10, then you need:
On the x86 platform, (use a cross-compiler) to compile the program code you wrote
Compile and generate (executable) The program is placed on the target development board and run on the ARM CPU
This is so-called: compiled on the x86 platform and run on the ARM platform.
Cross compilation is often written as cross compile in English. There are also other ways of writing: crosscompile, cross compiling, etc.
Why there is cross compilation
The main reason why there is cross compilation is: there are too few resources in the embedded system
The specific explanation is: the target environment in which the cross-compiled program is to be run has relatively limited resources, so it is difficult to directly compile it locally.
The most common situation is: when doing embedded development, the target platform, that is, the embedded development board, for example, is an ARM CPU with a maximum frequency of 200MHz, plus 32M RAM, plus 1G Nand Flash and so on. Under the premise of such relatively tight hardware resources, and on the premise that embedded Linux is already running, it is not convenient to directly compile it locally under embedded Linux or compile it under ARM CPU. Provides programs that ARM CPUs can run. Because compilation and development require relatively large amounts of CPU, memory, hard disk and other resources, and the few resources for embedded development are only enough to run the embedded (Linux) system, there are not many remaining resources for you to use locally. Compile.
BusyBox contains make and other tools related to compilation and development
Correspondingly, when you become familiar with embedded development and Busybox later, for example, configure Busybox in Buildroot, or separately When cross-compiling BusyBox:
[Record] Cross-compile BusyBox for QEMU's arm platform under Ubuntu
You will see that the later BusyBox, after the functions are added, has also included some, and Compilation and development related tools, such as make, etc.
These tools are originally only used on the PC side, that is, when developing under the x86 platform, they are only used during cross-compilation. The tool is now also supported in the embedded environment (BusyBox).
At this time, if you select all relevant development tools in BusyBox,
In addition, if the hardware configuration of your target development board is powerful enough, such as CPU The unit is GHz, etc.
If the relevant development libraries and tools are complete
In fact, at least in theory, it can also be used in your embedded Linux, To carry out, limited, or even to a large extent, local development, that is, directly on the ARM development board, embedded Linux, direct embedded development, and local compilation for ARM
For example, It is estimated that it is possible to compile a helloworld.
In this way, the cross-compilation mentioned here does not exist, or is avoided, and becomes local compilation.
is equivalent to the previous compilation on the PC side of x86. The local compilation of the program running on the x86 CPU is also implemented in ARM CPU and embedded Linux.
But obviously, for more complex programs or libraries, in The feasibility and efficiency of direct compilation on ARM development boards are relatively low
And if you are tossing Uboot and other things yourself, and the target operating environment does not have a complete (embedded Linux) system, then it will be even more impossible to achieve local compilation on the target platform.
You can still do it, as mentioned here, cross-compilation
Recommended learning: Linux video tutorial
The above is the detailed content of What is the use of linux cross compilation?. For more information, please follow other related articles on the PHP Chinese website!

The five core components of the Linux operating system are: 1. Kernel, 2. System libraries, 3. System tools, 4. System services, 5. File system. These components work together to ensure the stable and efficient operation of the system, and together form a powerful and flexible operating system.

The five core elements of Linux are: 1. Kernel, 2. Command line interface, 3. File system, 4. Package management, 5. Community and open source. Together, these elements define the nature and functionality of Linux.

Linux user management and security can be achieved through the following steps: 1. Create users and groups, using commands such as sudouseradd-m-gdevelopers-s/bin/bashjohn. 2. Bulkly create users and set password policies, using the for loop and chpasswd commands. 3. Check and fix common errors, home directory and shell settings. 4. Implement best practices such as strong cryptographic policies, regular audits and the principle of minimum authority. 5. Optimize performance, use sudo and adjust PAM module configuration. Through these methods, users can be effectively managed and system security can be improved.

The core operations of Linux file system and process management include file system management and process control. 1) File system operations include creating, deleting, copying and moving files or directories, using commands such as mkdir, rmdir, cp and mv. 2) Process management involves starting, monitoring and killing processes, using commands such as ./my_script.sh&, top and kill.

Shell scripts are powerful tools for automated execution of commands in Linux systems. 1) The shell script executes commands line by line through the interpreter to process variable substitution and conditional judgment. 2) The basic usage includes backup operations, such as using the tar command to back up the directory. 3) Advanced usage involves the use of functions and case statements to manage services. 4) Debugging skills include using set-x to enable debugging mode and set-e to exit when the command fails. 5) Performance optimization is recommended to avoid subshells, use arrays and optimization loops.

Linux is a Unix-based multi-user, multi-tasking operating system that emphasizes simplicity, modularity and openness. Its core functions include: file system: organized in a tree structure, supports multiple file systems such as ext4, XFS, Btrfs, and use df-T to view file system types. Process management: View the process through the ps command, manage the process using PID, involving priority settings and signal processing. Network configuration: Flexible setting of IP addresses and managing network services, and use sudoipaddradd to configure IP. These features are applied in real-life operations through basic commands and advanced script automation, improving efficiency and reducing errors.

The methods to enter Linux maintenance mode include: 1. Edit the GRUB configuration file, add "single" or "1" parameters and update the GRUB configuration; 2. Edit the startup parameters in the GRUB menu, add "single" or "1". Exit maintenance mode only requires restarting the system. With these steps, you can quickly enter maintenance mode when needed and exit safely, ensuring system stability and security.

The core components of Linux include kernel, shell, file system, process management and memory management. 1) Kernel management system resources, 2) shell provides user interaction interface, 3) file system supports multiple formats, 4) Process management is implemented through system calls such as fork, and 5) memory management uses virtual memory technology.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SublimeText3 Chinese version
Chinese version, very easy to use

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
