編者按:信不信,隨便逮住一個人問他知不知道CPU,我想他的答案一定會是肯定的,但是如果你再問他知道ARM和X86架構(gòu)么?這兩者的區(qū)別又是什么?絕大多數(shù)的人肯定是一臉懵逼。今天小編就帶你深入了解CPU的這兩大架構(gòu):ARM和X86。以后出去裝X就靠它了!
重溫下CPU是什么鬼
中央處理單元(CPU)主要由運算器、控制器、寄存器三部分組成,從字面意思看運算器就是起著運算的作用,控制器就是負責發(fā)出CPU每條指令所需要的信息,寄存器就是保存運算或者指令的一些臨時文件,這樣可以保證更高的速度。
CPU有著處理指令、執(zhí)行操作、控制時間、處理數(shù)據(jù)四大作用,打個比喻來說,CPU就像我們的大腦,幫我們完成各種各樣的生理活動。因此如果沒有 CPU,那么電腦就是一堆廢物,無法工作。移動設(shè)備其實很復雜,這些CPU需要執(zhí)行數(shù)以百萬計的指示,才能使它向我們期待的方向運行,而CPU的速度和功率效率是至關(guān)重要的。速度影響用戶體驗,而效率影響電池壽命。最完美的移動設(shè)備是高性能和低功耗相結(jié)合。
要了解X86和ARM,就得先了解復雜指令集(CISC)和精簡指令集(RISC) 從CPU發(fā)明到現(xiàn)在,有非常多種架構(gòu),從我們熟悉的X86、ARM,到不太熟悉的MIPS、IA64,它們之間的差距都非常大。但是如果從最基本的邏輯角度來分類的話,它們可以被分為兩大類,即所謂的“復雜指令集”與“精簡指令集”系統(tǒng),也就是經(jīng)??吹降摹癈ISC”與“RISC”。
Intel和ARM處理器的第一個區(qū)別是,前者使用復雜指令集(CISC),而后者使用精簡指令集(RISC)。屬于這兩種類中的各種架構(gòu)之間最大的區(qū)別,在于它們的設(shè)計者考慮問題方式的不同。下面小編分別來介紹:
x86:Intel一家獨大
提到芯片巨頭英特爾,每一個互聯(lián)網(wǎng)用戶應(yīng)該都不會感到陌生,英特爾的CPU制造技術(shù)冠絕全球,但是你知道這家巨頭企業(yè)是如何發(fā)家的么?
事情要從1978年6月8日說起,Intel發(fā)布了一款新型的微處理器“8086”。而這款處理器在新出現(xiàn)時并沒有得到什么關(guān)注,可是他卻創(chuàng)造了一個新的時代。8086意味著x86架構(gòu)的誕生,而x86作為特定微處理器執(zhí)行計算機語言的指令集,定義了芯片的基本使用規(guī)則。8086也直接帶動了Intel成為全球首屈一指的芯片巨頭。
而x86不僅僅使Intel平步青云,也成為了業(yè)界的一種標準。在過去的幾十年里,無論是筆記本、服務(wù)器、超級計算機還是編寫設(shè)備,都可以看到x86的身影。而且,x86架構(gòu)還在通過不同的方法進行改進,無論AMD、VIA都可以通過X86指令集的彈性來對付Intel,迫使x86進行改變。
通過幾十年的技術(shù)積累,x86服務(wù)器在服務(wù)器領(lǐng)域的地位幾乎是獨孤求敗。小巧靈活的x86服務(wù)器在市場上應(yīng)用十分廣泛,互聯(lián)網(wǎng)以及局域網(wǎng)內(nèi)的文件、打印、通訊、web、電子郵件、數(shù)據(jù)庫以及應(yīng)用服務(wù)等多個領(lǐng)域都可以一展身手。
x86服務(wù)器最大的特色在于可以兼容Windows操作系統(tǒng),全部都采用了Intel的CPU。而Intel的x86服務(wù)器也可以分為兩代,最初采用的80x86系列在發(fā)布了產(chǎn)品80486后,Intel對該系列產(chǎn)品進行了重新命名并注冊,這也就是現(xiàn)在Intel的Pentium系列,當然,這個系列在中國還有個更響亮的名字,即奔騰系列。
目前奔騰系列的CPU包括:Pentium、Pentium MMX、Pentium Pro、PII、PII Xeon(至強)、PIII、PIII Xeon、P4 Xeon、Celeron2(賽揚)等。
身處物聯(lián)網(wǎng)洪流的你還在等什么!“關(guān)注物聯(lián)網(wǎng)新機遇的你,怎能錯過這個饕餮盛宴!!由華強聚豐旗下電子發(fā)燒友網(wǎng)舉辦的第三屆“中國IoT大會”將 于12月2日在深圳隆重舉行:全球化的 視野、更高價值的獨家觀點、更專業(yè)的技術(shù)分享、更前沿的脈動把握,匯聚全球物聯(lián)網(wǎng)知名企業(yè)與精英的盛典,你不可錯過!更多信息歡迎大家繼續(xù)關(guān)注電子發(fā)燒友 網(wǎng)!”(點擊圖片查看詳情)
x86:40多年一路堅持
x86老么?從時間上來看,確實老了。x86從1978年至今已經(jīng)將近40年??山?jīng)過各種風云變幻之后,x86依然是服務(wù)器行業(yè)絕對的領(lǐng)導者,說這樣的一個服務(wù)器行業(yè)領(lǐng)袖已經(jīng)老去,那無非便是在指摘支撐起整個互聯(lián)網(wǎng)的服務(wù)器行業(yè)已老。
而且,經(jīng)歷了很多代的改進和變革,x86架構(gòu)服務(wù)器依然是最快的架構(gòu)之一。而且現(xiàn)在x86也是整個行業(yè)的標桿,從技術(shù)上來看x86從未落后過,只不過是和其他架構(gòu)的服務(wù)器相比差距大小是否被拉近了。
從指令集架構(gòu)來看,CISC確實是有些陳舊了。即便是Intel也已經(jīng)承認,CISC架構(gòu)確實限制了CPU的發(fā)展。在CISC微處理器程序的各條指令相互串聯(lián)執(zhí)行,指令操作也需要串行執(zhí)行,按照這種方式來進行任務(wù)執(zhí)行,其控制當然十分簡單,但計算機的整體利用率卻被拖了后腿,執(zhí)行速度相對偏慢。這也是CISC架構(gòu)為中低檔服務(wù)器所采用的原因之一。
復雜指令集是一種伴隨著計算機誕生便存在的一種指令集。其擁有較強的處理高級語言的能力,對于提高計算機性能有一定好處。而日趨復雜的指令系統(tǒng)不僅帶來的效率的低下,還致使系統(tǒng)結(jié)構(gòu)的復雜性增加,這種復雜性也將導致了CISC的通用性不佳。
ARM:移動端異軍突起
在PC領(lǐng)域,Intel的CPU一枝獨秀。而在移動端呢?那就當屬ARM了。ARM全稱為Advanced RISC Machine,也就是進階精簡指令集機器。ARM是RISC微處理器的代表作之一,其廣泛的在嵌入式系統(tǒng)設(shè)計中被使用。而且ARM處理器最大的特點在于節(jié)能,這也是其在移動通信領(lǐng)域無人能敵的原因之一。
打造ARM64位服務(wù)器
在過去,ARM專注于發(fā)展32位架構(gòu),在移動端稱霸多年,讓Intel眼饞不矣。而在PC和服務(wù)器領(lǐng)域,Intel的市場也讓ARM十分眼紅。ARM于2011年底發(fā)布的ARMv8為其首款64位處理器,而戴爾在2013年發(fā)布了其首款基于ARM64位構(gòu)架的服務(wù)器,相應(yīng)的服務(wù)器解決方案也被開發(fā)出來。
專家認為,盡管Intel的x86處理器在服務(wù)器領(lǐng)域依然無敵,但64位的ARM構(gòu)架應(yīng)該可以找到自己的一席之地,ARM在內(nèi)存和網(wǎng)絡(luò)接口同計算核心間的距離會被盡可能的拉近,并借此承載起密度極高的大量計算進程,這種特性與Web服務(wù)器及其應(yīng)用十分契合。
在服務(wù)器領(lǐng)域,Intel的芯片也有很多水土不服的領(lǐng)域,比如內(nèi)存容量、I/O和處理性能不成比例時,ARM處理器的表現(xiàn)會更加合格。ARM處理器的ISA復雜程度要低很多,開發(fā)成本也要低,相應(yīng)的,ARM服務(wù)器廠商針對這些應(yīng)用場景所開發(fā)的服務(wù)器也就擁有了打敗Intel的前提條件。而從這些應(yīng)用環(huán)境所切入服務(wù)器市場的ARM架構(gòu)服務(wù)器其針對客戶也正是x86的原有部分客戶。
而Intel是不會輕易放手的,在服務(wù)器領(lǐng)域,其工藝對ARM保持領(lǐng)先,其處理器性能也遠高于ARM處理器,可在功耗方面一直是Intel的一個心病。
此外,Intel也想進軍移動端,要打敗ARM,在低功耗的服務(wù)器領(lǐng)域發(fā)力便是一個好的選擇。采用了14nm工藝的Xeon-D,其包括的2個1.4G的Broadwell內(nèi)核和GPU的功耗才僅僅為6W,在性能功耗比方便比ARM要高出不少。
在2008年,Intel推出了Atom處理器,這款處理器是Intel史上體積最小,功耗最低的處理器,其開創(chuàng)出去便是之中彌補自己在移動計算領(lǐng)域先天不足的問題,而這一領(lǐng)域被ARM霸占多年,在技術(shù)和經(jīng)驗中Intel都不占優(yōu)勢,想要打敗ARM又談何容易?
既然雙方都對對方的領(lǐng)域虎視眈眈,那么ARM和Intel的大戰(zhàn)絕對是不可避免的。那么想要進入Intel的服務(wù)器領(lǐng)域,ARM就需要拿出來真本事了,以其64位元處理器作為基礎(chǔ)的芯片設(shè)計,功耗低、成本低,具備構(gòu)架彈性,以這些優(yōu)勢去硬碰Intel又能有幾成勝算呢?
換個角度看,ARM芯片架構(gòu)具備一定的靈活性,可以實現(xiàn)很多企業(yè)的特性需求,比如緩存一致性以及容錯和高可用性等,其軟件的生態(tài)環(huán)境成熟度卻不及Intel,即便是有了更多的企業(yè)關(guān)注也未必就能有把握擊敗Intel,那么又是什么支持這ARM來客場挑戰(zhàn)Intel呢?
ARM與X86大比拼
從幾個方面比較ARM與X86架構(gòu)Intel和ARM的處理器,除了最本質(zhì)的復雜指令集(CISC)和精簡指令集(RISC)的區(qū)別之外,下面我們再從以下幾個方面對比下ARM和X86架構(gòu)。
1、制造工藝ARM和Intel處理器的一大區(qū)別是ARM從來只是設(shè)計低功耗處理器,Intel的強項是設(shè)計超高性能的臺式機和服務(wù)器處理器。
一直以來,Intel都是臺式機的服務(wù)器行業(yè)的老大。然而進入移動行業(yè)時,Intel依然使用和臺式機同樣的復雜指令集架構(gòu),試圖將其硬塞入給移動設(shè)備使用的體積較小的處理器中。但是Intel i7處理器平均發(fā)熱率為45瓦?;贏RM的片上系統(tǒng)的發(fā)熱率最大瞬間峰值大約是3瓦,約為Intel i7處理器的1/15。其最新的Atom系列處理器采用了跟ARM處理器類似的溫度控制設(shè)計,為此Intel必須使用最新的22納米制造工藝。
2、64位計算對于64位計算,ARM和Intel也有一些顯著區(qū)別。Intel并沒有開發(fā)64位版本的x86 指令集。64位的指令集名為x86-64(有時簡稱為x64),實際上是AMD設(shè)計開發(fā)的。Intel想做64位計算,它知道如果從自己的32位x86架構(gòu)進化出64位架構(gòu),新架構(gòu)效率會很低,于是它搞了一個新64位處理器項目名為IA64。由此制造出了Itanium系列處理器。
而ARM在看到移動設(shè)備對64位計算的需求后,于2011年發(fā)布了ARMv8 64位架構(gòu),這是為了下一代ARM指令集架構(gòu)工作若干年后的結(jié)晶。為了基于原有的原則和指令集,開發(fā)一個簡明的64位架構(gòu),ARMv8使用了兩種執(zhí)行模式,AArch32和AArch64。顧名思義,一個運行32位代碼,一個運行64位代碼。ARM設(shè)計的巧妙之處,是處理器在運行中可以無縫地在兩種模式間切換。這意味著64位指令的解碼器是全新設(shè)計的,不用兼顧32位指令,而處理器依然可以向后兼容。
3、異構(gòu)計算ARM的big.LITTLE架構(gòu)是一項Intel一時無法復制的創(chuàng)新。在big.LITTLE架構(gòu)里,處理器可以是不同類型的。傳統(tǒng)的雙核或者四核處理器中包含同樣的2個核或者4個核。一個雙核Atom處理器中有兩個一模一樣的核,提供一樣的性能,擁有相同的功耗。ARM通過big.LITTLE向移動設(shè)備推出了異構(gòu)計算。這意味著處理器中的核可以有不同的性能和功耗。當設(shè)備正常運行時,使用低功耗核,而當你運行一款復雜的游戲時,使用的是高性能的核。
這是什么做到的呢?設(shè)計處理器的時候,要考慮大量的技術(shù)設(shè)計的采用與否,這些技術(shù)設(shè)計決定了處理器的性能以及功耗。在一條指令被解碼并準備執(zhí)行時,Intel和ARM的處理器都使用流水線,就是說解碼的過程是并行的。
為了更快地執(zhí)行指令,這些流水線可以被設(shè)計成允許指令們不按照程序的順序被執(zhí)行(亂序執(zhí)行)。一些巧妙的邏輯結(jié)構(gòu)可以判斷下一條指令是否依賴于當前的指令執(zhí)行的結(jié)果。Intel和ARM都提供亂序執(zhí)行邏輯結(jié)構(gòu),可想而知,這種結(jié)構(gòu)十分的復雜,復雜意味著更多的功耗。
那為什么反而ARM的比X86耗電少得多呢。這就和另外一個因素相關(guān)了,那就是設(shè)計。
設(shè)計又分為前端和后端設(shè)計,前端設(shè)計體現(xiàn)了處理器的構(gòu)架,精簡指令集和復雜指令集的區(qū)別是通過前端設(shè)計體現(xiàn)的。后端設(shè)計處理電壓、時鐘等問題,是耗電的直接因素。當然,其中任何一項都會使得時鐘和電源所控制的模塊無法工作。他們的區(qū)別在于,門控時鐘的恢復時間較短,而電源控制的時間較長。此外,如果條單條指令使用多個模塊的功能,在恢復功能的時候,并不是最慢的那個模塊的時間,而可能是幾個模塊時間相加,因為這牽涉到一個上電次序的問題,也就是恢復工作時候模塊間是有先后次序的,不遵照這個次序,就無法恢復。而遵照這個次序,就會使得總恢復時間很長。
所以在后端這塊,可以得到一個結(jié)論,為了省電,可以關(guān)閉一些暫時不會用到的處理器模塊。但是也不能輕易的關(guān)閉,否則一旦需要,恢復的話會讓完成某個指令的時間會很長,總體性能顯然降低。此外,子模塊的門控時鐘和電源開關(guān)通常是設(shè)計電路時就決定的,對于操作系統(tǒng)是透明的,無法通過軟件來優(yōu)化。
再來看前端。ARM的處理器有個特點,就是亂序執(zhí)行能力不如X86。換句話說,就是用戶在使用電腦的時候,他的操作是隨機的,無法預測的,造成了指令也無法預測。X86為了增強對這種情況下的處理能力,加強了亂序指令的執(zhí)行。此外,X86還增強了單核的多線程能力。這樣做的缺點就是,無法很有效的關(guān)閉和恢復處理器子模塊,因為一旦關(guān)閉,恢復起來就很慢,從而造成低性能。為了保持高性能,就不得不讓大部分的模塊都保持開啟,并且時鐘也保持切換。這樣做的直接后果就是耗電高。而ARM的指令強在確定次序的執(zhí)行,并且依靠多核而不是單核多線程來執(zhí)行。這樣容易保持子模塊和時鐘信號的關(guān)閉,顯然就更省電。
ARM和X86現(xiàn)在發(fā)展如何?
關(guān)于X86架構(gòu)和ARM架構(gòu)這兩者誰將統(tǒng)一市場的爭執(zhí)一直都有,但是也有人說這兩者根本不具備可比性,X86無法做到 ARM的功耗,而ARM也無法做到X86的性能?,F(xiàn)在ARM架構(gòu)已經(jīng)具備了進入服務(wù)器芯片的能力,眾多芯片研發(fā)企業(yè)紛紛采用ARM架構(gòu)研發(fā)服務(wù)器芯片無疑將促進其繁榮, 2015年一款采用ARM架構(gòu)的Windows 10平板現(xiàn)身,這也是目前曝光的全球首款非X86架構(gòu)、運行Windows系統(tǒng)的平板產(chǎn)品。
隨著移動網(wǎng)絡(luò)和互聯(lián)網(wǎng)融合互通日趨明顯,ARM發(fā)展后臺數(shù)據(jù)中心已經(jīng)是大勢所趨,所以與其說ARM倒更像是背水一戰(zhàn),無論是ARM還是Intel,雙方都沒有任何退路可言。
評論
查看更多