鸿蒙OS开源代码精要解读之——init
鸿蒙OS开源代码精要解读之——init
作者介绍:
中科创达OpenHarmony研究组
说明:
中科创达OpenHarmony研究组第一时间对https://codechina.csdn.net/openharmony上开源的代码进行了详尽的代码研读和学习。为此,我们打算编写一系列篇幅中等,内容精炼的源码分析文章来引领大家更进一步的走进鸿蒙OS。随着对代码的了解,广大开发者想亲自动手参与的意愿和信心也会随之增强——这也是鸿蒙OS开源的意义所在。
本篇内容摘要:
本篇以OpenHarmony中ipcamera_hi3518ev300为编译目标,介绍init进程的相关代码。
写在前面的话
我们对OpenHarmony的代码进行了一个简单粗略的统计。除去所有的third_party代码(即OpenHarmony使用的第三方开源库),其他剩余的代码中,以.c、.h文件为统计入口,总有效代码行数(不含注释、空行等,统计工具为tSourceCounter)为325627行。其中,归属kernel目录下的总有效代码行数为74150行。整个OpenHarmony中,kernel部分占比为22.8%左右,代码量上占大头的还在于kernel之上的、我们称之为Framework的部分。根据我们在Android系统上多年的摸索和经验,Framework恰恰是Android OS的精髓。所以,以OpenHarmony目前才20多万行的Framework代码量来看,感兴趣的开发者在这块参与共建、献策献力的机会非常大。
1. OpenHarmony源码的下载和编译
先介绍代码的下载和编译。我们研究组用得是ubuntu 19.10的主机环境。
1.1 源码下载
按照codechina.csdn官网的源码下载指南:https://codechina.csdn.net/openharmony/docs/-/blob/master/get-code/%E6%BA%90%E7%A0%81%E8%8E%B7%E5%8F%96.md
我们使用的是第四种方式“获取方式4:从代码仓库获取”。执行这一节中的几个命令,即可得到整个源码仓库。
1.2 编译源码
我们选择的编译目标是“Hi3518解决方案”,其编译后的输出目录名为ipcamera_hi3518ev300。ipcamera_hi3518ev300是一个基于海思的ip摄像头设备。相关的介绍文档入口在https://codechina.csdn.net/openharmony/docs/-/blob/master/quick-start/%E6%90%AD%E5%BB%BA%E7%8E%AF%E5%A2%83-2.md。
注意,编译不同的解决方案需要建立对应的编译环境。对hi3518来说,开发者需要按照上述链接里的“搭建环境”来下载和配置。
一切就绪后,在源码根目录下执行 python build.py。如果不带参数的话,它会提醒你指定编译目标,截图如下:
图1 python build.py不带参数的执行结果
这次,我们通过python build.py ipcamera_hi3518ev300即可编译“Hi3518解决方案”。编译耗时10几分钟。
注意,编译过程中可能出现找不到<valgrind/valgrind.h>的错误。这是因为目前我们下载的代码中没有包含valgrind的头文件。开发者可以手动将/usr/include/valgrind目录拷贝到prebuilts/lite/sysroot/usr/include下即可(仅限Ubuntu平台,需提前安装好valgrind工具)。
1.3 OpenHarmony编译相关小知识介绍
OpenHarmony源码编译系统使用了google开发的gn工具以及ninjia。这二者结合起来比传统的makefile编译系要高效,尤其适合大系统的并行编译。对开发者而言,如果要参与OpenHarmony的开发,需要对gn的语法有些了解。本文仅做一些最基本的介绍:
- 使用gn工具的话,开发者将编译规则写在名为BUILD.gn文件中。和Makefile一样,gn文件有自己的语法规则,属于领域语言(Domain Specific Language,DSL)。gn语法不难,但编译规则本身有很多内容,所以一下子要掌握全部内容也不容易。
- gn支持自定义模板函数,可放在名为.gni的文件中。OpenHarmony中最常见到的gn模板文件为./build/lite/config/component/lite_component.gni。.gn文件中通过import可导入gni模板文件。OpenHarmony定义了lite_component、lite_library等模板函数。
- gn中,可执行文件的编译函数入口为exectuable("文件名"),共享库的编译规则函数为shared_library("文件名")。所以,如果要搜索某个文件对应的编译规则,可以先搜索所有的BUILD.gn文件,然后grep executable。以下是我们grep所有的executable的结果截图。
图2 grep BUILD.gn中executable的结果示意
通过这种方式,我们能很快定位到比如init对应的代码在什么地方。
最后,我们再简单介绍下OpenHarmony编译系统中和底层OS有关的一个条件编译控制变量ohos_kernel_type。目前,该变量有四个取值,分别为"liteos_a"、"liteos_m"、"liteos_riscv"和"linux":
- "liteos_a"和"linux"经常做为一组进行判断。liteos_a实际对应的是Cortex-A系列,其性能相对较高,可以跑Linux系统。
- "liteos_m"和"liteos_riscv"往往是一组的。liteos_m对应的是Cortex-M系列,liteos_riscv是Riscv芯片的表示,二者可能都是针对性能一般,功耗较低的设备。
ohos_kernel_type的取值由build/lite/product/解决方案名.json文件中的product字段决定。例如,我们选择的ipcamera_hi3518ev300的配置文件内容截图如下,它的kernel字段值为"liteos_a"。
图3 build/lite/product/ ipcamera_hi3518ev300.json配置文件示意图
编译完成后,所有编译生成物都在out/ipcamera_hi3518ev300目录下。
2 init源码精要解析
init是Linux系统上的第一个应用进程,是其它进程的源头。对ipcamera_hi3518ev300来说,它的编译产物中也有一个init进程。
在上面提到的out/ipcamera_hi3518ev300目录下,有一个rootfs.tar文件。这个文件里就是设备上根文件系统的内容。打开其中的/rootfs/bin目录,可以看到此次编译的可执行程序如下截图所示:
图4 out/ipcamera_hi3518ev300/rootfs.tar/bin内容示意
借助图2里提到的办法,我们可以定位到init对应的代码路径为base/startup/services/init_lite/。其内容如下图所示:
图5 init_lite源码文件示意图
main.c是整个init的入口。我们简单看一下它的代码,如下所示。
图6 init_lite/main.c
init main函数非常精简,非常符合"lite"轻量简便的风格。当然,也不排除未来init的代码会越来越复杂。我们在AOSP上观察到的情况就是一个例子——AOSP里现在的init的相关代码非常复杂)。
我们对InitReadCfg比较感兴趣,这个函数内部将读取/etc/init.cfg文件。这个文件在图4中提到的rootfs.tar中可以找到,下图是其内容的示意:
图7 rootfs.tar/etc/init.cfg
init.cfg本质上是一个json格式的文件。它包括一个名为"jobs"的数组和一个名为"services"的数组。
- 对"jobs"来说:内部分别包含"pre-init"、"init"和"post-init"三个元素。从上面的截图中可以看出,这三个元素对应的就是设置挂载一些设备、设置好路径,启动服务等工作。
- 对"services"来说:它包含一组服务的定义。所谓的服务,就是系统里的关键进程。可以猜测到,init将根据service的配置来启动对应的服务程序,并设置它的uid、gid、进程优先级和权限等。
如果开发者对Android系统有一定了解的话,会发现OpenHarmony和AOSP在init的工作流程上有着相似的设计思路。不过,对OpenHarmony目标设备来说,使用json格式无疑是比较简单且方便的。
最后,我们再看一下init的另外一个重要职能——服务进程状况监控。init.cfg中的那些服务属于系统关键进程。运行过程中如果它们出现异常导致进程退出,需要有个办法将它们重新启动以保证业务连续性。
这个功能的实现就是利用Linux系统的SIGCHILD信号。init在SignalInitModule中监听了该信号并设置了对应的信号处理函数——SigHandler。SigHandler函数的具体处理过程则比此处说得要更复杂一点。现在,这部分内容就留给读者们自行探索了!!
鸿蒙OS开源代码精要解读之——init相关推荐
- 并注册烧写钩子 获取启动介质类型_鸿蒙OS开源代码精要解读之—— 系统服务框架子系统(服务启动)...
鸿蒙OS开源代码精要解读之-- 系统服务框架子系统(服务启动) 作者介绍: 中科创达OpenHarmony研究组 说明: 中科创达OpenHarmony研究组第一时间对https://codechin ...
- 鸿蒙os开源邀请全球开发者,全场景无缝连接 鸿蒙OS开源邀请全球开发者共助生态发展...
原标题:全场景无缝连接 鸿蒙OS开源邀请全球开发者共助生态发展 万众瞩目之下,鸿蒙OS终究还是亮相了. 在今日开始的华为开发者大会(HDC)上,我们熟悉的消费者业务CEO余承东首个登场,在回顾了华为消 ...
- 鸿蒙os开源连接,全场景无缝连接 鸿蒙OS开源邀请全球开发者共助生态发展
原标题:全场景无缝连接 鸿蒙OS开源邀请全球开发者共助生态发展 万众瞩目之下,鸿蒙OS终究还是亮相了. 在今日开始的华为开发者大会(HDC)上,我们熟悉的消费者业务CEO余承东首个登场,在回顾了华为消 ...
- 鸿蒙OS开源项目的OpenHarmony
点击上方的终端研发部,右上角选择"设为星标" 前言 华为消费者业务CEO余承东在华为开发者大会HDC 2020上正式发布了鸿蒙OS 2.0系统,并开源其源代码. OpenHarmo ...
- 华为宣布鸿蒙OS开源
[TechWeb]8月9日,华为2019开发者大会在东莞华为松山湖溪流背坡村举行.华为消费者业务CEO.华为技术有限公司常务董事余承东正式向全球发布其全新的基于微内核的面向全场景的分布式操作系统--鸿 ...
- 读了鸿蒙 OS 的代码后,我发现优秀项目都有这个共性!
作者 | 马超 责编 | 胡巍巍 出品 | 程序人生(ID:coder_life) 最近有人在Github上开源了鸿蒙OS(https://www.github.com/Awesome-Harmony ...
- 鸿蒙支持lOS,读了鸿蒙 OS 的代码后,我发现优秀项目都有这个共性!
最近有人在Github上开源了鸿蒙OS(https://www.github.com/Awesome-HarmonyOS)并且累计获得了一万多颗Star.从华为的官方宣传中就提到了"安卓总代 ...
- 鸿蒙开源代码数量,消息称华为鸿蒙此次开源代码量大约是 8GB,AOSP 超 60GB
来源:IT之家 在近期的华为鸿蒙伙伴峰会上,华为消费者业务 AI 与智慧全场景业务部副总裁杨海松接受媒体采访时表示,鸿蒙系统完全开源开放,今年会按照既定计划做到 128MB-4GB 的设备全栈系统开源 ...
- 鸿蒙公布源代码,消息称华为鸿蒙此次开源代码量大约是 8GB,AOSP 超 60GB
IT 之家 5 月 22 日消息 在近期的华为鸿蒙伙伴峰会上,华为消费者业务 AI 与智慧全场景业务部副总裁杨海松接受媒体采访时表示,鸿蒙系统完全开源开放,今年会按照既定计划做到 128MB-4GB ...
最新文章
- 老板说“我们要做个性化推荐”时,你该怎么办......
- Oracle查看死锁 .
- win10分辨率不能调整_Win10系统分辨率不能修改怎么办?屏幕分辨率的调节方法...
- DropDownList第一个默认值
- jmeter性能测试实战_Jmeter接口测试实战篇:10分钟学会Jmeter的用法
- 【毕业设计8】基于STM32的红外测距系统
- PRO/E配置文件选项
- eterm单人订座流程
- visual studio 版本的区别
- linux设置用户默认桌面背景,linux 修改桌面背景
- 1. 2020年《DeepMind&UCL深度学习讲座》第1讲:机器学习和AI入门【中文字幕】
- 简单的一道 SQL 题,谈如何提高编程水平
- 学习笔记10--CAN总线技术
- Excel-VBA文件操作
- 【CNC——第9.1篇】使用Setup引导程序整定步进电机(开环步进电机整定方式之1)
- 没有鼠标就无法对计算机进行操作,电脑鼠标不灵敏是什么原因?怎么解决?
- 搜索:Flood Fill
- kettle作业发送QQ邮箱提醒
- razer鼠标测试软件,驱动软实力对比测试_Razer 炼狱蝰蛇2013鼠标_键鼠评测-中关村在线...
- linux如何查看无线密码是多少个,在 Linux 中查看连接过的 WiFi 密码
热门文章
- 一文看懂为什么边缘计算是大势所趋 | GSMA 报告
- java读取.html文件并获取数据
- java ppt控件_Java版PPT操作控件Spire.Presentation v2.12.2新版来袭!支持获取具有超链接的目标幻灯片...
- Web安全-Tomcat禁用Web服务器内置不安全请求方法
- 离线语音远程遥控车控门制作教程(二)
- HDU 6608 Fansblog(随机素数测试+思维)
- UVA:1593 代码对齐
- [破解]天草初级笔记
- 德州仪器TM4C123GXL从入手到亮灯-开发环境配置
- 毕业论文 | 基于安卓手机蓝牙控制的智能小车设计(源代码)