IA-32: Difference between revisions
Guy Harris (talk | contribs) rvv |
bhj |
||
Line 12: | Line 12: | ||
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. |
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 sucks lADJk inytl antimalwar sofytwart o hiiujhn i droppeniod foodn on my floor plnmkj cyrr 32-bit boot loader |
|||
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 == |
|||
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 are described below. |
|||
; 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. |
|||
; 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 [[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 == |
|||
{| class="wikitable" |
|||
|- |
|||
! Operating mode |
|||
! [[Operating system]] required |
|||
! Type of code being run |
|||
! Default address size |
|||
! Default operand size |
|||
! Typical [[General-purpose register|GPR]] width |
|||
|- |
|||
| rowspan="2" | [[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-bit real-mode code |
||
| 16 bits |
| 16 bits |
Revision as of 11:37, 9 November 2017
IA-32 (short for "Intel Architecture, 32-bit", sometimes also called i386[1][2])[3] is the 32-bit version of the x86 instruction set architecture (ISA), first implemented in the Intel 80386 microprocessors 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]
The IA-32 instruction set was introduced in the Intel 80386 microprocessor in 1985 and, as of 2017[update], 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 sucks lADJk inytl antimalwar sofytwart o hiiujhn i droppeniod foodn on my floor plnmkj cyrr 32-bit boot loader | 16-bit real-mode code | 16 bits | 16 bits | 16 or 32 bits |}
See also
References
- ^ "DITTO". BSD General Commands Manual. Apple. 19 December 2008. Retrieved 3 August 2013.
Thin Universal binaries to the specified architecture [...] should be specified as "i386", "x86_64", etc.
- ^ "Additional Predefined Macros". intel.com. Intel. Retrieved 31 August 2013.
- ^ Kemp, Steve. "Running 32-bit Applications on 64-bit Debian GNU/Linux". Debian Administration.
- ^ "Intel 64 and IA-32 Architectures Software Developer's Manual". Intel Corporation. September 2014. p. 31.
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. (5 May 2009). "What do IA-32, Intel 64 and IA-64 Architecture mean?". software.intel.com. Intel. Retrieved 19 December 2014.
- ^ "Supported Hardware". Ubuntu Help. Canonical. Retrieved 31 August 2013.