对抗启发式代码仿真检测技术分析(2)_MySQL
bitsCN.com
,例如这样打开一个文件的操作,虽然我没有测试过这种方式。
mov ax, 3D02h ;0x3D02 是密钥
add ax, key
int 21h 1 通过指令预取反跟踪技术:
早期的处理器,像386或者486都使用了指令队列预期(PIQ)技术来提高代码执行效率。这一技术的本质是,当CPU将要执行一条指令时,它已经将该指令预先读到了CPU的cache中了。所以在此之前的修改对CPU来说已经没有影响了。让我看一个这样的例子:
mov word ptr cs:[offset piq], 20CDh
piq:
nop
nop 你应该会想到这个程序将结束运行,因为两个字节的nop 指令会被覆盖为 int 20h(译者注:int 20h 是返回DOS的指令)。但在386或486的机器上去并非如此,因为nop指令已经在cpu的cache中了。但在Pentium/Pentium II 体系的机器中运行时,指令则会被覆盖,程序执行后退出。
如果你想利用这一特性来对抗启发式检测技术的话,你就必须知道在386/486年代这是一种广泛的对抗启发式检测的手段。但是随着AVs的改进,他们已经加入了对指令预期技术的支持。这是不是件很不可思议的事情,他们仿真的东西竟是不存于现在的处理器当中的。让我们再看看上面的例子,这是我们用来对付他们的,在 pentium 或者更高级别的处理上面,像我所说的那样,程序会终止,因为这些处理器没有使用PIQ技术。但大部分的AVs会继续让代码执行那两个nops,因为他们要仿真PIQ。所有这块我们这样做:
mov word ptr [offset prefetch], 06C7h
prefetch:
int 20h
dw offset decrypt_key
dw key int 20h 指令将被覆盖,替换它的将是下面的指令
mov word ptr [decrypt_key], key 基于对PIQ的考虑,AVs将终止程序的执行。但实际上我们的程序将继续运行,在我们的加密处理函数中设置密钥。我们仅存在一个问题,那就是我们的代码要运行在Pentiums或更高级别的处理器上面。为了使之兼容486系列或更低一些处理器,我们只需清除掉PIQ之间的两条指令。
没有什么比这更简单的了!当然,你也要知道清除所有jump类指令(jmp, call, loop, int...)之间的PIQ(这一点是必需的,如果你想这样做的话)。但是我们不能简单的处理JMP Short $+2之间的指令,对于清除PIQ来说它应该是正常被执行的,因为代码仿真器是会察觉到这一点的。
但是我们可以使用一个特殊的功能,CPU的陷阱标志。如果这个标志被置位,那么其后的任何指令执行都将触发int 1 的中断调用,记住这样会清除PIQ。这通常是在的调试状态下,1号中断向量只是简单的 IRET,所以我们可以使用没有任何问题。无论如何,执行后再次清除陷阱标志都是个很好的主意。下面展示的代码可以运行在任何处理器上(assumes DS = CS)。
pushf ;flags on the stack
pop ax ;flags from stack into AX
or ax, 100000000b ;set trap flag
push ax ;put the modified flags in AX back...
popf ;into the flag register via the stack
mov word ptr [offset prefetch], 06C7h ;modify the following instruction
prefetch: ;here gets int1 called => clears PIQ
int 20h ;This is never executed
dw offset decrypt_key ;where we want to write our key to
dw key ;the actual decryption key
pushf ;clear the trap flag again with
pop ax ;the same method as above.
xor ax, 100000000b ;will also fool some debuggers
push ax
popf
mov word ptr [offset prefetch], 20CDh ;restore the int20h (next generations)bitsCN.com

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

本站7月29日消息,AMD銳龍9000系列處理器現已上架京東預約,首批推出四個型號產品,8月15日發售。這些處理器的評測資料將於上市前一天,也就8月14日解禁,但也有部分媒體或機構提前拿到了樣品並開始測試,所以目前R99900X、R79700X、R59600X處理器跑分資料已經洩露。 ▲圖源:@9550pro整體來看,從Zen4到Zen5預計會帶來10%到15%的單核心性能提升,以及10%到13%的多核心性能提升,但相比銳龍7000系列TDP有所降低,這也符合AMD官方公佈的IPC提升數據。 Ryzen

本站7月28日消息,根據外媒TechRader報道,富士通詳細介紹了計劃於2027年出貨的FUJITSU-MONAKA(以下簡稱MONAKA)處理器。 MONAKACPU基於「雲端原生3D眾核」架構,採用Arm指令集,面向資料中心、邊緣與電信領域,適用於AI運算,能實現大型主機層級的RAS1。富士通表示,MONAKA將在能源效率和性能方面實現飛躍:得益於超低電壓(ULV)製程等技術,該CPU可實現2027年競品2倍的能效,冷卻無需水冷;此外該處理器的應用性能也可達對手2倍。在指令方面,MONAKA配備的向量

本站7月16日消息,AMDXOC團隊在Zen5技術日上,為現場受邀媒體和嘉賓演示超頻銳龍99950X處理器,透過液態氮(LN2)方式超頻該處理器,在CineBenchR23中的得分超過5.5萬,功耗高達552W。 XOC團隊使用的超頻平台是華碩X670EROGCorsshairGene主機板,這是一款專為超頻玩家設計的主機板,配備了2個DDR5DIMM。銳龍99950X處理器使用液態氮後運轉溫度降至攝氏零下90度,功耗為552W,CPU超頻在6.4GHz下,在CineBenchR23中的得分超過55296

本站7月25日消息,消息源HXL(@9550pro)昨日(7月24日)發布推文,分享了基於Zen5的AMDEPYC9755“Turin”CPU相關信息,並在CPU-Z基準測試中取得了優異成績。 AMDEPYC9755「Turin」CPU資訊EPYC9755是AMD的第五代EPYC家族產品,在Zen5架構上配有128個核心和256個執行緒。 EPYC9755處理器的基礎時脈頻率為2.70GHz,加速時脈頻率可達4.10GHz,相比較前代核心/執行緒數增加了33%,時脈頻率增加了11%。 EPYC9755

本站7月9日訊息,現有一款搭載AMD銳龍79700X處理器的華碩測試機出現在了Geekbench資料庫中,配備ROGCROSSHAIRX670EHERO主機板、32GBDDR56000記憶體。 AMD銳龍79700X具有8核心16線程、3.8GHz基礎頻率、5.5GHz加速頻率、40MB快取(本站註:32MBL3+8MBL2)和65W的TDP設計,不過也有消息指出AMD已使其TDP提高至120W。如圖所示,測試平台在Geekbench6.3.0上跑出了3312分、16431分的單多核心成績,比R77700

本站8月10日訊息,AMD官方確認,部分EPYC和Ryzen處理器存在一個名為“Sinkclose”的新漏洞,代碼為“CVE-2023-31315”,可能涉及全球數百萬AMD用戶。那麼,什麼是Sinkclose呢?根據WIRED的一份報告,該漏洞允許入侵者在「系統管理模式(SMM)」中運行惡意程式碼。據稱,入侵者可以使用名為bootkit的惡意軟體來控制對方系統,而這種惡意軟體無法被防毒軟體偵測到。本站註:系統管理模式(SMM)是一種特殊的CPU工作模式,旨在實現高階電源管理和作業系統獨立功能,

本站5月31日消息,聯發科今日推出了Kompanio(迅鯤)838處理器。聯發科表示,這顆6nm製程SoC面向中高階Chromebook市場,相較Kompanio500系列產品圖形效能提升至高76%,在CPU基準測試中提升至高66%,Web基準測試中提升至高60%。本站整理Kompanio838處理器參數如下:CPU:8核心設計,2*ArmCortex-A78@2.6GHz+6*ArmCortex-A55@2.0GHz;GPU:ArmMali-G57MC3;AI處理器:NPU650,算力4TOPSS

本站8月21日消息,科技媒體WccFtech今日報道,英特爾酷睿Ultra9285K「ArrowLake」處理器現身GeekBench6跑分庫,超過酷睿i9-14900KS和Ryzen99950X處理器。測試平臺本次曝光的測試平台為華碩ROGSTRIXZ890-AGamingWIFI主機板,64GBDDR5-6400記憶體。英特爾酷睿Ultra9285K「ArrowLake-S」桌上型電腦處理器簡介英特爾酷睿Ultra9285K處理器的PL1功耗為125W,採用7nm製程(CPU-Z訊息,實際應採用英
