前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >x64 gs寄存器的一点资料

x64 gs寄存器的一点资料

作者头像
战神伽罗
发布2019-07-24 16:21:58
2.2K0
发布2019-07-24 16:21:58
举报

gs:[0x20] prcb gs:[0x30] TEB gs:[0x40] Pid gs:[0x48] Tid gs:[0x60] PEB gs:[0x68] LastError

gs:[0x188]     _ethread

值得一提的是,虽然gs:[0x60] 直接存放的PEB,但是由于vista/7后的地址随机化机制,还是从TEB获取比较靠谱. 0:009> dt 000007fffff98000 _TEB ntdll!_TEB +0×000 NtTib : _NT_TIB +0×038 EnvironmentPointer : (null) +0×040 ClientId : _CLIENT_ID +0×050 ActiveRpcHandle : (null) +0×058 ThreadLocalStoragePointer : (null) +0×060 ProcessEnvironmentBlock : 0x000007ff`fffd5000 _PEB //这里即是PEB //用c语言描述就是 #define x64_GetPeb() ( (LONG64*)(*((LONG64*)((BYTE*)x64_GetTeb()+0×060))) ) 得到了PEB,剩下的就和x86下一样了.只是偏移不一样了 0:009> dt 0x000007ff`fffd5000 _PEB ntdll!_PEB +0×000 InheritedAddressSpace : 0 ” +0×001 ReadImageFileExecOptions : 0 ” +0×002 BeingDebugged : 0×1 ” +0×003 BitField : 0×8 ” +0×003 ImageUsesLargePages : 0y0 +0×003 IsProtectedProcess : 0y0 +0×003 IsLegacyProcess : 0y0 +0×003 IsImageDynamicallyRelocated : 0y1 +0×003 SkipPatchingUser32Forwarders : 0y0 +0×003 SpareBits : 0y000 +0×008 Mutant : 0xffffffff`ffffffff Void +0×010 ImageBaseAddress : 0×00000000`ff310000 Void +0×018 Ldr : 0×00000000`77222640 _PEB_LDR_DATA 0:009> dt 0×00000000`77222640 _PEB_LDR_DATA ntdll!_PEB_LDR_DATA +0×000 Length : 0×58 +0×004 Initialized : 0×1 ” +0×008 SsHandle : (null) +0×010 InLoadOrderModuleList : _LIST_ENTRY [ 0x00000000`00202780 - 0x2421b0 ] +0×020 InMemoryOrderModuleList : _LIST_ENTRY [ 0x00000000`00202790 - 0x2421c0 ] +0×030 InInitializationOrderModuleList : _LIST_ENTRY [ 0x00000000`00202890 - 0x2421d0 ] 同样的,搜索InInitializationOrderModuleList 即可得到Kernel32的基址. 由于x64下vs2005没法直接使用内联汇编,所以只把必须使用汇编来做的事情写成单独的asm x64下.指针的长度已经是8个字节,所以偏移不一样了. 0:009> dt _LDR_DATA_TABLE_ENTRY ntdll!_LDR_DATA_TABLE_ENTRY +0×000 InLoadOrderLinks : _LIST_ENTRY +0×010 InMemoryOrderLinks : _LIST_ENTRY +0×020 InInitializationOrderLinks : _LIST_ENTRY +0×030 DllBase : Ptr64 Void +0×038 EntryPoint : Ptr64 Void +0×040 SizeOfImage : Uint4B +0×048 FullDllName : _UNICODE_STRING

https://blog.csdn.net/cosmoslife/article/details/52851788

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档