x86-64 (také AMD64/Intel64/EM64T) je 64bitová verze (původně rozšíření) architektury x86 vyvinutá společností AMD a představená v roce 2000 [1] , která umožňuje běh programů v 64bitovém režimu.
Jedná se o rozšíření architektury x86 a nyní jde o verzi architektury x86, která je téměř zcela zpětně kompatibilní s 32bitovou verzí architektury x86, nyní známou jako IA-32 .
Microsoft a Oracle používají termín „x64“ k označení této verze architektury x86, ale adresář obsahující soubory pro architekturu v 64bitovém systému Microsoft Windows se nazývá „amd64“ („i386“ pro x86). To je také pozorováno v repozitářích většiny distribucí Linuxu .
Instrukční sada x86-64 je aktuálně podporována:
Pro tuto 64bitovou x86 verzi platí následující konvence pojmenování:
V současné době jsou nejběžnější názvy pro 64bitovou verzi x86: "x64", "x86-64" a "AMD64".
Někdy zmínka o AMD uvádí uživatele v omyl, a to do té míry, že odmítají používat distribuce nativních verzí operačního systému s argumentem, že verze AMD nebude fungovat na jejich procesoru Intel – ve skutečnosti distributoři softwaru používají název amd64 pouze proto, že bylo to AMD, kdo byl průkopníkem vývoje 64bitové verze x86.
Uživatelé si často pletou architekturu x86-64 s IA-64 , omylem si stáhnou software pro tuto architekturu a pak zjistí, že se program nespustí. Aby se předešlo takovým chybám, je třeba mít na paměti, že Intel 64 a IA-64 jsou zcela odlišné, nekompatibilní architektury mikroprocesorů. Ten je nekompatibilní s x86-64.
Zástupci Intel 64:
Zástupci IA-64: rodiny Itanium a Itanium 2 .
Procesory této architektury podporují dva provozní režimy: Dlouhý režim ("dlouhý" režim) a Legacy režim ("zděděný" - režim kompatibility s 32bitovým x86).
Režim „Long“ je „nativní“ pro procesory AMD64. Tento režim umožňuje plně využít architekturu x86-64. Tento režim vyžaduje jakýkoli 64bitový operační systém (například Windows Server 2003/2003R2/2008/2008R2/2012, Windows XP Professional x64 Edition, Windows Vista x64, Windows 7/8/8.1/10/11 x64 nebo 64bitový varianty systémů podobných UNIX GNU/Linux , FreeBSD , OpenBSD , NetBSD (čistá 64bitová sestavení však mají schopnost spouštět 32bitové aplikace), Solaris (smíšené 32/64 sestavení s různými jádry pro 32bitové a 64bitové procesory), Mac OS X (smíšené 32/64 sestavení s 32bitovým jádrem, počínaje verzí 10.4.7).
Tento režim umožňuje spouštět 64bitové programy. Také (kvůli zpětné kompatibilitě) je poskytována podpora pro spouštění 32bitového kódu, například 32bitové aplikace (32bitové programy přirozeně, i když běží na 64bitovém systému, nebudou moci používat 64bitové -bitové systémové knihovny a naopak). Pro splnění tohoto úkolu poskytuje většina 64bitových operačních systémů dvě sady požadovaných systémových rozhraní API : jednu pro nativní 64bitové aplikace a jednu pro 32bitové programy (stejná technika používaná ranými 32bitovými systémy, jako jsou Windows 95 a Windows NT pro spouštění 16bitových programů).
V „dlouhém“ režimu je zrušena řada „základů“ architektury x86-32 , zejména virtuální režim 8086 , model segmentované paměti (zůstává však možné používat segmenty FS a GS, které je užitečný pro rychlé vyhledání důležitých dat vláken při přepínání úloh), hardwarový multitasking a také řadu příkazů, které implementují již nepodporované funkce a pracují s čísly BCD , které se v nových programech prakticky nepoužívaly. Režim "dlouhý" se aktivuje nastavením příznaku CR0.PG, který se používá k povolení stránkovacího MMU (za předpokladu, že je takové přepínání povoleno (EFER.LME=1), jinak jednoduše povolí MMU v "legacy" režimu ). Je tedy nemožné provést 64bitový kód se zakázaným stránkováním. To vytváří určité potíže při programování, protože při přepínání z „dlouhého“ do „staršího“ režimu a naopak (například pro volání funkcí BIOS nebo DOS , monitor virtuálního stroje atd.) je vyžadován dvojitý reset MMU, pro které musí být kód přepínače na identicky vykreslené stránce.
Tento „starší“ režim umožňuje procesoru x86-64 provádět instrukce pro procesory x86, a tak realizuje plnou kompatibilitu s 32bitovým kódem a 32bitovými operačními systémy pro x86. V tomto režimu se procesor chová úplně stejně jako procesor x86 (například Athlon nebo Pentium III). Funkce a vlastnosti poskytované architekturou x86-64 (například 64bitové registry) samozřejmě nejsou v tomto režimu dostupné. V tomto režimu nebudou fungovat 64bitové programy a operační systémy.
Instrukční sada x86-64 od AMD (později přejmenovaná na AMD64) je rozšířením architektury Intel IA-32 (x86-32). Hlavním rozlišovacím znakem AMD64 je podpora 64bitových obecných registrů, 64bitových aritmetických a logických operací na celých číslech a 64bitových virtuálních adres. Pro adresování nových registrů pro příkazy byly zavedeny tzv. "register extension prefixy", pro které byl zvolen rozsah kódů 40h-4Fh, používané pro příkazy INC <register> a DEC <register> v 32bitových režimech. Příkazy INC a DEC v 64bitovém režimu musí být kódovány v obecnější dvoubajtové podobě.
Architektura x86-64 má:
Při vývoji architektury AMD64 (implementace AMD x86-64) se inženýři AMD rozhodli navždy skoncovat s hlavním „základem“ architektury x86 – modelem segmentované paměti, který je podporován od 8086 . Kvůli tomu se však programátoři VMware při vývoji první x86-64 verze svého virtualizačního produktu setkali s nepřekonatelnými obtížemi při implementaci virtuálního stroje pro 64bitové hostující systémy [2] : protože program používal segmentační mechanismus, stal se tento úkol téměř neřešitelné.
AMD si chybu uvědomilo a vrátilo omezenou verzi organizace segmentované paměti, počínaje revizí D architektury AMD64, která umožňovala provoz 64bitových OS na virtuálních strojích . Intel se neřídil tímto příkladem a na jeho procesorech, které nepodporují Intel VT (Intel Virtualization Technology) [3] nástroje pro hardwarovou virtualizaci , není možné provozovat 64bitový virtuální stroj [4] . Pro kontrolu, zda procesor může provozovat 64bitové hostující OS, poskytuje VMware se svými produkty speciální nástroj.
Spuštění a instalace 64bitových hostujících systémů v současné době (od roku 2013) je již možné (produkt VMware - ESXi (pracovní stanice atd.) - podporuje architekturu x86-64).
Je třeba poznamenat, že příkazy LAHF a SAHF, které zpočátku padly pod nůž, které jsou také aktivně využívány virtualizačním softwarem, byly poté vráceny do systému příkazů. S rozšířením hardwarových virtualizačních nástrojů (Intel VT, AMD-V) postupně zmizí potřeba segmentace.
procesorů | Technologie digitálních|||||||||
---|---|---|---|---|---|---|---|---|---|
Architektura | |||||||||
Architektura instrukční sady | |||||||||
strojové slovo | |||||||||
Rovnoběžnost |
| ||||||||
Implementace | |||||||||
Komponenty | |||||||||
Řízení spotřeby |