熟女俱乐部五十路二区av,又爽又黄禁片视频1000免费,国产卡一卡二卡三无线乱码新区,中文无码一区二区不卡αv,中文在线中文a

新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 在 Zynq MPSoC 上運行 DOOM 游戲

在 Zynq MPSoC 上運行 DOOM 游戲

作者: 時間:2016-08-03 來源:電子產(chǎn)品世界 收藏

  最后,一旦處理器進(jìn)入 HYPER 模式,其指令就可以操作 RegisterHyper 和 HyperProgramCounter,而且程序可執(zhí)行 SWITCH-SUPER 和 EXITHYPER。

本文引用地址:http://www.bjwjmy.cn/article/201608/294978.htm

  

 

  圖 2:各種模式如環(huán)形所示

  HYPER 模式還允許處理器讀寫所有虛擬存儲器,0x0000_0000 至 0xFFFF_FFFF,以及讀寫實際物理存儲器。這些特權(quán)等級通常被直觀地用環(huán)形來描述(圖 2)。主環(huán),即 HYPER 環(huán)為特權(quán)等級較低的環(huán)賦予權(quán)限,最終可控制整個系統(tǒng)。

  理論結(jié)合實踐

  ARM® 創(chuàng)建處理器設(shè)計,供 ARM 合作伙伴構(gòu)建芯片用。ARM 處理器包含一個或多個內(nèi)核。每個內(nèi)核實現(xiàn)一個 ARM 架構(gòu)。例如, UltraScale+ 包含一個 ARM Cortex™-A53 處理器及四個 ARMv8-A 物理內(nèi)核(圖 3)。

  當(dāng)查看 ARM 處理器的文檔和代碼時,這種區(qū)別很重要;為了全面理解具有一個 ARM 內(nèi)核的“芯片”,可參考有關(guān)架構(gòu) (如 ARMv8-A) 和處理器 (如 Cortex-A53) 的文檔。ARMv8 架構(gòu)中有四個例外等級 (來源:ARM 架構(gòu)參考手冊,D1-1404):

  1、例外等級 0 (EL0),無需特權(quán)即可執(zhí)行;

  2、例外等級 1 (EL1),執(zhí)行 OS 以及任何執(zhí)行特權(quán)指令的內(nèi)容;

  3、例外等級 2 (EL2),允許硬件被虛擬化;以及

  4、例外等級 3 (EL3),允許在安全與非安全處理器狀態(tài)之間切換。

  以下程序通常在這些模式下運行,如ARM 架構(gòu)參考手冊 (D1–1404)中所述:EL0,應(yīng)用程序;EL1,OS 內(nèi)核以及通常所描述的相關(guān)特權(quán)函數(shù);EL2,管理程序;EL3,安全監(jiān)控器。我們的理論實例直接對應(yīng) ARMv8 執(zhí)行模式 EL0 至 EL2:USER 對應(yīng) EL0,SUPER 對應(yīng) EL1,HYPER 對應(yīng) EL2。ARM 添加第四個特權(quán)等級,即 EL3;利用這個特權(quán)等級,我們可在安全與非安全環(huán)境之間切換 EL0 和 EL1。盡管 EL3 的使用是一個很重要的論題,能夠為架構(gòu)增加大量的功能,但是在本實例中我們將其忽略,并著重介紹 EL0-EL2(利用管理程序的虛擬化)。如果對計算機如何保護(hù)金融交易感興趣,可以參閱 ARMv8 EL3 文檔(免費提供,需注冊)。這是非常好的參考文檔,從中可以獲得極為詳細(xì)的介紹。

  

 

  圖 3: UltraScale+ 架構(gòu)

  進(jìn)入和退出例外模式

  在真實系統(tǒng)中,模式之間的切換比我們的實例更復(fù)雜一些。ARM 總結(jié)了 ARMv8-A 架構(gòu)的行為并在參考手冊中給出。手冊中介紹,只有在接到例外或從例外返回時,才能改變執(zhí)行所處的例外等級。在接到例外時,例外等級只能升高或保持不變;在從例外返回時,例外等級只能降低或保持不變。只有三個指令能生成針對下個例外等級的例外:SVC (Supervisor Call),生成針對 EL1 的例外;HVC (Hypervisor Call),生成針對 EL2 的例外;SMC (Secure Monitor Call),生成針對 EL3 的例外。這些指令取值范圍為 0-65,555,允許每個例外等級有 216 個系統(tǒng)調(diào)用。這些指令針對下個例外等級,而且是唯一可供運行在較低例外等級的程序從運行在較高例外等級的程序請求某些內(nèi)容的機制。在我們的理論實例中,SVC 是 SWITCHSUPER,HVC 是 SWITCHHYPER。

  PetaLinux 工具包含一組命令,以供用戶在賽靈思 FPGA 和 SoC 上輕松創(chuàng)建和擴展 Linux 系統(tǒng)。

  在前一個部分,我們介紹了能夠讓運行在 USER 模式(EL0)的程序進(jìn)入 SUPER 模式 (EL1) 的事件。大多數(shù)運行在 USER 模式的程序生成的事件是請求存儲器。當(dāng)運行在 EL0 中的用戶空間程序從運行在 EL1 中的 OS 請求存儲器時,這個用戶空間程序的 C 代碼可能調(diào)用函數(shù) malloc(),再由該函數(shù)調(diào)用 mmap() 或 sbrk(),以從 OS 請求一個指向可用存儲器的指針。在 ARMv8-A 架構(gòu)中的 Linux 上,這個過程在幕后轉(zhuǎn)化為 SVC 系統(tǒng)調(diào)用。該系統(tǒng)調(diào)用會把處理器轉(zhuǎn)換為 EL1,從而將控制權(quán)送回 OS,后者會解讀調(diào)用內(nèi)容并提供正確的響應(yīng)——本例中是指向所請求存儲器區(qū)域的指針,或者是一個錯誤,用以指出沒有可用存儲器。

  演示創(chuàng)建和工具

  現(xiàn)在我們來介紹我們團(tuán)隊在 UltraScale+ QEMU Model 上運行 Doom 時所采用的步驟。這些步驟展示了如何獲得和構(gòu)建運行演示所需的每個組件,如何運行以及以什么順序運行每個組件,以及如何與演示交互。成功完成該演示之后,你會獲得一個環(huán)境,用來在上面進(jìn)行實驗,以了解 Xen 管理程序在仿真的 Zynq UltraScale+ 上的運行情況。還需要將此遷移植 Zynq UltraScale+ MPSoC 芯片,這可作為練習(xí)由用戶來完成。

  想玩 DOOM 嗎?

  為了讓過程更簡單,賽靈思提供基礎(chǔ)的根文件系統(tǒng),這樣用戶就無需花時間和精力自己構(gòu)建。此演示所需的所有下載內(nèi)容在以下網(wǎng)址中均有提供: www.wiki.xil- inx.com/Doom+on+Xen+Demo。

  該演示首先通過更新由賽靈思提供的預(yù)編譯根文件系統(tǒng) (rootFS),可包含所需的組件。然后,利用賽靈思的 PetaLinux 工具運行演示。rootFS 包含運行于 Linux 系統(tǒng)上的大部分程序——具體來說就是用來啟動系統(tǒng)的一組腳本,以及用來實現(xiàn)系統(tǒng)的應(yīng)用程序與函數(shù)庫集。我們用來擴展演示中的基礎(chǔ) rootFS 所使用的兩個工具分別是 Buildroot 和 PetaLinux。我們使用 Buildroot 為賽靈思提供的基礎(chǔ) rootFS 構(gòu)建 Doom 二進(jìn)制文件,同時使用 PetaLinux 創(chuàng)建 rootFS 的剩余部分并引導(dǎo)演示。

  Buildroot

  Buildroot 是一個簡單的構(gòu)建系統(tǒng),用于為 Linux 系統(tǒng)創(chuàng)建 rootFS。它使用 make menuconfig 接口,這是一個用來配置 Linux 內(nèi)核本身的常用方法。Buildroot 包含對 PrBoom 的默認(rèn)支持,這對于本演示很有幫助。(PrBoom 是我們所使用的 Doom 游戲的 GNU 通用公共許可證 [GPL] 版本。這里我們會穿插使用 PrBoom 和 Doom 這兩個術(shù)語。 )Buildroot 對 Xen 構(gòu)建不提供本地支持(盡管它可創(chuàng)建用于構(gòu)建 Xen 所需的所有庫和工具鏈),因此賽靈思提供 Xen、Xen 工具和為用戶預(yù)編譯的 Xen 庫以及其他一些所需的庫,以讓過程簡單直觀。



關(guān)鍵詞: Zynq MPSoC

評論


相關(guān)推薦

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

關(guān)閉