国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

【專欄精選】Cortex-M 的反編譯入門

電子發燒友論壇 ? 來源:未知 ? 2023-05-16 09:35 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

做電子發燒友技術探索官,分享你的原創電子行業文章!

本期為大家推薦一篇嵌入式相關技術文章,作者主要從事嵌入式領域的開發,感興趣的小伙伴可以關注學習哦~


本期推

專欄作者嵌入式大雜燴(點擊查看作者主頁)

介紹:該專欄主要介紹嵌入式開發相關的知識,與大家一起交流學習。


我們在寫單片機裸機程序時,在主函數之前,會有一段啟動代碼,而啟動代碼是用匯編寫的,有些朋友可能看到匯編頭都大了,當時要想深入研究底層架構,這快硬骨頭就必須去啃。


匯編:匯編文件轉換為目標文件(里面是機器碼)。

反匯編:可執行文件(目標文件,里面是機器碼),轉換為匯編文件。

關于匯編的基礎知識,請關注筆者專欄,閱讀以前的文章。

今天筆者以STM32F1的點燈程序為例,帶領大家進行反匯編,并閱讀反匯編后的代碼。

1 新建LED裸機程序

1.新建文件夾

新建文件夾“STM32F1”,當然名字也可以另取,在 STM32F1文件夾下,我們新建五個文件夾,分別為CMSIS、Listing、Output、Project、User。

其中CMSIS文件夾放啟動文件:


筆者的開發板芯片是STM32F103ZE,這個文件是根據STM32的固件庫startup_stm32f10x_md.s文件修改而來。

2.新建工程

打開Keil,在工具欄 Project->New μVision Project…新建我們的工程文件。


輸入工程名,保存即可。


窗口是讓我們選擇公司跟芯片的型號,我們用的芯片是 ST 公司的STM32F103ZE,有64K SRAM,512K Flash,屬于高集成度的芯片。按如下選擇即可。



后點擊項目管理。


最后修改后的內容如下:


并添加相應的文件。


其中main.c的內容如下所示:

/**
* @brief 延時函數
* @param d
* @retval None
*/
void delay(int d)
{
while(d--);
}


/**
* @brief main
* @param None
* @retval int
*/
int main(void)
{
unsigned int *pReg;

/* 使能GPIOB */
pReg = (unsigned int *)(0x40021000 + 0x18);
*pReg |= (1<<3);

/* 設置GPIOB0為輸出引腳 */
pReg = (unsigned int *)(0x40010C00 + 0x00);
*pReg |= (1<<0);


pReg = (unsigned int *)(0x40010C00 + 0x0C);

while (1)
{
/* 設置GPIOB0輸出1 */
*pReg |= (1<<0);

delay(1000000);


/* 設置GPIOB0輸出0 */
*pReg &= ~(1<<0);

delay(1000000);
}
}

startup.s文件的內容如下:

;************************************ STM32F1 ************************************
;* File Name : startup.s
;* Author : BruceOu
;* Version : V1.0
;* Date : 2021-06-27
;* Description : STM32F10x Medium Density Devices vector table for MDK-ARM
;* toolchain.
;* This module performs:
;* - Set the initial SP
;* - Set the initial PC == Reset_Handler
;* - Set the vector table entries with the exceptions ISR address
;* - Configure the clock system
;* - Branches to __main in the C library (which eventually
;* calls main()).
;* After Reset the CortexM3 processor is in Thread mode,
;* priority is Privileged, and the Stack is set to Main.
;*******************************************************************************
PRESERVE8
THUMB




; Vector Table Mapped to Address 0 at Reset
AREA RESET, DATA, READONLY
EXPORT __Vectors

__Vectors DCD 0
DCD Reset_Handler ; Reset Handler


AREA |.text|, CODE, READONLY


; Reset handler
Reset_Handler PROC
EXPORT Reset_Handler [WEAK]
IMPORT main


LDR SP, =(0x20000000+0x10000)
BL main


ENDP

END

接下來還有配置工程。


選擇Output文件夾。


選擇Listing文件夾。


基本配置就這些,接下來編譯工程。


只要沒有錯誤就可以了,最后就是下載程序,筆者使用的是J-Link,最后的現象如下:


LED會不停閃爍。

2 Keil反匯編

接下來才是今天正題,反匯編。

在KEIL的User選項中,如下圖添加這兩項:

fromelf --bin --output=STM32F1.bin ../Output/STM32F1.axf

fromelf --text -a -c --output=STM32F1.dis ../Output/STM32F1.axf

然后重新編譯,即可得到二進制文件STM32F1.bin(以后會分析)、反匯編文件STM32F1.dis。

如下圖所示:


正常編譯過程是分為四個階段進行的,即預處理(也稱預編譯,Preprocessing)、編譯(Compilation)、匯編 (Assembly)和鏈接(Linking)。

但是反編譯是講為二進制文件反編譯成匯編文件,因此反匯編的流程如下:

3 反匯編代碼解析

接下來就是查看反編譯代碼,打開反編譯文件Project/STM32F1.dis。這里只截取一段查看,因為格式都是一樣的,知識每條內容不同罷了。


第一列是鏈接地址,第二列是機器碼,第三列是匯編指令。

根本匯編指令,我們找到ARMv7-M Architecture Reference Manual_DDI 0403E.d (ID070218)中的LDR指令。


我們將F8DFD004變成二進制。


這個使用的32位的Thumb2指令集。


其中b0~b11是立即數,這里是4,對應的匯編代碼的也是4,這里要注意的是,ARM指令采用流水線機制,當前執行地址A的指令,同時已經在對下一條指令進行譯碼同時已經在讀取下下一條指令:PC = A +4 (Thumb/Thumb2指令集)。


B12~b15是寄存器,這段大小是0XC,對應的寄存器就是sp;


后面16bit除了23位意外,全是固定的,其中‘U’表示無條件執行,這里置為1。

其他的匯編指令對應的機器碼也是類似的,值得注意的是,不同的架構對應的機器碼也是不同的,這也就回答了為了不同的處理器架構會對應不同的指令集。

有興趣的可以對比Cortex-M系列和Cortex-A系列的的指令集。請參考以下手冊:

ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition.pdf

ARMv7-M Architecture Reference Manual.pdf

4 反匯編代碼全解析

進入debug模式,在View下選擇disassembly window。


這樣就可將機器碼和對應的代碼對應起來。當程序運行起來了,也就從異常向量表中跳轉到Reset_Handler中,然后跳轉到main函數中,而main函數是在棧中,因此需要設置占空間的起始位置。根據STM32的參考手冊,SRAM的其起始地址和大小如下:


因此棧頂為起始位置加上棧的大小即可,只要不超過SRAM即可。


值得注意的是,棧是__向低地址擴展的數據結構__,是一塊連續的內存區域,棧頂的地址和棧的最大容量是在通過LDR設置,因此需要根據應用需求合理分配棧空間。

接下來往下走,如果在匯編中不打斷點,會默認進入main函數的一條指令,就從這里分析。為了分析方便,這里還有使用上一節方便出來的文件。



【C代碼33行】

從內存地址0x0800 017c拷貝數據0x40021018到r3中,也就是

r3 = * 0x0800 017c

也就是將pReg指針保存到r3中。


【C代碼34行】

這里對應3條指令


首先將r3拷貝到r0中,然后將r0或上1左移3位,也就是

ORR r0,r0,#8

最后將r0的值寫入r3所指地址中。

【C代碼37行】

同33行,從內存地址0x0800 0180拷貝數據40010c00到r3中


【C代碼38行】

同34行,這里也對應3條指令:


【C代碼40行】

和33行不同的是,這里分了兩條指令:


筆者認為前面是編譯器優化了。根據ARM指令采用流水線機制,當前執行地址A的指令,同時已經在對下一條指令進行譯碼同時已經在讀取下下一條指令:PC = A +4 (Thumb/Thumb2指令集)。因此前面類似的代碼被優化了。

接下來就進入循環中。

后面就移植在死循環中,不斷操作GPIO的亮滅。

【C代碼45行】

這里是將B0設置為1,和34行類似。


【C代碼47行】

這里將進入延時函數。


進入延時函數:


NOP是字節對齊,減少指令的內存訪問次數。首先將變量d保存到r0,然后將r0賦給r1,接著是r0自減1,緊接著是r1與0比較,如果r1等于0,則會返回,否則,又從頭開始,值得注意的是,這里先比較,然后r0才自減的。

為了進一步說明,可以看--d的匯編代碼。


這里就是相當于r1先減1,然后再比較的。

【C代碼50行】

這行代碼對應一下指令,很簡單。

5 總結

在前面使用Keil進行了反匯編,也對相應的C代碼進行了分析。我們看到的反匯編代碼如下:


根據反匯編的代碼,可將其對應到Flash,在Flash上的內容如下表所示:

地址Flash****內容
0x0800000000000000
0x0800000408000009
0x08000008f8dfd004
0x0800000cf000f80c

最后總結下點燈的流程:

第一步:設置棧CPU會從0x08000000讀取值,用來設置SP。

第二步:跳轉:CPU從0x08000004得到地址值,根據它的BIT0切換為ARM狀態或Thumb狀態,然后跳轉。

__第三步:__對于cortex M3/M4,它只支持Thumb狀態,所以0x08000004上的值bit0必定是1,0x08000004上的值 = Reset_Handler + 1。從Reset_Handler繼續執行。

第四步:然后進入到主函數中執行相應C代碼。


原文地址:http://www.3532n.com/d/2071474.html




版權說明:

本內容為作者發布至電子發燒友平臺原創文章,相關創作版權歸原作者所有,如未經作者授權,禁止轉載!




聲明本文由電子發燒友社區發布,轉載請注明以上來源。如需社區合作及入群交流,請添加微信EEFans0806,或者發郵箱liuyong@huaqiu.com。


更多熱點文章閱讀

  • 電子工程師分享:常用電平轉換電路、電源自動切換電路、太陽能充電電路總結

  • 基于32位RISC-V設計的互聯型微控制器,沁恒微CH32V307開發樣例

  • RK3568!四核64位ARMv8.2A架構,匯聚編譯源碼及實戰樣例

  • 尺寸僅有21mm*51mm,板邊采用郵票孔設計,合宙 Air105 核心板開發總結

  • 基于ESP32芯片,搭載OpenHarmony操作系統,NiobeU4開發板應用實例


原文標題:【專欄精選】Cortex-M 的反編譯入門

文章出處:【微信公眾號:電子發燒友論壇】歡迎添加關注!文章轉載請注明出處。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴

原文標題:【專欄精選】Cortex-M 的反編譯入門

文章出處:【微信號:gh_9b9470648b3c,微信公眾號:電子發燒友論壇】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    Cortex-M0和Cortex-M0+的區別

    ),但是只使用了Thumb ISA的一個子集(56條指令),多數指令是16位,只有少數一些事32位。 一般來說,盡管指令具有不同大小,Cortex-M處理器可被歸為精簡指令集架構。 支持可選的單周期
    發表于 01-22 06:23

    最小化ARM Cortex-M CPU功耗的方法與技巧分享

    1 理解Thumb-2   首先,讓我們從一個看起來并不明顯的起點開始討論節能技術—指令集。所有Cortex-M CPU都使用Thumb-2指令集,它融合了32位ARM指令集和16位Thumb指令集
    發表于 01-21 06:19

    Cortex-M0 處理器介紹

    功耗的32位處理器。 Cortex-M0是Cortex-M家族中的M0系列。最大特點是低功耗的設計。Cortex-M0為32位、3級流水線RISC處理器,其核心仍為馮.諾依曼結構,是指
    發表于 01-16 08:04

    Cortex-M產品的特色

    低功耗設計:Cortex-M系列處理器核心被設計為低功耗架構,適用于移動電源和電池供電的嵌入式系統。 高性能處理:Cortex-M處理器具有高性能的特點,能夠處理復雜的實時任務,并擁有較高
    發表于 11-26 07:22

    Cortex-M內核中的精確延時的方法

    使用 CYCCNT寄存器來測量執行某個任務所花的周期數,這也可以用作時間基準相關的目的(操作系統中統計 CPU使用率可以用到它)。” Cortex-M中的DWT它有一個32位的寄存器叫CYCCNT
    發表于 11-21 07:51

    為什么cortex-M0+功耗低?

    1. 流水線層級簡化 Cortex-M0:采用 3級流水線(取指、解碼、執行)。 更多流水線層級導致每個時鐘周期需激活更多硬件單元,動態功耗較高。 流水線沖突(如分支預測錯誤)需刷新流水線,浪費
    發表于 11-19 08:15

    Cortex-M級別的轉換

    一、 簡述 Cortex-M 里面有特權級別的概念,不同級別可以設定不同的權限,如何轉換特權級別基本是本章的內容。 二、操作模式 ARM M 核操作模式有兩個: 線程(Thread)模式:在復位時或
    發表于 11-19 07:32

    請問NuMicro? Cortex-M? 系列芯片是否支持 I2C 監視器功能?

    NuMicro? Cortex-M? 系列芯片是否支持 I2C 監視器功能?
    發表于 08-21 06:04

    請問NuMicro? Cortex-M0/M4系列可以提供哪些USB器件示例代碼?

    NuMicro? Cortex-M0/M4系列可以提供哪些USB器件示例代碼?
    發表于 08-19 07:05

    嵌入式開發入門指南:從零開始學習嵌入式

    (設備驅動、內核編譯) 4. 推薦的學習資源書籍:《嵌入式系統軟件設計基礎》《ARM Cortex-M系列嵌入式開發》在線課程:慕課網、B站嵌入式教學視頻實踐平臺:Arduino、STM32開發板
    發表于 05-15 09:29

    瑞薩RA8快速上手指南:Cortex-M85內核瑞薩RA8開發環境搭建 并點亮一個LED

    因為Cortex-M內核,瑞薩RA8系列單片機支持多種市面上常見的開發環境,像Keil MDK、IAR EWARM等,而本文講述的是瑞薩自家官方的IDE(e2 studio)。
    的頭像 發表于 03-17 14:35 ?1934次閱讀
    瑞薩RA8快速上手指南:<b class='flag-5'>Cortex-M</b>85內核瑞薩RA8開發環境搭建 并點亮一個LED

    【瑞薩RA2L1入門學習】+Uart printf

    ? Cortex?-M23 核心(現今 Arm? Cortex-M 系列中功耗最低的 CPU)。 這款產品采用優化的制程和瑞薩電子的低功耗工藝技術,是業界一流水平的超低功耗微控制器。 RA2L1 產品
    發表于 03-09 17:33

    【瑞薩RA2L1入門學習】+Key control LED

    ? Cortex?-M23 核心(現今 Arm? Cortex-M 系列中功耗最低的 CPU)。 這款產品采用優化的制程和瑞薩電子的低功耗工藝技術,是業界一流水平的超低功耗微控制器。 RA2L1 產品
    發表于 03-09 17:21

    【瑞薩RA2L1入門學習】+Led flash

    ? Cortex?-M23 核心(現今 Arm? Cortex-M 系列中功耗最低的 CPU)。 這款產品采用優化的制程和瑞薩電子的低功耗工藝技術,是業界一流水平的超低功耗微控制器。 RA2L1 產品
    發表于 03-09 17:12

    【瑞薩RA2L1入門學習】00. 開箱 + 點燈

    架構的核心板,目前 Arm? Cortex-M 系列中功耗最低的 CPU。 板載USB轉TTL模塊,帶有2個LED,1個復位按鍵,1個自定義按鍵以及兩個觸摸按鍵。其實硬件資源挺豐富的,這里只介紹
    發表于 03-07 11:07