[007][x86匯編語(yǔ)言]各個(gè)數(shù)位的顯示 條件轉(zhuǎn)移指令(搭配cmp)Bochs命令:n 样悟、u 隙弛、info eflags

學(xué)習(xí)筆記

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》
http://www.reibang.com/p/d481cb547e9f

c06_mbr.asm

         ;代碼清單6-1
         ;文件名:c06_mbr.asm
         ;文件說(shuō)明:硬盤(pán)主引導(dǎo)扇區(qū)代碼
         ;創(chuàng)建日期: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                  ;設(shè)置數(shù)據(jù)段基地址 
         mov ds,ax
         
         mov ax,0xb800                 ;設(shè)置附加段基地址 
         mov es,ax
         
         cld
         mov si,mytext                 
         mov di,0
         mov cx,(number-mytext)/2      ;實(shí)際上等于 13
         rep movsw
     
         ;得到標(biāo)號(hào)所代表的偏移地址
         mov ax,number
         
         ;計(jì)算各個(gè)數(shù)位
         mov bx,ax
         mov cx,5                      ;循環(huán)次數(shù) 
         mov si,10                     ;除數(shù) 
  digit: 
         xor dx,dx
         div si
         mov [bx],dl                   ;保存數(shù)位
         inc bx 
         loop digit
         
         ;顯示各個(gè)數(shù)位
         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

運(yùn)行測(cè)試

c06_mbr.asm

代碼說(shuō)明

  • 邏輯地址0x0000:0x7c00
對(duì)應(yīng)的物理地址是 0x07c00
該地址又是段0x07c0的起始地址
等價(jià)的邏輯地址是 0x07c0:0x0000
------------------------------------------
mov ax,0x07c0                  ;設(shè)置數(shù)據(jù)段基地址 
mov ds,ax
  • 批量復(fù)制
源數(shù)據(jù) ds:si
目的地址 es:di

按字節(jié)傳遞 movsb
按字傳遞 movsw

正向傳遞 cld 低地址到高地址 DF = 0
反向傳遞 std 高地址到低地址 DF = 1

指令前綴 rep (repeat) :CX不為零則重復(fù)

批量復(fù)制
--------------------------------
   cld
         mov si,mytext                 
         mov di,0
         mov cx,(number-mytext)/2      ;實(shí)際上等于 13
         rep movsw
--------------------------------
  • Intel 8086 : [BX] [SI] [DI] [BP]
BX (Base Address Register)基址寄存器
SI (Source Index)源索引寄存器
DI  (Destination Index)目標(biāo)索引寄存器

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


AX (Accumulator)累加器
CX(Counter)計(jì)數(shù)器
DX( Data)數(shù)據(jù)寄存器
  • inc 指令
inc al
inc byte [bx]
inc word [label_a]
  • div 指令
dividnd dw 0x3f0  ;被除數(shù)
divisor db 0x3f  ; 除數(shù)
...

mov ax,[dividnd]
div byte [divisor]
  • cbw(convert byte to word)、cwd (convert word to double word)
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 cbw cwd

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第84頁(yè)

  • 無(wú)符號(hào)數(shù)與有符號(hào)數(shù) 范圍
無(wú)符號(hào)數(shù)
8位      0~255
16位 0~65535
32位 0~4294967295

有符號(hào)數(shù)
8位      -128~-1 0~127
16位 -32768~-1 0~32767

  • 無(wú)符號(hào)數(shù)除法 div 喧伞、有符號(hào)數(shù)除法 idiv
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》有符號(hào)數(shù)除法 idiv

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第86頁(yè)

  • 現(xiàn)有指令對(duì)標(biāo)志位的影響
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 現(xiàn)有指令對(duì)標(biāo)志位的影響

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第90頁(yè)

  • jns show 條件轉(zhuǎn)移指令
如果未設(shè)置符號(hào)位SF走芋,則轉(zhuǎn)移到標(biāo)號(hào) show 所在的位置處執(zhí)行;
有符號(hào)位 SF(sign flag)
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 jns show 條件轉(zhuǎn)移指令

當(dāng)顯示完最后一個(gè)數(shù)位后潘鲫,SI的內(nèi)容是零翁逞,執(zhí)行dec si指令后,由于產(chǎn)生了借位次舌,實(shí)際的運(yùn)算結(jié)果是0xffff(SI只能容納16個(gè)比特)熄攘,因其最高位是“1”,故處理器將標(biāo)志位SF置為“1”彼念,表明當(dāng)前SI中的結(jié)果可以理解為一個(gè)負(fù)數(shù)(-1)。于是浅萧,指向jns show時(shí)逐沙,條件不滿(mǎn)足,接著執(zhí)行后面指令洼畅。
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第88頁(yè)

  • 各種比較結(jié)果和相應(yīng)的條件轉(zhuǎn)移指令
《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》條件轉(zhuǎn)移指令

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第90頁(yè)

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 表6-1 各種比較結(jié)果和相應(yīng)的條件轉(zhuǎn)移指令

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第91頁(yè)

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 表6-1 各種比較結(jié)果和相應(yīng)的條件轉(zhuǎn)移指令(續(xù)表)

《x86匯編語(yǔ)言:從實(shí)模式到保護(hù)模式》 第92頁(yè)

  • $$$
 jmp near $
等價(jià)于
infi: jmp near infi

$ 是當(dāng)前行的匯編地址
-------------------------------------

$$ 是NASM匯編器提供的另一個(gè)標(biāo)記吩案,代表當(dāng)前匯編節(jié)(段)的起始匯編地址
--------------------------------------
 times 510-($-$$) db 0
                   db 0x55,0xaa
主引導(dǎo)扇區(qū)512個(gè)字節(jié),要求最后兩個(gè)字節(jié)分別是 0x55,0xaa帝簇,多余部分用零填充

Bochs 調(diào)試

  • 調(diào)試命令
n 命令 越過(guò)循環(huán)體
可以越過(guò)rep 徘郭、loop循環(huán)

u 命令 反匯編:根據(jù)機(jī)器指令生成可讀的匯編語(yǔ)言指令
u/2 指定反匯編的條數(shù)為2

info eflags 查看標(biāo)志寄存器:小寫(xiě)說(shuō)明標(biāo)志位0、大寫(xiě)為1
info eflags 查看標(biāo)志寄存器:小寫(xiě)說(shuō)明標(biāo)志位0丧肴、大寫(xiě)為1
檢測(cè)點(diǎn)6.5 使用反匯編命令定位到第53行jmp near $.png
  • 調(diào)試過(guò)程記錄
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][匯編語(yǔ)言]flag標(biāo)志寄存器

http://www.reibang.com/p/f694df2da5b4

  • [052][匯編語(yǔ)言]檢測(cè)點(diǎn)11.2(有符號(hào)數(shù)運(yùn)算判斷溢出OF的具體做法)

http://www.reibang.com/p/bf51348d18d4

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末残揉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子芋浮,更是在濱河造成了極大的恐慌抱环,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,681評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異镇草,居然都是意外死亡眶痰,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)梯啤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)竖伯,“玉大人,你說(shuō)我怎么就攤上這事因宇∏玻” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,421評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵羽嫡,是天一觀(guān)的道長(zhǎng)本姥。 經(jīng)常有香客問(wèn)我,道長(zhǎng)杭棵,這世上最難降的妖魔是什么婚惫? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,114評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮魂爪,結(jié)果婚禮上先舷,老公的妹妹穿的比我還像新娘。我一直安慰自己滓侍,他們只是感情好蒋川,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,116評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著撩笆,像睡著了一般捺球。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上夕冲,一...
    開(kāi)封第一講書(shū)人閱讀 52,713評(píng)論 1 312
  • 那天氮兵,我揣著相機(jī)與錄音,去河邊找鬼歹鱼。 笑死泣栈,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的弥姻。 我是一名探鬼主播南片,決...
    沈念sama閱讀 41,170評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼庭敦!你這毒婦竟也來(lái)了疼进?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 40,116評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤螺捐,失蹤者是張志新(化名)和其女友劉穎颠悬,沒(méi)想到半個(gè)月后矮燎,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,651評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赔癌,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,714評(píng)論 3 342
  • 正文 我和宋清朗相戀三年诞外,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灾票。...
    茶點(diǎn)故事閱讀 40,865評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡峡谊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出刊苍,到底是詐尸還是另有隱情既们,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布正什,位于F島的核電站啥纸,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏婴氮。R本人自食惡果不足惜斯棒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,211評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望主经。 院中可真熱鬧荣暮,春花似錦、人聲如沸罩驻。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,699評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)惠遏。三九已至砾跃,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間爽哎,已是汗流浹背蜓席。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,814評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留课锌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,299評(píng)論 3 379
  • 正文 我出身青樓祈秕,卻偏偏與公主長(zhǎng)得像渺贤,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子请毛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,870評(píng)論 2 361