MOVW 指令
MOVW:將DS:SI的內(nèi)容送至ES:DI,是復(fù)制過去,原來的代碼還在。很多書用了“移”這個字,實(shí)際上是復(fù)制過去。每次復(fù)制.DS:SI ,ES:DI自動加1
Linux內(nèi)核中引導(dǎo)部分一開始有這樣一段代碼:
45 entry start ! 告知連接程序,程序從start 標(biāo)號開始執(zhí)行。
46 start:
47 mov ax,#BOOTSEG ! 將ds 段寄存器置為0x7C0;
48 mov ds,ax
49 mov ax,#INITSEG??? ! 將es 段寄存器置為0x9000;
50 mov es,ax
51 mov cx,#256???????????? ! 移動計(jì)數(shù)值=256 字;
52 sub si,si??????????????????? ! 源地址 ds:si = 0x07C0:0x0000
53 sub di,di??????????????????? ! 目的地址 es:di = 0x9000:0x0000
54 rep????????????????????????????? ! 重復(fù)執(zhí)行,直到cx = 0
55 movw????????????????????????? ! 移動1 個字;
56 jmpi go,INITSEG????? ! 間接跳轉(zhuǎn)。這里INITSEG 指出跳轉(zhuǎn)到的段地址。
57 go: mov ax,cs??????????? ! 將ds、es 和ss 都置成移動后代碼所在的段處(0x9000)。
! 47--56 行作用是將自身(bootsect)從目前段位置0x07c0(31k)
! 移動到0x9000(576k)處,共256 字(512 字節(jié)),然后跳轉(zhuǎn)到
! 移動后代碼的go 標(biāo)號處,也即本程序的下一語句處。
注意,在55行執(zhí)行完畢之后,0x7c00之后的512字節(jié)應(yīng)當(dāng)與0x9000之后的512字節(jié)一模一樣。
然后看56行,這里的go是段內(nèi)偏移,也就是0x39(十進(jìn)制的57),而INITSEG=0x9000,所以執(zhí)行這條語句是跳到0x9000:0x39也就是復(fù)制過去的第57行,這樣代碼就相當(dāng)于在一個程序里繼續(xù)執(zhí)行了。
----------------------------------------------------
REP指令
每次執(zhí)行rep指令,CX減1,然后判斷CX是否等于0,如果不為0則繼續(xù)執(zhí)行rep指令后的串操作指令,直到CX為0,實(shí)現(xiàn)重復(fù)。
----------------------------------------------------
Jmpi指令
段間跳轉(zhuǎn),其Opcode為Eah,其格式為:jmpi Offset,
Segment Selector