IA-32: Difference between revisions
No edit summary |
m →top: Copy edit ▸ Content ▸ Suggested detail added for context. Tags: Mobile edit Mobile app edit Android app edit App select source |
||
(91 intermediate revisions by 53 users not shown) | |||
Line 1: | Line 1: | ||
{{ |
{{Short description|32-bit version of x86 architecture}} |
||
{{About|the 32-bit version of the Intel x86 instruction set architecture|the x86 instruction set architecture in general|x86}} |
|||
{{Use |
{{Use mdy dates|date=October 2018}} |
||
'''IA-32''' (short for "'''Intel Architecture, 32-bit'''", |
'''IA-32''' (short for "'''Intel Architecture, 32-bit'''", commonly called ''i386''<ref name="Ditto" /><ref name="Intelli" />)<ref name="Adm" /> is the [[32-bit]] version of the [[x86]] [[instruction set architecture]], designed by [[Intel]] and first implemented in the [[i386|80386]] [[microprocessor]] in 1985. IA-32 is the first incarnation of x86 that supports 32-bit computing;<ref>{{Cite web |
||
|url = http://www.intel.com/content/www/us/en/processors/architectures-software-developer-manuals.html |
|url = http://www.intel.com/content/www/us/en/processors/architectures-software-developer-manuals.html |
||
|title = Intel 64 and IA-32 Architectures Software Developer's Manual |
|title = Intel 64 and IA-32 Architectures Software Developer's Manual |
||
Line 9: | Line 10: | ||
|date = September 2014 |
|date = September 2014 |
||
|quote = The Intel386 processor was the first 32-bit processor in the IA-32 architecture family. It introduced 32-bit registers for use both to hold operands and for addressing. |
|quote = The Intel386 processor was the first 32-bit processor in the IA-32 architecture family. It introduced 32-bit registers for use both to hold operands and for addressing. |
||
|access-date = December 19, 2014 |
|||
⚫ | |||
|archive-date = January 26, 2012 |
|||
|archive-url = https://web.archive.org/web/20120126002939/http://www.intel.com/content/www/us/en/processors/architectures-software-developer-manuals.html |
|||
|url-status = live |
|||
⚫ | |||
Within various [[programming language]] directives, IA-32 is still sometimes referred to as the "i386" architecture. In some other contexts, certain iterations of the IA-32 ISA are sometimes labelled ''i486'', ''i586'' and ''i686'', referring to the instruction [[superset]]s offered by the [[i486|80486]], the [[P5 (microarchitecture)|P5]] and the [[P6 (microarchitecture)|P6 microarchitectures]] respectively. These updates offered numerous additions alongside the base IA-32 set including [[X87|floating-point capabilities]] and the [[MMX (instruction set)|MMX extensions]]. |
|||
The IA-32 instruction set was introduced in the [[Intel]] 80386 microprocessor in 1985 and, {{As of|2017|lc=yes}}, remains supported by contemporary PC microprocessors. Even though the instruction set has remained intact, the successive generations of microprocessors that run it have become much faster. Within various [[programming language]] directives, IA-32 is still sometimes referred to as the "i386" architecture. |
|||
Intel was historically the largest manufacturer of IA-32 processors, with the second biggest supplier having been [[Advanced Micro Devices|AMD]]. During the 1990s, [[VIA Technologies|VIA]], [[Transmeta]] and other chip manufacturers also produced IA-32 compatible processors (e.g. [[WinChip]]). In the modern era, Intel still produced IA-32 processors under the [[Intel Quark]] [[microcontroller]] platform until 2019; however, since the 2000s, the majority of manufacturers (Intel included) moved almost exclusively to implementing CPUs based on the 64-bit variant of x86, [[x86-64]]. x86-64, by specification, offers legacy operating modes that operate on the IA-32 ISA for backwards compatibility. Even given the contemporary prevalence of x86-64, as of today, IA-32 protected mode versions of many modern operating systems are still maintained, e.g. [[Microsoft Windows]] (until [[Windows 10]]),<ref>{{Cite web|url=https://www.microsoft.com/en-us/windows/windows-10-specifications#primaryR2|title=Windows 10 System Requirements & Specifications {{!}} Microsoft|website=www.microsoft.com|language=en-us|access-date=August 20, 2018|archive-date=May 1, 2018|archive-url=https://web.archive.org/web/20180501190351/https://www.microsoft.com/en-us/windows/windows-10-specifications#primaryR2|url-status=live}}</ref> [[Windows Server]] (until [[Windows Server 2008]])<ref>{{Cite web|url=https://betanews.com/2007/05/16/windows-server-2008-the-last-32-bit-operating-system/|title=Windows Server 2008 'The Last 32-bit Operating System'|author=Scott M. Fulton, III|website=BetaNews|date=May 16, 2007|access-date=April 1, 2023|archive-date=April 1, 2023|archive-url=https://web.archive.org/web/20230401164555/https://betanews.com/2007/05/16/windows-server-2008-the-last-32-bit-operating-system/|url-status=live}}</ref> and the [[Debian]] [[Linux]] distribution.<ref>{{Cite web|url=https://www.debian.org/ports/i386/|title=Debian GNU/Linux on x86 Machines|access-date=August 20, 2020|archive-date=April 28, 2019|archive-url=https://web.archive.org/web/20190428051247/https://www.debian.org/ports/i386/|url-status=live}}</ref> In spite of IA-32's name (and causing some potential confusion), the 64-bit evolution of x86 that originated out of AMD would not be known as "IA-64", that name instead belonging to Intel's discontinued [[IA-64|Itanium architecture]]. |
|||
Intel is the inventor and the biggest supplier of IA-32 processors, and the second biggest supplier is [[Advanced Micro Devices|AMD]]. For a while, [[VIA Technologies|VIA]], [[Transmeta]] and others also produced IA-32 processors, but since the 2000s all manufacturers moved to the 64-bit variant of x86, [[x86-64]]. |
|||
== Architectural features == |
== Architectural features == |
||
⚫ | The primary defining characteristic of IA-32 is the availability of 32-bit general-purpose [[processor register]]s (for example, EAX and EBX), 32-bit [[Integer (computer science)|integer]] arithmetic and logical operations, 32-bit offsets within a segment in [[protected mode]], and the translation of segmented addresses to 32-bit linear addresses. The designers took the opportunity to make other improvements as well. Some of the most significant changes |
||
⚫ | The primary defining characteristic of IA-32 is the availability of 32-bit general-purpose [[processor register]]s (for example, EAX and EBX), 32-bit [[Integer (computer science)|integer]] arithmetic and logical operations, 32-bit offsets within a segment in [[protected mode]], and the translation of segmented addresses to 32-bit linear addresses. The designers took the opportunity to make other improvements as well. Some of the most significant changes (relative to the 16-bit [[Intel 80286|286]] instruction set) are: |
||
; 32-bit integer capability |
|||
: All [[general-purpose register]]s (GPRs) are expanded from 16 [[bit]]s to 32 bits, and all arithmetic and logical operations, memory-to-register and register-to-memory operations, etc., can operate directly on 32-bit integers. [[Stack (data structure)|Pushes and pops]] on the [[Stack register|stack]] default to 4-byte strides, and non-segmented [[pointer (computer programming)|pointers]] are 4 bytes wide. |
; 32-bit integer capability: All [[general-purpose register]]s (GPRs) are expanded from 16 [[bit]]s to 32 bits, and all arithmetic and logical operations, memory-to-register and register-to-memory operations, etc., can operate directly on 32-bit integers. [[Stack (data structure)|Pushes and pops]] on the [[Stack register|stack]] default to 4-byte strides, and non-segmented [[pointer (computer programming)|pointers]] are 4 bytes wide. |
||
; More general addressing modes |
|||
: Any GPR can be used as a base register, and any GPR other than ESP can be used as an index register, in a memory reference. The index register value can be multiplied by 1, 2, 4, or 8 before being added to the base register value and displacement. |
; More general addressing modes: Any GPR can be used as a base register, and any GPR other than ESP can be used as an index register, in a memory reference. The index register value can be multiplied by 1, 2, 4, or 8 before being added to the base register value and displacement. |
||
; Additional segment registers |
; Additional segment registers: Two additional segment registers, FS and GS, are provided. |
||
⚫ | |||
: Two additional segment registers, FS and GS, are provided. |
|||
⚫ | ; Demand paging: 32-bit linear addresses are virtual addresses rather than physical addresses; they are translated to physical addresses through a [[page table]]. In the 80386, [[80486]], and the [[P5 (microarchitecture)|original Pentium]] processors, the physical address was 32 bits; in the [[Pentium Pro]] and later processors, the [[Physical Address Extension]] allowed 36-bit physical addresses, although the linear address size was still 32 bits. |
||
; Larger virtual address space |
|||
⚫ | |||
; Demand paging |
|||
⚫ | : 32-bit linear addresses are virtual addresses rather than physical addresses; they are translated to physical addresses through a [[page table]]. In the 80386, [[80486]], and the [[P5 (microarchitecture)|original Pentium]] processors, the physical address was 32 bits; in the [[Pentium Pro]] and later processors, the [[Physical Address Extension]] allowed 36-bit physical addresses, although the linear address size was still 32 bits. |
||
== Operating modes == |
== Operating modes == |
||
Line 63: | Line 64: | ||
| 16-bit real-mode code |
| 16-bit real-mode code |
||
| 16 bits |
| 16 bits |
||
| 16 bits |
|||
| 16 or 32 bits |
|||
|- |
|||
| [[Unreal mode]] |
|||
| 16-bit real-mode operating system or boot loader, or 32-bit boot loader |
|||
| 16-bit real-mode code |
|||
| 32 bits |
|||
| 16 bits |
| 16 bits |
||
| 16 or 32 bits |
| 16 or 32 bits |
||
Line 68: | Line 76: | ||
== See also == |
== See also == |
||
{{Portal|Information technology}} |
|||
* [[x86-64]] |
|||
* [[IA-64]] |
* [[IA-64]] |
||
* [[List of former IA-32 compatible processor manufacturers]] |
* [[List of former IA-32 compatible processor manufacturers]] |
||
* [[Speculative execution CPU vulnerabilities]] |
|||
==References== |
==References== |
||
{{Reflist|30em|refs= |
{{Reflist|30em|refs= |
||
<ref name=Intelli>{{cite web|title=Additional Predefined Macros|url= |
<ref name=Intelli>{{cite web|title=Additional Predefined Macros|url=https://software.intel.com/content/www/us/en/develop/documentation/cpp-compiler-developer-guide-and-reference/top/compiler-reference/macros/additional-predefined-macros.html|work=software.intel.com|publisher=[[Intel]]|access-date=November 25, 2020|archive-date=February 15, 2021|archive-url=https://web.archive.org/web/20210215084323/https://software.intel.com/content/www/us/en/develop/documentation/cpp-compiler-developer-guide-and-reference/top/compiler-reference/macros/additional-predefined-macros.html|url-status=live}}</ref> |
||
<ref name=Ditto>{{cite web|title= |
<ref name=Ditto>{{cite web|title=ditto(1) Mac OS X Manual Page|url=https://developer.apple.com/library/mac/#documentation/Darwin/Reference/ManPages/man1/ditto.1.html|work=BSD General Commands Manual|publisher=[[Apple Inc.|Apple]]|access-date=August 3, 2013|date=December 19, 2008|quote=Thin Universal binaries to the specified architecture [...] should be specified as "i386", "x86_64", etc.|archive-date=June 2, 2012|archive-url=https://web.archive.org/web/20120602013413/https://developer.apple.com/library/mac/#documentation/Darwin/Reference/ManPages/man1/ditto.1.html|url-status=dead}}</ref> |
||
<ref name=Adm>{{cite web|last=Kemp|first=Steve|title=Running 32-bit Applications on 64-bit Debian GNU/Linux|url=http://www.debian-administration.org/articles/534|work=Debian Administration}}</ref> |
<ref name=Adm>{{cite web|last=Kemp|first=Steve|title=Running 32-bit Applications on 64-bit Debian GNU/Linux|url=http://www.debian-administration.org/articles/534|work=Debian Administration|access-date=August 31, 2013|archive-date=September 16, 2013|archive-url=https://web.archive.org/web/20130916160905/http://www.debian-administration.org/articles/534|url-status=dead}}</ref> |
||
<ref name="Generally so">{{cite web |first=Ronald W. |last=Green |title=What do IA-32, Intel 64 and IA-64 Architecture mean? |url=https://software.intel.com/en-us/articles/ia-32-intelr-64-ia-64-architecture-mean/ |website=software.intel.com |publisher=[[Intel]] |date= |
<ref name="Generally so">{{cite web |first=Ronald W. |last=Green |title=What do IA-32, Intel 64 and IA-64 Architecture mean? |url=https://software.intel.com/en-us/articles/ia-32-intelr-64-ia-64-architecture-mean/ |website=software.intel.com |publisher=[[Intel]] |date=May 5, 2009 |access-date=December 19, 2014 |archive-date=December 19, 2014 |archive-url=https://web.archive.org/web/20141219144304/https://software.intel.com/en-us/articles/ia-32-intelr-64-ia-64-architecture-mean/ |url-status=live }}</ref> |
||
<ref name="Generally So - Ubuntu">{{cite web|title=Supported Hardware|url=https://help.ubuntu.com/12.04/installation-guide/en.i386/ch02s01.html|work=Ubuntu Help|publisher=[[Canonical Ltd.|Canonical]]| |
<ref name="Generally So - Ubuntu">{{cite web|title=Supported Hardware|url=https://help.ubuntu.com/12.04/installation-guide/en.i386/ch02s01.html|archive-url=https://archive.today/20141219153039/https://help.ubuntu.com/12.04/installation-guide/en.i386/ch02s01.html|url-status=dead|archive-date=December 19, 2014|work=Ubuntu Help|publisher=[[Canonical Ltd.|Canonical]]|access-date=August 31, 2013}}</ref> |
||
}} |
}} |
||
Line 89: | Line 98: | ||
[[Category:Computer-related introductions in 1985]] |
[[Category:Computer-related introductions in 1985]] |
||
[[Category:X86 architecture]] |
[[Category:X86 architecture]] |
||
[[Category:32-bit computers]] |
Latest revision as of 09:47, 9 December 2024
IA-32 (short for "Intel Architecture, 32-bit", commonly called i386[1][2])[3] is the 32-bit version of the x86 instruction set architecture, designed by Intel and first implemented in the 80386 microprocessor in 1985. IA-32 is the first incarnation of x86 that supports 32-bit computing;[4] as a result, the "IA-32" term may be used as a metonym to refer to all x86 versions that support 32-bit computing.[5][6]
Within various programming language directives, IA-32 is still sometimes referred to as the "i386" architecture. In some other contexts, certain iterations of the IA-32 ISA are sometimes labelled i486, i586 and i686, referring to the instruction supersets offered by the 80486, the P5 and the P6 microarchitectures respectively. These updates offered numerous additions alongside the base IA-32 set including floating-point capabilities and the MMX extensions.
Intel was historically the largest manufacturer of IA-32 processors, with the second biggest supplier having been AMD. During the 1990s, VIA, Transmeta and other chip manufacturers also produced IA-32 compatible processors (e.g. WinChip). In the modern era, Intel still produced IA-32 processors under the Intel Quark microcontroller platform until 2019; however, since the 2000s, the majority of manufacturers (Intel included) moved almost exclusively to implementing CPUs based on the 64-bit variant of x86, x86-64. x86-64, by specification, offers legacy operating modes that operate on the IA-32 ISA for backwards compatibility. Even given the contemporary prevalence of x86-64, as of today, IA-32 protected mode versions of many modern operating systems are still maintained, e.g. Microsoft Windows (until Windows 10),[7] Windows Server (until Windows Server 2008)[8] and the Debian Linux distribution.[9] In spite of IA-32's name (and causing some potential confusion), the 64-bit evolution of x86 that originated out of AMD would not be known as "IA-64", that name instead belonging to Intel's discontinued Itanium architecture.
Architectural features
[edit]The primary defining characteristic of IA-32 is the availability of 32-bit general-purpose processor registers (for example, EAX and EBX), 32-bit integer arithmetic and logical operations, 32-bit offsets within a segment in protected mode, and the translation of segmented addresses to 32-bit linear addresses. The designers took the opportunity to make other improvements as well. Some of the most significant changes (relative to the 16-bit 286 instruction set) are:
- 32-bit integer capability
- All general-purpose registers (GPRs) are expanded from 16 bits to 32 bits, and all arithmetic and logical operations, memory-to-register and register-to-memory operations, etc., can operate directly on 32-bit integers. Pushes and pops on the stack default to 4-byte strides, and non-segmented pointers are 4 bytes wide.
- More general addressing modes
- Any GPR can be used as a base register, and any GPR other than ESP can be used as an index register, in a memory reference. The index register value can be multiplied by 1, 2, 4, or 8 before being added to the base register value and displacement.
- Additional segment registers
- Two additional segment registers, FS and GS, are provided.
- Larger virtual address space
- The IA-32 architecture defines a 48-bit segmented address format, with a 16-bit segment number and a 32-bit offset within the segment. Segmented addresses are mapped to 32-bit linear addresses.
- Demand paging
- 32-bit linear addresses are virtual addresses rather than physical addresses; they are translated to physical addresses through a page table. In the 80386, 80486, and the original Pentium processors, the physical address was 32 bits; in the Pentium Pro and later processors, the Physical Address Extension allowed 36-bit physical addresses, although the linear address size was still 32 bits.
Operating modes
[edit]Operating mode | Operating system required | Type of code being run | Default address size | Default operand size | Typical GPR width |
---|---|---|---|---|---|
Protected mode | 32-bit operating system or boot loader | 32-bit protected-mode code | 32 bits | 32 bits | 32 bits |
16-bit protected-mode operating system or boot loader, or 32-bit boot loader | 16-bit protected-mode code | 16 bits | 16 bits | 16 or 32 bits | |
Virtual 8086 mode | 16- or 32-bit protected-mode operating system | 16-bit real-mode code | 16 bits | 16 bits | 16 or 32 bits |
Real mode | 16-bit real-mode operating system or boot loader, or 32-bit boot loader | 16-bit real-mode code | 16 bits | 16 bits | 16 or 32 bits |
Unreal mode | 16-bit real-mode operating system or boot loader, or 32-bit boot loader | 16-bit real-mode code | 32 bits | 16 bits | 16 or 32 bits |
See also
[edit]- x86-64
- IA-64
- List of former IA-32 compatible processor manufacturers
- Speculative execution CPU vulnerabilities
References
[edit]- ^ "ditto(1) Mac OS X Manual Page". BSD General Commands Manual. Apple. December 19, 2008. Archived from the original on June 2, 2012. Retrieved August 3, 2013.
Thin Universal binaries to the specified architecture [...] should be specified as "i386", "x86_64", etc.
- ^ "Additional Predefined Macros". software.intel.com. Intel. Archived from the original on February 15, 2021. Retrieved November 25, 2020.
- ^ Kemp, Steve. "Running 32-bit Applications on 64-bit Debian GNU/Linux". Debian Administration. Archived from the original on September 16, 2013. Retrieved August 31, 2013.
- ^ "Intel 64 and IA-32 Architectures Software Developer's Manual". Intel Corporation. September 2014. p. 31. Archived from the original on January 26, 2012. Retrieved December 19, 2014.
The Intel386 processor was the first 32-bit processor in the IA-32 architecture family. It introduced 32-bit registers for use both to hold operands and for addressing.
- ^ Green, Ronald W. (May 5, 2009). "What do IA-32, Intel 64 and IA-64 Architecture mean?". software.intel.com. Intel. Archived from the original on December 19, 2014. Retrieved December 19, 2014.
- ^ "Supported Hardware". Ubuntu Help. Canonical. Archived from the original on December 19, 2014. Retrieved August 31, 2013.
- ^ "Windows 10 System Requirements & Specifications | Microsoft". www.microsoft.com. Archived from the original on May 1, 2018. Retrieved August 20, 2018.
- ^ Scott M. Fulton, III (May 16, 2007). "Windows Server 2008 'The Last 32-bit Operating System'". BetaNews. Archived from the original on April 1, 2023. Retrieved April 1, 2023.
- ^ "Debian GNU/Linux on x86 Machines". Archived from the original on April 28, 2019. Retrieved August 20, 2020.