OpenHarmony適配新的開發(fā)板時(shí),啟動(dòng)流程init大概率會(huì)出現(xiàn)問題,其為內(nèi)核直接拉起的第一個(gè)用戶態(tài)進(jìn)程,問題定位手段只能依賴代碼走讀和增加調(diào)試打印,初始化過程中系統(tǒng)崩潰的問題就更難定位了。如果能使用gdb調(diào)試init,會(huì)極大的提高定位效率。
本文簡(jiǎn)單描述了一下L2二次啟動(dòng)的系統(tǒng)如何使用gdb調(diào)試init
-
首先將gdb打包到系統(tǒng)鏡像中。
Init不正常的情況下,系統(tǒng)無(wú)法正常啟動(dòng)工作,無(wú)法使用hdc工具加載gdb工具,所以直接在制做鏡像時(shí),將其打包到系統(tǒng)鏡像bin目錄下。如下圖:
?
2. 調(diào)試版本鏡像帶符號(hào),需要修改鏡像配置文件,改大其大小限制。尤其是system.img,編譯失敗時(shí)不會(huì)提示實(shí)際鏡像大小,需要修改到5G以上。
?
3.編譯調(diào)試版本,打開版本調(diào)試開關(guān)
./build.sh --product-name=ita260 --gn-args="is_debug=true use_unstripped_as_runtime_outputs=true"
4. 在init掛載好system、vendor等鏡像,并將根目錄切換到system鏡像后,在啟動(dòng)第二階段init時(shí),切換到shell下,停止init初始化流程,見下圖B處。
注意:A處的CloseStdio()需要注釋掉
考慮用gdb啟動(dòng)init第二階段,init絕大部分處理流程都在這一階段,從這里開始就可以用gdb調(diào)試了,init第一階段處理相對(duì)而言流程簡(jiǎn)單一些,代碼走讀和調(diào)試打印基本就能解決問題。
5. 在init主函數(shù)中去掉“不等于進(jìn)程1就返回的處理”,因?yàn)橛胓db起init第二階段時(shí),其進(jìn)程非1。
?
6. init進(jìn)程中不初始化Paramworkspace,前面pid=1的判斷,在gdb調(diào)試init時(shí)條件不成立,所以此處增加判斷init名就直接退出的處理。
?
7. 系統(tǒng)啟動(dòng),init初始化第一階段完成后,會(huì)停在shell 下,此時(shí)使用下述命令啟動(dòng)init第二階段:gdb --args /bin/init --second-stage為了調(diào)試init的子進(jìn)程,還需要gdb下述命令set follow-fork-mode child
?
當(dāng)前gdb調(diào)試init方法不適用L0、L1和一次啟動(dòng)的L2系統(tǒng)。
本文章針對(duì)OpenHarmony系統(tǒng)在調(diào)試init初始化流程時(shí),缺少高效的問題定位手段這一痛點(diǎn),引入了嵌入式系統(tǒng)開發(fā)的主流調(diào)試工具-gdb。詳細(xì)描述了這一方法涉及到的版本編譯、適配點(diǎn)修改以及調(diào)試命令操作等細(xì)節(jié)處理,指導(dǎo)開發(fā)者提高定位init問題的效率。需要注意,當(dāng)前gdb調(diào)試init方法有局限,不適用L0、L1和一次啟動(dòng)的L2系統(tǒng)。
更多熱點(diǎn)文章閱讀-
玩轉(zhuǎn)OpenHarmony PID:教你打造兩輪平衡車
-
基于SDIO協(xié)議的WiFi模塊實(shí)現(xiàn)指南
-
ArkUI框架,更懂程序員的UI信息語(yǔ)法
-
帶你玩轉(zhuǎn)OpenHarmony AI:基于Seetaface2的人臉識(shí)別
-
帶你玩轉(zhuǎn)OpenHarmony AI:打造智能語(yǔ)音子系統(tǒng)
提示:本文由電子發(fā)燒友社區(qū)發(fā)布,轉(zhuǎn)載請(qǐng)注明以上來(lái)源。如需社區(qū)合作及入群交流,請(qǐng)?zhí)砑游⑿臙EFans0806,或者發(fā)郵箱liuyong@huaqiu.com。
原文標(biāo)題:OpenHarmony系統(tǒng)使用gdb調(diào)試init
文章出處:【微信公眾號(hào):電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
原文標(biāo)題:OpenHarmony系統(tǒng)使用gdb調(diào)試init
文章出處:【微信號(hào):HarmonyOS_Community,微信公眾號(hào):電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
相關(guān)推薦
1、程序簡(jiǎn)介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)編寫的UI應(yīng)用類:HelloOpenHarmony。本案例是基于API9接口開發(fā)。本案例已在OpenHarmony凌蒙派-RK35
發(fā)表于 09-15 08:09
?442次閱讀
= 0;void led_init(){ gpio_reset_pin(LED); gpio_set_direction(LED, GPIO_MODE_OUTPUT);}void led_blink
發(fā)表于 08-01 07:47
本文將介紹如何為QEMU RISC-V虛擬平臺(tái)構(gòu)建OpenHarmony輕量系統(tǒng)。得益于QEMU的CPU指令集模擬執(zhí)行能力,該方法可以在沒有開發(fā)板的情況下調(diào)試和運(yùn)行OpenHarmony
發(fā)表于 07-15 10:36
?1125次閱讀
是否有可能在支持 gdb 的第三方集成開發(fā)環(huán)境中使用 DAS 配置調(diào)試?
發(fā)表于 07-02 07:29
OpenHarmony已經(jīng)支持了Bootchart工具,我們可以直接使用Bootchart工具,Bootchart工具介紹如下:
概述
Bootchart是一個(gè)用于系統(tǒng)啟動(dòng)過程性能分析的開源軟件工具
發(fā)表于 07-01 16:39
上文小編給大家介紹了一下如何使用VSCode結(jié)合cortex-debug插件進(jìn)行調(diào)試的方法。本篇就趁熱打鐵,進(jìn)一步深入了解一下如何切換gdb server。讓我們可以不僅僅使用JLinkGDBServer進(jìn)行調(diào)試。
發(fā)表于 05-09 11:02
?2308次閱讀
使用真機(jī)設(shè)備運(yùn)行和調(diào)試OpenHarmony應(yīng)用前,需要對(duì)應(yīng)用進(jìn)行簽名才能正常運(yùn)行。
發(fā)表于 04-22 16:52
?506次閱讀
VSCODE使用GDB調(diào)試不顯示寄存器
發(fā)表于 02-22 06:46
arm三個(gè)寄存器在gdb調(diào)試時(shí)作用? ARM是一種廣泛使用的微處理器架構(gòu),它廣泛應(yīng)用于移動(dòng)設(shè)備、嵌入式系統(tǒng)和其他高性能計(jì)算設(shè)備。當(dāng)我們?cè)谑褂?b class='flag-5'>gdb(GNU
發(fā)表于 01-31 10:44
?1045次閱讀
如何使用linux下gdb來(lái)調(diào)試python程序? 在Linux下,可以使用GDB(GNU調(diào)試器)來(lái)調(diào)試Python程序。
發(fā)表于 01-31 10:41
?2689次閱讀
linux用gdb調(diào)試遇到函數(shù)調(diào)用怎么辦? 在Linux上使用GDB調(diào)試時(shí),遇到函數(shù)調(diào)用是一個(gè)常見的情況。函數(shù)調(diào)用可能涉及到多個(gè)函數(shù)、多個(gè)文件,這就需要我們仔細(xì)審查代碼,理解函數(shù)之間的
發(fā)表于 01-31 10:33
?740次閱讀
GDB是一個(gè)功能強(qiáng)大的源代碼級(jí)調(diào)試工具,它提供了多種基本功能,幫助程序員** **更好地理解程序的運(yùn)行機(jī)制和定位問題** **。
發(fā)表于 01-28 17:44
?1371次閱讀
TLT507-GDB程序調(diào)試方法說明
發(fā)表于 01-26 10:11
?1003次閱讀
1 關(guān)鍵字
啟動(dòng)、Init、產(chǎn)品配置、啟動(dòng)配置
2 簡(jiǎn)要描述
本文檔主要以XX開發(fā)版為例分析OpenHarmony系統(tǒng)啟動(dòng)過程、產(chǎn)品配置、啟動(dòng)配置,并舉例說明如何配置。
內(nèi)核加載Init
發(fā)表于 01-26 10:04
RK3568-GDB程序調(diào)試方法說明
發(fā)表于 01-19 16:16
?1946次閱讀
評(píng)論