色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

如何利用IDA Pro逆向分析ARM二進制映像

技術讓夢想更偉大 ? 來源:技術讓夢想更偉大 ? 2023-11-30 10:30 ? 次閱讀

在本文中,我們將以ANYTONE 878UVII對講機中的固件為例,為大家演示如何對ARM固件映像進行逆向分析。不過,本文中的大部分內容,對于ARM架構來說都是通用的。

本文假設讀者已經熟悉IDA Pro,并且至少分析過一些普通的二進制文件。如果您還不熟悉IDA,只需在網上搜索一下,就能找到許多非常優秀的入門教程,大家可以先通過它們來掌握相關的基礎知識。

固件映像就本文來說,我們只需IDA Pro和ANYTONE 878UVII對講機的固件映像就能搞定我們的實驗。并且,所需的映像還可以從分銷商網站下載。實際上,下載哪個版本并不重要,但本文是將以2.04版本為例進行介紹。

wKgaomVn9TuACAuwAAAQISh9Rf4210.png

在下載的更新包中,我們可以找到FW文件夾,其中包含三個文件:CDI、SPI和CDD文件。其中,CDD是最大的文件,它實際上就是我們要分析的固件映像。

這次我們的運氣不錯,因為這個固件映像并沒有加密,否則,事情就會麻煩一些。它只是內部閃存中的映像,甚至連文件頭都沒有。并且,該文件的元數據被拆分為單獨的文件。所以,我們可以直接在IDA Pro中加載CDD文件。

技術背景ANYTONE 878系列對講機使用的是GigaDevice GD32 ARM Cortex-M4微控制器:通過拆開對講機,我們就能看到這些芯片的型號。

除了拆對講機外,實際上還有另一種更方便的方法:查詢FCC。如果您的設備符合FCC的要求,網上應該有關于它的公開信息。這時,我們可以直接在FCC或獨立的數據庫中搜索制造商的信息。大多數情況下,我們會找到一份帶有“內部照片”的文件。這個文件通常能夠提供我們感興趣的信息,比如芯片型號等,這樣,我們就不用拆機了。

重要的是,我們建議大家下載CPU的數據表,并保存起來供后面使用:后面步驟中需要設置的參數,都可以從中找到。

關于CPU的相關設置首先要做的是,把CDD拖到打開的IDA Pro窗口中,或者通過文件菜單打開它。IDA會檢測出這是一個二進制文件。然后,將“Processor type”指定為 “ARM little-endian”,具體如下圖所示。

wKgaomVn9TqAS66SAABsZUG96zU804.png

現在,先別按“Ok”按鈕,因為還要對處理器選項進行一些設置。我們知道,這種設備使用的處理器是基于ARMv7E-M架構的。因此,我們必須對處理器選項做相應的修改。最佳設置如下圖所示;為此,需要按下“Processor options”菜單中的“Edit ARM architecture Options”按鈕,這樣就可以找到中間的窗格了。

wKgaomVn9TuAcsO5AAKzuKC6O_A269.png

由于這個項目與Thumb指令集高度相關,所以也建議在“ARM specific options”中勾選“No automatic ARM THUMB switching”選項。雖然這一點并沒有顯示在上面的截圖中,但對本項目來說的確是一個非常有用的設置。

加載映像現在,我們已經完成了基本的CPU設置。接下來,我們需要將加載的固件映像重新定位到正確的偏移量處。這個固件映像將被加載到IDA數據庫的ROM部分。由于CPU不會從文件中的0x00處開始加載映像,所以,我們必須重新定位。如果跳過這一步,交叉引用將被破壞,反匯編文件將無法正常工作。我們的目標設備中使用的ARM CPU將要求映像從偏移量0x8004000處開始。這里其實就是映射到物理ROM的內存位置,所以,我們需要將文件映射到這個地址。

在單擊“Load new file”對話框中的Ok按鈕之后,將會出現如下所示的對話框。通常情況下,RAM的大小和ROM的大小并不需要調整。它們現在已經正確地自動填充好了。

wKgaomVn9TuADb8rAAA8_LCw2hI762.png

接下來要做的事情,就是創建一個RAM分區。為此,可以勾選“Create RAM section”,分配的RAM將從0x20000000位置開始,長度為0x17FFF。

如何找到正確的內存偏移量如果讀者是第一次接觸這方面的內容,通常會有這樣的疑問:這些值是如何確定的?答案很簡單,我們可以從之前下載的數據手冊中找到它們。

從第17頁的內存映射部分,我們可以找到主閃存(固件文件)的加載地址。而在第16頁中,我們可以找到SRAM偏移量和這段內存的長度。

wKgaomVn9TuAf6wbAACSYjkg5G0430.png

很簡單吧?上面所做的只是將文件/映像重新定位到從我們的數據表中獲取的正確位置。關于主閃存有一個小技巧,第一個0x4000似乎是由引導程序獲取的,所以,我們的二進制文件必須位于0x8004000處。

二進制文件的結構對于第一次使用IDA的讀者來說,感覺可能非常奇怪:它并沒有像其他軟件一樣進行自動分析,也沒有展示程序代碼,相反,它只是給出了大量的十六進制字符。難道是我們哪里做錯了嗎?很可能不是。如果您正在使用IDA Pro分析固件映像,這是非常正常的現象。這里的難點在于,我們必須自己從頭開始進行分析。

wKgZomVn9TuABCT7AAMoC0T1-QA117.png

但這也沒有想象的那么難。首先,讓我們考察文件的開頭位置。這是ARM CPU開始執行代碼的地方。在這個偏移量處,一個被稱為向量表的結構被定位,它在ARM Cortex通用用戶指南中有很好的詳細描述。

wKgaomVn9TuAfPaKAAB2E3mYq2w884.png

正如我們在用戶指南的圖形中所看到的,偏移量0x0000(0x08004000)處包含初始堆棧指針。CPU將在這個地址加載接下來的四個字節,并將其用作指向未來堆棧的指針。

復位處理程序接下來的字節是各種處理程序,最重要的是復位處理程序(reset handler)。它正是CPU要啟動或重新啟動時將會跳轉到的地方。

wKgZomVn9TuAf5jMAAAc8p4rBvA873.png

它又是一個4字節的地址,對于我們的映像來說,這個地址很容易解析。正如鏈接的ARM用戶指南文章所告訴我們的,如果地址的最低有效位為1,則處理程序為Thumb。

在我們的例子中,該地址的最后一個字節是0xF9,二進制形式為11111001B。我們可以看到,這里的最低有效位確實是1。因此,我們需要將復位處理程序的入口點改為Thumb。實際上,復位處理程序的實際偏移量也由于該位的值而移動了一個字節。

0xF9 = 11111001b (with Thumb indicator)

0xF8 = 11111000b (without)

單擊這個偏移量,就會跳轉到復位處理程序的地址減1個字節的地方。現在,請按“Alt+G”,這時會打開一個對話框,我們需要將下面的部分定義為Thumb(CODE16)。

wKgZomVn9TqABPyIAAAWqTFaDgU504.png

這個項目主要涉及Thumb指令集,因此,您也可以從ROM段的第一個字節開始使用Thumb代碼。請記住,這一點并非適用于所有的ARM項目。但對于這個項目來說,這是沒問題的。

將當前偏移量改為CODE16后,只需按“C”,就能在該偏移量處創建代碼了。現在,我們就應該可以看到復位處理程序的代碼了。

wKgZomVn9TqABC0uAAAVwLd4rm4605.png

查找其他代碼和字符串上面介紹的方法雖然能用,但是通過手動方式來創建所有的代碼是相對繁瑣的。別擔心,我們可以借助于腳本來完成這些任務。實際上,Maddie Stone已經為IDA Pro創建了許多非常方便的腳本,能夠給我們帶來極大的便利。

由于她的腳本不能用于較新的IDA版本(在寫這篇文章時,最新的版本為7.7),所以,我們專門把適用于IDA 7.x版本的腳本上傳到了Github上,讀者可以從https://github.com/alexander-pick/IDAPythonEmbeddedToolkit下載。為了支持基于ARM的項目,我已經對這些代碼做了相應的處理。

首先,我們可以使用腳本define_code_functions.py,在0x08004000到0x080963DC大致范圍內創建代碼。如果腳本詢問是否要撤銷現有的代碼,請選擇No。

IDA Pro應該可以正常工作了,此時的ROM部分應該開始變得更有趣了。

wKgZomVn9TuAIWLoAAAC6lENaAg511.png

接下來,我們可以使用make_strings.py腳本,在ROM的其余部分創建字符串。這時,你會在其中發現許多我們感興趣的字符串。

關于字符串引用分析這個固件時,我們會發現一個奇怪的現象。由于ANYTONE的開發人員為多國語言創建了固件,所以,他們使用了引用表。因此,這可能導致我們會遺漏某些字符串的引用。之所以會發生這種情況,是因為這些字符串是根據選擇的語言來動態加載的。遺憾的是,基于IDA的靜態分析是無法解決這個問題的。

不過,引導過程中的一些字符串是直接嵌入的,所以它們解析起來問題不大。因此,我們可以從這些字符串開始下手。

wKgZomVn9TuAMFoyAABau0RWYtw939.png

為了做進一步的分析,我們需要能夠識別一些基本的OS函數,即操作嵌入字符串的函數,比如“print”或“read”函數等。當然,類似“memcpy”這樣的函數在各種操作系統中都是非常常見的。

非常值得注意的是“print_string”函數(一旦識別出來,我就把它重命名為這個名字)。它接受一些坐標和一個字符串作為參數,并將字符串顯示在屏幕上給定的位置處。這個函數在啟動菜單中被大量使用。

從固件鏡像中的字符串可以識別出設備使用的RTOS(實時操作系統)是μC/OS-II。μC/OS-II是一個用ANSI C編寫的免費實時操作系統。關于該系統的進一步介紹,以及相關文檔,讀者可以在這里找到;而相關代碼則可以從這里下載。感興趣的讀者可以參考這些資料,它們應該對您有很大的幫助。

I/O和外圍設備像這樣基于ARM的CPU通常使用特殊的內存區域來處理地址總線、GPIO、I/O或簡單的定時器時鐘,具體請參閱數據表。實際上,在第14頁中,大家可以找到我們用來指定加載偏移量的內存映射。該映射還包含要添加到數據庫中的特殊內存區域。

打開IDA中的內存區域視圖(segments view)并將它們添加到數據庫中,結果應該與下圖類似。如果你想偷懶,則可以使用這個IDC(https://github.com/alexander-pick/useful-script-and-code/blob/master/GD32F303xx_segments.idc)來完成這個過程。

wKgZomVn9TuAeKUGAAEqeV2b0sA150.png

現在,請重新運行自動分析(Options -> General -> Reanalyse program)以創建交叉引用。

一旦你完成了上面的步驟,就可以查看感興趣的內存區域,看看是否有對它們的交叉引用。這些可以幫助您找到使用特定總線、GPIO或I/O的函數。

如果您查找操作UART的函數,只需檢查UART區域,就會找到對它的引用。這在沒有或只有很少字符串作為引用的情況下是特別有用的。

小結我認為,到目前為止,您應該已經具備了自己研究這一主題所需的一切。

審核編輯:湯梓紅

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

    關注

    134

    文章

    9098

    瀏覽量

    367693
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10870

    瀏覽量

    211876
  • 二進制
    +關注

    關注

    2

    文章

    795

    瀏覽量

    41663
  • IDA
    IDA
    +關注

    關注

    0

    文章

    8

    瀏覽量

    7942

原文標題:如何利用IDA Pro逆向分析ARM 二進制映像

文章出處:【微信號:技術讓夢想更偉大,微信公眾號:技術讓夢想更偉大】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    如何進行Linux二進制分析

    器和逆向工具并且依賴我們的黑客直覺來掌控我們正在逆向的目標程序。我們必須理解二進制格式、內存布局和給定處理器指令集的復雜性。我們因此成為微處理器上的程序的主人。一個逆向工程師對
    發表于 07-18 06:25

    二進制絕對調相(解調)工作原理

    二進制絕對調相工作原理:二進制絕對調相(相絕對調相)利用載波不同  位的絕對值來傳遞數字信息。(2BPSK)
    發表于 10-21 13:00 ?5566次閱讀
    <b class='flag-5'>二進制</b>絕對調相(解調)工作原理

    二進制相對調相(二進制差分調相2DPSK)的工作原理

    二進制相對調相(二進制差分調相2DPSK)的工作原理
    發表于 10-21 13:01 ?3205次閱讀
    <b class='flag-5'>二進制</b>相對調相(<b class='flag-5'>二進制</b>差分調相2DPSK)的工作原理

    二進制

    二進制   二進制與十進制的區別在于數碼的個數和進位規律有很大的區別,顧名思義,二進制的計數規律為逢二進一,是以2為基數的計數體制。10這
    發表于 04-06 23:48 ?8203次閱讀
    <b class='flag-5'>二進制</b>

    二進制時鐘電路

    二進制時鐘電路
    發表于 09-11 11:22 ?3114次閱讀
    <b class='flag-5'>二進制</b>時鐘電路

    同步二進制計數器

    同步二進制計數器 1.   同步與異步二進制加法計數器比較態序表和工作波形一樣電路結構不同:  異步二進制加法
    發表于 09-30 18:37 ?1.2w次閱讀
    同步<b class='flag-5'>二進制</b>計數器

    二進制編碼和二進制數據

    二進制編碼和二進制數據   二進制編碼是計算機內使用最多的碼制,它只使用兩個基本符號"0"和"1",并且通過由這兩個符號組成的
    發表于 10-13 16:22 ?4792次閱讀

    二進制數的運算規則

    二進制數的運算規則  二進制數之間可以執行算術運算和邏輯運算,其規則簡單,容易實現。  (1) 加法運算規則    0 + 0 = 0         例如:
    發表于 10-13 16:24 ?2.3w次閱讀

    什么是二進制計數器,二進制計數器原理是什么?

    什么是二進制計數器,二進制計數器原理是什么? 計數器是數字系統中用得較多的基本邏輯器件。它不僅能記錄輸入時鐘脈沖的個數,還可以實現
    發表于 03-08 13:16 ?3.1w次閱讀

    二進制電平,什么是二進制電平

    二進制電平,什么是二進制電平 在二進制數字通信系統中,每個碼元或每個符號只能是“1”和“0”兩個狀態之一。若將每個碼元可能取的狀態增
    發表于 03-17 16:51 ?2361次閱讀

    二進制移頻鍵控原理圖分析

    二進制移頻鍵控原理圖分析 1.2FSK信號的產生原理框圖
    發表于 03-19 16:48 ?2383次閱讀

    二進制加法程序【匯編版】

    二進制加法程序【匯編版】二進制加法程序【匯編版】二進制加法程序【匯編版】二進制加法程序【匯編版】
    發表于 12-29 11:02 ?0次下載

    二進制加法程序【C語言版】

    二進制加法程序【C語言版】二進制加法程序【C語言版】二進制加法程序【C語言版】二進制加法程序【C語言版】
    發表于 12-29 11:03 ?0次下載

    二進制SCA指紋提取黑科技: go語言逆向技術

    二進制SCA指紋提取黑科技: go語言逆向技術 華為云DevCloud軟件開發平臺在2022華為伙伴暨開發者大會重磅推出了4大新能力,其中的二進制成分分析安全檢測能力,能夠實現對開源軟件漏洞的全面
    的頭像 發表于 10-13 22:20 ?690次閱讀
    <b class='flag-5'>二進制</b>SCA指紋提取黑科技: go語言<b class='flag-5'>逆向</b>技術

    二進制編碼器工作原理 如何選擇二進制編碼器

    二進制編碼器是一種數字電路,它將輸入的二進制代碼轉換為對應的輸出信號。在數字系統中,編碼器用于將數據從一種形式轉換為另一種形式,以便于處理和傳輸。 二進制編碼器工作原理 輸入與輸出關系 :
    的頭像 發表于 11-06 09:44 ?822次閱讀
    主站蜘蛛池模板: 热の中文 AV天堂| 美女靠逼漫画| 国产在线AV一区二区香蕉| 暖暖 免费 高清 日本 在线| 亚洲综合国产精品| 国产午夜视频在永久在线观看| 日韩大胆视频| 被滋润的艳妇疯狂呻吟白洁老七| 免费国产福利| 99国产精品偷窥熟女精品视频| 美女的避毛| 99精品欧美一区二区三区美图| 美国兽皇zoo在线播放| 最近中文字幕MV免费高清在线| 久久强奷乱码老熟女| 在线观看免费视频a| 久久久99精品成人片中文| 樱花草在线影视WWW日本动漫| 久久精品无码一区二区日韩av | 拍戏被CAO翻了H| 成人国产在线视频| 午夜A级理论片左线播放| 韩国羞羞秘密教学子开车漫书| 野花日本免费完整版高清版动漫 | 国产日韩欧美高清免费视频| 亚洲AV成人片色在线观看网站| 国产在线精品亚洲第一区| 亚洲免费视频观看| 久久这里只有精品视频9| 96.8在线收听| 色大姐综合网| 果冻传媒视频在线播放| 在线 | 果冻国产传媒61国产免费| 麻豆高清区在线| 粗好大用力好深快点漫画| 校花被扒衣吸乳羞羞漫画| 久久精品AV麻豆| 抽插内射高潮呻吟爆乳| 亚洲国产精品无码中文字幕 | 久草在线精彩免费视频| 99热久久这里只有精品|