fs 的一些参考

本文介绍了在用户模式(R3)和系统模式(R0)下,FS段如何指向TEB(Thread Environment Block)和KPCR(Kernel Processor Control Region)。在R3中,FS常用于获取kernel32.dll的基地址和线程、进程信息。详细列举了FS段在不同偏移处所存储的系统数据,如线程ID、PEB指针、错误号等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

经常在r3 下调试经常会看到

mov    eax,fs:[18h]             ;获取TEP 其实就只指向自己fs:[0]
mov    eax,[eax+30h]        ;获取PEB

这样的语句。

fs段在用户模式(R3)和系统模式(R0)分别指向两个最重要的系统结 构:
Ring3:
fs --> TEB (Thread Environment Block)结 构表 --> 7FFDE000即“线程环境块”。

Ring0:
fs --> KPCR (Kernel Processor Control Region) 结构表 --> FFFDF000 即“内核处理器控制域”。

通常在其r3 下fs被用于获取kernel32.dll的基地址 或者其他有关于程序线程和进程的信息。

以下是一些参考资料

FS:[0x00] Win9x and NT Current SEH frame
FS:[0x04] Win9x and NT Top of stack
FS:[0x08] Win9x and NT Current bottom of stack
FS:[0x10] NT Fiber data
FS:[0x14] Win9x and NT Arbitrary data slot
FS:[0x18] Win9x and NT Linear address of TIB(TEB— 也叫做线程信息块 TIB)
FS:[0x20] NT Process ID
FS:[0x24] NT Current thread ID
FS:[0x2C] Win9x and NT Linear address of the thread local storage array
FS:[0x30] Pointer to PEB

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值