YanYuan death. The Master said, ‘Eeee! Mourning for the day! Heaven lost!” The Analects of Confucius: Advanced chapter

A hundred blog series. This is:

V50. Xx HongMeng kernel source code analysis (compile environment) | compiler HongMeng drop pit prevention guide

Compilation and construction related articles are:

  • V50. Xx HongMeng kernel source code analysis (compile environment) | compiler HongMeng drop pit prevention guide
  • V57. Xx HongMeng kernel source code analysis (compilation) | simple case at compilation process
  • Script v58. Xx HongMeng kernel source code analysis (environment) | compiler HongMeng so simple
  • V59. Xx HongMeng kernel source code analysis, build tools | suitable melon touch cane debugging HongMeng build process
  • Its v60. Xx HongMeng kernel source code analysis (designed.the gn) | designed.the gn syntax and use in HongMeng
  • V61. Xx HongMeng kernel source code analysis (ninja ninja) | ninja can upset

Some notes

  • Kernel_liteos_a_note | Chinese annotation HongMeng kernel is based on the OpenHarmony kernel_liteos_a add Chinese annotation to the kernel source code version. Monthly synchronization with official source code, synchronization history is as follows:

    • 2021/9/14Common, Extended, and several directory structures and Makefile adjustments
    • 2021/8/19— Each category has been increasedBUILD.gnFile, file system part file adjustment
    • 2021/7/15— Not much changed, newblackbox.hidumperTo normalize the use of some macros
    • 2021/6/27– Major changes to the file system/device driver, reorganized directory structure
    • 2021/6/08– Major changes to build, task and signal modules
    • 2021/5/28— Minor changes, mainly for spelling correction of some wrong words
    • 2021/5/13— System call, task switching, signal processing, exception takeover, file management, shell has been greatly updated, and the code structure is clearer
    • 2021/4/21— Official optimization of a lot of jokes before, like
    • 2020/9/16— Starting point of Chinese annotated version
  • weharmonyos.com| HongMeng research station

    It is divided into three parts

    • OpenHarmony Developer Docs is a very cool static site for official docs. It supports sidebar/breadcrumb/search/Both English and Chinese. It is very easy to view official docs and greatly improves learning and development efficiency
    • Hundreds of blog analysis hongmeng kernel is the kernel source code annotation process sorted out the content output.
    • Collation of some analysis of the kernel tools and books such as: hongmeng source analysis. Offline documentation, GNU assembly, GN reference manual
  • Subsystem annotation repository

    In the process of annotating the source code of the masked kernel, we found that only annotating the kernel repository is not enough, because it is associated with other subsystems, if you do not understand these subsystems is difficult to annotate the masked kernel completely, so we also annotated some of these associated repositories, including:

    • Compile build subsystem | build_lite
    • Protocol stack | lwip
    • The file system | NuttX
    • The standard library | musl

HongMeng version

This paper mainly uses Windows + Docker compilation hongmeng. Document the compilation process so that you don’t have to go through a bunch of invalid, misleading documents later to find the most useful information, which can be time-consuming. Using different kernels for different scenarios, OpenHarmony has two open source versions.

  • Standard System version, also known as (Linux /L2/ mobile) version, L2 Open Source (2021/06/02), which uses the Linux 4.19 kernel. Huawei Mobile phones (HarmonyOS2.0) are commercial releases based on this open source version.
  • Light and small System versions, also called (LitEOS /L0 to L1/ embedded) versions, L0 open source (2020/09/10),L1 open source (2020/12/02), lite-OS-A/M kernel, intended for embedded devices.

This article explains the compilation process for both versions in detail.

Install the Docker Desktop

Install Docker Desktop to download Windows version and proceed to the next step.

No technical content of the toss, quickly solve the two pain points before compilation conditions: source code and compilation environment

Prepare the source code

There are two ways to obtain the source code, one is a direct gitee repository (REPO) download, one is a site download. Because of the large amount of code, coupled with the network speed, the gitee warehouse itself, there is a probability of failure in the first way, waste of time, such no technical content of torment is not meaningful, this paper adopts the direct site download, please compare to go to download.

Source path

LTS version source download address -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- the standard version Lightweight version at https://repo.huaweicloud.com/harmonyos/os/2.0/code-2.0-canary.tar.gz https://repo.huaweicloud.com/harmonyos/os/1.1.1/code-v1.1.1-LTS.tar.gzCopy the code

Source download this unity on E: \ openharmony docker – standard directory, and create a good two empty directories, code – 1.1.1 code – 2.0 – canary, current contents as follows: / / under Windows powershell

PS E:\openharmony-docker-standard> ls
    目录: E:\openharmony-docker-standard
Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
da----          2021/4/2      9:27                code-1.1.1
da----         2021/6/17     18:24                code-2.0-canary
-a----         2021/6/18      9:44      323145491 code-1.1.1.tar.gz
-a----          2021/6/5     17:49     1433581461 code-2.0-canary.tar.gz 
Copy the code

The reason for doing this is because you need to unpack the tar packages, but these two tar packages need to be unpacked in Linux, which needs to be done in Docker.

Preparing the compilation environment

To have a compilation environment, compilation environment is a headache, it is too troublesome to install by yourself, and easy to make mistakes, but Docker is really sweet, the official also helped us solve this problem. Similarly, two versions correspond to two Docker images

LTS versions mirror address -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- the standard version docker pull Swr.cn-south-1.myhuaweicloud.com/openharmony-docker/openharmony-docker-standard:0.0.1 lightweight version docker pull swr.cn-south-1.myhuaweicloud.com/openharmony-docker/openharmony-docker:0.0.5Copy the code

Build standard Edition (L2/Linux)

Select the standard version of the image to create the container, do a good job as shown in the binding selection

After the container is created, you can right-click the container inspect in VScode to view the bound directory.

"HostConfig": { "Binds": [" E: \ \ openharmony docker - standard \ \ code - 2.0 - canary: / home/openharmony ", "E: \ \ openharmony docker - standard: / home/tar"].Copy the code

Vscode right-click the container attach shell and enter the container.

Gz code-2.0-canary code-2.0-canary.tar.gz root@95720c1a0803:/home/tar# ls code-1.1.1 code-1.1.1.tar.gz // Run the decompression command root@95720c1a0803:/home/tar# tar -zxvf code-2.0-canary.tar.gz.... Code - 2.0 - canary/base/iot_hardware/peripheral interfaces/kits/iot_gpio. H Code - 2.0 - canary/base/iot_hardware/peripheral interfaces/kits/iot_uart. H Code - 2.0 - canary/base/iot_hardware/peripheral interfaces/kits/reset. H / / / home/openharmony after decompression under direct have to compile the source code root@95720c1a0803:/home/openharmony# ls applications build build.sh device domains foundation kernel out productdefine Third_party Vendor Base build.py developtools docs drivers interface ocompanies config.json prebuilts test utils root@95720c1a0803:/home/openharmony# .. /scripts/prepare.sh ... /build.sh --product-name {product_name} //{product_name} indicates the platform supported by the current version. For example, Hi3516DV300. root@95720c1a0803:/home/openharmony#./build.sh --product-name Hi3516DV300 ... / / compile the generated files are archived in the out/ohos - arm - release/root directory @ 95720 c1a0803: / home/openharmony/out/ohos - arm - release# ls NOTICE_FILES build.ninja clang_x64 dist global lib.unstripped obj sa_profile third_party ace build.ninja.d common distributeddatamgr graphic module_list_files override sorted_action_duration.txt toolchain.ninja args.gn build.trace.gz communication exe.unstripped hiviewdfx multimedia packages src_installed_parts.json updater build.log build_configs developtools gen Js_declaration multimodalinput qrcode src_sa_infos_tmp. Json / / the result image output in the out/ohos - arm - release/packages/phone/images/directory root@95720c1a0803:/home/openharmony/out/ohos-arm-release/packages/phone/images# ls Hi3516DV300-emmc.xml u-boot-hi3516dv300_emmc.binCopy the code

Build light version (L0~L1/LiteOS)

Select the lightweight version of the image to create a container, refer to the standard layout for binding operations. After the container is created, you can right-click the container inspect in VScode to view the bound directory.

"HostConfig": { "Binds": [" E: \ \ openharmony docker - standard \ \ code - 1.1.1: / home/openharmony ", "E: \ \ openharmony docker - standard: / home/tar"].Copy the code

Vscode right-click the container attach shell and enter the container.

Gz code-2.0-canary code-2.0-canary.tar.gz root@0d3e98ee3fe0:/home/tar# ls code-1.1.1 code-1.1.1.tar.gz // Run the decompression command root@0d3e98ee3fe0:/home/tar# tar -zxvf code-1.1.1.tar.gz... Code - 1.1.1 / base/iot_hardware/peripheral interfaces/kits/iot_gpio. H Code - 1.1.1 / base/iot_hardware/peripheral interfaces/kits/iot_uart. H Code - 1.1.1 / base/iot_hardware/peripheral interfaces/kits/reset. H / / / home/openharmony after decompression under direct have to compile the source code root@0d3e98ee3fe0:/home/openharmony# ls applications base build build.py developtools device docs domains drivers foundation kernel prebuilts test third_party utils vendorCopy the code

Compile the project selection | hb set

root@0d3e98ee3fe0:/home/openharmony# hb set
[OHOS INFO] Input code path: .
OHOS Which product do you need?  (Use arrow keys)

hisilicon
❯ ipcamera_hispark_aries
wifiiot_hispark_pegasus
ipcamera_hispark_taurus
Copy the code

So I’m going to press enter and I’m going to select IPcamerA_hispark_aries

Compile command | hb env

After the path is set, you can view the current configuration information

root@0d3e98ee3fe0:/home/openharmony# hb env
[OHOS INFO] root path: /home/openharmony
[OHOS INFO] board: hispark_aries
[OHOS INFO] kernel: liteos_a
[OHOS INFO] product: ipcamera_hispark_aries
[OHOS INFO] product path: /home/openharmony/vendor/hisilicon/hispark_aries
[OHOS INFO] device path: /home/openharmony/device/hisilicon/hispark_aries/sdk_liteos
Copy the code

Compile the crater | 10 – > LLVM llvm9

CJSON/libcjson_shared.cjson. o error: LLVM 10 is changed to llVM9.

Compile command | hb build – f

Due to the slow compilation speed of Docker, the test subsystem is removed for fast compilation, so that half of the test files can be compiled less. The removal method is as follows: Go to.. \code-1.1.1\vendor\hisilicon\hispark_aries\config.json Deletes the test subsystem

{ "subsystem": "vendor", "components": [ { "component": "middleware", "features":[] }, { "component": "Hi3518ev300_subsystem ", "features":[]}, {" Component ": "hardware", "features":[]}]}, // Delete the test subsystem (optional) {"subsystem": "ai", "components": [ { "component": "ai_engine", "features":[] } ] } root@0d3e98ee3fe0:/home/openharmony# hb build -f ... [OHOS INFO] [965/974] SOLINK ./librecorder_lite.so [OHOS INFO] [966/974] STAMP obj/foundation/multimedia/media_lite/frameworks/recorder_lite/media_lite.stamp [OHOS INFO] [967/974] SOLINK ./libplayer_lite.so [OHOS INFO] [968/974] STAMP obj/foundation/multimedia/media_lite/services/media_ndk.stamp [OHOS INFO] [969/974] STAMP obj/foundation/multimedia/media_lite/services/media_lite.stamp [OHOS INFO] [970/974] STAMP obj/build/lite/ohos.stamp [OHOS INFO] [971/974] SOLINK ./libaudio_lite_api.so [OHOS INFO] [972/974] STAMP obj/foundation/multimedia/media_lite/frameworks/player_lite/media_lite.stamp [OHOS INFO] [973/974] ACTION //build/lite:gen_rootfs(//build/lite/toolchain:linux_x86_64_ohos_clang) [OHOS INFO] [974/974] STAMP Stamp [OHOS INFO] ipcamera_hispark_aries build success Each directory meaning below the root @ 0 d3e98ee3fe0: / home/openharmony# ls applications build developtools docs drivers kernel out test utils base build.py device domains foundation ohos_config.json prebuilts third_party vendorCopy the code
Sample applications, including wifi-iot, Software service subsystem set hardware service subsystem set componentialized compilation, construction, and configuration scripts Drivers subsystem set software service subsystem set foundation system basic capability subsystem set Kernel kernel subsystem prebuilts Compiler and tool chain system test Test subsystem third_party Open-source third-party component utils Common tool set Software provided by vendor Build. py Compilation script file out Generated after compilationCopy the code

Compiler output | out directory

Output directory: out/hispark_aries/ipcamera_hispark_aries

root@0d3e98ee3fe0:/home/openharmony/out/hispark_aries/ipcamera_hispark_aries# ls
args.gn      build.ninja             data            gen               NOTICE_FILE     OHOS_Image.bin    server.map       userfs
bin          build.ninja.d           dev_tools       libs              obj             OHOS_Image.map    test             userfs_jffs2.img
bm_tool.map  bundle_daemon_tool.map  etc             liteos.bin        OHOS_Image      rootfs_jffs2.img  test_info        vendor
build.log    config                  foundation.map  media_server.map  OHOS_Image.asm  rootfs.tar        toolchain.ninja
Copy the code

Intensive reading of the kernel source code

Four code stores synchronous annotation kernel source code, >> view the Gitee repository

Analysis of 100 blogs. Dig deep into the core

Add comments to hongmeng kernel source code process, sort out the following article. Content based on the source code, often in life scene analogy as much as possible into the kernel knowledge of a scene, with a pictorial sense, easy to understand memory. It’s important to speak in a way that others can understand! The 100 blogs are by no means a bunch of ridiculously difficult concepts being put forward by Baidu. That’s not interesting. More hope to make the kernel become lifelike, feel more intimate. It’s hard, it’s hard, but there’s no turning back. 😛 and code bugs need to be constantly debug, there will be many mistakes and omissions in the article and annotation content, please forgive, but will be repeatedly amended, continuous update. Xx represents the number of modifications, refined, concise and comprehensive, and strive to create high-quality content.

Compile build The fundamental tools Loading operation Process management
Compile environment

The build process

Environment script

Build tools

Designed.the gn application

Ninja ninja

Two-way linked list

Bitmap management

In the stack way

The timer

Atomic operation

Time management

The ELF format

The ELF parsing

Static link

relocation

Process image

Process management

Process concept

Fork

Special process

Process recycling

Signal production

Signal consumption

Shell editor

Shell parsing

Process of communication Memory management Ins and outs Task management
spinlocks

The mutex

Process of communication

A semaphore

Incident control

The message queue

Memory allocation

Memory management

Memory assembly

The memory mapping

Rules of memory

Physical memory

Total directory

Scheduling the story

Main memory slave

The source code comments

Source structure

Static site

The clock task

Task scheduling

Task management

The scheduling queue

Scheduling mechanism

Thread concept

Concurrent parallel

The system calls

Task switching

The file system Hardware architecture
File concept

The file system

The index node

Mount the directory

Root file system

Character device

VFS

File handle

Pipeline file

Compilation basis

Assembly and the cords

Working mode

register

Anomaly over

Assembly summary

Interrupt switch

Interrupt concept

Interrupt management

HongMeng station | into a little bit every day, the original is not easy, welcome to reprint, please indicate the source.