吴忠躺衫网络科技有限公司

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

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

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

基于51單片機的反匯編方法

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2021-01-20 14:24 ? 次閱讀

1.怎樣正確獲取程序的目標代碼

要正確獲取程序的目標代碼,首先要明確程序代碼的存放地點。51單片機的程序存儲器最大空間為64KB,在一個實際的應用系統(tǒng)中,程序存儲器的分布情況可能有以下幾種:

(1)只使用了片內(nèi)程序空間。而沒有使用片外的程序空間。

其硬件特征為:/EA引腳接VCC;/PSEN引腳為空腳。

這種情況比較簡單,全部應用程序都在單片機內(nèi)部的程序存儲器中,我們只要使用編程器將程序代碼讀出來,保存為一個目標代碼文件就可以了。要注意的是,有一些新型的單片機具有加密功能,如果進行了加密,其中的程序代碼就是不能讀出。

(2)沒有使用片內(nèi)程序空間,片外程序空間由單個存儲芯片構(gòu)成。

其硬件特征為:/EA引腳接GND;/PSEN引腳接到一個存儲芯片上。

這種情況下,全部應用程序都在單片機外部的程序存儲器中,原則上我們只要使用編程器將程序代碼讀出來,保存為一個目標代碼文件就可以了。但要注意的是,這樣得到的并不一定是真正的目標代碼,因為,為了防止程序代碼被讀取、反匯編,很多設計人員都采取跳接線的方法,將某些地址線跳接或?qū)⒛承?shù)據(jù)線跳接或?qū)⒌刂肪€、數(shù)據(jù)線都進行跳接,從而保護自己的程序不被反匯編。這樣一來,我們從存儲器中讀取的就不是真正的程序目標代碼,必須進行某種變換,將其轉(zhuǎn)換為真正的程序目標代碼,才能進行反匯編。

要進行目標代碼的變換,首先必須根據(jù)硬件畫出實際的地址和數(shù)據(jù)的接線圖,然后借助于工具軟件進行變換。在“51匯編集成開發(fā)環(huán)境”關的介紹,其中,提供了一個變換工具,從軟件界面的[輔助工具]-[目標代碼轉(zhuǎn)換]-[bin代碼還原]就可以啟動這個工具。

單擊[瀏覽]可以選擇要轉(zhuǎn)換的代碼文件,注意:這里的代碼文件只能是二進制代碼文件,即bin文件,如果你通過編程器讀取后保存的文件不是bin文件,就需要先將其轉(zhuǎn)換為bin文件,在“51匯編集成開發(fā)環(huán)境”的[輔助工具]-[目標代碼轉(zhuǎn)換]菜單下,有相應的轉(zhuǎn)換工具。

單擊[另存為]可以選擇轉(zhuǎn)換結(jié)果的存放地點和文件名,轉(zhuǎn)換結(jié)果也一定是bin文件。

再根據(jù)實際的地址、數(shù)據(jù)的接線圖,來選擇地址線跳接、數(shù)據(jù)線跳接,設置其接線表,然后單擊[還原]即完成了代碼的變換。

(3)沒有使用片內(nèi)程序空間,片外程序空間由多個存儲芯片構(gòu)成其硬件特征為:/EA引腳接GND;/PSEN引腳接到了幾個存儲芯片上。

這種情況下,全部應用程序在單片機外部的多個存儲芯片中,我們首先需要使用編程器將每一個存儲芯片上的程序代碼讀出來,分別保存為一個目標代碼文件,然后將它們合并為一個文件。

在讀取存儲芯片上的程序代碼時,要注意查看硬件接線有無跳接線,如果有跳接線,必須進行代碼的變換。

在合并程序代碼時,要注意每一個存儲芯片的地址范圍,必須按地址連接,才能得到真正的目標代碼文件。

在“51匯編集成開發(fā)環(huán)境”中,從[輔助工具][目標代碼轉(zhuǎn)換]-[bin代碼合并]可以啟動合并工具。

單擊[瀏覽]可以選擇要合并的兩個代碼文件,注意:第一個代碼文件必須是從0地址開始的文件,單擊[另存為]可以選擇合并后的文件存放地點和文件名,然后單擊[開始]即完成了代碼的合并。

若選擇直接連接,則第二個代碼文件將緊接著第一個文件后連接;若選擇按地址連接,則第二個代碼文件將從指定的地址開始連接。如果兩個代碼文件之間有空字節(jié),則將填充為“00H”或“FFH”;如果兩個代碼文件在空間上有重疊,則將得到提示:“地址空間存在重合現(xiàn)象,不能正常合并!”。

(4)既使用了片內(nèi)程序空間,也使用片外的程序空間其硬件特征為:/EA引腳接VCC;/PSEN引腳接到一個存儲芯片或幾個存儲芯片上。

在這種情況下,全部應用程序分布在單片機內(nèi)部的程序存儲器和外部的多個存儲芯片中,獲取程序代碼的基本方法同(3)。

這里要注意的是,片外程序存儲器的地址范圍應該在1000H~FFFFH之間,如果某一片程序存儲器的地址是從0000H開始的,那么其 0000H~0FFFH之間的代碼是無效的,必須將其去除。借助于“51匯編集成開發(fā)環(huán)境”的[輔助工具]-[目標代碼轉(zhuǎn)換]菜單下的[bin代碼拆分],可以完成這一工作。

單擊[瀏覽]可以選擇要轉(zhuǎn)換的代碼文件,再選擇片內(nèi)ROM空間為4KB,然后單擊[開始]即可。

2.怎樣進行反匯編要想成功進行反匯編,還必須有一個好的反匯編工具。

在“51匯編集成開發(fā)環(huán)境”中集成有一個反匯編工具。該工具目前不支持對非0地址開始的部分代碼進行反匯編,因為非O地址開始的部分代碼無法區(qū)分程序和數(shù)據(jù),但是對于從O地址開始的全部或部分代碼的反匯編效果較好,能夠智能分段、自動地分離出程序和數(shù)據(jù),使獲得的源程序具有較好的可讀性。

從軟件界面的[編譯]-[反匯編]-[MCS-51反匯編]可以啟動這個工具。

3.實例

設有一個單片機的應用系統(tǒng) 單片機的/EA引腳接VCC;/PSEN引腳接到一個存儲芯片28C64上,全部應用程序分布在單片機內(nèi)部的程序存儲器(4KB)和片外的28C64中,其中28C64還進行了跳線處理。要進行反匯編必須按以下步驟進行:

(1)借助于編程器分別從單片機和28C64中讀取代碼,保存為兩個文件。

其中,從單片機中讀取的文件名為CODE0.bin;從28C64中讀取的文件名為CODE1.bin。

(2)用“51匯編集成開發(fā)環(huán)境”中的[bin代碼還原],將從28C64中讀取

的文件CODE1.bin轉(zhuǎn)換為真正的程序代碼,保存為文件CODE2.bin。

(3)用“51匯編集成開發(fā)環(huán)境”中的[bin代碼合并],將CODE0.bin和ODE2.bin合并為一個文件CODE3.bin.

(4)用“51匯編集成開發(fā)環(huán)境”中的[MCS51反匯編],對CODE3.bin

進行反匯編,得到的源程序文件保存為CODE.ASM。

至此,反匯編成功。

來源:網(wǎng)絡

審核編輯 黃昊宇

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

    關注

    274

    文章

    5705

    瀏覽量

    124294
  • 反匯編
    +關注

    關注

    1

    文章

    29

    瀏覽量

    10554
收藏 人收藏

    評論

    相關推薦

    51單片機pwm和spwm

    51單片機pwm
    發(fā)表于 01-08 15:54 ?2次下載

    51單片機溫度報警器

    電子發(fā)燒友網(wǎng)站提供《51單片機溫度報警器.zip》資料免費下載
    發(fā)表于 12-30 14:16 ?0次下載

    51單片機核心板原理圖

    51單片機核心板原理圖
    發(fā)表于 12-16 11:30 ?3次下載

    51單片機中為什么很少出現(xiàn)printf的身影

    51單片機中為什么很少出現(xiàn) printf 的身影?是用不了嗎? 不是的,51單片機可以用 printf,只是不建議使用。 平時我們在操作系統(tǒng)上寫C語言代碼,使用 printf 可以把數(shù)
    的頭像 發(fā)表于 12-03 10:46 ?524次閱讀
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>中為什么很少出現(xiàn)printf的身影

    基于51單片機的手動數(shù)字時鐘

    具體實現(xiàn)功能由51單片機+8位共陰數(shù)碼管+獨立按鍵構(gòu)成。具體功能:(1)利用數(shù)碼管顯示時分秒,顯示格式為“時-分-秒”;(2)利用6個按鍵控制時、分、秒,設定好后自動開始時鐘顯示;(3)設置秒復位
    的頭像 發(fā)表于 10-22 14:12 ?299次閱讀
    基于<b class='flag-5'>51</b><b class='flag-5'>單片機</b>的手動數(shù)字時鐘

    基于51單片機的遙控開關仿真(雙機通信)

    具體實現(xiàn)功能由51單片機+獨立按鍵+繼電器+LED燈等構(gòu)成。實現(xiàn)功能:(1)本仿真設計的是一款遙控開關,采用51單片機進行遙控器與主機的設計;(2)遙控器由
    的頭像 發(fā)表于 10-22 14:12 ?393次閱讀
    基于<b class='flag-5'>51</b><b class='flag-5'>單片機</b>的遙控開關仿真(雙機通信)

    如何實現(xiàn)51單片機與PC的串行通信

    的詳細步驟和方法。 硬件連接 首先,我們需要將51單片機與PC的串行接口連接起來。通常,我們使用RS-232接口進行連接。RS-232接口是一種常用的串行通信接口,它使用9個引腳進行
    的頭像 發(fā)表于 10-21 11:35 ?1288次閱讀

    51單片機驅(qū)動

    電子發(fā)燒友網(wǎng)站提供《51單片機驅(qū)動.exe》資料免費下載
    發(fā)表于 09-20 11:46 ?5次下載

    51單片機晶振的問題總結(jié)

    電子發(fā)燒友網(wǎng)站提供《51單片機晶振的問題總結(jié).doc》資料免費下載
    發(fā)表于 09-07 09:32 ?0次下載

    stm32和51單片機的區(qū)別是什么

    架構(gòu)差異: STM32是基于ARM Cortex-M系列內(nèi)核的32位微控制器,具有更高效的處理能力和更豐富的外設。 51單片機是基于8051內(nèi)核的8位微控制器,處理能力相對較低,外設也相對有限
    的頭像 發(fā)表于 09-02 09:33 ?914次閱讀

    51單片機燒錄軟件怎么用

    準備工作 確保您已經(jīng)安裝了51單片機燒錄軟件,如Keil、IAR等。 準備好51單片機開發(fā)板和燒錄器,如STC-ISP等。 確保您的計算機已經(jīng)安裝了相應的驅(qū)動程序。 安裝燒錄軟件 從官
    的頭像 發(fā)表于 08-22 09:26 ?1498次閱讀

    國產(chǎn)單片機(MCU)崛起 —— 51系列

    一、51系列單片機的命名由來51系列單片機的命名由來與它的設計和開發(fā)歷史相關。這個系列的單片機主要由Intel的8051微控制器發(fā)展而來,后
    的頭像 發(fā)表于 08-14 08:39 ?2557次閱讀
    國產(chǎn)<b class='flag-5'>單片機</b>(MCU)崛起 —— <b class='flag-5'>51</b>系列

    你知道嗎? 51單片機也有動態(tài)內(nèi)存分配

    、realloc、free。他們的頭文件在中,所以使用內(nèi)存管理必須包含該頭文件。二、使用方法51單片機需要使用內(nèi)存管理API必須要手動調(diào)用初始化堆內(nèi)存管理函數(shù):init_
    的頭像 發(fā)表于 04-26 08:10 ?1642次閱讀
    你知道嗎? <b class='flag-5'>51</b><b class='flag-5'>單片機</b>也有動態(tài)內(nèi)存分配

    ?51單片機串口通信詳細介紹-小白必看

    51單片機串口通信是單片機與外部設備通信的重要方式,它基于串行通信的原理,以字節(jié)為單位進行數(shù)據(jù)傳輸。在51單片機中,串口通信主要依賴于兩個關
    的頭像 發(fā)表于 04-17 09:33 ?2151次閱讀
    ?<b class='flag-5'>51</b><b class='flag-5'>單片機</b>串口通信詳細介紹-小白必看

    51單片機流水燈制作

    ?流水燈是學習51單片機的一個基本項目,是我們對單片機IO口輸出認識的基本項目。當然學會了花樣流水燈也很好玩。 下面就分享一種51單片機流水
    的頭像 發(fā)表于 02-26 10:06 ?1705次閱讀
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>流水燈制作
    百家乐官网线上游戏| 运城百家乐官网的玩法技巧和规则| 百家乐技巧在那里| 网络百家乐模拟投注| 大发888官方 df888 gfxzylc8| 美高梅百家乐官网娱乐城| 博E百百家乐现金网| 赚钱的棋牌游戏| 网上百家乐官网大赢家筹码| 百家乐破解仪恒达| 银河国际娱乐城| 博彩百家乐官网带连线走势图| 百家乐输惨了| 百家乐官网开户送彩网址| 百家乐桌颜色可定制| 永利高娱乐场| 网上百家乐官网返水| 娱乐百家乐可以代理吗| 澳门百家乐官网赢技巧| 百人百家乐软件供应| 大发888在线娱乐二十一点| 百家乐官网智能分析| 微信百家乐群资源| 百家乐官网赌博机有鬼吗| 精通百家乐的玩法技巧和规则| 百家乐官网娱乐天上人间| 百家乐赌博分析网| 百家乐官网咨询网址| 高科技百家乐牌具| 百家乐官网免费试玩游戏| 百家乐赢钱公式论| 百家乐官网偷码| 百家乐技巧技巧| 至尊百家乐官网2014| 墨尔本百家乐的玩法技巧和规则| 日博| 菲律宾百家乐游戏| 信丰县| 澳门百家乐送彩金| 菲律百家乐官网太阳城| 威尼斯人娱乐城真人百家乐|