0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

rt smart應(yīng)用程序調(diào)試記錄

冬至子 ? 來(lái)源:zms123456 ? 作者:zms123456 ? 2023-09-13 16:29 ? 次閱讀

本文是在qemu-virt64-aarch64下運(yùn)行smart-fetch的調(diào)試記錄

準(zhǔn)備

編譯

按照userapps的readme進(jìn)行編譯,編譯前鍵入如下命令,即可編譯出帶調(diào)試信息的userapps

xmake f --mode=debug

gdb配置

在調(diào)試過(guò)程中需要進(jìn)入內(nèi)核,所以需要同時(shí)加載內(nèi)核和應(yīng)用程序的elf符號(hào)表。設(shè)置.gdbinit文件如下:

target remote localhost:1234
file ../../../rt-thread/bsp/qemu-virt64-aarch64/rtthread.elf
add-symbol-file ../../apps/build/rootfs/bin/smart-fetch

首先使用readelf工具查看smart-fetch程序,發(fā)現(xiàn)其entry point是0x200000的_start,于是在gdb中打斷點(diǎn)b *0x200000(或b _start),在輸入smart-fetch后成功暫停

1.jpg

libc庫(kù)查看
本工程采用musl libc,可以自行下載查看源碼

調(diào)試記錄
以下按函數(shù)執(zhí)行的順序來(lái)進(jìn)行記錄

_start
該函數(shù)將當(dāng)前用戶態(tài)棧指針設(shè)置為0xffff80000000,為用戶空間較高的地址,之后跳到_start_c

_start_c

1.jpg

所傳入的參數(shù)*p地址為smart預(yù)先設(shè)置的0xfffffffff000。這里存放了應(yīng)用程序初始化所需的參數(shù),由操作系統(tǒng)設(shè)置,最后調(diào)用傳參為_(kāi)_libc_start_main(main, 1, "/bin/smart-fetch",_init,_fini, 0 )

__libc_start_main

1.jpg

首先獲得程序的環(huán)境變量(操作系統(tǒng)設(shè)置,含有操作系統(tǒng)名稱,執(zhí)行文件的信息等)
調(diào)用__init_libc(envp, "/bin/smart-fetch")
asm ( "" : "+r"(stage2) : : "memory" )表示保證在之后stage2采用更新后的值,避免使用緩存的值

__init_libc

1.jpg

該函數(shù)前面主要是通過(guò)envp來(lái)獲取一些程序信息如pagesize等,接下來(lái)執(zhí)行__init_tls和__init_ssp

__init_tls

該函數(shù)目的是初始化線程局部存儲(chǔ)(thread local storage)。它需要根據(jù)elf文件的類型為PT_TLS的段來(lái)對(duì)線程局部存儲(chǔ)進(jìn)行初始化。這里由于smart-fetch不是多線程程序,沒(méi)有PT_TLS類型的段,故該函數(shù)在這里沒(méi)有進(jìn)行實(shí)際的操作。

__init_ssp

該函數(shù)是初始化棧保護(hù)機(jī)制,但這里并未實(shí)現(xiàn)該機(jī)制。執(zhí)行dummy函數(shù),不做任何操作

libc_start_main_stage2

1.jpg

首先執(zhí)行__libc_start_init進(jìn)行初始化
之后調(diào)用main函數(shù)獲取返回值
之后調(diào)用exit(main_ret)來(lái)進(jìn)行清理

__libc_start_init

1.jpg

調(diào)用事先注冊(cè)好的初始化函數(shù)列表__init_array_start。
本處調(diào)用了frame_dummy函數(shù),該函數(shù)并不是musl庫(kù)里的函數(shù),而是gcc編譯時(shí)插入的函數(shù)。該函數(shù)調(diào)用初始化函數(shù)(即定義了__attribute__((constructor))的函數(shù)),并調(diào)用register_tm_clones來(lái)注冊(cè)多線程下的克隆函數(shù)。因?yàn)檫@個(gè)程序無(wú)初始化函數(shù)和多線程的特性,所以該函數(shù)實(shí)際上并未執(zhí)行任何操作。

exit

1.jpg

__funcs_on_exit:無(wú)操作
__libc_exit_fini:該函數(shù)對(duì)應(yīng)于__libc_start_init,調(diào)用解構(gòu)函數(shù),注銷多線程克隆函數(shù),在這里也沒(méi)有實(shí)質(zhì)性的操作
_stdio_exit:關(guān)閉所有打開(kāi)文件及標(biāo)準(zhǔn)輸入、輸出、錯(cuò)誤文件
_Exit:調(diào)用SYS_exit_group系統(tǒng)調(diào)用,之后就是操作系統(tǒng)進(jìn)行資源回收
缺頁(yè)異常處理
當(dāng)訪問(wèn)一個(gè)不存在頁(yè)時(shí),aarch改變的寄存器

sp 0xffff80000000 -> 0xffff0000002b6520
pc 0x20008 -> 0xffff0000000c6400
cpsr 0 -> 0x3c5
elr_el1 0x200000 -> 0x200008
sp_el0 0 -> 0xffff80000000
ESR_EL1 0-> 0x92000045
FAR_EL1 0 -> 0xffff7fffffd0

aarch64自動(dòng)做的事(通過(guò)對(duì)比缺頁(yè)觸發(fā)前后寄存器值得出):

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5253

    瀏覽量

    119201
  • 存儲(chǔ)器
    +關(guān)注

    關(guān)注

    38

    文章

    7366

    瀏覽量

    163091
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1239

    瀏覽量

    39430
  • GDB調(diào)試
    +關(guān)注

    關(guān)注

    0

    文章

    24

    瀏覽量

    1423
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用GDB調(diào)試Linux應(yīng)用程序

    本篇講解使用GDB調(diào)試Linux應(yīng)用程序,以下以 `hellowld.c` 為例介紹 GDB 的調(diào)試入門。
    發(fā)表于 06-27 15:48 ?411次閱讀

    RT-Thread Smart 入門指南

    、qemu 工具等。編譯應(yīng)用程序# 進(jìn)入到 rt-smart 目錄cd rt-smart# 設(shè)置對(duì)應(yīng)的環(huán)境變量,和原 RT-Thread 相比,多了 RTT_CC_PREFIX 環(huán)境變
    發(fā)表于 03-29 06:40

    RT-Smart的資料合集

    時(shí),需要使用 GDB 直接進(jìn)行代碼調(diào)試。本文檔記錄了以 RT-Thread qemu-vexpress-a9 BSP 為例,使用 GDB 對(duì) RT-Smart 進(jìn)行代碼
    發(fā)表于 03-22 15:06

    快速上手RT-Thread Smart入門指南

    應(yīng)用程序當(dāng)要編譯應(yīng)用程序時(shí),使用方式和 Linux 的類似:編譯 rt-smart 內(nèi)核編譯無(wú)誤后,會(huì)在當(dāng)前目錄下生成 kernel7.img 文件,這個(gè)是樹(shù)莓派上 32 位的版本。目前
    發(fā)表于 04-01 17:38

    分析一下在rt-smart操作系統(tǒng)中將一個(gè)應(yīng)用程序運(yùn)行起來(lái)要經(jīng)過(guò)哪些步驟

    1、RT-Smart ELF 應(yīng)用程序加載運(yùn)行在用戶態(tài)應(yīng)用程序處理的任務(wù)中,elf 加載運(yùn)行是一個(gè)比較重要的步驟,下面就分析一下在 rt-smart 操作系統(tǒng)中,想要將一個(gè)
    發(fā)表于 04-13 17:17

    請(qǐng)問(wèn)RT -SMART支持GDB調(diào)試嗎?

    RT-SMART介紹,應(yīng)用程序開(kāi)發(fā)可以用GDB在線調(diào)試?,F(xiàn)在發(fā)布的版本已經(jīng)具有還功能了嗎?原文摘錄:為了更好的支持應(yīng)用程序調(diào)試,在
    發(fā)表于 04-20 09:35

    rt-smart操作系統(tǒng)中將ELF應(yīng)用程序運(yùn)行起來(lái)要經(jīng)過(guò)哪些步驟

    1、RT-Smart ELF應(yīng)用程序加載運(yùn)行在用戶態(tài)應(yīng)用程序處理的任務(wù)中,elf 加載運(yùn)行是一個(gè)比較重要的步驟,下面就分析一下在 rt-smart 操作系統(tǒng)中,想要將一個(gè)
    發(fā)表于 06-13 18:18

    RT-Thread Smart快速上手

    : done building targets.編譯應(yīng)用程序rt-smart沒(méi)有開(kāi)放用戶態(tài)程序依賴的第三方庫(kù)librtthread源碼,因此ARM926的處理器暫時(shí)無(wú)法使用用戶態(tài)APP。原作者:Yanye0xFF
    發(fā)表于 10-26 14:48

    rt-smart應(yīng)用程序系統(tǒng)調(diào)用實(shí)現(xiàn)過(guò)程是怎么樣的?

    rt-smart應(yīng)用程序系統(tǒng)調(diào)用實(shí)現(xiàn)過(guò)程是怎么樣的? 比如open時(shí)候怎么一步一步切換到內(nèi)核態(tài)的?
    發(fā)表于 09-08 17:00

    樹(shù)莓派上rt-smart的應(yīng)用編程入門

    文章,一些介紹及樹(shù)莓派上rt-smart的應(yīng)用編程入門(更多的從應(yīng)用程序角度入手)。后續(xù)還包括在rt-smart上的不同應(yīng)用程序介紹: wget curl移植 busybox移植 sd
    的頭像 發(fā)表于 05-13 14:10 ?2979次閱讀
    樹(shù)莓派上<b class='flag-5'>rt-smart</b>的應(yīng)用編程入門

    如何在rt-smart簡(jiǎn)化應(yīng)用程序開(kāi)發(fā)

    RT-Thread Smart做為一個(gè)“新”的系統(tǒng),在開(kāi)發(fā)上相比原來(lái)的RT-Thread模式還是存在著挺大的不同。
    的頭像 發(fā)表于 01-04 15:59 ?1846次閱讀

    RT-Smart ELF應(yīng)用程序加載運(yùn)行過(guò)程分析

    在用戶態(tài)應(yīng)用程序處理的任務(wù)中,elf 加載運(yùn)行是一個(gè)比較重要的步驟,下面就分析一下在 rt-smart 操作系統(tǒng)中,想要將一個(gè)應(yīng)用程序運(yùn)行起來(lái)要經(jīng)過(guò)哪些步驟。
    的頭像 發(fā)表于 11-02 09:57 ?855次閱讀

    基于xmake的RT-Thread Smart用戶態(tài)開(kāi)發(fā)教程

    RT-Thread Smart(以下簡(jiǎn)稱 Smart) 是基于 RT-Thread 操作系統(tǒng)上的混合操作系統(tǒng),簡(jiǎn)稱為 rt-smart,它把
    的頭像 發(fā)表于 06-07 11:44 ?1182次閱讀
    基于xmake的<b class='flag-5'>RT</b>-Thread <b class='flag-5'>Smart</b>用戶態(tài)開(kāi)發(fā)教程

    帶有RT-Thread的Arduino應(yīng)用程序

    電子發(fā)燒友網(wǎng)站提供《帶有RT-Thread的Arduino應(yīng)用程序.zip》資料免費(fèi)下載
    發(fā)表于 06-14 11:22 ?6次下載
    帶有<b class='flag-5'>RT</b>-Thread的Arduino<b class='flag-5'>應(yīng)用程序</b>

    基于xmake的RT-Thread Smart用戶態(tài)開(kāi)發(fā)教程

    RT-Thread Smart(以下簡(jiǎn)稱 Smart) 是基于 RT-Thread 操作系統(tǒng)上的混合操作系統(tǒng),簡(jiǎn)稱為 rt-smart,它把
    的頭像 發(fā)表于 09-14 11:48 ?996次閱讀
    基于xmake的<b class='flag-5'>RT</b>-Thread <b class='flag-5'>Smart</b>用戶態(tài)開(kāi)發(fā)教程