本頁使用了標題或全文手工轉換

x86-64

維基百科,自由的百科全書
前往: 導覽搜尋

x86-64( 又稱x64,即英文詞64-bit extended,64位元拓展 的簡寫)是x86架構64位元拓展,向後相容於16位元32位元的x86架構。x64於1999年由AMD設計,AMD首次公開64位元集以擴充給x86,稱為「AMD64」。其後也為英特爾所採用,現時英特爾稱之為「Intel 64」,在之前曾使用過「Clackamas Technology」 (CT)、「IA-32e」及「EM64T」。

蘋果公司RPM套件管理員以「x86-64」或「x86_64」稱呼此64位元架構。甲骨文公司Microsoft 稱之為「x64」。BSD 家族及其他 Linux發行版則使用「amd64」,32位元版本則稱為「i386」(或 i486/586/686),Arch Linux用x86_64稱呼此64位元架構。

AMD64[編輯]

AMD64的標誌

AMD64指令集被應用在Athlon 64Athlon 64 FXAthlon 64 X2Turion 64Turion 64 X2Opteron及較新款的SempronPhenomAMD APUAMD Ryzen等處理器上。

架構特色[編輯]

在x86-64出現以前,英特爾與惠普聯合設計出IA-64架構;惟IA-64並不與x86相容,且市場反應較冷淡,同時受制於多個專利權,使其他廠商不能模仿。與x86相容的AMD64架構便應運而生,其主要特點如名稱所述,既有支援64位元通用暫存器、64位元整數及邏輯運算、以及64位元虛擬位址,設計人員又為架構作出不少改進,部份重大改變如下:

  • 新增暫存器
  • 位址闊度加長
  • SSE2SSE3指令
  • NX位元:AMD64其中一個特色是擁有「禁止執行」(No-Execute)的位元,可在一定程度上防止蠕蟲病毒緩衝區溢位的方式來進行攻擊。

市場分析[編輯]

AMD64代表AMD放棄了跟隨Intel標準的一貫作風,選擇了像把16位元的Intel 8086擴充成32位元的80386般,去把x86架構擴充成64位元版本,且相容原有標準。

AMD64架構在IA-32上新增了64位元暫存器,並相容早期的16位元和32位元軟體,可使現有以x86為對象的編譯器容易轉為AMD64版本。除此之外,NX bit也是引人注目的特色之一。

不少人認為,像DEC Alpha般的64位元RISC晶片,最終會取代現有過時及多變的x86架構。但事實上,為x86系統而設的應用軟體實在太龐大,成為Alpha不能取代x86的主要原因,AMD64能有效地把x86架構移至64位元的環境,並且能相容原有的x86應用程式。

Intel 64[編輯]

Intel 64指令集被應用於Pentium 4Pentium DPentium Extreme EditionCeleron DXeonIntel Core 2Intel Core i3Intel Core i5Intel Core i7處理器上。

概要[編輯]

Intel 64計劃的歷史可謂相當長及複雜,其原因主要是因為Intel自身的內政問題。該計劃開始時,其代號為「Yamhill」,不過Intel一直對外宣稱其計劃不存在;至2004年初,Intel才改口承認,並把代號改為CT(Clackamas Technology)。在宣布CT計劃的數個星期內,Intel為計劃給予多個新名稱。在2004年春季的Intel開發者論壇後,Intel將之命名為「IA-32E」,意即IA-32的延伸;在數星期後,才改稱為EM64T。

Intel曾長時間把該計劃保持機密,其原因有以下兩點。第一,Intel不想給客戶混淆資訊,把未來Itanium IA-64處理器的展望與x86混為一談;但在Intel眼見使用AMD64的Opteron及Athlon 64取得成功,便需要對競爭者的威脅作出迎擊。而第二個原因,是Intel為了自身的面子,必然不會承認使用了對手AMD的技術,因此Intel把該技術以EM64T這個名字來推出,雖然核心與AMD64幾乎相同,猶如一對孿生兄弟,但如果Intel使用了AMD64這名字,等於在幫對手做廣告宣傳。在以往Intel的行銷中,Intel總把AMD的產品貶為自家技術的仿製品;不過這回AMD率先開發民用64位元技術,Intel需要反過來吸納AMD的技術,使Intel在研發x86處理器技術的領導地位受到重挫,因此Intel在造勢方面便需要使用更多的人力物力。Intel主席Craig Barrett英語Craig Barrett (chief executive)之後也承認,在保密方面,這個機密算是保護得最差的。

在Intel 64(EM64T)的檔案中,對於其指令集的起源隻字不提;因此有媒體為它起了「iAMD64」這個別名,諷刺Intel在迎擊AMD的民用64位元技術上,使用了AMD的技術,直接把AMD64吸納過來,並以新名重新包裝使用。後來Intel索性將此技術正式命名為Intel 64

架構特色[編輯]

Intel 64可使處理器直接存取超過4GB的記憶體,容許執行更大的應用程式。而x86-64架構也加入了額外的暫存器及其他改良在指令集上。透過64位元的記憶體位址上限,其理論記憶體大小上限達16,000,000TB(16EB),不過在初期的應用上並未能支援完整的64位元位址。

Intel在之前已在Itanium處理器上使用了自家的64位元IA-64技術,雖然說Intel 64也是64位元,但兩者並不相容,即IA-64的軟體不能直接在Intel 64上執行。Intel 64所用的x86-64是IA-32指令集的延伸,而IA-64則是另一款獨立的架構,沒有任何IA-32的影子。雖然IA-64可透過模擬來執行IA-32的指令,但指令在執行前需經轉換,才能在IA-64上執行,導致其速度變慢。由於x86-64是從IA-32衍生而來,因此執行IA-32與64位元程式的表現也顯得綽綽有餘。

首顆使用Intel 64技術的處理器屬於Xeon型號,支援雙處理器,其核心名稱為Nocona。由於Xeon是直接建基於桌上型Pentium 4的架構上,因此Pentium 4主機板也可使用Intel 64,如使用超執行緒(Hyper-Threading)等。不過Intel 64在初期的Prescott版本尚未啟用,其原因大概是當時其尚未完善。在使用Prescott核心E0更新版本的Pentium 4處理器已可使用Intel 64,被稱為Pentium 4 F。再者,E0更新版本加入了「禁止執行」位元,稱為XD bit(eXecute Disable),相當於AMD64的NX bit

虛擬位址空間的細節[編輯]

儘管虛擬位址有64位元的寬度,但目前的實現機制(以及任何已知處在計劃階段的晶片)並不允許整個16EB的虛擬位址空間都被使用。大多數的作業系統和應用程式在可見的未來都用不到如此巨大的位址空間(比如,Windows在AMD64上的實現僅應用了16TB,即44位元的寬度),所以實現如此巨大的位址寬度只會增加系統的複雜度和位址轉換的成本,帶不來任何好處。AMD因此決定,在對這一架構的首次實現中,只有虛擬位址的最低48位元才會在位址轉換(頁表查詢)時被使用。但是,任何虛擬位址的48位元至63位必須與47位一致(按照符號位擴展的方式),否則處理器將會報告一個異常。符合這一規則的位址被稱作「傳統格式」。傳統格式將從0至00007FFF`FFFFFFFF,以及從FFFF8000`00000000至FFFFFFFF`FFFFFFFF總計256TB的位址範圍作為可以使用的虛擬位址空間。

這種「古怪」的規則為日後擴展到真正的64位元尋址保留了一個重要的特性:很多的作業系統(包括但不限於Windows NT系列)將位址空間的高半部分(被稱作內核空間)留給自己,將低半部分(用戶空間)留給應用程式代碼、用戶態棧、堆和其他資料區。這種「傳統位址」的設計保證了每一個符合AMD64的實現都擁有兩個內存片段:低半段從00000000`00000000開始,隨著更多的虛擬位址位元變得可用而「向上生長」;高半部分被「懸掛」在位址空間的頂部而「向下生長」。同樣,將未被使用的位址位元內容固定下來防止被作業系統用作標誌位、特權級標號等其他用途,是爲了避免當架構擴展至52, 56, 60和64位元的時候出現問題。

目前48位元的實現方式

AMD64-canonical--48-bit.svg

56位的實現方式

AMD64-canonical--56-bit.svg

完全64位元的實現方式

AMD64-canonical--64-bit.svg

(非按比例繪製)

64位元尋址模式(長模式),是實體位址擴展(PAE)的超集;因此,記憶體分頁大小可以是4KB,2MB,或1GB。但是,與系統在PAE模式下使用的三級分頁表機制不同,長模式下系統使用四級分頁表:PAE的頁目錄指針表的表項從4個擴展到了512個,而且附加了一個第四級頁面對映表(Page-Map Level 4 Table,PML4 Table),包含512個採用48位元實現的表項。在提供更大虛擬位址的實現中,這個表既可以進行擴展來提供足夠數量的表項(對於64位元實現來說理論值高達33,554,432個)以描述整個位址空間,也可以再被一個更高層對映級所對映,像是PML5。整個48位元位址空間的4KB頁面完整對映層級將會占據略多於512GB的記憶體(256TB虛擬位址空間的0.196%)。

執行模式[編輯]

執行模式 作業系統要求 已編譯程式重新構建 預設位址長度(位元) 預設操作數長度(位元) 暫存器擴充功能 典型通用暫存器寬度(位元)
長模式
(IA-32e)
64位元模式 64位元 需要 64 32 可用 64
相容模式 64位元(拓展) 不需要 32 不可用 32
16
遺留模式 保護模式 遺留32位元 不需要 32 不可用
遺留16位元 16 16 或 32
虛擬8086模式 遺留32位元 16
真實模式 遺留16位元 16 或 32

作業系統支援[編輯]

以下作業系統均支援長模式(long mode)的x86-64架構。

DOS[編輯]

DOS環境下可透過DOS Extender(例如DOS4GW)來進入保護模式。

FreeBSD[編輯]

FreeBSD在5.1正式版曾為x86-64作試驗,至6.0正式版解決了在x86-64執行32位元程式出現的一些問題,以及能支援不少驅動程式。

Linux[編輯]

Linux在2.6版本的內核開始加入長模式,支援x86-64,能相容32位元程式及模擬32位元系統,容許在32位元的環境下,把程式編譯為64位元版本。

Mac OS X[編輯]

Mac OS X 10.6 Snow Leopard開始提供64位元內核,並可以在部分處理器上開啟64位元內核。64位元內核只支援64位元的內核擴充功能,反之亦然;但對於普通應用程式,無論32位元或64位元內核均可以支援兩種位寬的應用程式,但32位元程式只能使用4GB的記憶體空間[1][2]

Mac OS X 10.5 Leopard在Intel與PowerPC上提供對Cocoa, Quartz, OpenGLX11的GUI程式的64位元支援[3],並支援全部的命令列庫和程式。但內核仍只有32位元版本。

Mac OS X使用通用二進位檔案格式將32位元和64位元程式和庫代碼包裝在同一檔案中,在載入時自動選擇最合適的版本。在Mac OS X 10.6中,內核和內核擴充功能也使用通用二進位格式以同時支援兩種構架。

MenuetOS[編輯]

x86-64版本的MenuetOS系統於2005年6月推出,雖然原有的32位元版本Menuet以GPL授權,但x86-64版本則維持專屬,並以免費軟體方式發布,以及提供部分元件的原始碼。

NetBSD[編輯]

x86-64版本的NetBSD最早於2001年6月19日被提出,至2004年12月9日推出的NetBSD 2.0已能完全支援x86-64。

OpenBSD[編輯]

OpenBSD自2004年5月1日推出的3.5版起,已支援x86-64。

Solaris[編輯]

昇陽的Solaris自版本10開始已支援x86-64。

Windows[編輯]

供用戶端使用的Windows XP Professional x64 Edition以及供伺服器使用的Windows Server 2003 SP1 x64 Edition均已於2005年3月推出。Windows VistaWindows Server 2008Windows 7Windows 8Windows 8.1以及Windows 10均有對應的64位元版本.Windows Server 2008 R2只提供64位元版本。

業界稱謂慣例[編輯]

由於AMD64和Intel64基本上一致,很多軟硬體產品都使用一種不傾向任何一方的詞彙來表明它們對兩種架構的同時相容。出於這個目的,AMD對這種CPU架構的原始稱呼——「x86-64」被不時地使用,還有變體「x86_64」。其他公司如微軟昇陽電腦在行銷資料中使用「x64」作為對「x86-64」的縮寫。

許多作業系統及產品,尤其那些是在Intel進入這塊市場之前就引入「x86-64」支援的,使用「AMD64」或「amd64」同時指代AMD64和Intel64。

  • BSD系統(如FreeBSDNetBSDOpenBSD)和一些Linux發行版(如DebianUbuntu、和Gentoo)將AMD64和Intel64都稱作「amd64」。Red HatRPM將x86-64稱為x86_64或x86-64,將32位元的IA-32稱為i*86(*為數字3-6,比如i386)。Arch Linux將x86-64稱為x86_64。
  • Fedora PackageKit稱64位元架構為「x86_64」。
  • Java Development Kit(JDK):包含x86-64檔案的目錄命名為「amd64」。
  • Mac OS X:終端下的命令arch以及開發人員文件都表明蘋果稱64位元架構為「x86_64」。
  • Microsoft Windows:稱在IA-32處理器上使用64位元技術為「x64」,但一些相關目錄使用AMD64來標明。例如,Windows x64版安裝CD上的系統目錄命名為「AMD64」,而32位元版本上用「i386」。
  • Solaris:作業系統的命令isalist將AMD64和Intel64都定義成「amd64」。

應用產品[編輯]

以下處理器產品使用了x86-64技術。

參考文獻[編輯]

  1. ^ John Siracusa. Mac OS X 10.6 Snow Leopard: the Ars Technica review. Ars Technica LLC. [2010-06-20]. 
  2. ^ Mac OS X Technology. Apple. [2010-05-24]. (原始內容存檔於2009-11-12). 
  3. ^ Apple - Mac OS X Leopard - Technology - 64 bit 網際網路檔案館存檔,存檔日期2009-01-12.

參見[編輯]

  • NX bit
  • AMD K8
  • AMD K10(由於K9在英語發音上不好聽(Canine,狗類),因此AMD在K8代號後,直接使用K10為代號)
  • IA-64

外部連結[編輯]