INT 2DH中断

立春好时节……Mark一个2dh中断。

;       push    offset _seh     ;
;       push    fs:[0]          ; > 设置seh
;       mov     fs:[0], esp     ;/
;
;       int     2dh             ; 如果被调试则正常运行
;                               ; 否则异常
;       nop
;       pop     fs:[0]          ;\ 清楚seh
;       add     esp, 4          ;/
;
;       ...
;       debugger detected         检查到调试器时运行
;       ...
;
;       _seh:
;       debugger not detected   未检查到调试器时运行


第2dh号中断处理函数是KiDebugService,执行Int 2dh指令时,进程如果没有处于被调试状态,将会抛出异常,如果在被调试状态则能够正常执行。我们可以利用这一点检测调试器的存在
; Besides this, int 2Dh can also be used as code obfuscation method.
; With attached debugger, after executing int 2Dh, system skips one byte
; after int 2Dh:
;
;       int      2dh
;        nop                      ; never executed
;        ...



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>