x86-64
x86-64 (též AMD64, EM64T, IA-32E) je v informatice označení generace 64bitových procesorů pro počítače IBM PC kompatibilní. Procesor je zpětně kompatibilní s 32bitovou (viz IA-32) a 16bitovou architekturou (viz x86), a proto se na IBM PC prosadil. Hlavní výhodou nastupujícího 64bitového režimu je odstranění limitu přímé dostupnosti paměti nad 4 GiB operační paměti RAM, podpora NX bitu a vyšší rychlost zpracování 64bitových operací. Procesory jsou obdobně jako předchozí generace realizovány interně jako RISCová architektura emulující pomocí mikrokódu architekturu CISC.
Vlastnosti
V novém 64bitovém režimu jsou použity strojové instrukce, které pracují se 64bitovými čísly a adresami, takže je možné využívat celá čísla až 264=1,8×1019, což je až 18 Exabajtů operační paměti RAM (reálně však podporují procesory méně, viz níže). Kvůli prodloužení operandů strojových instrukcí z 32bitových na 64bitové došlo k tzv. zřídnutí kódu (stejný strojový kód je v 64bitové variantě delší, než v 32bitové), a proto jsou nároky na dostupnou operační paměť u 64bitového systému vyšší, než kdyby byl použit stejný 32bitový operační systém (v systému Windows 7 jsou minimální požadavky 1 GB pro 32bitový systém a 2 GB RAM pro 64bitový systém).[1]
Velikost paměti
Teoreticky může 64bitový procesor používat 64bitové adresy pro adresaci paměti, ale z praktických důvodů je to méně. První 64bitové procesory používaly pro adresaci 48 bitů, což znamená maximálně 248 bajtů = 256 TB adresovatelné paměti (resp. virtuální paměti, protože reálně může být operační paměti RAM v počítači mnohem méně). Procesor díky mechanismu stránkování paměti umožňuje efektivně využívat i tak velký adresní prostor procesu.
V roce 2019 zavedla 10. generace procesorů Intel (Ice Lake) podporu pro 5 úrovní tabulek stránek pro stránkování paměti. Firma AMD uvedla podporu v procesoru Zen 4 vydaném v roce 2022. Podporu pro jádro Linuxu začala firma Intel vytvářet už v roce 2017. Tato vlastnost slouží k podpoře 57bitové adresace virtuální paměti, což je 128 PB (257=1,4×1017).[2]
Úrovně architektury
V roce 2020 definovaly firmy AMD, Intel, Red Hat a SUSE úrovně architektury (anglicky architecture levels) pro 64bitové procesory Intel-kompatibilních procesorů,[3] které slouží k tomu, aby bylo možné lépe využívat rozšiřujících schopnosti novějších procesorů v knihovnách i v běžných programech. Definované úrovně architektury jsou:
- x86-64-v1 – nejstarší 64bitové procesory (AMD Opteron z roku 2003, Intel Xeon Nocona z roku 2004)
- x86-64-v2 – instrukce sady SSE4.2, SSSE3, instrukci POPCNT a CMPXCHG16B (Intel Nehalem z roku 2008, AMD Bulldozer z roku 2011)
- x86-64-v3 – vektorové instrukce do AVX2, MOVBE (AMD Excavator z roku 2015, Intel Haswell z roku 2013)[4]
- x86-64-v4 – vektorové instrukce od variant AVX-512 (AMD Zen 4 z roku 2022, některé modely Intel Skylake od roku 2015, mimo procesorů Atom)[3]
V roce 2022 byl stanoven minimální požadavek na x86-64 procesor v Red Hat Enterprise Linuxu verze 9 na x86-64-v2 (na starších neběží),[3] pro verzi RHEL 10 se uvažuje o minimálním požadavku na x86-64-v3.[5] K rozlišení schopností procesorů je používána instrukce CPUID, úroveň architektury lze v Linuxu zjistit uživatelsky různými způsoby (např. skriptem).[6]
Windows 8 (rok 2012) vyžadují procesor s podporou SSE2, čemuž vyhověly všechny 64bitové procesory (některé 32bitové však nikoliv). Od Windows 8.1 (rok 2013) byly na 64bitové platformě požadovány některé strojové instrukce, které chyběly u prvních 64bitových procesorů Intel a AMD (CMPXCHG16b, PrefetchW and LAHF/SAHF).[2] Windows 11 od svého vydání v roce 2021 vyžadují alespoň 8. generaci procesorů Intel Coffee Lake z roku 2017, ale běh na starších procesorech je v roce 2024 stále možný, pokud splní podmínku pro verzi 8.1.[7] Windows 11 budou od verze 24H2 (tj. od konce roku 2024) vyžadovat procesor alespoň s instrukční sadou SSE 4.2,[8] což je úroveň architektury x86-64-v2 (tj. procesory od roku 2008).
64bitový režim
Je-li na počítači s 64bitovým procesorem (x86-64) spuštěn 64bitový operační systém, je možné přímo spouštět 64bitové i 32bitové aplikace v chráněném režimu. Dále je možné spouštět 16bitové aplikace v chráněném režimu procesoru Intel 80286, avšak nelze spouštět 16bitové aplikace v reálném režimu procesoru Intel 8086.
V 64bitových Windows NT (např. Windows 7 nebo Windows 10) však subsystém NTVDM nepodporuje běh 16bitových aplikací v chráněném režimu procesoru Intel 80286, takže je nelze spustit, i když hardwarové omezení pro to není. Omezení lze obejít pomocí virtualizace (spuštění virtualizovaného 32bitového nebo 16bitového systému a uvnitř něj pak požadované aplikace).
V 64bitovém systému Linux lze 16bitové aplikace v chráněném režimu procesoru Intel 80286 spouštět bez omezení pomocí Wine.
32bitový režim
Je-li na počítači se 64bitovým procesorem použit 32bitový systém, není možné spouštět 64bitové aplikace, ale je možné spouštět 16bitové aplikace jak v chráněném režimu procesoru Intel 80286, tak v reálném režimu procesoru Intel 8086.
16bitový režim
Na počítači s 64bitovým procesorem (x86-64) lze spustit 16bitový systém v reálném režimu (např. operační systém DOS), avšak pak nelze přímo spustit ani 32bitové ani 64bitové aplikace. Protože však v reálném 16bitovém režimu neexistuje žádná ochrana a žádná omezení (chybí privilegovaný režim), může si kterákoliv aplikace přepnout procesor do 32bitového nebo 64bitového režimu (jak to dělá např. DJGPP pro využití DPMI). Návrat zpět pak nemusí být bez restartu počítače možný.
Vývoj
Architektura AMD64 byla ohlášena roku 1999 společností AMD a plně specifikována v srpnu 2000 jako alternativa k radikálně odlišné architektuře IA-64, kterou se snažila prosadit dvojice Intel a Hewlett-Packard.[9] AMD64 byl evoluční krok CISC architektury podobný nástupu 32bitové architektury IA-32 na rozdíl od architektury IA-64 (procesor Itanium), která byla pokusem o prosazení nové zpětně nekompatibilní 64bitové architektury typu RISC. Jako první bylo na novou architekturu adaptováno jádro Linuxu v roce 2001 (ještě před fyzickou dostupností procesorů).[10][11] Jako první byl s podporou x86-64 v roce 2003 na trh uveden procesor Opteron. Původní označení x86-64 bylo společností AMD změněno na AMD64,[12] zatímco Intel používá u svých procesorů označení EM64T a IA-32E[13] a VIA „64-bit processors in VIA's x86 platform“.[14] Microsoft technologii nazývá „64-bit extended systems“ nebo x64.[13]
Základní rozšíření
Kvůli zpětné kompatibilitě je rozšíření realizováno jako další režimy procesoru. K reálnému, chráněnému a V86 režimu i386, nyní zvanými „Legacy“ (zděděný) režim, přibyly dva „Long“ (dlouhé) režimy: 64bitový a kompatibilní. Procesor je možné provozovat buď s 32bitovým jádrem operačního systému (kterým může být i systém určený pro i386) v Legacy režimech, nebo s 64bitovým jádrem v Long režimu – jádro potom běží v 64bitovém režimu a aplikace v 64bitovém nebo v kompatibilním režimu.
Většina vylepšení architektury se týká pouze 64bitového režimu, menšina i kompatibilního. Legacy režimy nemají žádné vylepšení (na rozdíl od i386, kde byl vylepšen i starý reálný režim).
- Plná podpora 64bitových celých čísel – veškeré aritmetické i logické operace se provádí v 64 bitech.
- Rozšíření registrů – registry byly rozšířeny na 64 bitů (stále je přístupná 32bitová, 16bitová a 8bitová část).
- Rozšíření počtu registrů – k původní sadě 8 'general-purpose' registrů přibylo dalších 8. To umožňuje držet více lokálních proměnných v registrech a tedy významně zrychluje aplikace. 16 registrů je ovšem stále málo v porovnání s RISCovými stroji. Zdvojnásoben z 8 na 16 byl i počet XMM registrů.
- Rozšíření virtuálního adresového prostoru – současné implementace AMD64 mohou adresovat 256 TiB (248), v budoucnu bude možné rozšířit na 16 EiB (264). Pointerová aritmetika běží v 64 bitech, omezení je dáno metodou překladu virtuálních adres na fyzické.
- Rozšíření fyzického adresového prostoru – původní implementace AMD64 mohla adresovat maximálně 1 TiB (240) RAM; od roku 2007 (AMD K10) je používáno 48 bitů, což je adresace maximálně 256 TiB; architektura umožňuje rozšíření až na 4 PiB (252). V legacy režimech je podporováno PAE (rozšíření fyzických adres), stejně jako na moderních procesorech architektury i386, umožňující přístup k 64 GiB.
- Adresace relativní k ukazateli instrukce – adresace relativní k RIP zvyšuje efektivitu kódu nezávislého na pozici používaného ve sdílených knihovnách.
- SSE instrukce – součástí architektury je povinná implementace rozšíření procesorů i386 SSE a SSE2 pro výpočty v pohyblivé řádové čárce. Podpora SSE3 byla přidána dodatečně.
- No-eXecute bit – stránku paměti je bitem NX možné označit jako obsahující pouze data a zabránit tak spuštění kódu z dané stránky. Tato vlastnost umožňuje chránit systém před většinou buffer overrun (přetečení bufferu) chyb, které často zneužívá k útoku malware.
- Odstranění starších vlastností – v Long režimu procesor nepodporuje některé méně používané vlastnosti i386, jako je segmentace paměti (částečně stále fungují registry FS a GS), TSS nebo v86.
Operační módy
Režim procesoru | Potřebný operační systém | Nutno znovu přeložit stávající programy | Výchozí velikost adresy | Výchozí velikost operandu | Je k dispozici 64bitové rozšíření registrů | Typická šířka registru | |
---|---|---|---|---|---|---|---|
Nové režimy | 64bitový Long | 64bitový OS | ano | 64 | 32 | ano | 64 |
Režim kompatibility | ne | 32 | 32 | ne | 32 | ||
16 | 16 | 16 | |||||
Dosavadní režimy | Chráněný režim | Klasický 16 nebo 32bitový OS | ne | 32 | 32 | ne | 32 |
16 | 16 | 16 | |||||
Virtuální 8086 režim | 16 | 16 | 16 | ||||
Reálný režim | Klasický 16bitový OS |
Podpora operačních systémů
Následuje popis některých operačních systémů, které podporují architekturu x86-64:
DOS
Je možné provozovat long mód pod DOSem bez DOS rozšíření, ale uživatel se musí vrátit do normálního módu BIOS nebo DOS přerušeními. Je dokonce možné vstoupit do long módu s rozšířením pro DOS podobně jako to dělá DOS/4GW, ale mnohem komplexněji od té doby, co x86-64 nemá virtuální 8086 mód.
Linux
Linux byl prvním z operačních systémů, který podporoval architekturu x86-64 v long módu. Učinil tak ve své verzi 2.4 z ledna 2001, a to ještě dříve, než byl dostupný x86-64 hardware. Linux ovšem také poskytuje zpětnou kompatibilitu pro spouštění 32bitových programů.
Několik linuxových distribucí je v současné době dodáváno s nativními x86-64 jádry. Některé, jako například Arch Linux, SUSE, Mandriva nebo Debian umožňují uživatelům instalovat 32bitové komponenty a knihovny, které poběží mimo x86-64. Jiné distribuce, například Fedora, Slackware nebo Ubuntu jsou dostupné ve verzích pro jak pro 32bitovou architekturu, tak i pro x86-64. Fedora a Red Hat Enterprise Linux dovolují instalaci všech komponent v obou verzích (32 i 64bitové) na 64bitový systém.
X32 ABI (Application Binary Interface), které bylo představeno ve verzi 3.4 jádra Linuxu, dovoluje programům kompilovaným pro x32 ABI běžet v 64bitovém módu, když se používají 32bitové ukazatele a datové pole. I když to limituje program k využití 4 GB paměti, také to snižuje nároky na paměť programu a v některých případech to umožní programu běžet rychleji.
64bitový Linux dovoluje využít až 128 TB virtuálního adresního prostoru pro jeden proces a umí adresovat téměř 64 TB fyzické paměti (musí se přihlížet k limitům procesoru a systému).
OS X
Mac OS X verze 10.4.7 a vyšší verze Mac OS X v10.4 umožňují běh 64bitových utilit příkazového řádku pomocí POSIXu a matematických knihoven na zařízeních s 64bitovými Intel procesory i 64bitovými PowerPC. Žádné jiné knihovny nebo frameworky nepracují s 64bitovými aplikacemi v Mac OS X v10.4. Jádro společně se svými rozšířeními je pouze 32bitové.
Mac OS X v10.5 podporuje 64bitové grafické aplikace a používá k tomu Cocoa, Quartz, OpenGL a X11 na zařízeních s 64bitovými Intel procesory i s 64bitovými PowerPC. Všechny negrafické knihovny a frameworky také podporují 64bitové verze. Jádro i jeho rozšíření jsou 32bitové.
Mac OS X v10.6 je první verze OS X, které má 64bitové jádro. Nicméně, ne všechny 64bitové počítače umožňují běh 64bitového jádra, a ne všechny, které to umí, to také implicitně dělají. 64bitové jádro, stejně jako to 32bitové, podporuje běh 32bitových aplikací. Obě jádra také podporují 64bitové aplikace. 32bitové aplikace mají virtuální adresní prostor limitovaný 4 GB pod jádrem.
OS X v10.7 a vyšší má pouze 64bitové jádro, ale je ponechaná podpora běhu 32bitových aplikací (a to dokonce i pro 64bitové počítače, které v Mac OS X 10.6 mohli používat pouze 32bitové jádro).
64bitové jádro nepodporuje 32bitové rozšíření jádra a 32bitové jádro nepodporuje 64bitové rozšíření jádra. Od OS X 10.9 lze používat pouze digitálně podepsaná 64bitová rozšíření jádra.
Solaris
Solaris 10 a pozdější podporují x86-64 architekturu. Solaris 10 (stejně jako architektura SPARC) má pouze jeden obraz operačního systému, který obsahuje 32 i 64bitové jádro. Má název „x64/x86“ DVD-ROM image. Výchozí chování je to, že se nabootuje 64bitové jádro umožňující běh 32 i 64bitových programů. 32bitové jádro může být zvoleno manuálně, ale znamená to, že bude umožněn běh pouze 32bitových aplikací. Příkazem isainfo
se zjistí, zda běží 64bitové jádro.
Solaris 11 už obsahuje pouze 64bitové jádro. Nicméně, 64bitové jádro podporuje 32 i 64bitové programy, knihovny a systémová volání.
Windows
Windows XP Professional x64 Edition a Windows Server 2003 x64 Edition byly prvními verzemi Windows s podporou 64bitového režimu. Obě tyto edice byly uvolněny v březnu 2005. Obě edice jsou interně stejného buildu (5.2.3790.1830 SP1). Obě sdílejí stejný zdroj a binárky, takže i systémové updaty jsou vydávány v unifikovaných balíčcích.[zdroj?]
- Windows Vista, který má mnoho různých edicí, byl vydán v lednu 2007.
- Windows 7 vyšel v červnu 2009.
- Windows Server 2008 (R2), od R2 dostupné pouze v 64bitových verzích.
- Windows Server 2012 (R2)
Windows x64 má tyto charakteristiky:
- 8 TB virtuálního adresního prostoru pro jeden proces (user mode). 64bitový program může využívat 8 TB v plném rozsahu, samozřejmě nehledě na limity systému. 8 TB je 4096× větší, než je poskytováno na 32bitových systémech Windows, tedy pouze 2 GB.
- 8 TB virtuálního adresního prostoru pro jádro. Nárůst je opět 4096× (viz virtuální adresní prostor pro jeden proces).
- Možnost běhu 32bitových aplikací (.exe) a dynamických knihoven (.dll) s použitím WoW64. Mimoto, pokud je 32bitový program nalinkován s možností „large address aware“, může použít až 4 GB virtuálního adresního prostoru v 64bitových Windows.
- Pokud nejsou 32 i 64bitové aplikace nalinkovány s možností „large address aware“, jsou limitovány 2 GB virtuálního adresního prostoru.
- Možnost využít fyzickou paměť (RAM) v těchto rozsazích: 128 GB (Windows XP a Vista), 192 GB (Windows 7), 512 GB (Windows 8) a 1 TB (Windows Server 2012).
- LLP64: datové typy int a long jsou široké 32 bitů, long long je 64bitový, pokud jsou ukazatele a typy odvozeny od 64bitových ukazatelů.
- Na 64bitových systémech musí být kernel mode ovladače 64bitové. User-mode ovladače mohou být 32bitové.
- 16bitové Windows a aplikace pro DOS neběží na 64bitových verzích Windows kvůli tomu, že byl odstraněn virtual DOS machine subsystém (NTVDM).
- Plná implementace ochrany NX (No Execute) page. To je také implementováno v 32bitových verzích Windows, když jsou spuštěny v PAE módu.
- Microsoft Visual Studio dokáže kompilovat nativní aplikace pro 64bitovou architekturu. Taková aplikace může být pouze spuštěna na 64bitových Windows nebo na architektuře IA-32, která dokáže spustit 32bitovou aplikaci na 32bitových Windows nebo 64bitových Windows s WoW64 emulačním módem.
BSD
Operační systémy DragonFly BSD, FreeBSD, NetBSD a OpenBSD také podporují 64bitovou architekturu.
Reference
V tomto článku byl použit překlad textu z článku x86-64 na anglické Wikipedii.
- ↑ Požadavky na systém Windows 7. [s.l.]: [s.n.] Dostupné online.
- ↑ a b LARABEL, Michael. Linux Looking To Make 5-Level Paging Support Unconditional For x86_64 Kernel Builds. Phoronix.com [online]. 2024-07-04 [cit. 2024-07-05]. Dostupné online. (anglicky)
- ↑ a b c WEIMER, Florian. Building Red Hat Enterprise Linux 9 for the x86-64-v2 microarchitecture level. Red Hat Developer [online]. 2021-01-05 [cit. 2024-07-04]. Dostupné online. (anglicky)
- ↑ JEŽEK, David. Red Hat Enterprise Linux 10 a úvahy o x86-64-v3. Root.cz [online]. 2024-01-03 [cit. 2024-07-05]. Dostupné online.
- ↑ WEIMER, Florian. Exploring x86-64-v3 for Red Hat Enterprise Linux 10. Red Hat Developer [online]. 2024-01-02 [cit. 2024-07-05]. Dostupné online. (anglicky)
- ↑ How do I check if my CPU supports x86-64-v2?. Unix & Linux Stack Exchange [online]. 2021-01-28 [cit. 2024-07-05]. Dostupné online. (anglicky)
- ↑ Instalace Windows 11 na zařízeních, která nesplňují minimální požadavky na systém. support.microsoft.com [online]. Podpora Microsoftu [cit. 2024-07-05]. Dostupné online.
- ↑ SOUČEK, Jiří. Windows 11 24H2 nenajedou bez SSE 4.2. Diit.cz [online]. 2024-04-25 [cit. 2024-04-25]. Dostupné online.
- ↑ Advanced Micro Devices: AMD Releases x86-64 Architectural Specification; Enables Market Driven Migration to 64-Bit Computing, tisková zpráva, August 10, 2000, [cit. 2007-08-03], Dostupné on-line.
- ↑ Andi Kleen. Porting Linux to x86-64 [online]. 2001-06-26 [cit. 2010-11-09]. Dostupné v archivu pořízeném dne 2010-09-10.
- ↑ Andi Kleen. Andi Kleen's Page [online]. Dostupné online.
- ↑ – The Debian GNU/Linux AMD64 HOW-TO. alioth.debian.org [online]. [cit. 2010-11-09]. Dostupné v archivu pořízeném dne 2010-11-13.
- ↑ a b – AMD64? X86-64? EM64T? X64? Anymore?
- ↑ VIA. VIA Nano™ Processor [online]. VIA [cit. 2010-11-09]. Dostupné v archivu pořízeném dne 2008-05-30. (anglicky)
Externí odkazy
- Matthew Kerner, Neil Padgett: A History of Modern 64-bit Computing