[007][x86汇编语言]各个数位的显示 条件转移指令(搭配cmp)Bochs命令:n 、u 、info eflags

学习笔记

《x86汇编语言:从实模式到保护模式》
https://www.jianshu.com/p/d481cb547e9f

c06_mbr.asm

         ;代码清单6-1
         ;文件名:c06_mbr.asm
         ;文件说明:硬盘主引导扇区代码
         ;创建日期:2011-4-12 22:12 
      
         jmp near start
         
  mytext db 'L',0x07,'a',0x07,'b',0x07,'e',0x07,'l',0x07,' ',0x07,'o',0x07,\
            'f',0x07,'f',0x07,'s',0x07,'e',0x07,'t',0x07,':',0x07
  number db 0,0,0,0,0
  
  start:
         mov ax,0x07c0                  ;设置数据段基地址 
         mov ds,ax
         
         mov ax,0xb800                 ;设置附加段基地址 
         mov es,ax
         
         cld
         mov si,mytext                 
         mov di,0
         mov cx,(number-mytext)/2      ;实际上等于 13
         rep movsw
     
         ;得到标号所代表的偏移地址
         mov ax,number
         
         ;计算各个数位
         mov bx,ax
         mov cx,5                      ;循环次数 
         mov si,10                     ;除数 
  digit: 
         xor dx,dx
         div si
         mov [bx],dl                   ;保存数位
         inc bx 
         loop digit
         
         ;显示各个数位
         mov bx,number 
         mov si,4                      
   show:
         mov al,[bx+si]
         add al,0x30
         mov ah,0x04
         mov [es:di],ax
         add di,2
         dec si
         jns show
         
         mov word [es:di],0x0744

         jmp near $

  times 510-($-$$) db 0
                   db 0x55,0xaa

运行测试

c06_mbr.asm

代码说明

  • 逻辑地址0x0000:0x7c00
对应的物理地址是 0x07c00
该地址又是段0x07c0的起始地址
等价的逻辑地址是 0x07c0:0x0000
------------------------------------------
mov ax,0x07c0                  ;设置数据段基地址 
mov ds,ax
  • 批量复制
源数据 ds:si
目的地址 es:di

按字节传递 movsb
按字传递 movsw

正向传递 cld 低地址到高地址 DF = 0
反向传递 std 高地址到低地址 DF = 1

指令前缀 rep (repeat) :CX不为零则重复

批量复制
--------------------------------
   cld
         mov si,mytext                 
         mov di,0
         mov cx,(number-mytext)/2      ;实际上等于 13
         rep movsw
--------------------------------
  • Intel 8086 : [BX] [SI] [DI] [BP]
BX (Base Address Register)基址寄存器
SI (Source Index)源索引寄存器
DI  (Destination Index)目标索引寄存器

[bx+si]
[bx+di]
[bp+si]
[bp+di]


AX (Accumulator)累加器
CX(Counter)计数器
DX( Data)数据寄存器
  • inc 指令
inc al
inc byte [bx]
inc word [label_a]
  • div 指令
dividnd dw 0x3f0  ;被除数
divisor db 0x3f  ; 除数
...

mov ax,[dividnd]
div byte [divisor]
  • cbw(convert byte to word)、cwd (convert word to double word)
《x86汇编语言:从实模式到保护模式》 cbw cwd

《x86汇编语言:从实模式到保护模式》 第84页

  • 无符号数与有符号数 范围
无符号数
8位      0~255
16位 0~65535
32位 0~4294967295

有符号数
8位      -128~-1 0~127
16位 -32768~-1 0~32767

  • 无符号数除法 div 、有符号数除法 idiv
《x86汇编语言:从实模式到保护模式》有符号数除法 idiv

《x86汇编语言:从实模式到保护模式》 第86页

  • 现有指令对标志位的影响
《x86汇编语言:从实模式到保护模式》 现有指令对标志位的影响

《x86汇编语言:从实模式到保护模式》 第90页

  • jns show 条件转移指令
如果未设置符号位SF,则转移到标号 show 所在的位置处执行;
有符号位 SF(sign flag)
《x86汇编语言:从实模式到保护模式》 jns show 条件转移指令

当显示完最后一个数位后,SI的内容是零,执行dec si指令后,由于产生了借位,实际的运算结果是0xffff(SI只能容纳16个比特),因其最高位是“1”,故处理器将标志位SF置为“1”,表明当前SI中的结果可以理解为一个负数(-1)。于是,指向jns show时,条件不满足,接着执行后面指令。
《x86汇编语言:从实模式到保护模式》 第88页

  • 各种比较结果和相应的条件转移指令
《x86汇编语言:从实模式到保护模式》条件转移指令

《x86汇编语言:从实模式到保护模式》 第90页

《x86汇编语言:从实模式到保护模式》 表6-1 各种比较结果和相应的条件转移指令

《x86汇编语言:从实模式到保护模式》 第91页

《x86汇编语言:从实模式到保护模式》 表6-1 各种比较结果和相应的条件转移指令(续表)

《x86汇编语言:从实模式到保护模式》 第92页

  • $$$
 jmp near $
等价于
infi: jmp near infi

$ 是当前行的汇编地址
-------------------------------------

$$ 是NASM汇编器提供的另一个标记,代表当前汇编节(段)的起始汇编地址
--------------------------------------
 times 510-($-$$) db 0
                   db 0x55,0xaa
主引导扇区512个字节,要求最后两个字节分别是 0x55,0xaa,多余部分用零填充

Bochs 调试

  • 调试命令
n 命令 越过循环体
可以越过rep 、loop循环

u 命令 反汇编:根据机器指令生成可读的汇编语言指令
u/2 指定反汇编的条数为2

info eflags 查看标志寄存器:小写说明标志位0、大写为1
info eflags 查看标志寄存器:小写说明标志位0、大写为1
检测点6.5 使用反汇编命令定位到第53行jmp near $.png
  • 调试过程记录
Next at t=0
(0) [0x0000fffffff0] f000:fff0 (unk. ctxt): jmpf 0xf000:e05b          ; ea5be000f0
<bochs:1> s
Next at t=1
(0) [0x0000000fe05b] f000:e05b (unk. ctxt): xor ax, ax                ; 31c0
<bochs:2> b 0x7c00
<bochs:3> c

...

<bochs:30> s
Next at t=17404890
(0) [0x000000007c60] 0000:7c60 (unk. ctxt): jns .-16 (0x00007c52)     ; 79f0
<bochs:31> u/3
00007c60: (                    ): jns .-16                  ; 79f0
00007c62: (                    ): mov word ptr es:[di], 0x0744 ; 26c7054407
00007c67: (                    ): jmp .-3                   ; e9fdff
<bochs:32> b 0x7c67
<bochs:33> c
(0) Breakpoint 2, 0x0000000000007c67 in ?? ()
Next at t=17404920
(0) [0x000000007c67] 0000:7c67 (unk. ctxt): jmp .-3 (0x00007c67)      ; e9fdff
<bochs:34>

参考

  • [050][汇编语言]flag标志寄存器

https://www.jianshu.com/p/f694df2da5b4

  • [052][汇编语言]检测点11.2(有符号数运算判断溢出OF的具体做法)

https://www.jianshu.com/p/bf51348d18d4

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