汇编原理(二)寄存器——CPU工作原理

寄存器:所有寄存器都是16位(0-15),可以存放两个字节

AX,BX,CX,DX存放一般性数据,称为通用寄存器

AX的逻辑结构。最大存放的数据为2的16次方减1。可分为AH和AL,兼容8位寄存器。

:1word = 2Byte。二进制和八进制、十六进制的转化(0000)-(0)。

汇编指令

不区分大小写

"越位"会"丢弃":"丢弃"只是指禁止为不能在8位的寄存器中保存,但是cpu不是真的丢弃这个进位值。

物理地址:内存单元有地址,所有的内存单元构成的储存空间是一个一维的线性空间

16位的cpu:运算器一次最多可以处理16位的数据;寄存器的最大宽度位16位;寄存器与运算器之间的通路是16位。(64位同理)

地址加法器: 物理地址(20位) = 段地址(16位) × 16 + 加偏移地址(16位 )

  1. cpu可以用不同的段地址和物理地址形成同一个物理地址

2.仅通过变化偏移地址来进行寻址,最多可以定位0 - FFFFH,64K个内存单元。 (不太明白各种量度之间的转换)

3.格式:短地址XXXX:偏移地址YYYY。意思是在短地址XXXX的基础上,乘16,加上偏移地址,之间用冒号隔开。

比喻:

:并不是内存被划分位一个一个段,是自己怎么看

一个段的起始地址一定是16的倍数,因为"段地址×16";偏移地址为16位,所以一个段的最大长度为16位

段寄存器:用来存储段地址(CS、DS、SS、ES等)

CS(存放段地址)和IP(存放偏移地址):最关键的寄存器,指示当前CPU要读取指令的地址:CS是代码段寄存器,IP是指令指针寄存器

用CS作为寄存器,代码将会被当作指令,其他三种寄存器则不然,有可能当作数据或其他。

IP怎么知道他每次移动多少?比如说怎么知道从20000到20003?整个工作原理过程还不是很懂

修改CS、IP的指令:传送指令mov不能修改CS、IP的内容,而应该用转移指令jmp。

指令:jmp 段地址:偏移地址。含义:用指令中给出的段地址修改CS,偏移地址修改IP

指令:jmp 某一合法寄存器。含义:仅修改IP的内容,类似于:jmp IP, ax

举例:如果不跳转,IP每次加2或者3。但如果遇到例如 jmp bx,IP变为0,跳转回去。

流程如下:死循环

代码段:将长度为N(<64KB)的一组代码段,存在一组地址连续、起始地址为16的倍数的内存单元中,这段内存是用来存放代码的,从而定义了一个代码段。

怎么看这个代码段的长度、存储在那一段内存单元、段地址

要将CS:IP指向,所定义的代码段中的第一条指令的首地址

debug调试程序:(后面还需要学)

r:查看、改变CPU寄存器的内容。

d:查看内存中的内容

e:改写内存中的内容(使用机器指令?)

a:以汇编指令的格式在内存中写入一条机器指令 u:将机器指令翻译为湖

相关推荐
鸽芷咕2 天前
DOSBox 汇编环境搭建完整教程:安装配置 + MASM/LINK/DEBUG 工具链配置详解
汇编
Gofarlic_OMS3 天前
UG/NX许可证管理高频技术问题解答汇编
java·大数据·运维·服务器·汇编·人工智能
iCxhust3 天前
如何在汇编中修改CS:IP
汇编·单片机·嵌入式硬件·51单片机·微机原理
枷锁—sha3 天前
【CTFshow-pwn系列】03_栈溢出【pwn 073】详解:静态编译下的自动化 ROP 链构建
网络·汇编·笔记·安全·网络安全·自动化
wechatbot8885 天前
极客互动企业微信聚合聊天与接口能力全景展示
汇编·微信·企业微信·ipad
枷锁—sha5 天前
【CTFshow-pwn系列】03_栈溢出【pwn 072】详解:无字符串环境下的多级 Ret2Syscall 与 BSS 段注入
服务器·网络·汇编·笔记·安全·网络安全
iCxhust8 天前
8088汇编测试程序 (MASM/TASM) — 显示 “HELLO 8088!“ + “LCD1602 OK“
汇编·单片机·嵌入式硬件·51单片机·微机原理
lhbian8 天前
AI编程革命:Codex让脚本开发提速10倍
开发语言·汇编·jvm·c#
wechatbot88810 天前
企业微信全场景消息发送接口开发实现及接口调用
java·汇编·微信·企业微信
wechatbot88810 天前
企业微信 iPad 协议接口全功能开发实战
汇编·人工智能·ios·微信·企业微信·ipad