在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 處理器系列之PowerPC指令集

            處理器系列之PowerPC指令集

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

              對(duì)  體系結(jié)構(gòu)家族樹的所有分支來說, 體系結(jié)構(gòu)和應(yīng)用級(jí)編程模型是通用的。

            本文引用地址:http://www.biyoush.com/article/201801/374368.htm

               體系結(jié)構(gòu)是一種精減指令集計(jì)算機(jī)(Reduced Instruction Set Computer,RISC)體系結(jié)構(gòu),定義了 200 多條指令。PowerPC 之所以是 RISC,原因在于大部分指令在一個(gè)單一的周期內(nèi)執(zhí)行,而且通常只執(zhí)行一個(gè)單一的操作(比如將內(nèi)存加載到寄存器,或者將寄存器數(shù)據(jù)存儲(chǔ)到內(nèi)存)。

              PowerPC 體系結(jié)構(gòu)分為三個(gè)級(jí)別(或者說是“book”)。通過對(duì)體系結(jié)構(gòu)以這種方式進(jìn)行劃分,為實(shí)現(xiàn)可以選擇價(jià)格/性能比平衡的復(fù)雜性級(jí)別留出了空間,同時(shí)還保持了實(shí)現(xiàn)間的代碼兼容性。

              Book I. 用戶指令集體系結(jié)構(gòu)

              定義了通用于所有 PowerPC 實(shí)現(xiàn)的用戶指令和寄存器的基本集合。這些是非特權(quán)指令,為大多數(shù)程序所用。

              Book II. 虛擬環(huán)境體系結(jié)構(gòu)

              定義了常規(guī)應(yīng)用軟件要求之外的附加的用戶級(jí)功能,比如高速緩存管理、原子操作和用戶級(jí)計(jì)時(shí)器支持。雖然這些操作也是非特權(quán)的,但是程序通常還是通過操作系統(tǒng)調(diào)用來訪問這些函數(shù)。

              Book III. 操作環(huán)境體系結(jié)構(gòu)

              定義了操作系統(tǒng)級(jí)需要和使用的操作。其中包括用于內(nèi)存管理、異常向量處理、特權(quán)寄存器訪問、特權(quán)計(jì)時(shí)器訪問的函數(shù)。Book III 中詳細(xì)說明了對(duì)各種系統(tǒng)服務(wù)和功能的直接硬件支持。

              從最初的 PowerPC 體系結(jié)構(gòu)的開發(fā)開始,就根據(jù)特定的市場(chǎng)需求而發(fā)生分支。當(dāng)前,PowerPC 體系結(jié)構(gòu)家族樹有兩個(gè)活躍的分支,分別是PowerPC AS體系結(jié)構(gòu)和 PowerPC Book E體系結(jié)構(gòu)。PowerPC AS 體系結(jié)構(gòu)是 IBM 為了滿足它的 eServer pSeries UNIX 和 Linux 服務(wù)器產(chǎn)品家族及它的 eServer iSeries 企業(yè)服務(wù)器產(chǎn)品家族的具體需要而定義的(參閱 參考資料中的鏈接以獲得更多資料)。PowerPC Book E 體系結(jié)構(gòu),也被稱為 Book E,是 IBM 和 Motorola 為滿足嵌入式市場(chǎng)的特定需求而合作推出的。PowerPC AS 所采用的原始 PowerPC 體系結(jié)構(gòu)與 Book E 所采用的擴(kuò)展之間的主要區(qū)別大部分集中于 Book III 區(qū)域中。

              在這些衍生的體系結(jié)構(gòu)中還有一些適當(dāng)?shù)膽?yīng)用級(jí)擴(kuò)展,這些擴(kuò)展大部分與具體應(yīng)用的場(chǎng)合相關(guān),但是 PowerPC AS 和 PowerPC Book E 共享在 PowerPC 體系結(jié)構(gòu)的 Book I 中定義的基本指令集。雖然三種體系結(jié)構(gòu)主要在操作系統(tǒng)級(jí)別上表現(xiàn)出不同,但它們?cè)诤艽蟪潭壬暇邆鋺?yīng)用級(jí)的兼容性。

              PowerPC 最初定義了同時(shí)對(duì) 32 位和 64 位實(shí)現(xiàn)的支持,可以讓 32 位的應(yīng)用程序運(yùn)行于 64 位系統(tǒng)之上。在 IBM pSeries 和 iSeries 服務(wù)器上使用的 PowerPC AS 系統(tǒng)現(xiàn)在只提供體系結(jié)構(gòu)的 64 位實(shí)現(xiàn),新的 64 位應(yīng)用程序和遺留的 32 位的應(yīng)用程序可以運(yùn)行于同一個(gè)系統(tǒng)之上。PowerPC Book E 體系結(jié)構(gòu)同時(shí)有 32 位實(shí)現(xiàn)和 64 位實(shí)現(xiàn),64 位實(shí)現(xiàn)也完全兼容 32 位 PowerPC 應(yīng)用程序。這兩種體系結(jié)構(gòu)都具備與 PowerPC Book I 指令和寄存器的完全兼容性,同時(shí)提供了對(duì)內(nèi)存管理、異常和中斷、計(jì)時(shí)器支持和調(diào)試支持等各方面的系統(tǒng)級(jí)擴(kuò)展。

              POWER 的自然歷史

              POWER 和 PowerPC 微有著漫長(zhǎng)而傳奇的歷史,最初是 IBM 801,其后是 POWER、RS64 和 PowerPC 芯片系列(這些并不是線性發(fā)展的)。每個(gè)芯片家族都對(duì)計(jì)算世界有自己強(qiáng)有力的影響,從游戲控制臺(tái)到主機(jī),從數(shù)字手表到高端工作站,到處都得到了應(yīng)用。欲了解全部歷史,請(qǐng)閱讀“ 人類的 POWER:IBM 的芯片制造歷史”。

              最初的 PowerPC 體系結(jié)構(gòu)仍是 PowerPC AS 和 PowerPC Book E 的主要組成部分,并仍保持了其完整性,表現(xiàn)出了令人信服的應(yīng)用級(jí)兼容性。

              PowerPC 應(yīng)用程序編程模型

              當(dāng)用到不只一種類型的 PowerPC 時(shí),開發(fā)人員應(yīng)時(shí)刻謹(jǐn)記處理內(nèi)存的方式存在一些差異。

              PowerPC 存儲(chǔ)模型

              PowerPC 體系結(jié)構(gòu)本身支持字節(jié)(8 位)、半字(16 位)、字(32 位) 和雙字(64 位) 數(shù)據(jù)類型。

              PowerPC 實(shí)現(xiàn)還可以處理最長(zhǎng) 128 字節(jié)的多字節(jié)字符串操作。32 位 PowerPC 實(shí)現(xiàn)支持 4-gigabyte 的有效地址空間,而 64 位 PowerPC 實(shí)現(xiàn)支持 16-exabyte 的有效地址空間。所有存儲(chǔ)都可以字節(jié)尋址。

              對(duì)于錯(cuò)位數(shù)據(jù)訪問來說,不同的產(chǎn)品家族提供了不同的校準(zhǔn)支持,有一些是以處理異常的方式,其他的是通過硬件中的一步或者多步操作來處理訪問。

              最高位字節(jié)在最前(Big-endian)還是最低位字節(jié)在最前(little-endian)?

              PowerPC、PowerPC AS 以及早期的 IBM PowerPC 4xx 家族大部分是字節(jié)排列順序最高位在最前的機(jī)器,這就意味著對(duì)半字、字以及雙字訪問來說,最重要的字節(jié)(most-significant byte,MSB)位于最低的地址。各實(shí)現(xiàn)對(duì)最低位在最前的字節(jié)排列順序方式的支持不同。PowerPC 和 PowerPC AS 提供了最小限度的支持,而 4xx 家族為最低位字節(jié)在最前的存儲(chǔ)提供了更為健壯的支持。Book E 是字節(jié)排列順序無關(guān)的,因?yàn)?nbsp;Book E 體系結(jié)構(gòu)完全支持這兩種訪問方法。

              PowerPC 應(yīng)用級(jí)寄存器

              PowerPC 的應(yīng)用級(jí)寄存器分為三類:通用寄存器(general-purpose register,GPR)、浮點(diǎn)寄存器(floating-point register [FPR] 和浮點(diǎn)狀態(tài)和控制寄存器 [Floating-Point Status and Control Register,F(xiàn)PSCR])和專用寄存器(special-purpose register,SPR)。讓我們來分別看一下這三類寄存器。

              通用寄存器(GPR)

              用戶指令集體系結(jié)構(gòu)(Book I)規(guī)定,所有實(shí)現(xiàn)都有 32 個(gè) GPR(從GPR0 到 GPR31)。GPR 是所有整數(shù)操作的源和目的,也是所有加載/存儲(chǔ)操作的地址操作數(shù)的源。GPR 還提供對(duì) SPR 的訪問。所有 GRP 都是可用的,只有一種情況例外:在某些指令中,GPR0 只是代表數(shù)值 0,而不會(huì)去查找 GPR0 的內(nèi)容。

              浮點(diǎn)寄存器(FPR)

              Book I 規(guī)定,所有實(shí)現(xiàn)都有 32 個(gè) FPR(從 FPR0 到 FPR31)。FPR 是所有浮點(diǎn)操作的源和目的操作數(shù),可以存放 32 位和 64 位的有符號(hào)和無符號(hào)整數(shù),以及單精度和雙精度浮點(diǎn)數(shù)。FPR 還提供對(duì) FPSCR 的訪問。

              注意,嵌入式微處理器實(shí)現(xiàn)時(shí)經(jīng)常不提供對(duì)浮點(diǎn)指令集的直接硬件支持,或者只是提供一個(gè)附加浮點(diǎn)硬件的接口。很多嵌入式應(yīng)用程序很少或者根本不需要浮點(diǎn)算法,而當(dāng)需要的時(shí)候,對(duì) PowerPC 浮點(diǎn)指令執(zhí)行進(jìn)行軟件仿真就足夠了。在嵌入式微處理器中,硬件中省去浮點(diǎn)(支持)而為實(shí)現(xiàn)帶來的芯片面積和功率的減少是至關(guān)重要的。

              浮點(diǎn)狀態(tài)和控制寄存器(FPSCR)捕獲浮點(diǎn)操作的狀態(tài)和異常結(jié)果,F(xiàn)PSCR 還具有控制位,以支持特定的異常類型和對(duì)四種舍入模式之一的選擇。對(duì) FPSCR 的訪問要通過 FPR。

              專用寄存器(SPR)

              SPR 給出處理器核心內(nèi)部資源的狀態(tài)并對(duì)其進(jìn)行控制。不需要系統(tǒng)服務(wù)的支持就可以由應(yīng)用程序讀寫的 SPR 包括計(jì)數(shù)寄存器(Count Register)、鏈接寄存器(Link Register)和整型異常寄存器(Integer Exception Register)。需要系統(tǒng)服務(wù)的支持才可以由應(yīng)用程序讀寫的 SPR 包括時(shí)基(Time Base)和其他各種可能支持的計(jì)時(shí)器。

              指令地址寄存器(Instruction Address Register,IAR)

              這個(gè)寄存器就是程序員們所熟知的 程序計(jì)數(shù)器或者 指令指針。它是當(dāng)前指令的地址。這實(shí)際上是一個(gè)偽寄存器,用戶只能通過“branch and link”指令才能直接使用這個(gè)寄存器。IAR 主要是由調(diào)試器使用,顯示將要被執(zhí)行的下一條指令。

              鏈接寄存器(Link Register,LR)

              這個(gè)寄存器存放的是函數(shù)調(diào)用結(jié)束處的返回地址。某些轉(zhuǎn)移指令可以自動(dòng)加載 LR 到轉(zhuǎn)移之后的指令。每個(gè)轉(zhuǎn)移指令編碼中都有一個(gè) LK 位。如果 LK 為 1,轉(zhuǎn)移指令就會(huì)將程序計(jì)數(shù)器移為 LR 中的地址。而且,條件轉(zhuǎn)移指令 bclr 轉(zhuǎn)移到 LR 中的值。

              定點(diǎn)異常寄存器(Fixed-Point Exception Register,XER)

              這個(gè)寄存器存放整數(shù)運(yùn)算操作的進(jìn)位以及溢出信息。它還存放某些整數(shù)運(yùn)算操作的進(jìn)位輸入以及加載和存儲(chǔ)指令( lswx 和 stswx )中傳輸?shù)淖止?jié)數(shù)。

              計(jì)數(shù)寄存器(Count Register,CTR)

              這個(gè)寄存器中存放了一個(gè)循環(huán)計(jì)數(shù)器,會(huì)隨特定轉(zhuǎn)移操作而遞減。條件轉(zhuǎn)移指令 bcctr 轉(zhuǎn)移到 CTR 中的值。

              條件寄存器(Condition Register,CR)

              這個(gè)寄存器分為八個(gè)字段,每個(gè)字段 4 位。很多 PowerPC 指令將指令的第 31 位編碼為 Rc 位,有一些指令要求 Rc 值等于 1。當(dāng) Rc 等于 1 且進(jìn)行整數(shù)操作時(shí),CR 字段 0 被設(shè)置來表示指令操作的結(jié)果:相等(Equal, EQ),大于(Greater Than, GT),小于(Less Than, LT),以及和溢出(Summary Overflow, SO)。當(dāng) Rc 等于 1 且進(jìn)行浮點(diǎn)操作時(shí),CR 字段 1 被設(shè)置用來表示 FPSCR 中異常狀態(tài)位的狀態(tài):FX、FEX、VX 和 OX。任何一個(gè) CR 字段都可以是整數(shù)或者浮點(diǎn)比較指令的目標(biāo)。CR 字段 0 還被設(shè)置用來表示條件存儲(chǔ)指令( stwcx 或者stdcx ) 的結(jié)果。還有一組指令可以操縱特定的 CR 位、特定的 CR 字段或者整個(gè) CR,通常為了測(cè)試而將幾個(gè)條件組合到同一個(gè)位中。

              處理器版本寄存器(Processor Version Register,PVR)

              PVR 是一個(gè) 32 位只讀寄存器,標(biāo)識(shí)處理器的版本和修訂級(jí)別。處理器版本由 PowerPC 體系結(jié)構(gòu)過程分配。修訂級(jí)別由實(shí)現(xiàn)定義。需要有特權(quán)才能訪問 PVR,所以應(yīng)用程序只能在操作系統(tǒng)函數(shù)的幫助下才可以確定處理器版本。


            上一頁(yè) 1 2 3 4 下一頁(yè)

            關(guān)鍵詞: 處理器 PowerPC

            評(píng)論


            相關(guān)推薦

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

            關(guān)閉