學(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)志寄存器
- [052][匯編語(yǔ)言]檢測(cè)點(diǎn)11.2(有符號(hào)數(shù)運(yùn)算判斷溢出OF的具體做法)