(四)标记寄存器

8086 CPU 的标记寄存器有 16 位,其中存储的信息通常被称为程序状态字(PSW),标记寄存器和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义,而标记寄存器是按位起作用的,它的每一位都有专门的含义记录特定的信息,有些指令的执行是影响标记寄存器的,比如 add sub mul div inc or and 等,它们大都是运算指令,在使用一条指令的时候,要注意执行结果对标记寄存器的那些标志位造成影响。
标记寄存器的结构如下:

1、CF 进位标记位

标记寄存器的第 0 位是 CF 进位标记位。一般情况下,在进行无符号数运算的时候,它记录了运算结果的最高有效位向更高位的进位值,或从更高位的借位值。

2、PF 奇偶标记位

标记寄存器的第 2 位是 PF 奇偶标记位,它记录相关指令执行后,其结果的所有 bit 位中 1 的个数是否为偶数,如果 1 的个数为偶数,PF = 1,如果 1 的个数为奇数,PF = 0

3、ZF 零标记位

标记寄存器的第 6 位是 ZF 零标记位,它记录相关指令执行后,其结果是否为 0,如果为 0ZF = 1,如果不为 0ZF = 0

4、SF 符号标记位

标记寄存器的第 7 位是 SF 符号标记位,它记录相关指令执行后,其结果是否为负数,如果为负数,SF = 1,如果非负,SF = 0

5、DF 方向标志位

标记寄存器的 10 位是 DF ,在串处理指令中,控制每次操作后 si di 的增减。

df = 0 每次操作后 si、di 递增
df = 1 每次操作后 si、di 递减
看一下下面的串传送指令
指令:movsb
功能:执行 movsb 指令相当于进行下面几个步骤
(1)((es) 16 + (di))= ((ds) 16 + (si))
(2)如果 df = 0 则:(si)= (si)+ 1
(di)= (di)+ 1

(2)如果 df = 0 则:(si)= (si)- 1
(di)= (di)- 1

由于 df 位决定着串传送指令执行后 sidi 改变的方向,所以 CPU 提供下面两条指令对 df 位进行设置

cld 指令:将标志寄存器的 df 位置 0
stb 指令:将标志寄存器的 df 位置 1

6、OF 溢出标记位

标记寄存器的第 11 位是 OF 溢出标记位,一般情况下,它记录了有符号数运算的结果是否发生了溢出,如果发生溢出,OF = 1,如果没有,OF = 0

7、ADC 指令

adc 是带进位加法指令,它利用了 CF 位上记录的进位值

指令格式:adc 操作对象1,操作对象2
功能:操作对象1 = 操作对象1 + 操作对象2 + CF

8、SBB 指令

sbb 是带借位减法指令,它利用了 CF 位上记录的借位值

指令格式:sbb 操作对象1,操作对象2
功能:操作对象1 = 操作对象1 - 操作对象2 - CF

9、CMP 指令

cmp 是比较指令,cmp 相当于减法指令,只是不保存结果,cmp 指令执行后将对标记寄存器产生影响,其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。

指令格式:cmp 操作对象1,操作对象2
功能:操作对象1 - 操作对象2,但不保存结果,仅仅根据计算结果对标记寄存器进行设置

10、检测比较结果的条件转移指令

常用的根据无符号的比较结果进行转移的条件转移指令
指令 含义 检测的相关标志位
je 等于则跳转 zf = 1
jne 不等于则跳转 zf = 0
jb 低于则跳转 cf = 1
jnb 不低于则跳转 cf = 0
ja 高于则跳转 cf = 0 且 zf = 0
jna 不高于则跳转 cf = 1 且 zf = 1
这些指令比较常用,他们都比较好记忆,第一个字母都是 j ,表示 jump ,后面的字母表示如下含义
含义
e 表示 equel
ne 表示 not equel
b 表示 below
nb 表示 not below
a 表示 above
na 表示 not above

11、pushf 和 popf 指令

pushf 的功能是将标志寄存器的值压栈,而 popf 是从栈中弹出数据,送入标记寄存器中,pushfpopf 为直接访问标志寄存器提供了一直方法。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

  • 8086汇编 本笔记是笔者观看小甲鱼老师(鱼C论坛)《零基础入门学习汇编语言》系列视频的笔记,在此感谢他和像他一样...
    Gibbs基阅读 37,106评论 8 114
  • 计算机通过执行指令序列来使机器得以工作,所以对于每一系列的计算机都有指定的一组指令集供计算机使用,这组指令...
    未来科技工作室阅读 7,861评论 1 10
  • 指令是使计算机执行某种特定操作的二进制编码。8086 CPU指令系统有133条指令,通常分为数据寻址方式和程序寻址...
    刀月水阅读 1,618评论 0 1
  • 我站在孟婆桥两边徘徊,我一直在等、等一个不可能出现的他。.孟婆拿着汤碗向我走来,语气冷淡:“孩子 还是把它喝了吧。...
    我是阿雅1003阅读 607评论 1 5
  • 后来,工作半年,大专文凭也下来了!当小张赶上时代的东风评上小一职称时,那么多比我工作早的前辈因为文凭...
    萌枝阅读 394评论 0 2