色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 嵌入式FORTH虛擬計(jì)算機(jī)的實(shí)現(xiàn)

          嵌入式FORTH虛擬計(jì)算機(jī)的實(shí)現(xiàn)

          作者: 時(shí)間:2013-12-17 來源:網(wǎng)絡(luò) 收藏

          本文引用地址:http://cafeforensic.com/article/256992.htm

          1.引言

          虛擬機(jī)最初是美國(guó)計(jì)算機(jī)科學(xué)家波佩克(Popek)與戈德堡(Gerald)在虛擬化需求中給出了定義,專指有效的、孤立的真實(shí)計(jì)算機(jī)的副本,現(xiàn)在則指可像真實(shí)計(jì)算機(jī)一樣運(yùn)行程序的軟件實(shí)現(xiàn),包括跟任何真實(shí)計(jì)算機(jī)無關(guān)的虛擬機(jī)。根據(jù)運(yùn)用和與機(jī)器的相關(guān)性可分為系統(tǒng)虛擬機(jī)和程序虛擬機(jī),一個(gè)提供了完整的操作系統(tǒng),另一個(gè)則以運(yùn)行單個(gè)計(jì)算機(jī)程序?yàn)橹鳌?/p>


          應(yīng)用領(lǐng)域,系統(tǒng)相關(guān)的CPU芯片和微計(jì)算機(jī)硬件系統(tǒng)種類繁多,并且不斷推陳出新,甚至多核處理器已被普遍采用。但是在新平臺(tái)上,難以針對(duì)每一種芯片或平臺(tái)制定一種計(jì)算機(jī)語言來編程。解決的方法一是可采用公共計(jì)算機(jī)語言,用不同的編譯器來生成機(jī)器碼,但該方法需要具有該語言的編譯器,在新平臺(tái)上往往難以具備。另一種方法即建立一個(gè)虛擬機(jī),然后用一個(gè)計(jì)算機(jī)語言,用一個(gè)解釋器來解釋執(zhí)行。采用該方法,難點(diǎn)在于虛擬機(jī)的構(gòu)建,要能夠適應(yīng)多種環(huán)境、快速構(gòu)建、可擴(kuò)展。


          是一種與眾不同的計(jì)算機(jī)程序設(shè)計(jì)語言。它具有極強(qiáng)的擴(kuò)展性,通過字的定義,可實(shí)現(xiàn)不斷堆疊和擴(kuò)展。同時(shí),它又具有極好的交互性,指令可解釋執(zhí)行,這就為應(yīng)用的調(diào)試帶來了極大的便捷。本文基于語言,以自主構(gòu)建的JLP虛擬平臺(tái)為例,詳細(xì)闡述FORTH虛擬機(jī)的實(shí)現(xiàn)原理和核心實(shí)現(xiàn)方法,模擬和實(shí)現(xiàn)了通用的交互式計(jì)算機(jī)結(jié)構(gòu),實(shí)現(xiàn)了真實(shí)計(jì)算機(jī)的典型工作流程[4],并且一改過去FORTH代碼和數(shù)據(jù)混合存儲(chǔ)的方式,在內(nèi)存的存儲(chǔ)上以分段的方式將內(nèi)存分為CS、VS、DS、SS四個(gè)段,分別存儲(chǔ)指令和數(shù)據(jù),這樣,就實(shí)現(xiàn)了系統(tǒng)指令和用戶數(shù)據(jù)的分離,有效地提高了代碼和系統(tǒng)的安全性,并且調(diào)試方便、擴(kuò)展性強(qiáng),尤其適合應(yīng)用于對(duì)安全性、兼容性、移植性、擴(kuò)展性、交互性要求高的嵌入式系統(tǒng)領(lǐng)域。

          2.FORTH虛擬機(jī)實(shí)現(xiàn)原理


          真實(shí)計(jì)算機(jī)的基本工作原理是存儲(chǔ)和控制。計(jì)算機(jī)在控制器的指揮下,取出預(yù)先存儲(chǔ)的指令序列(即程序)和數(shù)據(jù),通過控制器譯碼,按指令的要求,取出數(shù)據(jù)完成運(yùn)算,再把結(jié)果重新存儲(chǔ)起來,如此循環(huán),直至完成全部指令。對(duì)真實(shí)計(jì)算機(jī)來說,這個(gè)過程依托中央處理器CPU來實(shí)現(xiàn),CPU包括運(yùn)算器、控制器和寄存器。如果描述CPU核心工作過程,主要包括以下步驟:


          (1)提取程序計(jì)數(shù)器值,該值指向的地址即指令地址;


          (2)從該地址取出指令;


          (3)程序計(jì)數(shù)器增加指令長(zhǎng)度,即指向下一條指令地址;


          (4)解碼執(zhí)行指令;


          (5)返回結(jié)果。


          由于FORTH虛擬機(jī)是工作在真實(shí)計(jì)算機(jī)上的,因此要實(shí)現(xiàn)FORTH虛擬機(jī)必須用對(duì)應(yīng)關(guān)系依托真實(shí)計(jì)算機(jī)的代碼來實(shí)現(xiàn)這個(gè)核心過程。


          在FORTH虛擬機(jī)中,用核心算法--NEXT模擬了這個(gè)過程,將虛擬機(jī)指令和真實(shí)計(jì)算機(jī)指令實(shí)現(xiàn)對(duì)應(yīng),通過建立字典表,設(shè)置地址跳轉(zhuǎn),以串線碼的方式將虛擬機(jī)命令字和直接機(jī)器指令實(shí)現(xiàn)對(duì)應(yīng),依托真實(shí)計(jì)算機(jī)指令完成了CPU的處理過程。如圖1所示。


          具體過程是:在FORTH定義字時(shí)創(chuàng)建鏈結(jié)構(gòu)的字典表,在其中存儲(chǔ)各個(gè)字的名稱、長(zhǎng)度、狀態(tài)、指令碼以及鏈接指針。例如定義FORTH字S:S DUP *;在字典表存放了各個(gè)FORTH高級(jí)字的名稱和代碼執(zhí)行地址,其中也有S字的定義,在S字的代碼場(chǎng)中存有S字的代碼執(zhí)行地址,該代碼執(zhí)行地址與code所描述的直接機(jī)器執(zhí)行代碼相對(duì)應(yīng),構(gòu)成間接串線編碼。當(dāng)執(zhí)行該指令時(shí),首先查找字典表,找到S定義后,取出其WPF指令碼中存放的地址,然后跳轉(zhuǎn)到代碼場(chǎng)該地址中,由于是FORTH高級(jí)字定義,所以首先執(zhí)行“:”機(jī)器碼將程序計(jì)數(shù)器所記錄的下一條指令返回地址壓入棧,然后跳轉(zhuǎn)到參數(shù)場(chǎng)地址依序執(zhí)行,直到最后的“;”返回指令執(zhí)行后,再將原先存入棧的返回地址彈出,這樣即完成一條指令的執(zhí)行。其中,代碼場(chǎng)和參數(shù)場(chǎng)分別存儲(chǔ)指令和參數(shù)。以下以JLP FORTH虛擬機(jī)為例,詳細(xì)描述其字典表、代碼場(chǎng)、參數(shù)場(chǎng)的定義、虛擬機(jī)存儲(chǔ)和指針的分配,以及核心算法。

          linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

          上一頁 1 2 3 下一頁

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉