SYSCALL SWAPGS

友链

文章目录


references:

swapgs指令会将GS寄存器的值和MSR地址为C0000102H(IA32_KERNEL_GS_BASE)的值进行交换

当时用SYSCALL实现系统调用的时候,不存在内核栈空间,也不存在指向保存了内核栈空间内核结构的指针

因此,内核没办法去保存通用寄存器的值或者引用的内存里的值

关于为什么要保存通用寄存器或者内存里的值到栈里面请参考这篇文章:https://blog.csdn.net/ma_de_hao_mei_le/article/details/124604874

SWAPGS指令不需要任何操作数

在使用该指令之前不需要保存任何通用寄存器,

在交换完毕之后就可以使用GS作为段地址来访问内核结构了

尝试给nt!KiSystemCall64函数下断点,下完断点之后g直接导致虚拟机崩溃了

在这里插入图片描述

后来网上搜可一下

https://stackoverflow.com/questions/65367333/breakpoint-setting-in-ntkisystemcall64-not-working

说是因为该函数的前三条指令是用于设置内核栈空间的,内核调试需要先执行这三条指令来设置栈空间,也就是说这三条指令上面是不能下断点的,需要往后偏移

还有就是如果断点一直不被触发,有可能是因为目标机器上装了什么杀软导致的,卸载再尝试一下

在这里插入图片描述

从push 2B那条指令开始调试,也就是bp nt!KiSystemCall64+0x15

段寄存器+偏移量和虚拟地址的映射

; 看了一下书,书上说前面那些操作是在设置内核栈空间,我不知道作者是怎么知道这些的
; gs就是KPCR 后面的偏移量就是指代了特定的成员

在这里插入图片描述

gs:[10]就是UserRsp,也就是说该成员变量就是用于保存用户空间的rsp的值的

然后gs:[1a8]是KPCR结构体中的_KPRCB结构体中的一个成员变量
在这里插入图片描述

1a8-180 = 28
在这里插入图片描述
看样子PRCB并不是一个结构体,因为这个成员的值根本就不是一个地址,哎呀我也搞不太明白,算了就这样吧

https://docs.microsoft.com/en-us/windows-hardware/drivers/debugger/dx–display-visualizer-variables-

哦明白了,相当于把这个地址解释成特定的类型((ntkrnlmp!_KPRCB *))

所以这个gs:[1a8]就是将要被设置为内核栈空间的rsp的值

mark

完整注释 base64 encode

kd> uf fffff803`eb4fadc0
Flow analysis was incomplete, some code may be missing
nt!KiSystemCall64:
; swap gs base register
; swap value in GS and C0000102H (IA32_KERNEL_GS_BASE)(MSR)
fffff803`eb4fadc0 0f01f8          swapgs
; 将rsp的值保存到gs:[10h]   00000065`0d31f6d8   之前的rsp的值
fffff803`eb4fadc3 654889242510000000 mov   qword ptr gs:[10h],rsp
; 设置rsp的值为gs:[1a8h]   
; 下断点调试了一下 gs:[1A8h] 的值是 fffff88003004c90 ，rsp 已经进入内核空间了
fffff803`eb4fadcc 65488b2425a8010000 mov   rsp,qword ptr gs:[1A8h]
; 这个2B不知道是啥意思，有趣的是gs寄存器的值也是2B
 
fffff803`eb4fadd5 6a2b            push    2Bh
; 之前的rsp的值压栈   00000065`0d31f6d8
fffff803`eb4fadd7 65ff342510000000 push    qword ptr gs:[10h]
; 保存寄存器啥的，push 33我也不知道是啥玩意儿
fffff803`eb4faddf 4153            push    r11
fffff803`eb4fade1 6a33            push    33h
fffff803`eb4fade3 51              push    rcx
fffff803`eb4fade4 498bca          mov     rcx,r10
; 开辟8字节的栈空间
fffff803`eb4fade7 4883ec08        sub     rsp,8
; 保存rbp，保不保存都无所谓，反正64位处理器rbp一直都是0  靠  当我没说，刚才看了一下rbp的值并不是0
fffff803`eb4fadeb 55              push    rbp
; 再开辟0x158字节栈空间
fffff803`eb4fadec 4881ec58010000  sub     rsp,158h
; 改变rbp的值 为当前rsp+80h
fffff803`eb4fadf3 488dac2480000000 lea     rbp,[rsp+80h]
; 初始化局部变量（栈空间）
fffff803`eb4fadfb 48899dc0000000  mov     qword ptr [rbp+0C0h],rbx
fffff803`eb4fae02 4889bdc8000000  mov     qword ptr [rbp+0C8h],rdi
; 80h+d0h也只是150h，没有超出之前分配的局部变量空间158h
fffff803`eb4fae09 4889b5d0000000  mov     qword ptr [rbp+0D0h],rsi
; 初始化一个char类型的变量  为2 不知道这里2是啥意思  
fffff803`eb4fae10 c645ab02        mov     byte ptr [rbp-55h],2
;kd> dq /c 1 gs:[188]
;002b:00000000`00000188  fffffa80`1a86f540      不知道gs 188h有什么特殊的含义
; gs[188]是KPRC的_KPRCB的currenttherad成员  可能会在恢复到用户空间的时候用的吧
fffff803`eb4fae14 65488b1c2588010000 mov   rbx,qword ptr gs:[188h]
; 这个指令用于把操作数写入到CPU的一级或者二级缓存中  
; 这个指令取出来的数组长度取决于处理器的具体实现  https://www.felixcloutier.com/x86/prefetchw
; 我这里就不细看，姑且当他是qword
;kd> dq /c 1 fffffa80`1a86f540+90 L1
;fffffa80`1a86f5d0  fffff880`04557380
; windbg显示 rbx+90也就是current（ETHREAD）的90偏移量是
; [+0x090] TrapFrame        : 0xfffff88003004b00 [Type: _KTRAP_FRAME *]
; 我也也不知道他为什么叫trapfram，正好我看的这一节的标题就是trap，可能是跟使用trap实现systemcall有关吧
fffff803`eb4fae1d 0f0d8b90000000  prefetchw [rbx+90h]
;stmxcsr—— Store MXCSR Register State   将MXCSR寄存器的值保存到操作数指定的内存中
; MXCSR寄存器：https://help.totalview.io/previous_releases/2019/html/index.html#page/Reference_Guide/Intelx86MXSCRRegister.html
;；kd> r mxcsr
;mxcsr=00001f80
;kd> dd /c 1 rbp-54
;fffff880`045573ac  00001f80
fffff803`eb4fae24 0fae5dac        stmxcsr dword ptr [rbp-54h]
; 这个指令我都不用搜我就知道他的意思是 从操作数load 到MXCSR寄存器的
;kd> dd /c 1 gs:[180h]
;002b:00000000`00000180  00001f80
; 巧了，gs[180h]的值跟mxcsr本来的值是一样的   按道理讲 gs很栈是没啥关系的，不知道什么原理这个地址处的值和mxcsr寄存器的值一致
; gs:180就是KPRCB的第一个成员
; [+0x000] MxCsr            : 0x1f80 [Type: unsigned long]   所以他和mxcsr有关系一点也不意外
fffff803`eb4fae28 650fae142580010000 ldmxcsr dword ptr gs:[180h]
;kd> db /c 1 rbx+3 L1
;fffffa80`1a86f543  00  .
; rbx是从gs:188h来的，这个gs有很多重要的东西呀，gs又来自于   C0000102H (IA32_KERNEL_GS_BASE)(MSR)  还是他存的东西多
; rbx+3 就是KPRCB中的currentthread的header的 TimerMiscFlags  这个东西具体是干啥的
; 我不知道，网上也没有详细的相关解释
fffff803`eb4fae31 807b0300        cmp     byte ptr [rbx+3],0
;初始化一个长度为2字节的局部变量为0
fffff803`eb4fae35 66c785800000000000 mov   word ptr [rbp+80h],0
; je条件满足，跳
fffff803`eb4fae3e 0f848c000000    je      nt!KiSystemCall64+0x110 (fffff803`eb4faed0)  Branch

nt!KiSystemCall64+0x84:
fffff803`eb4fae44 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4fae48 48894db8        mov     qword ptr [rbp-48h],rcx
fffff803`eb4fae4c 488955c0        mov     qword ptr [rbp-40h],rdx
fffff803`eb4fae50 f6430303        test    byte ptr [rbx+3],3
fffff803`eb4fae54 4c8945c8        mov     qword ptr [rbp-38h],r8
fffff803`eb4fae58 4c894dd0        mov     qword ptr [rbp-30h],r9
fffff803`eb4fae5c 7405            je      nt!KiSystemCall64+0xa3 (fffff803`eb4fae63)  Branch

nt!KiSystemCall64+0x9e:
fffff803`eb4fae5e e8bd160000      call    nt!KiSaveDebugRegisterState (fffff803`eb4fc520)

nt!KiSystemCall64+0xa3:
fffff803`eb4fae63 f6430380        test    byte ptr [rbx+3],80h
fffff803`eb4fae67 7442            je      nt!KiSystemCall64+0xeb (fffff803`eb4faeab)  Branch

nt!KiSystemCall64+0xa9:
fffff803`eb4fae69 b9020100c0      mov     ecx,0C0000102h
fffff803`eb4fae6e 0f32            rdmsr
fffff803`eb4fae70 48c1e220        shl     rdx,20h
fffff803`eb4fae74 480bc2          or      rax,rdx
fffff803`eb4fae77 483983f0000000  cmp     qword ptr [rbx+0F0h],rax
fffff803`eb4fae7e 742b            je      nt!KiSystemCall64+0xeb (fffff803`eb4faeab)  Branch

nt!KiSystemCall64+0xc0:
fffff803`eb4fae80 48398300020000  cmp     qword ptr [rbx+200h],rax
fffff803`eb4fae87 7422            je      nt!KiSystemCall64+0xeb (fffff803`eb4faeab)  Branch

nt!KiSystemCall64+0xc9:
fffff803`eb4fae89 488b93f0010000  mov     rdx,qword ptr [rbx+1F0h]
fffff803`eb4fae90 0fba6b740a      bts     dword ptr [rbx+74h],0Ah
fffff803`eb4fae95 66ff8be6010000  dec     word ptr [rbx+1E6h]
fffff803`eb4fae9c 48898280000000  mov     qword ptr [rdx+80h],rax
fffff803`eb4faea3 fb              sti
fffff803`eb4faea4 e8970d0000      call    nt!KiUmsCallEntry (fffff803`eb4fbc40)
fffff803`eb4faea9 eb0b            jmp     nt!KiSystemCall64+0xf6 (fffff803`eb4faeb6)  Branch

nt!KiSystemCall64+0xeb:
fffff803`eb4faeab f6430340        test    byte ptr [rbx+3],40h
fffff803`eb4faeaf 7405            je      nt!KiSystemCall64+0xf6 (fffff803`eb4faeb6)  Branch

nt!KiSystemCall64+0xf1:
fffff803`eb4faeb1 0fba6b7412      bts     dword ptr [rbx+74h],12h

nt!KiSystemCall64+0xf6:
fffff803`eb4faeb6 488b45b0        mov     rax,qword ptr [rbp-50h]
fffff803`eb4faeba 488b4db8        mov     rcx,qword ptr [rbp-48h]
fffff803`eb4faebe 488b55c0        mov     rdx,qword ptr [rbp-40h]
fffff803`eb4faec2 4c8b45c8        mov     r8,qword ptr [rbp-38h]
fffff803`eb4faec6 4c8b4dd0        mov     r9,qword ptr [rbp-30h]
fffff803`eb4faeca 660f1f440000    nop     word ptr [rax+rax]

nt!KiSystemCall64+0x110:
; 其实跳转之前的代码我一点都没看懂，完全不知道在干什么
; sti——Set Interrupt Flag    This allows the processor to respond to maskable hardware interrupts.
; 至于什么叫做maskable hardware interrupts ，就是可以被忽略或者禁用（拒绝—）的中断
;这个指令有延迟效应，只会在跟着sti之后的一条指令执行完毕后才会接受中断请求
; 具体为什么要这么设计，文档上说的是为了能够正好在一个例程ret之前接受中断请求，其实我完全不；理解这句话是tm的什么意思
; 我也不知道他为什么非要延迟一条指令，反正是cli跟在sti后面等于啥也没干，因为sti还没产生效果cli已经把IF标志复位了
fffff803`eb4faed0 fb              sti
; 这里又是在干嘛俺也不知道  这也不是栈，是gs[188h]指示的地址 并不清楚这些地址有什么特殊的含意
; 看了一下书，书上说前面那些操作是在设置内核栈空间，我不知道作者是怎么知道这些的
; gs就是KPCR  后面的偏移量就是指代了特定的成员
; rbx就是currentthread
;[+0x080] SystemCallNumber : 0x59 [Type: unsigned long]
 ;   [+0x084] Spare1           : 0x0 [Type: unsigned long]
 ;;   [+0x088] FirstArgument    : 0x3 [Type: void *]
  ;  [+0x090] TrapFrame        : 0xfffff88003004b00 [Type: _KTRAP_FRAME *]
;现在这几个值都被覆盖了   rcx是由r10初始化的，而r10又是个什么东西我是不知道的  000000000000001f
;上面也没有对eax或者rax进行过任何初始化，所以我也不知道他是啥    0000000000001006 
;rsp就是当前内核栈空间的顶
;奥，我知道了 
; sycall指令是从下面调用过来的，所以r10和eax现在都有了着落  rcx是返回地址,之所以叫做firstarguments，是因为
;rcx一般确定是作为函数的第一个参数进行传递的
;   eax是系统调用index
; 03: .text:00000001800030F0 mov r10, rcx 
;04: .text:00000001800030F3 mov eax, 53h
;05: .text:00000001800030F8 syscall
;我们可以先在ntdll!NtCreateFile下断点来得到确切的值  等到这个断点触发之后
; 在下syscall的断点bp nt!KiSystemCall64+0x15
;说实话，我有点看不太懂，他说rcx保存的是返回地址，可是我看rcx的值也不是syscall之后的地址呀
;还是说他的意思是rcx要存放返回地址，所以需要先把rcx的值挪到r10中
; 那rcx是在什么时候保存的返回地址呢？  难道是在syscall调用结束之后？
; 看样子好像是的   After the system call fi nishes its work and 
;returns, the system call dispatcher uses the SYSRET instruction, which sets RIP 
;；to RCX so it goes back to user mode.
fffff803`eb4faed1 48898b88000000  mov     qword ptr [rbx+88h],rcx
fffff803`eb4faed8 898380000000    mov     dword ptr [rbx+80h],eax
fffff803`eb4faede 4889a390000000  mov     qword ptr [rbx+90h],rsp
;下面这几步操作我看不懂是在干嘛
fffff803`eb4faee5 8bf8            mov     edi,eax
fffff803`eb4faee7 c1ef07          shr     edi,7
fffff803`eb4faeea 83e720          and     edi,20h
fffff803`eb4faeed 25ff0f0000      and     eax,0FFFh

nt!KiSystemServiceRepeat:
fffff803`eb4faef2 4c8d1507ca2d00  lea     r10,[nt!KeServiceDescriptorTable (fffff803`eb7d7900)]
fffff803`eb4faef9 4c8d1d40ca2d00  lea     r11,[nt!KeServiceDescriptorTableShadow (fffff803`eb7d7940)]
; ThreadFlags   96  test结果为0
;不知道windbg输出中这种形式是啥意思  [+0x078 ( 0: 0)]  我猜是启用的bit位  反正应该是跟flag的那些bit位有关
;从windbg的输出来看，40确实是guitheraad的标志位的值，因此这个就是判断是不是gui线程
fffff803`eb4faf00 f7437840000000  test    dword ptr [rbx+78h],40h
;ne不成立  如果是gui线程，那么zf标志位不为0，ne不成立 也就不会使用KeServiceDescriptorTableShadow这个表
fffff803`eb4faf07 4d0f45d3        cmovne  r10,r11
;这他妈到底是在干什么呀  上面那个edi右移和与操作是什么几把玩意
;这里难道是判断eax这个index是不是超出了limit？  嘿嘿，刚才看了一下书上的注释，还真蒙对了哈哈哈哈
;就是判断limit的 rdi+10h就是limit在KSERVICE_TABLE_DESCRIPTOR结构体中的偏移量
;上面的操作中，eax只剩下低位置的12个有效bit位   是不是说系统调用的index最高也不会超过2的12次方-1
; 不过这个rdi的操作我就有点看不太懂了  右移7bit再取第6位是他妈的什么意思  如果eax不超过2的12次方-1
;那rdi最后的结果肯定就是0  _KSERVICE_TABLE_DESCRIPTOR结构体的前两个成员每个占用8字节，那么第三个成员的偏移量
; 就是10h，也就是limit
;现在想一想的话，rdi只有一个作用，那就是越过非GUI的_KSERVICE_TABLE_DESCRIPTOR，指向GUI的_KSERVICE_TABLE_DESCRIPTOR   如果rdi有值，那也只能是0x20  不过我不知道为什么GUI线程需要跳过0x30字节才能到达limit
; 按理来讲只需要跳过8+8+4+8+8 = 0x24字节就到limit了，这多出来的12字节不知道填充到哪里了  可能书中给的
; _KSERVICE_TABLE_DESCRIPTOR的定义并不是完整的
;刚才调试了一下，发现nt!KeServiceDescriptorTableShadow+10h+0x20确实是limit
;；kd> dd /c 1 rdi+r10+10h L1
;fffff803`943d6970  000003da
;而且eax的值是11a3 ，在和0xfff与完之后，最高有效位的1被丢掉了，这可能是GUI syscall的特殊计算规则
fffff803`eb4faf0b 423b441710      cmp     eax,dword ptr [rdi+r10+10h]
;超过了就退出了，这里我们肯定是没有超过，所以继续往下看
fffff803`eb4faf10 0f83f2020000    jae     nt!KiSystemServiceExit+0x1ad (fffff803`eb4fb208)  Branch

nt!KiSystemServiceRepeat+0x24:
;现在r10已经指向了kiservicetable数组，里面全都是函数的地址或者偏移量
;而且如果rdi=0x20，那也就说明了_KSERVICE_TABLE_DESCRIPTOR结构体的大小应该是0x20字节
;第一个成员是8字节的函数数组地址
fffff803`eb4faf16 4e8b1417        mov     r10,qword ptr [rdi+r10]
;一个地址占用4个字节，这和之前说的那个32位整数的解码操作吻合
;如果目标操作数位数比源操作数位数要多，那么就进行符号位扩充  符号位扩充，之前已经讲过了  https://blog.csdn.net/ma_de_hao_mei_le/article/details/126025473?spm=1001.2014.3001.5501
fffff803`eb4faf1a 4d631c82        movsxd  r11,dword ptr [r10+rax*4]
;现在r11就是未解码的那个数字，存到rax中先
fffff803`eb4faf1e 498bc3          mov     rax,r11
; sar和shr唯一的区别就是前者保留了符号位，如果一开始的数字的最高位是1，那么sar之后最高位依然是1而不是0
fffff803`eb4faf21 49c1fb04        sar     r11,4
;r10是数组的基地址  r11解码完成，和数组基址相加得到真正的函数地址
fffff803`eb4faf25 4d03d3          add     r10,r11
;这里edi是0，jne跳  edi要么是0要么是20h，所以这里只要不是GDI系统调用就会跳到KiSystemServiceGdiTebAccess
fffff803`eb4faf28 83ff20          cmp     edi,20h
fffff803`eb4faf2b 7553            jne     nt!KiSystemServiceGdiTebAccess+0x4c (fffff803`eb4faf80)  Branch

nt!KiSystemServiceRepeat+0x3b:
;而对于gui调用，还需要进行一些处理
;kd> dt nt!_KTHREAD fffffa801a7bd580   fffffa801a7bd580就是rbx

;   +0x0f0 Teb              : 0x000007f6`20fd7000 Void
fffff803`eb4faf2d 4c8b9bf0000000  mov     r11,qword ptr [rbx+0F0h]
;没有关于Teb定义的东西 类型直接是void
;kd> dd /c 1 0x000007f6`20fd7000+1740
;000007f6`20fd8740  00000000

fffff803`eb4faf34 4183bb4017000000 cmp     dword ptr [r11+1740h],0
;je正常跳转  和非GUI系统调用到达同一处代码
fffff803`eb4faf3c 7442            je      nt!KiSystemServiceGdiTebAccess+0x4c (fffff803`eb4faf80)  Branch

nt!KiSystemServiceGdiTebAccess+0xa:
fffff803`eb4faf3e 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4faf42 48894db8        mov     qword ptr [rbp-48h],rcx
fffff803`eb4faf46 488955c0        mov     qword ptr [rbp-40h],rdx
fffff803`eb4faf4a 498bd8          mov     rbx,r8
fffff803`eb4faf4d 498bf9          mov     rdi,r9
fffff803`eb4faf50 498bf2          mov     rsi,r10
fffff803`eb4faf53 48c7c107000000  mov     rcx,7
fffff803`eb4faf5a 4833d2          xor     rdx,rdx
fffff803`eb4faf5d 4d33c0          xor     r8,r8
fffff803`eb4faf60 4d33c9          xor     r9,r9
fffff803`eb4faf63 e8b8293f00      call    nt!PsInvokeWin32Callout (fffff803`eb8ed920)
fffff803`eb4faf68 488b45b0        mov     rax,qword ptr [rbp-50h]
fffff803`eb4faf6c 488b4db8        mov     rcx,qword ptr [rbp-48h]
fffff803`eb4faf70 488b55c0        mov     rdx,qword ptr [rbp-40h]
fffff803`eb4faf74 4c8bc3          mov     r8,rbx
fffff803`eb4faf77 4c8bcf          mov     r9,rdi
fffff803`eb4faf7a 4c8bd6          mov     r10,rsi
fffff803`eb4faf7d 0f1f00          nop     dword ptr [rax]

nt!KiSystemServiceGdiTebAccess+0x4c:
;eax是之前保存的未解码的那个值，和0xf与操作获得需要使用栈传递的参数个数（最后四位）
fffff803`eb4faf80 83e00f          and     eax,0Fh
;eax如果是0的话，就跳到  nt!KiSystemServiceCopyEnd (fffff803`eb4fb040)  
;不过eax怎么会是0呢，还有这种情况的嘛？
fffff803`eb4faf83 0f84b7000000    je      nt!KiSystemServiceCopyEnd (fffff803`eb4fb040)  Branch

nt!KiSystemServiceGdiTebAccess+0x55:
;eax右移3bit，本来就只剩4bit，现在只有原来4bit的最高位了，要么是0要么是1，
;也就是说只要eax《8就肯定是0了
fffff803`eb4faf89 c1e003          shl     eax,3
;又给rsp减去70h
fffff803`eb4faf8c 488d642490      lea     rsp,[rsp-70h]
fffff803`eb4faf91 488d7c2418      lea     rdi,[rsp+18h]
;rbp是在很上面的地方由rsp进行初始化的，是一个局部变量的地址 lea     rbp,[rsp+80h]
;现在再加100h 已经超出局部变量的范围了 吵了 sub     rsp,158h  超了-0x28  我有点不太知道这个0x28
;应该指向谁了  需要测试一下 push 33h到底占用栈几个字节
; 测过了，在64位中，push一个数字，不管这个数字本身有多大，都会占用8个字节的栈空间
;测试项目：https://github.com/wqreytuk/x64_ASM    
;算了一下，+28h的话，应该会指向最前面的指令中，压栈的gs:[10h]的值，实际调试测试一下去
;确实如此，不过真的有必要通过栈来获取吗，gs:[10]这个地方的值也没有被改变过呀，直接用不行吗
;这个值是用户空间的rsp值
fffff803`eb4faf96 488bb500010000  mov     rsi,qword ptr [rbp+100h]
;用户栈加20h是要干啥
fffff803`eb4faf9d 488d7620        lea     rsi,[rsi+20h]
;rbp+f0也超出了在局部变量的范围 +18h   33h   取出来一个字节就是33   肯定不相等  我不知道这个33是啥  书上也没写
fffff803`eb4fafa1 f685f000000001  test    byte ptr [rbp+0F0h],1
fffff803`eb4fafa8 7416            je      nt!KiSystemServiceGdiTebAccess+0x8c (fffff803`eb4fafc0)  Branch

nt!KiSystemServiceGdiTebAccess+0x76:
; 这个MmUserProbeAddress又是什么东西
;如果rsi大于等于这个值，就把这个值给rsi   当前rsi小于这个值
fffff803`eb4fafaa 483b354fc02d00  cmp     rsi,qword ptr [nt!MmUserProbeAddress (fffff803`eb7d7000)]
fffff803`eb4fafb1 480f433547c02d00 cmovae  rsi,qword ptr [nt!MmUserProbeAddress (fffff803`eb7d7000)]
;nop后面加一个操作数是为了内存对齐，可以看到nop指令后面的指令地址为16字节对齐的，结尾为0
fffff803`eb4fafb9 0f1f8000000000  nop     dword ptr [rax]

nt!KiSystemServiceGdiTebAccess+0x8c:
fffff803`eb4fafc0 4c8d1d79000000  lea     r11,[nt!KiSystemServiceCopyEnd (fffff803`eb4fb040)]
;rax是使用栈传递的参数个数，r11我不太知道是个什么东西
fffff803`eb4fafc7 4c2bd8          sub     r11,rax
;靠，直接跳走了，就没了，我去看看书去   不对，还在这个函数里面，因为r11本身就还在这个函数里面，减去一个很小的rax还在这里面
;nt!KiSystemServiceCopyStart+0x68:   不对。copystart就不在这里面了   不对  就是给nt!KiSystemServiceCopyEnd函数往前剪了rax
; 此处就是8字节  正好是两条指令
;rsi是用户栈+20h或者nt!MmUserProbeAddress  rdi是rsp+18h  是一个局部变量，现在用来存放
;rax，注意这个时候的rax被修改了  变成了用户空间栈中的一个值  相当于用户栈+28h  这个值是啥我不太清楚
;windbg看了一下是0
;fffff800`6cc98038 488b4608        mov     rax,qword ptr [rsi+8]
;fffff800`6cc9803c 48894708        mov     qword ptr [rdi+8],rax
fffff803`eb4fafca 41ffe3          jmp     r11

nt!KiSystemServiceCopyEnd:
;不知道这个是干啥的   这个符号windbg找不到 PerfGlobalGroupMask
fffff803`eb4fb040 f7053ec02d0040000000 test dword ptr [nt!PerfGlobalGroupMask+0x8 (fffff803`eb7d7088)],40h
fffff803`eb4fb04a 0f8556020000    jne     nt!KiSystemServiceExit+0x24b (fffff803`eb4fb2a6)  Branch

nt!KiSystemServiceCopyEnd+0x10:
;这里调用了真正的处理函数
fffff803`eb4fb050 41ffd2          call    r10

nt!KiSystemServiceCopyEnd+0x13:
fffff803`eb4fb053 65ff0425382e0000 inc     dword ptr gs:[2E38h]

nt!KiSystemServiceExit:
fffff803`eb4fb05b 488b9dc0000000  mov     rbx,qword ptr [rbp+0C0h]
fffff803`eb4fb062 488bbdc8000000  mov     rdi,qword ptr [rbp+0C8h]
fffff803`eb4fb069 488bb5d0000000  mov     rsi,qword ptr [rbp+0D0h]
fffff803`eb4fb070 654c8b1c2588010000 mov   r11,qword ptr gs:[188h]
fffff803`eb4fb079 f685f000000001  test    byte ptr [rbp+0F0h],1
fffff803`eb4fb080 0f8455010000    je      nt!KiSystemServiceExit+0x180 (fffff803`eb4fb1db)  Branch

nt!KiSystemServiceExit+0x2b:
fffff803`eb4fb086 440f20c1        mov     rcx,cr8
fffff803`eb4fb08a 410a8b42020000  or      cl,byte ptr [r11+242h]
fffff803`eb4fb091 410b8be4010000  or      ecx,dword ptr [r11+1E4h]
fffff803`eb4fb098 0f85d4010000    jne     nt!KiSystemServiceExit+0x217 (fffff803`eb4fb272)  Branch

nt!KiSystemServiceExit+0x43:
fffff803`eb4fb09e fa              cli
fffff803`eb4fb09f 65488b0c2588010000 mov   rcx,qword ptr gs:[188h]
fffff803`eb4fb0a8 80b9c200000000  cmp     byte ptr [rcx+0C2h],0
fffff803`eb4fb0af 7457            je      nt!KiSystemServiceExit+0xad (fffff803`eb4fb108)  Branch

nt!KiSystemServiceExit+0x56:
fffff803`eb4fb0b1 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4fb0b5 33c0            xor     eax,eax
fffff803`eb4fb0b7 488945b8        mov     qword ptr [rbp-48h],rax
fffff803`eb4fb0bb 488945c0        mov     qword ptr [rbp-40h],rax
fffff803`eb4fb0bf 488945c8        mov     qword ptr [rbp-38h],rax
fffff803`eb4fb0c3 488945d0        mov     qword ptr [rbp-30h],rax
fffff803`eb4fb0c7 488945d8        mov     qword ptr [rbp-28h],rax
fffff803`eb4fb0cb 488945e0        mov     qword ptr [rbp-20h],rax
fffff803`eb4fb0cf 660fefc0        pxor    xmm0,xmm0
fffff803`eb4fb0d3 0f2945f0        movaps  xmmword ptr [rbp-10h],xmm0
fffff803`eb4fb0d7 0f294500        movaps  xmmword ptr [rbp],xmm0
fffff803`eb4fb0db 0f294510        movaps  xmmword ptr [rbp+10h],xmm0
fffff803`eb4fb0df 0f294520        movaps  xmmword ptr [rbp+20h],xmm0
fffff803`eb4fb0e3 0f294530        movaps  xmmword ptr [rbp+30h],xmm0
fffff803`eb4fb0e7 0f294540        movaps  xmmword ptr [rbp+40h],xmm0
fffff803`eb4fb0eb b901000000      mov     ecx,1
fffff803`eb4fb0f0 440f22c1        mov     cr8,rcx
fffff803`eb4fb0f4 fb              sti
fffff803`eb4fb0f5 e8c6310600      call    nt!KiInitiateUserApc (fffff803`eb55e2c0)
fffff803`eb4fb0fa fa              cli
fffff803`eb4fb0fb b900000000      mov     ecx,0
fffff803`eb4fb100 440f22c1        mov     cr8,rcx
fffff803`eb4fb104 488b45b0        mov     rax,qword ptr [rbp-50h]

nt!KiSystemServiceExit+0xad:
fffff803`eb4fb108 65488b0c2588010000 mov   rcx,qword ptr gs:[188h]
fffff803`eb4fb111 f70100000140    test    dword ptr [rcx],40010000h
fffff803`eb4fb117 742e            je      nt!KiSystemServiceExit+0xec (fffff803`eb4fb147)  Branch

nt!KiSystemServiceExit+0xbe:
fffff803`eb4fb119 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4fb11d f6410201        test    byte ptr [rcx+2],1
fffff803`eb4fb121 740e            je      nt!KiSystemServiceExit+0xd6 (fffff803`eb4fb131)  Branch

nt!KiSystemServiceExit+0xc8:
fffff803`eb4fb123 e834d40f00      call    nt!KiCopyCounters (fffff803`eb5f855c)
fffff803`eb4fb128 65488b0c2588010000 mov   rcx,qword ptr gs:[188h]

nt!KiSystemServiceExit+0xd6:
fffff803`eb4fb131 f6410340        test    byte ptr [rcx+3],40h
fffff803`eb4fb135 740c            je      nt!KiSystemServiceExit+0xe8 (fffff803`eb4fb143)  Branch

nt!KiSystemServiceExit+0xdc:
fffff803`eb4fb137 488d6580        lea     rsp,[rbp-80h]
fffff803`eb4fb13b 4833c9          xor     rcx,rcx
fffff803`eb4fb13e e87d0d0000      call    nt!KiUmsExit (fffff803`eb4fbec0)

nt!KiSystemServiceExit+0xe8:
fffff803`eb4fb143 488b45b0        mov     rax,qword ptr [rbp-50h]

nt!KiSystemServiceExit+0xec:
fffff803`eb4fb147 0fae55ac        ldmxcsr dword ptr [rbp-54h]
fffff803`eb4fb14b 4d33d2          xor     r10,r10
fffff803`eb4fb14e 6683bd8000000000 cmp     word ptr [rbp+80h],0
fffff803`eb4fb156 7441            je      nt!KiSystemServiceExit+0x13e (fffff803`eb4fb199)  Branch

nt!KiSystemServiceExit+0xfd:
fffff803`eb4fb158 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4fb15c e84f130000      call    nt!KiRestoreDebugRegisterState (fffff803`eb4fc4b0)
fffff803`eb4fb161 65488b042588010000 mov   rax,qword ptr gs:[188h]
fffff803`eb4fb16a 488b80b8000000  mov     rax,qword ptr [rax+0B8h]
fffff803`eb4fb171 488b80c0020000  mov     rax,qword ptr [rax+2C0h]
fffff803`eb4fb178 480bc0          or      rax,rax
fffff803`eb4fb17b 7418            je      nt!KiSystemServiceExit+0x13a (fffff803`eb4fb195)  Branch

nt!KiSystemServiceExit+0x122:
fffff803`eb4fb17d 6683bdf000000033 cmp     word ptr [rbp+0F0h],33h
fffff803`eb4fb185 750e            jne     nt!KiSystemServiceExit+0x13a (fffff803`eb4fb195)  Branch

nt!KiSystemServiceExit+0x12c:
fffff803`eb4fb187 4c8b95e8000000  mov     r10,qword ptr [rbp+0E8h]
fffff803`eb4fb18e 488985e8000000  mov     qword ptr [rbp+0E8h],rax

nt!KiSystemServiceExit+0x13a:
fffff803`eb4fb195 488b45b0        mov     rax,qword ptr [rbp-50h]

nt!KiSystemServiceExit+0x13e:
fffff803`eb4fb199 4c8b8500010000  mov     r8,qword ptr [rbp+100h]
fffff803`eb4fb1a0 4c8b8dd8000000  mov     r9,qword ptr [rbp+0D8h]
fffff803`eb4fb1a7 33d2            xor     edx,edx
fffff803`eb4fb1a9 660fefc0        pxor    xmm0,xmm0
fffff803`eb4fb1ad 660fefc9        pxor    xmm1,xmm1
fffff803`eb4fb1b1 660fefd2        pxor    xmm2,xmm2
fffff803`eb4fb1b5 660fefdb        pxor    xmm3,xmm3
fffff803`eb4fb1b9 660fefe4        pxor    xmm4,xmm4
fffff803`eb4fb1bd 660fefed        pxor    xmm5,xmm5
fffff803`eb4fb1c1 488b8de8000000  mov     rcx,qword ptr [rbp+0E8h]
fffff803`eb4fb1c8 4c8b9df8000000  mov     r11,qword ptr [rbp+0F8h]
fffff803`eb4fb1cf 498be9          mov     rbp,r9
fffff803`eb4fb1d2 498be0          mov     rsp,r8
fffff803`eb4fb1d5 0f01f8          swapgs
fffff803`eb4fb1d8 480f07          sysretq

nt!KiSystemServiceExit+0x180:
fffff803`eb4fb1db 488b95b8000000  mov     rdx,qword ptr [rbp+0B8h]
fffff803`eb4fb1e2 49899390000000  mov     qword ptr [r11+90h],rdx
fffff803`eb4fb1e9 8a55a8          mov     dl,byte ptr [rbp-58h]
fffff803`eb4fb1ec 41889332020000  mov     byte ptr [r11+232h],dl
fffff803`eb4fb1f3 fa              cli
fffff803`eb4fb1f4 488be5          mov     rsp,rbp
fffff803`eb4fb1f7 488badd8000000  mov     rbp,qword ptr [rbp+0D8h]
fffff803`eb4fb1fe 488ba42400010000 mov     rsp,qword ptr [rsp+100h]
fffff803`eb4fb206 fb              sti
fffff803`eb4fb207 c3              ret

nt!KiSystemServiceExit+0x1ad:
fffff803`eb4fb208 83ff20          cmp     edi,20h
fffff803`eb4fb20b 755b            jne     nt!KiSystemServiceExit+0x20d (fffff803`eb4fb268)  Branch

nt!KiSystemServiceExit+0x1b2:
fffff803`eb4fb20d 894580          mov     dword ptr [rbp-80h],eax
fffff803`eb4fb210 48894d88        mov     qword ptr [rbp-78h],rcx
fffff803`eb4fb214 48895590        mov     qword ptr [rbp-70h],rdx
fffff803`eb4fb218 4c894598        mov     qword ptr [rbp-68h],r8
fffff803`eb4fb21c 4c894da0        mov     qword ptr [rbp-60h],r9
fffff803`eb4fb220 e8eb4f0000      call    nt!KiConvertToGuiThread (fffff803`eb500210)
fffff803`eb4fb225 0bc0            or      eax,eax
fffff803`eb4fb227 8b4580          mov     eax,dword ptr [rbp-80h]
fffff803`eb4fb22a 488b4d88        mov     rcx,qword ptr [rbp-78h]
fffff803`eb4fb22e 488b5590        mov     rdx,qword ptr [rbp-70h]
fffff803`eb4fb232 4c8b4598        mov     r8,qword ptr [rbp-68h]
fffff803`eb4fb236 4c8b4da0        mov     r9,qword ptr [rbp-60h]
fffff803`eb4fb23a 4889a390000000  mov     qword ptr [rbx+90h],rsp
fffff803`eb4fb241 0f84abfcffff    je      nt!KiSystemServiceRepeat (fffff803`eb4faef2)  Branch

nt!KiSystemServiceExit+0x1ec:
fffff803`eb4fb247 488d3d12c72d00  lea     rdi,[nt!KeServiceDescriptorTableShadow+0x20 (fffff803`eb7d7960)]
fffff803`eb4fb24e 8b7710          mov     esi,dword ptr [rdi+10h]
fffff803`eb4fb251 488b3f          mov     rdi,qword ptr [rdi]
fffff803`eb4fb254 3bc6            cmp     eax,esi
fffff803`eb4fb256 7310            jae     nt!KiSystemServiceExit+0x20d (fffff803`eb4fb268)  Branch

nt!KiSystemServiceExit+0x1fd:
fffff803`eb4fb258 488d3cb7        lea     rdi,[rdi+rsi*4]
fffff803`eb4fb25c 0fbe0438        movsx   eax,byte ptr [rax+rdi]
fffff803`eb4fb260 0bc0            or      eax,eax
fffff803`eb4fb262 0f8ef3fdffff    jle     nt!KiSystemServiceExit (fffff803`eb4fb05b)  Branch

nt!KiSystemServiceExit+0x20d:
fffff803`eb4fb268 b81c0000c0      mov     eax,0C000001Ch
fffff803`eb4fb26d e9e9fdffff      jmp     nt!KiSystemServiceExit (fffff803`eb4fb05b)  Branch

nt!KiSystemServiceExit+0x217:
fffff803`eb4fb272 b94a000000      mov     ecx,4Ah
fffff803`eb4fb277 4533c9          xor     r9d,r9d
fffff803`eb4fb27a 450f20c0        mov     r8,cr8
fffff803`eb4fb27e 450bc0          or      r8d,r8d
fffff803`eb4fb281 7514            jne     nt!KiSystemServiceExit+0x23c (fffff803`eb4fb297)  Branch

nt!KiSystemServiceExit+0x228:
fffff803`eb4fb283 b901000000      mov     ecx,1
fffff803`eb4fb288 450fb68342020000 movzx   r8d,byte ptr [r11+242h]
fffff803`eb4fb290 458b8be4010000  mov     r9d,dword ptr [r11+1E4h]

nt!KiSystemServiceExit+0x23c:
fffff803`eb4fb297 488b95e8000000  mov     rdx,qword ptr [rbp+0E8h]
fffff803`eb4fb29e 4c8bd5          mov     r10,rbp
fffff803`eb4fb2a1 e85a000000      call    nt!KiBugCheckDispatch (fffff803`eb4fb300)

nt!KiSystemServiceExit+0x24b:
fffff803`eb4fb2a6 4883ec50        sub     rsp,50h
fffff803`eb4fb2aa 48894c2420      mov     qword ptr [rsp+20h],rcx
fffff803`eb4fb2af 4889542428      mov     qword ptr [rsp+28h],rdx
fffff803`eb4fb2b4 4c89442430      mov     qword ptr [rsp+30h],r8
fffff803`eb4fb2b9 4c894c2438      mov     qword ptr [rsp+38h],r9
fffff803`eb4fb2be 4c89542440      mov     qword ptr [rsp+40h],r10
fffff803`eb4fb2c3 498bca          mov     rcx,r10
fffff803`eb4fb2c6 e811071400      call    nt!PerfInfoLogSysCallEntry (fffff803`eb63b9dc)
fffff803`eb4fb2cb 488b4c2420      mov     rcx,qword ptr [rsp+20h]
fffff803`eb4fb2d0 488b542428      mov     rdx,qword ptr [rsp+28h]
fffff803`eb4fb2d5 4c8b442430      mov     r8,qword ptr [rsp+30h]
fffff803`eb4fb2da 4c8b4c2438      mov     r9,qword ptr [rsp+38h]
fffff803`eb4fb2df 4c8b542440      mov     r10,qword ptr [rsp+40h]
fffff803`eb4fb2e4 4883c450        add     rsp,50h
fffff803`eb4fb2e8 41ffd2          call    r10
fffff803`eb4fb2eb 488945b0        mov     qword ptr [rbp-50h],rax
fffff803`eb4fb2ef 488bc8          mov     rcx,rax
fffff803`eb4fb2f2 e881061400      call    nt!PerfInfoLogSysCallExit (fffff803`eb63b978)
fffff803`eb4fb2f7 488b45b0        mov     rax,qword ptr [rbp-50h]
fffff803`eb4fb2fb e953fdffff      jmp     nt!KiSystemServiceCopyEnd+0x13 (fffff803`eb4fb053)  Branch


  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值