1.鸿蒙内核源码分析(构建工具篇) | 顺瓜摸藤调试鸿蒙构建过程
2.鸿蒙开发环境搭建、鸿蒙鸿蒙源码下载和编译
3.鸿蒙轻内核M核源码分析:LibC实现之Musl LibC
4.鸿蒙内核源码分析(编译过程篇) | 简单案例窥视编译全过程
5.v51.04 鸿蒙内核源码分析(ELF格式) | 应用程序入口并非main | 百篇博客分析OpenHarmony源码
6.鸿蒙轻内核M核源码分析:中断Hwi
鸿蒙内核源码分析(构建工具篇) | 顺瓜摸藤调试鸿蒙构建过程
构建工具的源码源码重要性不言而喻,它在工程的自制编译、连接、下载打包过程中发挥着关键作用。鸿蒙鸿蒙构建工具定义了哪些源文件需要被编译、源码源码qq飞车休闲辅助源码如何编译,自制哪些库文件需要创建以及如何创建,下载最终输出所需文件的鸿蒙鸿蒙规则。鸿蒙轻内核(L1/liteos)的源码源码构建工具是hb,它是自制ohos-build的简称,而ohos则是下载openharmony os的简称。hb通过命令行安装,鸿蒙鸿蒙是源码源码一个用Python编写的构建工具。其源代码位于./build/lite目录下。自制
鸿蒙构建系统由Python、gn、ninja、makefile几个部分组成。每个部分都有其特定功能,负责处理各自擅长的构建任务。在构建过程中,如果直接跳过hb部分,而使用gn gen命令,可以看到构建流程的简化结果。
为了更有效地调试hb,推荐使用VSCode进行。创建一个launch.json文件,然后粘贴特定代码即可进行调试。调试过程包括设置和编译两个关键步骤。
在设置阶段,通过执行hb set命令,系统会在源码根目录生成ohos_config.json配置文件。这个配置文件包含固定的配置项,由Config类管理。通过设置断点,源码如何形成程序可以直观地观察调试现场,为后续的编译步骤做好准备。
编译阶段通过hb build命令进行。源码主要位于./build/lite/hb/build/*.py目录下。建议深入探索这些源码,以理解每个细节。编译流程分为两步:首先通过gn_build生成.ninja文件,然后使用ninja_build执行构建任务。关于gn和ninja的使用方法,后续会有详细的文章进行说明。
在执行编译过程时,最后会调用exec_command方法来执行相关命令。这个方法位于build/lite/hb/common/utils.py文件中,通过在此处设置断点,可以跟踪exec_command方法的调用流程,深入了解构建工具的内部实现细节。
通过深入理解和调试构建工具,开发者可以更高效地完成项目构建任务,同时也能对构建流程有更深入的了解。最后,建议在调试过程中保持耐心,逐步探索每个步骤的细节,以便更好地掌握构建工具的使用和优化。
鸿蒙开发环境搭建、源码下载和编译
搭建鸿蒙开发环境,涉及到Linux与Windows主机的协同工作。Linux主机主要负责源码下载与编译,而Windows主机则用于程序烧写以及源码编辑。推荐在C盘预留至少G空间以确保顺畅运行。
相较于虚拟机,Win的Ubuntu子系统(WSL)在内存与CPU资源消耗上更为高效。同时,由于可以直接访问WSL环境,相较于多系统操作,文件交互更为便捷。访问php 显示源码安装Ubuntu . LTS可通过Win应用商店完成。
初次启动Ubuntu . LTS会涉及软件安装与配置,耐心等待几分钟直至完成。安装目录为%USERPROFILE%\AppData\Local\Packages,Linux系统的根目录为rootfs,而你的家目录为/home/yourname。WSL下系统硬盘自动挂载,如C/D盘对应/mnt/c,/mnt/d。
安装VcXsrv以实现X远程显示,下载后进行默认安装。启动XLaunch,选择“one large window”,Display number设置为0,其余保持默认即可。
安装桌面环境所需的必要软件,遇到问题时先更新apt-get,问题通常迎刃而解。配置CCSM(桌面控制中心)后,输入相应命令在XLaunch上显示桌面。
在Windows与Linux之间互看文件,可以通过在Ubuntu下查看“/mnt”目录实现。若需查看Ubuntu Python版本,可在/usr/bin下执行ls -l python*命令。系统中应包含python3.7及以上版本,确保满足需求。
修改python命令指向的版本,使用mv命令将python3改名为python3.bak,然后使用ln -s命令将python3.8链接至python。配置repo工具用于下载与管理源码。
下载Harmony OS源码,如已完成,安装文件系统打包工具(dosfstools、mtools、zip)。客服中心网页源码执行编译指令前,确保scons命令路径在环境变量中。
使用虚拟env环境编译源码,执行编译目标平台的命令:/bin/python build.py wifiiot。如果在过程中遇到编译器问题,检查文件路径是否在环境变量中,添加至环境变量即可解决。
整个过程耗时约一天,系统空间需求接近G,建议在安装前做好系统空间管理,确保过程顺畅。通过以上步骤,成功搭建鸿蒙开发环境,为后续的源码下载与编译打下坚实基础。
鸿蒙轻内核M核源码分析:LibC实现之Musl LibC
本文探讨了LiteOS-M内核中Musl LibC的实现,重点关注文件系统与内存管理功能。Musl LibC在内核中提供了两种LibC实现选项,使用者可根据需求选择musl libC或newlibc。本文以musl libC为例,深度解析其文件系统与内存分配释放机制。
在使用musl libC并启用POSIX FS API时,开发者可使用文件kal\libc\musl\fs.c中定义的文件系统操作接口。这些接口遵循标准的POSIX规范,具体用法可参阅相关文档,或通过网络资源查询。例如,mount()函数用于挂载文件系统,而umount()和umount2()用于卸载文件系统,后者还支持额外的卸载选项。open()、close()、unlink()等文件操作接口允许用户打开、关闭和删除文件,其中open()还支持多种文件创建和状态标签。read()与write()用于文件数据的抖音源码开源读写操作,lseek()则用于文件读写位置的调整。
在内存管理方面,LiteOS-M内核提供了标准的POSIX内存分配接口,包括malloc()、free()与memalign()等。其中,malloc()和free()用于内存的申请与释放,而memalign()则允许用户以指定的内存对齐大小进行内存申请。
此外,calloc()函数在分配内存时预先设置内存区域的值为零,而realloc()则用于调整已分配内存的大小。这些函数构成了内核中内存管理的核心机制,确保资源的高效利用与安全释放。
总结而言,musl libC在LiteOS-M内核中的实现,通过提供全面且高效的文件系统与内存管理功能,为开发者提供了强大的工具集,以满足不同应用场景的需求。本文虽已详述关键功能,但难免有所疏漏,欢迎读者在遇到问题或有改进建议时提出,共同推动技术进步。感谢阅读。
鸿蒙内核源码分析(编译过程篇) | 简单案例窥视编译全过程
一个 .c 源文件的编译过程,从源文件开始,经过预处理、编译、汇编、链接,最终生成可执行文件。
GCC 是 GNU 编译器套件,用于多种编程语言的编译。
以 main.c 为例,编译过程分为以下几个步骤:
1. 预处理:处理源代码中的预处理指令,生成 main.i 文件。此步骤主要处理 # 开始的指令。
2. 编译:将预处理后的文件进行词法、语法和语义分析,优化后生成汇编代码,即 main.s。
3. 汇编:将汇编代码转化为机器指令,生成机器码文件,main.o 为主要目标文件。
4. 链接:链接器 ld 将所有目标文件合并,解决符号和库依赖关系,生成可执行文件。
执行程序:运行可执行文件,执行程序。
在链接阶段,可能会发现 s_inter_init() 和 s_exter_no_init() 之间的地址只相差两个字节,而 int 变量应为四个字节。这是由于 GCC 在链接过程中使用了重定位,将符号引用与实际的内存地址关联,从而优化内存使用和性能。这种重定位在编译和链接阶段进行,确保程序在不同环境中运行时的一致性。
v. 鸿蒙内核源码分析(ELF格式) | 应用程序入口并非main | 百篇博客分析OpenHarmony源码
鸿蒙内核源码分析(ELF格式篇) | 应用程序入口并非main
深入解析ELF格式与鸿蒙源码的关系,探寻应用程序入口的奥秘。本文将带你从一段简单的C代码开始,跟踪其编译成ELF格式后的神秘结构,揭秘ELF的组成与内部运作机制。
以E:\harmony\docker\case_code_目录下的main.c文件为例,通过编译生成ELF文件,运行后使用readelf -h命令查看应用程序头部信息。了解ELF文件的全貌,从ELF头信息、段信息、段区映射关系、区表等多方面深入探讨。
ELF格式文件由四大部分组成:头信息、段信息、段区映射关系和区表。头信息包含关键元数据,如文件类型、字节顺序、文件大小等;段信息描述了可执行代码和数据段的属性和位置;段区映射关系展示了段与区的关联;区表则存储了每个区的详细信息。
通过readelf -l命令,可以观察到段信息及其在程序中的作用,如初始化数组、动态链接、栈区等。在运行时,不同段以特定方式映射到内存中,实现代码的加载和执行。
在深入分析后,发现应用程序的真正入口并非通常理解的main函数,而是一个名为_start的特殊函数。这揭示了鸿蒙内核在启动时的执行流程,以及如何在ELF格式中组织和加载代码。
本文以ELF格式为切入点,带你全面理解鸿蒙内核源码的组织结构与运行机制。通过百万汉字注解,带你精读内核源码,深入挖掘其地基。在Gitee仓(gitee.com/weharmony/ker...)同步注解,共同探索鸿蒙研究站(weharmonyos)的奥秘。
鸿蒙轻内核M核源码分析:中断Hwi
在鸿蒙轻内核源码分析系列中,本文将深入探讨中断模块,旨在帮助读者理解中断相关概念、鸿蒙轻内核中断模块的源代码实现。本文所涉及源码基于OpenHarmony LiteOS-M内核,读者可通过开源站点 gitee.com/openharmony/k... 获取。中断概念介绍
中断机制允许CPU在特定事件发生时暂停当前执行的任务,转而处理该事件。这些事件通常由外部设备触发,通过中断信号通知CPU。中断涉及硬件设备、中断控制器和CPU三部分:设备产生中断信号;中断控制器接收信号并发出中断请求给CPU;CPU响应中断,执行中断处理程序。中断相关的硬件介绍
硬件层面,中断源分为设备、中断控制器和CPU。设备产生中断信号;中断控制器接收并转发这些信号至CPU;CPU在接收到中断请求后,暂停当前任务,转而执行中断处理程序。中断相关的概念
每个中断信号都附带中断号,用于识别中断源。中断优先级根据事件的重要性和紧迫性进行划分。当设备触发中断后,CPU中断当前任务,执行中断处理程序。中断处理程序由设备特定,且通常以中断向量表中的地址作为入口点。中断向量表按中断号排序,存储中断处理程序的地址。鸿蒙轻内核中断源代码
中断相关的声明和定义
在文件 kernel\arch\arm\cortex-m7\gcc\los_interrupt.c 中定义了结构体、全局变量和内联函数。关键变量 g_intCount 记录当前正在处理的中断数量,内联函数 HalIsIntActive() 用于检查是否正在处理中断。中断向量表在中断初始化过程中设置,用于映射中断号到相应的中断处理程序。中断初始化 HalHwiInit()
系统启动时,在 kernel\src\los_init.c 中初始化中断。HalHwiInit() 函数在 kernel\arch\arm\cortex-m7\gcc\los_interrupt.c 中实现,负责设置中断向量表和优先级组,配置中断源,如系统中断和定时器中断。创建中断 HalHwiCreate()
开发者可通过 HalHwiCreate() 函数注册中断处理程序,传入中断号、优先级和中断模式。函数内部验证参数,设置中断处理程序,最终通过调用 CMSIS 函数完成中断创建。删除中断 HalHwiDelete()
中断删除操作通过 HalHwiDelete() 实现,接收中断号作为参数,调用 CMSIS 函数失能中断,设置默认中断处理程序,完成中断删除。中断处理执行入口程序
默认的中断处理程序 HalHwiDefaultHandler() 仅用于打印中断号后进行死循环。HalInterrupt() 是中断处理执行入口程序的核心,它包含中断数量计数、中断号获取、中断前后的操作以及调用中断处理程序的逻辑。开关中断
开关中断用于控制CPU是否响应外部中断。通过宏 LOS_IntLock() 关闭中断, LOS_IntRestore() 恢复中断状态, LOS_IntUnLock() 使能中断。这组宏对应汇编函数,使用寄存器 PRIMASK 控制中断状态。小结
本文详细解析了鸿蒙轻内核中断模块的源代码,涵盖了中断概念、初始化、创建、删除以及开关操作。后续文章将带来更多深入技术分享。欢迎在 gitee.com/openharmony/k... 分享学习心得、提出问题或建议。关注、点赞、Star 和 Fork 到个人账户,便于获取更多资源。鸿蒙OS是用什么语言编写的,它的应用又是用什么语言可以编写
鸿蒙操作系统是由华为自主研发的,其架构基于Linux内核。内核之上是麒麟处理器的运行库,为系统提供了底层支持。编译器用于将源代码转换为可执行文件,虚拟机则负责运行这些文件。鸿蒙系统的源代码主要使用C语言编写,这是一种广泛应用于操作系统开发的编程语言,因其高效性和稳定性著称。
开发鸿蒙应用程序需要使用华为开发工具DevEco Studio。DevEco Studio是华为为鸿蒙系统设计的集成开发环境,它不仅支持程序的开发、调试和维护,还提供了丰富的功能来帮助软件工程师进行高效工作。DevEco Studio支持多种编程语言,包括但不限于C、C++以及JavaScript等,这使得开发者可以根据项目需求灵活选择合适的语言。
值得一提的是,DevEco Studio还具备可视化编程能力。通过直观的界面,开发者可以更加便捷地构建应用程序,实时查看编程效果。这种可视化编程方式不仅简化了开发流程,也极大地降低了开发难度。对于初学者来说,这无疑是一种很好的学习工具。
由于鸿蒙系统采用了多语言支持策略,开发者可以使用C、C++、JavaScript等语言进行开发。这些语言各有优势,能够满足不同类型的应用场景。例如,C和C++适用于对性能要求较高的场景,而JavaScript则更适合Web开发和跨平台应用。