指令的执行过程
data:image/s3,"s3://crabby-images/4c489/4c489e9b04b60555679bc8b70c0eda7d78fb8c3e" alt=""
1.png
data:image/s3,"s3://crabby-images/cbf1a/cbf1aec51010bc5ac551c1ea37971f395b48f637" alt=""
2.png
data:image/s3,"s3://crabby-images/fc235/fc2352856be9e3298f33dfd3ca5217eff2ce2147" alt=""
3.png
data:image/s3,"s3://crabby-images/269c7/269c7bea386ac053b2216a37fb068d2ee1abb67d" alt=""
4.png
data:image/s3,"s3://crabby-images/a9a35/a9a35dc5788964977fcc97cdf38570ecc9a274a7" alt=""
5.png
data:image/s3,"s3://crabby-images/36ae9/36ae9cdeb0d62b86817ad1180ce84659b58921ff" alt=""
6.png
data:image/s3,"s3://crabby-images/e9c49/e9c49c0605e6634f8caed298fad29b21df8b83e2" alt=""
7.png
data:image/s3,"s3://crabby-images/bf10c/bf10cd60cd60eeaab5d8beac2e1dbc67df411043" alt=""
8.png
data:image/s3,"s3://crabby-images/64707/64707f5cff214aa3f314c942f35da1b88db1c8e5" alt=""
9.png
data:image/s3,"s3://crabby-images/a0fc1/a0fc1d705f2d802f5dd43b85ae9244938133c340" alt=""
10.png
data:image/s3,"s3://crabby-images/352c7/352c7d7b09a27372e5727d5f0bc441db0a24e657" alt=""
11.png
data:image/s3,"s3://crabby-images/bd6d3/bd6d3cd7d8babe3195db4ab22ce403ca6fc5d756" alt=""
12.png
data:image/s3,"s3://crabby-images/42234/422347b67e41cb183cdd37aa6b663d3e10df69b4" alt=""
13.png
data:image/s3,"s3://crabby-images/b9816/b981616169db3eeb16fed057a29a04b7c419f6e4" alt=""
14.png
data:image/s3,"s3://crabby-images/63dd8/63dd8a5869961c06143b6d9c7cb9ad668ee8a919" alt=""
总结.png
1.CS 段地址+ IP偏移地址 通过地址加法器,生成20位物理地址,通过20位的地址总线并找到内存对应的代码指令(这是一个寻址的过程)
2.寻址成功后,控制总线通过指令传递给数据总线,并告诉数据总线是读写的操作过程
3.数据总线通过 BIOS(Basic Input Output System)基本输入输出系统,到指令缓冲器,指令缓存器这里存取代码指令中的数据如(B8 23 01
4 指令缓冲器存取ok后到执行控制器,再通过CPU的三大控制器传递到各通用的寄存器(ax,bx,cx,dx)
这里还有个重点,当数据到达指令缓存器的时候,IP=IP+所读取指令的长度,已经开始指向下一条指令,(这在反汇编的过程中,很重要,我们读取的是IP的下一条地址,而不是当前的IP地址)
- 指令和数据
- 在内存或者磁盘上,指令和数据没有任何区别,都是二进制信息
- CPU在工作的时候把有的信息看做指令,有的信息看做数据,为同样的信息赋予了不同的意义
例如:内存中的二进制信息1000100111011000,计算机可以把它看作大小89D8H的数据来处理,也可以将其看作指令mov ax bx来执行
1000100111011000 ->89D8H(数据)
1000100111011000 ->mov ax,bx (程序)
- CPU根据什么将内存中的信息看做指令?
- CPU将CS:IP指向的内存单元的内容看做指令
- 如果内存中的某段内容曾被CPU执行过,那么它所在的内存单元必然被CS:IP指向过
jmp指令
- CPU从何处执行指令是由CS、IP中的内容决定的,我们可以通过改变CS、IP的内容来控制CPU执行目标指令
- 8086提供了一个mov指令(传送指令),可以用来修改大部分寄存器的值,比如
mov ax,10、mov bx,20、mov cx,30、mov dx,40
- 但是,mov指令不能用于设置CS、IP的值,8086没有提供这样的功能
- 8086提供了另外的指令来修改CS、IP的值,这些指令统称为转移指令,最简单的是jmp指令
data:image/s3,"s3://crabby-images/ab1e3/ab1e34917bd340c55c3b3b181df669883b045758" alt=""
imge.png
data:image/s3,"s3://crabby-images/ab952/ab952b443dc2bd232b9bc82cd5d03a027b6ccb0b" alt=""
imge.png
jmp指令 -- 练习
data:image/s3,"s3://crabby-images/e2b5d/e2b5dc4753c8cf22a2c34ba61ad69a825ba2387e" alt=""
images.png
data:image/s3,"s3://crabby-images/00f89/00f892027ad3105da89270b16ac5cb406dd579c5" alt=""
image.png
data:image/s3,"s3://crabby-images/c72c9/c72c98725b689828bc6a8ede930bbe2fd4a5a5e7" alt=""
image.png
data:image/s3,"s3://crabby-images/f7a64/f7a64891a524391de181dcc9ca858b3de67c111f" alt=""
image.png
代码段
data:image/s3,"s3://crabby-images/88681/886819768d983549d403ed0417dc6435e781a6dd" alt=""
image.png
data:image/s3,"s3://crabby-images/8339b/8339bdcad1aed2fdd63b229037275df0fa36b4e1" alt=""
image.png
data:image/s3,"s3://crabby-images/cc343/cc3438cedc5c1677b98d745bfe2d66d90792ba63" alt=""
image.png
网友评论