PWN-汇编学习笔记

目录

一、汇编和PWN的关系

二、常用知识点

三、windows下搭建debug实验环境


一、汇编和PWN的关系

PWN需要对逆向了解,调试模式中会产生大量的汇编代码解读,需要对汇编有一定的基础。本文基于《汇编语言》第四版 王爽 一书进行一定知识点的提取和总结。

二、常用知识点

8086的CPU通用寄存器均为16位,可以存放两个字节,AX,BX,CX,DX四个寄存器存一般性数据。

PWN-汇编学习笔记_第1张图片

ah:AX高位寄存器 al:AX地位寄存器

字节(byte):8位bit,存在8位寄存器中

字(word):两个字节,16位bit,存于16位通用寄存器中

段寄存器:CS/DS/SS/ES

段寄存器的由来:已知寄存器位数16,而地址总线为20位,要利用16位寄存器来访问20位的地址时,需要进行(16*段寄存器+偏移地址)=地址总线 的方式来进行寻址。

CS与IP寄存器:指示当前CPU要读取的指令地址,CS:代码段寄存器  IP:指令指针寄存器

设CS中为M,IP为N,8086CPU将从Mx16+N读取指令开始执行,也称为:CS:IP指向内容作为指令执行。

指令运行的全过程:

CS:IP通过地址加法器,经过输入输出电路、20位地址总线进入内存找到地址,提取机器指令,返回到指令缓冲器及执行控制器,执行指令后根据指令长度,IP加值长度。

jump指令:jump CS:IP 相当于执行CS:IP的命令

例子:jump 2AE3:3 执行后:CS=2AE3H,IP=0003H,CPU从2AE33H处读取信息

Jump ax 相当于:mov IP,ax,即将某一寄存器里的值赋值给IP

三、windows下搭建debug实验环境

实验工具(配合上述教科书)

PWN-汇编学习笔记_第2张图片

SS:SP指向栈顶元素

栈的push动态过程: 

PWN-汇编学习笔记_第3张图片

栈的pop动态过程:

PWN-汇编学习笔记_第4张图片 POP及PUSH指令:

PWN-汇编学习笔记_第5张图片

 PWN-汇编学习笔记_第6张图片

用例:

PWN-汇编学习笔记_第7张图片

与结束相关的指令:

PWN-汇编学习笔记_第8张图片

类[BX]用法:

 mov ax,[bx]

将bx寄存器中值EA作为偏移量,ds寄存器中作为段地址SA,将SA:EA处数据送入ax中,即:
(ax) = ((ds)*16 + (bx))

PWN-汇编学习笔记_第9张图片

 

 

 

 

 

你可能感兴趣的:(PWN,安全,开发语言,反汇编,pwn)