自制反匯編逆向分析工具 迭代第六版本 (五)

本工具從最初版的跳轉分布圖只為了更直觀地分析反匯編代碼的分支結構,第三版開始對直觀圖進行逆向分支代碼的輸出,第四版對分支輸出策略的一些探索,第五版結合之前的探索進行改進。第六版在現在功能的基礎上進行增強,利用第六版(一)的基本功能-直譯,第六版(二)對條件分支增加條件判斷翻譯,以及改進在函數調用處附帶備選參數參考。

第六版(三)將(一)和(二)組合在一起進行逆向代碼輸出。

第六版(四),在(三)的基礎上增加對原子操作指令的逆向以及c++函數的逆向。

本篇是(五),對待c風格的函數符號調用的翻譯,通過導入c風格符號的函數原型來參考分析。

上一篇在介紹對待 c++風格的函數符號調用的情況,提到了c風格的函數符號沒有太多的原型信息可供參考,但是它唯一不被重載,參數約定使用標準的約定,所以用古老(老土)的辦法就好了。就是導入c風格符號的函數原型(主要是符號名和參數序列)。

有外部的是參考信息,就可以對函數調用配用相應的寄存器和存儲單元。我并不想讓機器去試圖臆意猜測一個不知道原型的函數參數序列,因為過猶不及,而且不嚴謹,機器猜測誤導坑更加大。試想一下,一個c風格的函數,你可以單從函數被調用前的準備參數的工作流就能分辨出是foo(double, int)還是foo(int, double)嗎?我是不能做到這種超人的程序了,我必須要通過外部信息來指導機器進行分析工作。

下面貼上機器逆向出來的代碼:

CA::Transaction::add_root
{// 0 pushq %rbp// 1    rbp = rsp;// 4 pushq %r14// 6 pushq %rbx// 7    rbx = rsi;// 10    r14 = rdi;// 13    rdi = & CA::Transaction::roots_lock;// 20 call
    OSSpinLockLock(CA::Transaction::roots_lock);// 25    rdi = CA::Transaction::roots;// 32 testq %rdi, %rdi// 35if (!) { // 32 (0 != rdi)// 37    edi = 0;// 39    esi = 0;// 41    edx = 0;// 43    ecx = 0;// 45    r8d = 0;// 48    r9d = 0;// 51 callx_hash_table_new_(0, 0, 0, 0, 0, 0);// 56    rdi = rax;// 59     CA::Transaction::roots = rdi;} // 66// 66    rsi = rbx;// 69    rdx = rbx;// 72 callx_hash_table_insert((x_hash_table*)rax, (uintptr_t)esi, (uintptr_t)edx);// 77 testb %al, %al// 79if (!) { // 77 (0 == al)// 81 lock// 82    OSAtomicIncrement32((volatile int32_t*)&rbx->_0);// 84 testb $0x10, 0x84(%r14)// 92if (!) { // 84 (0 == (0x10 & r14->_84))// 94    rax = (int64_t)(int32_t&)r14->_8;// 98 testq %rax, %rax// 101if () { // 98 (0 > rax)// gen jmp 113goto _f113;// 103 cmpl $0x0, 0xa8(%rbx,%rax,4)} // 111else if () { // 103 ((int32_t&)((uint32_t*)&rbx->_a8)[rax] != 0x0)// gen jmp 124goto _f124;}else { // 111 next_f113:     // from 101} // 113// 113    rdi = rbx;// 116    rsi = r14;// 119 call((CA::Layer*)rbx)->thread_flags_((CA::Transaction*)r14);_f124:     // from 111} // 124} // 124// 124    rdi = & CA::Transaction::roots_lock;// 131 popq %rbx// 132 popq %r14// 134 popq %rbp// 135 retreturn;    // jmp 0x1041ecb2a; symbol stub for: OSSpinLockUnlock// 140    rbx = rax;// 143    rdi = & CA::Transaction::roots_lock;// 150 call
    OSSpinLockUnlock(CA::Transaction::roots_lock);// 155    rdi = rbx;// 158 call
    _Unwind_Resume;// 163 nop/*****
* global variables
*
*/// 13 extern ent_off__0x5146c;    leaq 0x51458(%rip), %rdi;     CA::Transaction::roots_lock
// 25 extern ent_off__0x51464;    movq 0x51444(%rip), %rdi;     CA::Transaction::roots
// 59 extern ent_off__0x51464;    movq %rdi, 0x51422(%rip);     CA::Transaction::roots
// 124 extern ent_off__0x5146c;    leaq 0x513e9(%rip), %rdi;     CA::Transaction::roots_lock
// 143 extern ent_off__0x5146c;    leaq 0x513d6(%rip), %rdi;     CA::Transaction::roots_lock
}
CA::Transaction::add_root

?

CA::Transaction::run_deferred_visibility_layer_calls
{// 0 pushq %rbp// 1    rbp = rsp;// 4 pushq %r15// 6 pushq %r14// 8 pushq %rbx// 9 pushq %rax// 10    r14 = rdi;// 13    rbx = r14->_78;// 17 testq %rbx, %rbx// 20if (!) { // 17 (0 == rbx)_b22:     // from 81// 22    r15 = rbx->_0;// 25 testq %r15, %r15// 28if (!) { // 25 (0 == r15)// 30    rdi = r15;// 33 call((CA::Layer*)r15)->call_did_become_visible();// 38    eax = 0xffffffff;// 43 lock// 44    OSAtomicAdd32(eax, (volatile int32_t*)&r15->_0);// 48 cmpl $0x1, %eax// 51if (!) { // 48 (eax != 0x1)// 53    rdi = r15;// 56 call((CA::Layer*)r15)->~Layer();// 61    edi = 0xb;// 66    rsi = r15;// 69 callx_mem_dealloc_bucket(0xb, (void*)r15);} // 74} // 74// 74    rbx = rbx->_8;// 78 testq %rbx, %rbx// 81if () // 78 (0 != rbx)goto _b22;// 83    rdi = r14->_78;// 87 callx_list_free((x_list*)r14->_78);// 92    r14->_78 = 0x0;} // 100// 100    rsp = rsp + 0x8;// 104 popq %rbx// 105 popq %r14// 107 popq %r15// 109 popq %rbp// 110 ret
return;
// 111 nop
}
CA::Transaction::run_deferred_visibility_layer_calls

?

轉載于:https://www.cnblogs.com/bbqzsl/p/5512642.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/255251.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/255251.shtml
英文地址,請注明出處:http://en.pswp.cn/news/255251.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

模型搜索 及 輪廓搜索 的原理

模型搜索 及 輪廓搜索 的原理

Linux中設置vim自動在運算符號兩邊加上空格

vim中設置自動在-之類的運算符號左右兩邊加上空格。原版的vim不帶這個功能,寫出的代碼例如zxy,不美觀,很多編譯器(如VS)能夠自動在符號兩邊加上空格,如z x y,看起來比較美觀。 只要在.vimrc里…

HALCON示例程序class_ndim_norm.hdev基于多通道圖像的分類

HALCON示例程序class_ndim_norm.hdev基于多通道圖像的分類 示例程序源碼(加注釋) 讀入圖片 read_image (Image, ‘ic’)得到圖片大小 get_image_size (Image, Width, Height)關閉窗口 dev_close_window ()根據圖片大小打開窗口 dev_open_window (0, 0,…

centos7搭建FTP服務器

1.   使用 yum 安裝 vsftpd:yum install -y vsftpd 2.  啟動 VSFTPD:systemctl start vsftpd.service 3.  啟動后可監聽到21端口:netstat -nltp | grep 21 4.  配置FTP權限:(vsftpd.conf,修改前先備…

[HDOJ2586]How far away?(最近公共祖先, 離線tarjan, 并查集)

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid2586 這題以前做過…現在用tarjan搞一發…竟然比以前暴力過的慢………… 由于是離線算法,需要Query來保存查詢數據,Ans來保存結果。最后輸出的時候按照idx的順序輸出,所以胡搞…

愛普生SCARA機器人參考文檔列表

愛普生SCARA機器人參考文檔列表軟件EPSON RC 5.0 用戶指南記載了機器人系統與程序開發軟件。 - 安全 - 機器人系統的操作與設定 - 程序開發軟件 EPSON RC GUI的操作 - SPEL語言、應用程序 - 機器人…

HALCON示例程序classify_citrus_fruits.hdev應用常規gmm分類器進行水果分類

HALCON示例程序classify_citrus_fruits.hdev應用常規gmm分類器進行水果分類 示例程序源碼(加注釋) 讀入圖片、顯示與顯示相關設置 read_image (Image, ‘color/citrus_fruits_01’) get_image_pointer1 (Image, Pointer, Type, Width, Height) dev_clos…

python進階10 MySQL補充 編碼、別名、視圖、數據庫修改

python進階10 MySQL補充 編碼、別名、視圖、數據庫修改 一、編碼問題 #MySQL級別編碼 #修改位置: /etc/mysql/mysql.conf.d/mysqld.cnf default-character-set utf8character-set-server utf8 collation-server utf8_general_ci#最佳實踐 #1、無論mysql是否設…

教你如何剖析源碼

一、源碼閱讀需求 在學習中,我們會需要了解,學習,使用一個框架,一個新的函數庫。在工作中,因為業務需求,因為性能問題,可能通過一個更高性能的工具,架構去優化我們的程序。 那么&…

SPEL + 中的錯誤處理

SPEL 中的錯誤處理 如果在SPEL程序中發生錯誤,可以將執行轉到錯誤處理例程中進行錯誤處理。該例程必須在函數定義內。下一頁的表格顯示了用于錯誤處理的程序指令。 項目 目的 OnErr 使用OnErr語句定義錯誤處理…

HALCON示例程序classify_halogen_bulbs.hdev使用SVM分類器檢測鹵素燈泡的好壞

HALCON示例程序classify_halogen_bulbs.hdev使用SVM分類器檢測鹵素燈泡的好壞 示例程序源碼(加注釋) 得到halcon默認圖片存儲路徑 get_system (‘image_dir’, HalconImages) 獲得操作系統類型 get_system (‘operating_system’, OS) OS{0:2}的意思是…

php調用API支付接口(轉自劉68)

首先訪問 https://charging.teegon.com/ 注冊賬號, 找到開發配置 記下client_id和client_secret。 點擊 天工開放平臺 點擊天工收銀 點擊 SDK下載與使用 選擇php版下載 解壓后獲得 打開form.php這個是樣板文件可以用它來測試是否成功,測試前需要先修…

S3C2440 SPI驅動框架

S3C2440 SPI驅動代碼詳細解讀: https://www.linuxidc.com/Linux/2012-08/68402p4.htm 一、platform device and board_info /* /arch/arm/plat-s3c24xx*/static struct resource s3c_spi0_resource[] { [0] {.start S3C24XX_PA_SPI,.end S3C24XX_PA_SPI 0…

單目相機標定原理

一.相機標定主要涉及三個坐標系:圖像坐標系、攝像機坐標系和世界坐標系 【圖像坐標系】 攝像機采集的圖像變換為數字圖像后,每副數字圖像在計算機內為M x N數組,M行N列的圖像中每一個元素(pixel)數值就是圖…

HALCON示例程序classify_image_class_gmm.hdev使用GMM分類器分割彩色圖片

HALCON示例程序classify_image_class_gmm.hdev使用GMM分類器分割彩色圖片 示例程序源碼(加注釋) dev_update_off () dev_close_window () dev_open_window (0, 0, 735, 485, ‘black’, WindowHandle) set_display_font (WindowHandle, 14, ‘mono’, …

Android開始之 activity_lifecycle和現場保護

生命周期: oncreate—onstart—onresume,--onpause--onstop,——onrestart——onstart——onresume,。。onpause。。。onstop。。。ondestroy 現在保護---保存系統狀態 通過這個方法保存到數據庫中或者xml中,&#xff…

Apache啟動錯誤:could not bind to address[::]:443

Q:Windows環境下啟動apache報錯如下: 可是在httpd.conf文件中apache listen的明明是http 80端口,為什么會報443的錯誤? A:因為你的計算機安裝了VM,所有有個vm的進程一直占用著443端口,在命令行下…

針孔相機拍攝的圖像坐標和空間點的對應關系

一:攝像機成像原理 攝像機成像模型一般有三種:透鏡投影模型(小孔攝像機模型)、正交投影模型和透視投影模型 光學中最基本的高斯成像公式:1/u 1/v 1/f (式一) 原理圖如下: 二:認識三個…

window.onload中動態獲得img的高度

$(function(){}); window.οnlοadfunction(){} $(function(){}) 是在DOM結構渲染完成以后調用的,這時候網頁中一些資源還沒有加載,比如圖片等資源,但是DOM結構已經渲染成功了 window.onload是在網頁DOM結構渲染完成,而且資源已經…

HALCON關于顯示的函數與介紹(持續更新)

點擊下方直達算子藍色字體 目錄1、dev_update_off ();dev_update_on2、dev_close_window ()3、dev_open_window( : : Row, Column, Width, Height, Background : WindowHandle)4、set_display_font( : : WindowHandle, Size, Font, Bold, Slant : )5、dev_set_draw(…