标志寄存器-神秘的第十四个寄存器flag
axbxcxdx sidi bpspip csssdses flag 按位起作用
特殊之处 OF(overflow)1:ov ; 0:nv -溢出
DF (direction) 1DN 0UP 方向
SF sign符号 ng pl 1 negative 0positive
ZF zero零值 zr / nz zero / notzero
PF Parity奇偶数 1pe 0 po odd/even
CF carry进位
直接访问flag的方法pushf popf
ZF 结果是零的话 寄存器就zf=1; 很多如add sub mul都会影响zf
PF parityflag - 记录指令执行后结果的所有二进制位中1的个数
1的个数为偶数个 pf=1
SF - 结果看作有符号数 结果为负数sf=1;
见机行事 看作正数负数
CF 进位标志 CF=1 有进位或借位----针对无符号数
对比CF–针对无符号数;OF-针对有符号数
综合 一条指令可以带来多少标志寄存器的变化
带进位的加法指令adc用cf位记录进位值 adc ax,bx-------就这个机制 -感觉别扭 但是往后看大数相加 合理
adc指令应用 大数相加---------分组-低十六位-高十六位 ;地位产生的进位通过adc解决了!
128位数相加
特别注意:思考!
不可以!!!还有个目的是cf清零
不可以!!! inc di不会影响flag 而add di2 会影响
sbb—带借位减法指令 sbb ax bx
cmp比较指令 cmp 操作对象1,操作对象2-------二者相减结果不保存----------指令执行后将对flag产生影响—以此确定比较结果
无符号数 例如 相等:zf=1 ; 不等于 zf=0 ;小于:cf = 0;
条件转移指令 jxxx标号-----套路je:jump equal 结果相等跳转
条件转移指令的使用—直接考虑cmp和jxxx指令配合出来的逻辑含义就可以了----------例如:cmp ah,bh je sadd ah,bh jmp short ok
条件转移指令的应用–本质 转移–修改ip; 和cmp配合使用cmp改变标志位
双分支结构的实现—对比c语言
统计8的数量
DF方向标志位和段传送—
原本方法:mov ax ,【si】 mov【di】,ax add si,2 add di,2
更简洁方法
DF=0:每次操作后si di 递增
在串处理指令中,控制每次操作后si di的增减 ; 对DF位进行设置的指令:cld df=0;std df=1;
rep指令 —根据cx重复执行后面的指令-------常常与串传送指令搭配 rep movsb
中断—导学------精华
移位指令
逻辑左移:影响cf 和cf一起左移 补零 循环左移 影响cf 但是后面也得加上移出去的那个数 算数左移
shl sal rcl
惯常用法:逻辑左移乘法
显示的原理—屏幕的内容=显存中的数据
显示缓冲区 每个两个字节,一行八十个-----一行160字节
显示想显示的东西 不同颜色
标号
改进
改进:标号法a: db 1,2,3,4 ; 然后 用这个数据 就直接 mov si ,offset a ; 随后 做各种操作就直接cs:【si】
更加改进: 去掉:的数据标号 adb 1,2,3,4,后面就直接 mov si,0 ;然后直接操作 a【si】像数组一样
a db 1,2,3,4,5,6,7,8; b dw 0 其中 b代表地址为code:8,长度为字的内存单元—还表明了长度!
常用方式 数据段中用数据标号
注意:a db 1,2,3,4,5,…---------a相当于保存开始的地址—也就是指针; c dw offset a,offset b; c还是指针,相当于指针的指针;
数据的直接定址表----最简方案 查表 做成一个表 直接要啥给啥
利用表 在两个数据集合之间建立一种映射关系
定址表 – 空间换时间
代码的直接定址表—
中断-内(INT)-外(键盘等)
0: 除法错误div除法溢出;1:单步 4:into 溢出中断; n INT指令 下面举例
13,10表示回车换行; $结束符号
int 21h中断—然后看ax里面,ax里面是ah是9,执行九号操作 去显示那个ds:dx–然后是里面是显示helloworld
hello world的写法
cpu接到中断信息 去执行中断处理程序–需要改变cs:ip------根据中断信息去找中断处理程序-----查中断向量表
8086cpu的中断向量表—找cs:ip
案例 0号中断
中断过程—cpu硬件自动完成,用终端类型码找到中断向量,并用它设置cs:ip80
8086CPU中断过程1.从中断中获取中断类型码2.标志寄存器的值入栈----中断过程重要改变标志寄存器的值,需要先行保护。3设置标志寄存器的第八位tf和第九位if的值为0.4cs内容入栈5ip内容入栈6从中断向量表中读取中断处理程序的入口地址,设置cs:ip
编制中断处理程序----常驻内存
自己编织中断处理程序–除法错误为例
do0子程序–自己制作
把自己的程序安装到内存里面 再把这个地址写道中断向量表
用内存复制的那个程序指令----从si 复制到 di----串传送-----长度–offset do0end-offset do0
设置中断向量表 就是把内存那个地方改一下数值
小结!!!
常驻内存程序编制-----套路-----由自己安装到内存的指定区域的代码和数据
如果是haike呢–她骗人安装他的程序,然后运行。他的程序把自己的脏东西串传送到内存某个地方,然后触发中断,让自己的脏东西获得cpu运行,然后就可以显示自己的东西了。或者简单点,别人运行他的程序,他就直接开始干活了,脏东西挥洒了
单步中断–寄存器flag—TF trap flag ,tf=1每条指令执行后产生陷阱,由系统控制计算机,当tf=0,cpu正常工作,不产生陷阱
if interrupt flag 当if=1,允许cpu相应可屏蔽中断请求,if=0关闭中断
中断不响应情况
原因–设置ss:sp强制要求连续完成 以此保证栈的准确正确
int n引发中断
疑问 什么时候if tf恢复?
@
int指令调动子程序,此子程序就是中断处理程序简称 中断例程 ------可以自定义中断例程来实现特定功能
具体7ch 存在0000:7ch*4这个地方
中断例程 参数:放在ax里面可以
出入栈 操作一一对应,执行irep返回的时候意义出栈
中断例程2
bios 和 dos中断处理
bios–在系统版的rom存放–容量8KB,地址从FE000H开始
BIOS要做硬件系统的检测和初始化工作,外部中断和内部终端的中断例程也在里面 对于硬件设备进行io的中断例程,还有和其他硬件操作的中断例程 里面都有---------ddr3八脚直接式BIOS芯片
bios 如此好 解放了大量程序员工作 不去理解底层
BIOS-比如显示内容 必须要算 推算了解显示的内存区域在哪里
bios的10h中断,(ah)=2调用第十号h终端的2耗子程序没设置光标位置
(ah)=9 调用10h中断的9号子程序 在光标位置显示字符
bios调用两个中断完成 显示高亮闪烁a
直接BIOS终端手册-----例子
汇编还有DOS中断–强大
小结-bios,dos中断
程序返回 int 21H DOS中断例程----其实就是mov ax,4c00h int 21h
显示高亮a 方便的 dos中断例程!!牛逼
Bios和dos中断例程的安装过程
端口的读写–声音为例: out in 等指令
in al 61h 这条指令为例实际上就是控制 设备控制器(61h)
注意 端口-------就是外部设备
cpu可以访问三种东西,十四个寄存器,内存单元,端口—就—外部设备-------各种网卡 显卡。。主板上的接口芯片。
各种芯片都有寄存器,由cpu读写
cpu把各个寄存器当作端口统一编制,某几个地址对应一个设备
端口读写就用in out来操作
端口的读写,cpu地址线选中芯片寄存器,cpu发出控制线的读命令,然后通过数据线送进cpu数据
精彩!
IO端口分配–共
in out只能用ax或者al来存放端口读入数据或者发送的数据
# CMOS RAM芯片—包含一个实时钟(电子表)和一个128个存储单元的ram存储器------这个128B的ram里面存内部实时钟 系统配置信息,相关的程序(用于开机时配置系统信息)
这块ram靠电池供电 不丢失信息—芯片由70h 71h端口读写-------70h提供地址 71提供数据
提取CMOS RAM存储的时间信息