Jump to content

32-bit computing

From Wikipedia, the free encyclopedia
(Redirected from 32 bits)

32-bit computing refers to computer architectures with a processor, memory, and other major components that operate on 32-bit units of data.[1][2] Compared to smaller bit widths, 32-bit computers can perform large calculations more efficiently and process more data per clock cycle. From the 1980s to about 2006, typical 32-bit personal computers had a 32-bit address bus, permitting up to 4 GiB of RAM to be accessed.[3]

32-bit designs have been used since the earliest days of electronic computing, in experimental systems and then in large mainframe and minicomputer systems. The first hybrid 16/32-bit microprocessor, the Motorola 68000, was introduced in the late 1970s and used in systems such as the original Macintosh. Fully 32-bit microprocessors such as the HP FOCUS, Motorola 68020 and Intel 80386 were launched in the early to mid 1980s and became dominant by the early 1990s. This generation of processors enabled the first mass-adoption of the World Wide Web. While 32-bit architectures are still widely used in specific applications, since the mid-2000s PCs, smartphones, and servers have moved on to 64 bits using architectures such as x86-64, with installed memory in entry-level computers often exceeding the 32-bit address limit of 4 GiB.[citation needed]

Range for storing integers

[edit]

A 32-bit register can store 232 different values. The range of integer values that can be stored in 32 bits depends on the representation used. With the two most common representations, the range is 0 through 4,294,967,295 (232 − 1) for representation as an (unsigned) binary number, and −2,147,483,648 (−231) through 2,147,483,647 (231 − 1) for representation as two's complement.

This means a processor with 32-bit logical or virtual addresses can directly access at most 4 GiB of byte-addressable address space. A processor with 32-bit physical addresses can directly access at most 4 GiB of byte-addressable main memory; 32-bit processors don't necessarily always use 32-bit physical addresses, and implementations using more or fewer exist.[4]

Technical history

[edit]
A 1984 Motorola 68020 prototype. It features a 32-bit ALU, addresses, and data buses.

In 1948 the Manchester Baby, the first stored-program electronic computer, used a 32-bit architecture although it was only a proof of concept and had little practical capacity. It held only 32 32-bit words of RAM on a Williams tube, and had no addition operation, only subtraction.

Memory, other digital circuits, and wiring was expensive during the first decades of 32-bit architectures (the 1960s to the 1980s).[5] Older 32-bit processor families often had many compromises and limitations to cut costs. This could include a 16-bit ALU, or buses narrower than 32 bits, which limited memory size or reduced the speed of operations.

These early processors are still 32-bit, having 32-bit registers and instructions to manipulate 32-bit quantities. For example, the IBM System/360 Model 30 had an 8-bit ALU, 8-bit internal data paths, and an 8-bit path to memory,[6] and the original Motorola 68000 had a 16-bit data ALU and a 16-bit external data bus, but had 32-bit registers and a 32-bit oriented instruction set. The 68000 design was sometimes referred to as 16/32-bit.[7]

However, the opposite is often true for newer 32-bit designs. For example, the Pentium Pro processor is a 32-bit machine, with 32-bit registers and instructions that manipulate 32-bit quantities, but has an 36 bit wide external address bus, giving a larger address space than 4 GB, and a 64 bit wide external data bus, allowing more efficient prefetch of instructions and data.[8] Likewise, the PowerPC 604 is a 32-bit machine with a 64-bit external data bus.[9]

Architectures

[edit]

Prominent 32-bit instruction set architectures used in general-purpose computing include the IBM System/360, IBM System/370 (which had 24-bit addressing), System/370-XA, ESA/370, and ESA/390 (which had 31-bit addressing), the DEC VAX, the NS320xx, the Motorola 68000 family (the first two models of which had 24-bit addressing), the Intel IA-32 32-bit version of the x86 architecture, and the 32-bit versions of the ARM,[10] SPARC, MIPS, PowerPC and PA-RISC architectures. 32-bit instruction set architectures used for embedded computing include the 68000 family and ColdFire, x86, ARM, MIPS, PowerPC, and Infineon TriCore architectures.

Applications

[edit]

On the x86 architecture, 32-bit applications normally use the 32-bit linear address space possible with the 80386 and later chips. The term came about because MS-DOS, Windows and OS/2[11] were originally written for the 8088/8086 or 80286, 16-bit microprocessors with a segmented address space where programs had to switch between segments to reach more than 64 kilobytes of memory, causing performance to suffer. Programming with segments is complicated; requiring special keywords or memory models in assembly and high level languages.

The 80386 and successors support the 80286's 16-bit segments reuse the technique for 32-bit address offsets. If the base address of all 32-bit segments is set to 0, and segment registers are not used explicitly, the segmentation can be forgotten and the processor appears as having a simple linear 32-bit address space. Operating systems like Windows or OS/2 provide the possibility to run 16-bit (segmented) programs as well as 32-bit programs. The former possibility exists for backward compatibility and the latter is usually meant to be used for new software development.[12]

Images

[edit]

32-bit digital images usually refers to RGBA color space, with every pixel using eight bits each for red, green, blue and transparency. Other image formats such as RGBE also use 32 bits per pixel.

In digital images, 32-bit sometimes refers to high-dynamic-range imaging (HDR) formats that use 32 bits per channel, a total of 96 bits per pixel. 32-bit-per-channel images are used to represent values more precisely than sRGB color space allows. This precision can be used to retain more detail when editing the image.

File formats

[edit]

A 32-bit file format is a binary file format for which each elementary information is defined on 32 bits (or 4 bytes). An example of such a format is the Enhanced Metafile Format.

See also

[edit]

References

[edit]
  1. ^ Prosise, Jeff (1995-11-07). "16 or 32 Bits: Should It Matter to You?". PC Magazine. pp. 321–322. Retrieved 2022-11-30.
  2. ^ Buchanan, William (1997). Software Development for Engineers : C/C++, Pascal, Assembly, Visual Basic, HTML, Java Script, Java DOS, Windows NT, UNIX. Burlington: Elsevier Science. p. 230. ISBN 978-0-08-054137-2. OCLC 854975383.
  3. ^ Venkateswarlu, N.B. (2012). Essential Computer and IT Fundamentals for Engineering and Science Students. S. Chand Publishing. p. 143. ISBN 978-81-219-4047-4.
  4. ^ Harris, David Money; Harris, Sarah L. (2013). Digital Design and Computer Architecture. Elsevier. p. 567. ISBN 978-0-12-394424-5.
  5. ^ Patterson, David; Ditzel, David (2000). Readings in Computer Architecture. San Diego: Academic Press. p. 136. ISBN 9781558605398.
  6. ^ IBM System/360 Model 30 Functional Characteristics (PDF). IBM. August 1971. pp. 8, 9. GA24-3231-7.
  7. ^ "Motorola 68000 Family Programmer's Reference Manual" (PDF). 1992. p. 1-1. Retrieved 18 January 2022.
  8. ^ Gwennap, Linley (16 February 1995). "Intel's P6 Uses Decoupled Superscalar Design" (PDF). Microprocessor Report. Retrieved 3 December 2012.
  9. ^ Gwennap, Linley (April 18, 1994). "PPC 604 Powers Past Pentium" (PDF). Microprocessor Report. 8 (5). Retrieved 8 December 2025.
  10. ^ "ARM architecture overview" (PDF).
  11. ^ There were also variants of UNIX for the 80286.
  12. ^ This article is based on material taken from 32-bit+application at the Free On-line Dictionary of Computing prior to 1 November 2008 and incorporated under the "relicensing" terms of the GFDL, version 1.3 or later.
[edit]