www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀]COMET虛擬機的設計與實現

1  引言

虛擬機就是一臺假想的機器。一臺虛擬機與一臺真實存在的計算機不同之處在于前者只是一個技術規(guī)范。虛擬機技術從很早就開始研究,并且在軟件技術中廣為應用。目前,高度可移植的JAVA編程語言采用的就是虛擬機技術。虛擬機不僅有廣泛的商業(yè)應用價值,同時也可作為一種很好的教學輔助工具。通過虛擬機,學生可以很好地學習理解計算機的結構和工作原理。因此,設計并實現一個簡單的虛擬機有很好的教學意義[4,5]。

COMET虛擬機開始只是作為CASL匯編語言的運行平臺而設計,并由中國計算機軟件專業(yè)技術資格和水平考試大綱中給出的CASL匯編語言文本定義(下文將簡稱為文本)。作者在文本的基礎上,對COMET虛擬機的功能進行了一定的改進和擴充,并實現了一個功能完善的虛擬機實例[1]。

2  COMET虛擬機設計 2.1 邏輯結構

圖1 COMET虛擬機結構

COMET虛擬機是一臺基于寄存器模型結構的計算機。COMET虛擬機系統(tǒng)主要包括三個部分:中央處理器(CPU)、存儲器和出入輸出設備。COMET計算機的邏輯結構如圖1所示。

CPU是由寄存器、算術邏輯部件和控制邏輯組成。寄存器在程序運行時存儲計算過程的各種信息;算術邏輯部件的功能是進行所有的算術和邏輯運算。由于COMET計算機是虛擬的計算機,因此,它的控制邏輯對于我們是透明的[1,4,5]。

2.2 寄存器

COMET虛擬機有5個通用寄存器GR(16位),一個指令計數器PC(16位)和一個標志寄存器FR(2位)。

GR(通用寄存器) 5個通用寄存器的編號為0、1、2、3、4,分別記為GR0、GR1、GR2、GR3、GR4。這些通用寄存器用于算術、邏輯、移位等運算,其中GR1、GR2、GR3、GR4通用寄存器兼做變址寄存器。另外,GR4還兼做棧指針(SP)用,棧指針是存放棧頂地址用的寄存器。

PC(指令計數器) 在執(zhí)行指令的過程中,PC中存放著正在執(zhí)行的指令的第一個字的地址。當指令執(zhí)行結束時,一般是把PC的內容加上當前指令的長度(不同指令的長度不同),只有在執(zhí)行轉移指令且條件成立時,才將轉移指令地址置入PC中。

FR(標志寄存器) 在ADD、SUB、MUL、DIV、MOD、AND、OR、EOR、CPA、CPL、SLA、SRA、SLL、SRL、LEA等指令執(zhí)行結束時,根據執(zhí)行的結果,將FR設置成00、01或10(大于、等于、小于或負數、零、正數)。它們不會因其他指令的執(zhí)行而改變。

2.3 存儲器

COMET虛擬機是一臺16位的定點計算機,主存儲器的基本存儲單位是字,總容量為65536(216=16k)字,各個字的地址按照0000-FFFF(十六進制)編號。一個字的16位二進制采用從左到右次序編號,如圖2所示。

圖2 字節(jié)順序

COMET虛擬機可以處理三種數據,即字符數據、帶符號整數、地址數據。字符數據采用16位的Unicode字符;帶符號整數采用二進制補碼表示,可表示的數值范圍為[-215,215-1];地址數據為無符號的整數,范圍是[0,216-1]。

在實現的COMET虛擬機中,內存的高1k字保留用于各種專用的外設寄存器[1,3]。

2.4 指令系統(tǒng)

COMET虛擬機和文本相比,新增加了HALT、MUL、SUB、MOD四條指令。下面只給出HALT、MUL、SUB、MOD四條指令的說明,其他的指令可以參考文本。

HALT指令執(zhí)行停機操作,占一個字長。MUL指令執(zhí)行乘法操作,操作規(guī)則和ADD等指令相似,占2個字長。SUB指令執(zhí)行除法操作,操作規(guī)則和ADD指令相似,占2個字長。MOD指令執(zhí)行取模操作,操作規(guī)則和ADD指令相似,占2個字長。

2.5 指令格式

COMET虛擬機機器指令一般包含三種信息:OP,GR,XR,ADR。其中OP為機器指令的編號,對應第一個字的[0-7]位;GR為通用寄存器編號,對應第一個字中的[8-11]位;XR為變址寄存器編號,對應第一個字的[12-15]位,[12-15]位為0表示沒有變址(GR0不能作為變址寄存器);ADR為操作數,對應地二個字的[0-15]位。如果一個指令不含某種信息(例如,沒有ADR),則忽律該字段。OP、GR、XR、ADR的存儲細節(jié)如圖3所示。

圖3 指令格式

根據指令操作數據的類型的不同,可將COMET虛擬機的機器指令分為四種:寄存器-存儲器型,存儲器型,寄存器型,空操作數型。如果一個COMET虛擬機指令不涉及主存儲器操作(無ADR),則為1個字長,其他均為2個字長。

2.6 字節(jié)碼格式

字節(jié)碼文件是COMET虛擬機的可執(zhí)行文件。在啟動虛擬機時,由命令行中的參數給出字節(jié)碼文件名。字節(jié)碼文件含有程序的長度、裝載位置、程序指令等信息。虛擬機依據這些信息,將字節(jié)碼中的指令從二級存儲器裝載到相應的虛擬機內存。這一系列操作和操作系統(tǒng)的程序加載器的工作情況類似[4]。

COMET虛擬機的字節(jié)碼文件是一種二進制格式文件,格式如圖4所示。

圖4 字節(jié)碼結構

其中addr為字節(jié)碼在虛擬機內存的裝載地址,len為字節(jié)碼中指令的個數(不包含len和addr),ins1、ins2、…、insn為要載入虛擬機的指令。

2.7 輸入輸出設備

文本中并沒有明確定義COMET虛擬機的輸入輸出設備,只是給出IN、OUT幾個IO操作宏指令。在這里,我們采用將外部設備寄存器在內存中統(tǒng)一編址的方法來處理輸入和輸出設備[1,3]。

COMET虛擬機默認的I/O設備是鍵盤和顯示器。利用操作系統(tǒng)提供的從定向功能用戶也可以將它們重新定向到其他的設備。

COMET虛擬機輸入輸出設備的兩個專用寄存器為:IO_ADDR、IO_FLAG,分別對應0xFD100、xFD10地址內存。IO_ADDR用于保存要傳輸數據的內存地址;IO_FLAG為IO設備的標志位,其8-15位是要傳輸數據的個數(0表示無IO),7位表示輸入或輸出(1表示輸入,0為輸出),6位在出現IO錯誤時設置,3-5位為傳輸的類型(有字符、八進制、十進制、十六進制等),0-2位保留。[!--empirenews.page--]

2.8  調試器

COMET調試器是一個內嵌在虛擬機里的機器級的調試器。當需要調試一個COMET虛擬機的程序時,只需要在啟動COMET虛擬機的時給出相應的命令參數就啟動調試功能了[2,4]。

COMET調試器的基本功能有:顯示幫助(help),運行程序直到停止(go),分步執(zhí)行(step n),跳轉程序(jump),顯示寄存器內容(regs),顯示內存數據(dMem),顯示內存指令(iMem),修改內存數據(alter),遍歷指令(trace),指令記數功能(print),重新裝載字節(jié)碼(clear),退出調試器(quit)。每個調試命令的具體用法可以參考COMET虛擬機的幫助文件。

3  COMET虛擬機實現 3.1 虛擬機數據結構

struct comet

{

off_t pc;

short fr;

short gr[5];

short mem[MEMSIZE];

} cmt;

虛擬機結構變量cmt是一個全局變量,成員分別為:指令計數器(pc)、標志寄存器(fr)、通用寄存器(gr)、存儲器(mem)。將cmt設計為全局變量的優(yōu)點是個函數不用傳遞復雜的結構體參數,缺點是每個進程同時只能有一個虛擬機實例。

3.2 主函數

int

main(int argc, char *argv[])

{

init(argc, argv);

if(debug) comet_debug();

else while(comet_step());

fclose(source);

return 0;

}

函數init首先初始化COMET虛擬機并裝載字節(jié)碼,如果發(fā)生錯誤則停止。然后根據調試器狀態(tài),選擇運行虛擬機的方式。如果調試開關(debug)被設置,則調用comet_debug函數在調試狀態(tài)下運行COMET虛擬機。如果沒有打開調試開關,則循環(huán)調用單步執(zhí)行函數comet_step,直到程序結束[1,2]。

3.3 字節(jié)碼載入

void

comet_load(void)

{

unsigned short n, flag[2];

fseek(source, 0, SEEK_SET);

n = fread(flag,

sizeof(off_t), 2, source);

n = fread(&cmt.mem[flag[0]],

sizeof(off_t),tmp[1],source);

/* 其他處理代碼 */

}

變量n用于記錄讀取字節(jié)碼的數目,如果n小于相應的值,則發(fā)生字節(jié)碼裝載錯誤。變量flag用于保存字節(jié)碼裝載信息,分別字節(jié)碼裝載地址和字節(jié)碼大小。

COMET字節(jié)碼設計比較簡單,也存在很多不足。例如,沒有標志文件格式的魔數,沒有更完善的錯誤檢測措施。我們的目的是讓讀者了解字節(jié)碼的工作原理,因此只給出了一種最簡單的實現[1,2,4]。

3.4 指令解析

指令的解析一般包含這個幾個過程:取指令,解碼,執(zhí)行。其中解碼對虛擬機的執(zhí)行效率有很大的影響[5]。這里采用下標索引技術來解碼指令。具體代碼如下:

void comet_ld(void);    /* LD指令*/

void comet_ld(void);    /*ST指令 */

void comet_ld(void);    /* LEA指令 */

/* 其他指令函數聲明 */

int comet_step(void)

{

static void (*comet_op)() = {

comet_ld, comet_st, comet_lea,

/* 其他指令執(zhí)行函數指針 */

};

/* 解析指令,存放在op中 */

short op = get_op();

/* 執(zhí)行op對應的代碼 */

(*comet_op [op])();

/* 返回執(zhí)行狀態(tài) */

return val;

}

例如,有指令LEA,其對應的機器碼為031,那么將通過函數指針數組comet_op直接定位到(*comet_op[031])函數,即并執(zhí)行相應的comet_lea函數。

3.5 輸入輸出設備

COMET虛擬機在解析每個指令前,先讀取IO設備狀態(tài)寄存器IO_FLAG中的值,如果IO_FLAG被設置,則執(zhí)行相應的IO操作[3]。具體代碼如下:

void

comet_io(void)

{

switch(cmt.mem[IO_FLAG]&IO_TYPE)

{

case IO_NULL:

/* 無IO操作 */

case IO_OCT & IO_IN:

/* 八進制輸入 */

case IO_DEC & IO_IN:

/* 十進制輸入 */

case IO_HEX & IO_IN:

/* 十六進制輸入 */

case IO_OCT & IO_OUT:

/* 八進制輸出 */

case IO_DEC & IO_OUT:

/* 十進制輸出 */

case IO_HEX & IO_OUT:

/* 十六進制輸出 */

default:

/* 未知IO類型 */

}

/* 重置IO狀態(tài)寄存器IO_FLAG */

}

3.6 調試器

調試程序是建立和單步執(zhí)行的COMET虛擬機之上的。當沒有打開調試功能時,循環(huán)執(zhí)行COMET虛擬機字節(jié)碼程序,直到停止。當打開了調試功能時,調試函數debug根據調試命令,執(zhí)行相應步的指令、顯示或操作相關的數據。

/* 各種調試命令 */

typedef enum

{

GO, STEP, JUMP, REGS,

IMEM, DMEM, ALTER,

TRACE, PRINT, CLEAR,

HELP, QUIT

} DbType;

/* 調試函數 */

void

comet_debug(void)

{

int cmd;     /* 保存調試命令 */

while(1) {

/* 讀調試命令 */

switch(cmd) {

case HELP: /* 幫助文件 */

case GO  : /* 執(zhí)行程序 */

case STEP: /* 分步執(zhí)行 */

/* 其他調試命令 */

default  : /* 未知命令 */

}

}

}

調試函數comet_debug根據不同的調試命令執(zhí)行相應的操作,并顯示虛擬機狀當前的狀態(tài)信息。

4  運行虛擬機

下面通過一個求(1 + 2 + … + n)的程序,來介紹其在COMET虛擬機上的執(zhí)行的流程。程序的字節(jié)碼由相關的工具生成,保存為sum.comet文件(后綴為comet)。

4.1 普通運行

輸入命令:comet sum

在COMET虛擬機獲得sum參數后,會自動識別為sum.comet字節(jié)碼文件。

輸入100,表示求1+2+…+100的和。

COMET虛擬機輸出:

===============

COMET虛擬計算機[!--empirenews.page--]

===============

100

5050[root@knuth /root]#

表示1+2+…+100等于5050,結果正確。

4.2 調試運行

輸入命令:comet –d sum

===============

COMET虛擬計算機

===============

調試 (幫助輸入 help)...

輸入命令: t

指令顯示功能打開

輸入命令: p

指令計數功能打開

輸入命令: r

顯示寄存器數據

GR[0] =    0    PC =    0

GR[1] =    0    SP = fc00

GR[2] =    0    FR =   01

GR[3] =    0

輸入命令: d

顯示內存數據

mem[0   ] = 1200

輸入命令: i

顯示內存指令

mem[0]: JMP  5

輸入命令:g

mem[0]: JMP  5

mem[5]: ST   GR0, fe00

mem[7]: PUSH fe00

mem[9]: LEA  GR0, 4

mem[b]: ST   GR0, fd10

mem[d]: LEA  GR0, c01

mem[f]: ST   GR0, fd11

mem[11]: POP  GR0

3

mem[12]: LD   GR0, 4

mem[14]: ST   GR0, 2

……

6mem[4f]: JMP 51

mem[51]: HALT

執(zhí)行指令數目 = 71

輸入命令: q

退出調試...

其中t、p、d、r、g分別是調試命令trace、print、dMem、regs、go的縮寫;3(mem[11  ]的下一行)是用戶輸入的數據,不是調試命令。6(mem[4f  ]行)表示1+2+3的和為6。

COMET虛擬機內嵌的調試器功能非常強大,熟練掌握后對COMET虛擬機的程序開發(fā)會有很大的幫助。調試命令細節(jié)可以通過幫助命令help獲得。

5  結語

本文給出了COMET虛擬機的硬件設計方案。該方案闡述了虛擬機各個基本部分的詳細設計思路及需要注意的問題。目前已經實現了COMET虛擬機、CASL匯編器和TINY編譯器。我們將基于COMET虛擬機開發(fā)一個小型的文件系統(tǒng),使得其應用于實際教學任務[1,4,5]。

參考文獻

[1] CASL匯編語言文本[M].中國計算機軟件專業(yè)技術資格和水平考試大綱

[2] 劉福江,柴樹杉. CASL匯編器的設計與實現[J].計算機與信息技術.2006,7:76-78

[3] (美)Kenneth C. Louden. 編譯原理及實踐[M].北京:機械工業(yè)出版社,2003

[4] (澳)John Lions.萊昂氏UNIX源代碼分析[M].北京:機械工業(yè)出版社,2000

[5] (美)Bill Blunden.虛擬機的設計與實現——C/C++[M].北京:機械工業(yè)出版社,2003

[6] 王亞平,陳甫舟.基于Linux平臺上的BOST虛擬機的硬件設計與實現[J].現代電子技術.2004,15:8-10

更多計算機與外設信息請關注:21ic計算機與外設頻道

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉