Revision as of 17:02, 4 February 2023 editIdanST (talk | contribs)730 editsm →Timeline of eventsTags: Reverted use of deprecated (unreliable) source Visual edit← Previous edit | Latest revision as of 16:20, 15 December 2024 edit undoKvng (talk | contribs)Extended confirmed users, New page reviewers108,245 editsm unpiped links using script | ||
(27 intermediate revisions by 15 users not shown) | |||
Line 1: | Line 1: | ||
{{short description| |
{{short description|none}} | ||
⚫ | {{History of computing}} | ||
{{multiple issues| | {{multiple issues| | ||
{{More citations needed|date=March 2009}} | {{More citations needed|date=March 2009}} | ||
{{Original research|date=March 2009}} | {{Original research|date=March 2009}} | ||
}} | }} | ||
⚫ | {{History of computing}} | ||
The '''history of general-purpose ]s''' is a continuation of the earlier ]. | The '''history of general-purpose ]s''' is a continuation of the earlier ]. | ||
Line 16: | Line 18: | ||
By the end of the 1950s, commercial builders had developed factory-constructed, truck-deliverable computers. The most widely installed computer was the ], which used ] onto which programs were loaded using either paper ] or ]s. Some very high-end machines also included ] which provided higher speeds. ]s were also starting to grow popular. | By the end of the 1950s, commercial builders had developed factory-constructed, truck-deliverable computers. The most widely installed computer was the ], which used ] onto which programs were loaded using either paper ] or ]s. Some very high-end machines also included ] which provided higher speeds. ]s were also starting to grow popular. | ||
A computer is an automatic ]. The type of number system affects the way it works. In the early 1950s, most computers were built for specific numerical processing tasks, and many machines used decimal numbers as their basic number system; that is, the mathematical functions of the machines worked in base-10 instead of base-2 as is common today. These were not merely ] (BCD). Most machines had ten vacuum tubes per digit in each ]. Some early ] computer designers implemented systems based on ]; that is, a bit could have three states: +1, 0, or -1, corresponding to positive, zero, or negative voltage. | A computer is an automatic ]. The type of number system affects the way it works. In the early 1950s, most computers were built for specific numerical processing tasks, and many machines used decimal numbers as their basic number system; that is, the mathematical functions of the machines worked in base-10 instead of base-2 as is common today. These were not merely ] (BCD). Most machines had ten vacuum tubes per digit in each ]. Some early ] computer designers implemented systems based on ]; that is, a bit could have three states: +1, 0, or -1, corresponding to positive, zero, or negative voltage. | ||
An early project for the ], ] attempted to make a lightweight, simple computer by using binary arithmetic. It deeply impressed the industry. | An early project for the ], ] attempted to make a lightweight, simple computer by using binary arithmetic. It deeply impressed the industry. | ||
Line 33: | Line 35: | ||
To do this, they designed one ''reference computer'' named '']'' (S/360). This was a virtual computer, a reference instruction set, and abilities that all machines in the family would support. To provide different classes of machines, each computer in the family would use more or less hardware emulation, and more or less ] emulation, to create a machine able to run the full S/360 ]. | To do this, they designed one ''reference computer'' named '']'' (S/360). This was a virtual computer, a reference instruction set, and abilities that all machines in the family would support. To provide different classes of machines, each computer in the family would use more or less hardware emulation, and more or less ] emulation, to create a machine able to run the full S/360 ]. | ||
For instance, a low-end machine could include a very simple processor for low cost. However this would require the use of a larger microcode emulator to provide the rest of the instruction set, which would slow it down. A high-end machine would use a much more complex processor that could directly process more of the S/360 design, thus running a much simpler and faster emulator. | For instance, a low-end machine could include a very simple processor for low cost. However, this would require the use of a larger microcode emulator to provide the rest of the instruction set, which would slow it down. A high-end machine would use a much more complex processor that could directly process more of the S/360 design, thus running a much simpler and faster emulator. | ||
IBM chose consciously to make the reference ] quite complex, and very capable. Even though the computer was complex, its '']'' holding the ] would stay relatively small |
IBM chose consciously to make the reference ] quite complex, and very capable. Even though the computer was complex, its '']'' holding the ] would stay relatively small and could be made with very fast memory. Another important effect was that one instruction could describe quite a complex sequence of operations. Thus the computers would generally have to fetch fewer instructions from the main memory, which could be made slower, smaller and less costly for a given mix of speed and price. | ||
As the S/360 was to be a successor to both scientific machines like the ] and data processing machines like the ], it needed a design that could reasonably support all forms of processing. Hence the instruction set was designed to manipulate simple binary numbers, and text, scientific floating-point (similar to the numbers used in a calculator), and the ] arithmetic needed by accounting systems. | As the S/360 was to be a successor to both scientific machines like the ] and data processing machines like the ], it needed a design that could reasonably support all forms of processing. Hence the instruction set was designed to manipulate simple binary numbers, and text, scientific floating-point (similar to the numbers used in a calculator), and the ] arithmetic needed by accounting systems. | ||
Line 49: | Line 51: | ||
== 1970s: Microprocessor revolution == | == 1970s: Microprocessor revolution == | ||
] ] ]] | ] ] ]] | ||
The first commercial ], the ] (BCD) based ], was released by ] in 1971.<ref name="tout1">{{cite web|author=Nigel Tout|title=The Busicom 141-PF calculator and the Intel 4004 microprocessor|url=http://www.vintagecalculators.com/html/busicom_141-pf_and_intel_4004.html|access-date=November 15, 2009}}</ref><ref name="sasaki">{{cite web|last=Aspray|first=William|date=1994-05-25|title=Oral-History: Tadashi Sasaki|url=https://ethw.org/Oral-History:Tadashi_Sasaki|access-date=2022-09-14|website=Engineering and Technology History Wiki |publisher=The Institute of Electrical and Electronics Engineers, Inc.}}</ref> In March 1972, Intel introduced a microprocessor with an ] architecture, the ], an integrated ] re-implementation of the ] (TTL) based ] CPU. | The first commercial ], the ] (BCD) based ], was released by ] in 1971.<ref name="tout1">{{cite web|author=Nigel Tout|title=The Busicom 141-PF calculator and the Intel 4004 microprocessor|url=http://www.vintagecalculators.com/html/busicom_141-pf_and_intel_4004.html|access-date=November 15, 2009}}</ref><ref name="sasaki">{{cite web|last=Aspray|first=William|date=1994-05-25|title=Oral-History: Tadashi Sasaki|url=https://ethw.org/Oral-History:Tadashi_Sasaki|access-date=2022-09-14|website=Engineering and Technology History Wiki |publisher=The Institute of Electrical and Electronics Engineers, Inc.}}</ref> In March 1972, Intel introduced a microprocessor with an ] architecture, the ], an integrated ] re-implementation of the ] (TTL) based ] CPU. | ||
4004 designers ] and ] went on to design the 8008's successor, the ], a slightly more ]-like microprocessor, largely based on customer feedback on the limited 8008. Much like the 8008, it was used for applications such as terminals, printers, cash registers and industrial robots. However, the more able 8080 also became the original target CPU for an early ] ] ] called ] and was used for such demanding control tasks as ]s, and many other uses. Released in 1974, the 8080 became one of the first really widespread microprocessors. | 4004 designers ] and ] went on to design the 8008's successor, the ], a slightly more ]-like microprocessor, largely based on customer feedback on the limited 8008. Much like the 8008, it was used for applications such as terminals, printers, cash registers and industrial robots. However, the more able 8080 also became the original target CPU for an early ] ] ] called ] and was used for such demanding control tasks as ]s, and many other uses. Released in 1974, the 8080 became one of the first really widespread microprocessors. | ||
Line 61: | Line 63: | ||
Custom CISCs were commonly constructed using ''bit slice'' computer logic such as the AMD 2900 chips, with custom microcode. A bit slice component is a piece of an ] (ALU), register file or microsequencer. Most bit-slice integrated circuits were 4 bits wide. | Custom CISCs were commonly constructed using ''bit slice'' computer logic such as the AMD 2900 chips, with custom microcode. A bit slice component is a piece of an ] (ALU), register file or microsequencer. Most bit-slice integrated circuits were 4 bits wide. | ||
By the early 1970s, the ] ] ] was developed, arguably the most advanced small computer of its day. In the late |
By the early 1970s, the ] ] ] was developed, arguably the most advanced small computer of its day. In the late 1970s, wider-word ]s were introduced, such as the ] ]. | ||
IBM continued to make large, fast computers. However, the definition of large and fast now meant more than a megabyte of RAM, clock speeds near one megahertz,<ref>{{cite web|url=http://www.hometoys.com/mentors/caswell/sep00/trends01.htm|title=Twenty Technology Trends that Affect Home Networking|first=Wayne|last=Caswell|website=Home Toys|date=18 February 2008|archive-url=https://web.archive.org/web/20160327021421/https://hometoys.com/mentors/caswell/sep00/trends01.htm|archive-date=March 27, 2016}}</ref><ref>{{cite book|chapter-url=http://research.microsoft.com/users/GBell/Computer_Structures_Principles_and_Examples/csp0727.htm|chapter=The Structure of SYSTEM/360|title=Computer Structures: Principles and Examples}}</ref> and tens of megabytes of disk drives. | IBM continued to make large, fast computers. However, the definition of large and fast now meant more than a megabyte of RAM, clock speeds near one megahertz,<ref>{{cite web|url=http://www.hometoys.com/mentors/caswell/sep00/trends01.htm|title=Twenty Technology Trends that Affect Home Networking|first=Wayne|last=Caswell|website=Home Toys|date=18 February 2008|archive-url=https://web.archive.org/web/20160327021421/https://hometoys.com/mentors/caswell/sep00/trends01.htm|archive-date=March 27, 2016}}</ref><ref>{{cite book|chapter-url=http://research.microsoft.com/users/GBell/Computer_Structures_Principles_and_Examples/csp0727.htm|chapter=The Structure of SYSTEM/360|title=Computer Structures: Principles and Examples}}</ref> and tens of megabytes of disk drives. | ||
Line 71: | Line 73: | ||
All these different developments competed for market share. | All these different developments competed for market share. | ||
The first single-chip ] microprocessor was introduced in 1975. ], a conglomerate formed by Japanese companies ], ], and ], introduced the MN1610, a commercial 16-bit microprocessor.<ref name="16-bit Microprocessors">{{cite web|title=16-bit Microprocessors|url=http://www.cpu-museum.com/161x_e.htm|publisher=CPU Museum|access-date=5 October 2010}}</ref><ref name="fujitsu">{{cite web|title=History|url=http://www.pfu.fujitsu.com/en/profile/history.html|access-date=5 October 2010|publisher=]}}</ref><ref name="PANAFACOM Lkit-16">, ]</ref> According to Fujitsu, it was "the world's first 16-bit ] on a single chip".<ref name="fujitsu"/> | The first single-chip ] microprocessor was introduced in 1975. ], a conglomerate formed by Japanese companies ], ], and ], introduced the MN1610, a commercial 16-bit microprocessor.<ref name="16-bit Microprocessors">{{cite web|title=16-bit Microprocessors|url=http://www.cpu-museum.com/161x_e.htm|publisher=CPU Museum|access-date=5 October 2010}}</ref><ref name="fujitsu">{{cite web|title=History|url=http://www.pfu.fujitsu.com/en/profile/history.html|access-date=5 October 2010|publisher=]}}</ref><ref name="PANAFACOM Lkit-16">, ]</ref> According to Fujitsu, it was "the world's first 16-bit ] on a single chip".<ref name="fujitsu"/> | ||
The Intel 8080 was the basis for the 16-bit Intel ], which is a direct ancestor to today's ubiquitous ] family (including ] and ]). Every instruction of the 8080 has a direct equivalent in the large x86 instruction set, although the opcode values are different in the latter. | The Intel 8080 was the basis for the 16-bit Intel ], which is a direct ancestor to today's ubiquitous ] family (including ] and ]). Every instruction of the 8080 has a direct equivalent in the large x86 instruction set, although the opcode values are different in the latter. | ||
Line 118: | Line 120: | ||
===VLIW and EPIC=== | ===VLIW and EPIC=== | ||
The instruction scheduling logic that makes a superscalar processor is |
The instruction scheduling logic that makes a superscalar processor is ]. In the early 1990s, a significant innovation was to realize that the coordination of a multi-ALU computer could be moved into the ], the software that translates a programmer's instructions into machine-level instructions. | ||
This type of computer is called a '']'' (VLIW) computer. | This type of computer is called a '']'' (VLIW) computer. | ||
Line 179: | Line 181: | ||
* the ] (1962), then the fastest computer on Earth<!-- Built of discrete transistors, and thus, not a microprocessor. --> | * the ] (1962), then the fastest computer on Earth<!-- Built of discrete transistors, and thus, not a microprocessor. --> | ||
* The Caltech Asynchronous Microprocessor, the world-first asynchronous microprocessor (1988) | * The Caltech Asynchronous Microprocessor, the world-first asynchronous microprocessor (1988) | ||
* the ]-implementing ] (1993 and 2000) | * the ]-implementing ] (1993 and 2000) | ||
* the asynchronous implementation of ] ], named MiniMIPS (1998)<ref></ref> | * the asynchronous implementation of ] ], named MiniMIPS (1998)<ref></ref> | ||
* the SEAforth ] processor from ]<ref>{{cite web|url=http://www.intellasys.net/index.php?option=com_content&task=view&id=21&Itemid=41|title=SEAforth Overview|quote=... asynchronous circuit design throughout the chip. There is no central clock with billions of dumb nodes dissipating useless power. ... the processor cores are internally asynchronous themselves.|archive-url=https://web.archive.org/web/20080202055942/http://www.intellasys.net/index.php?option=com_content&task=view&id=21&Itemid=41 |archive-date=2008-02-02 |url-status=dead}}</ref> | * the SEAforth ] processor from ]<ref>{{cite web|url=http://www.intellasys.net/index.php?option=com_content&task=view&id=21&Itemid=41|title=SEAforth Overview|quote=... asynchronous circuit design throughout the chip. There is no central clock with billions of dumb nodes dissipating useless power. ... the processor cores are internally asynchronous themselves.|archive-url=https://web.archive.org/web/20080202055942/http://www.intellasys.net/index.php?option=com_content&task=view&id=21&Itemid=41 |archive-date=2008-02-02 |url-status=dead}}</ref> | ||
=== Optical communication === | === Optical communication === | ||
In theory, an optical computer's components could directly connect through a holographic or phased open-air switching system. This would provide a large increase in effective speed and design flexibility, and a large reduction in cost. Since a computer's connectors are also its most likely failure points, a busless system may be more reliable. | |||
Further, as of 2010, modern processors use 64- or 128-bit logic. Optical wavelength superposition could allow data lanes and logic many orders of magnitude higher than electronics, with no added space or copper wires. | Further, as of 2010, modern processors use 64- or 128-bit logic. Optical wavelength superposition could allow data lanes and logic many orders of magnitude higher than electronics, with no added space or copper wires. | ||
Line 198: | Line 200: | ||
=== Belt machine architecture === | === Belt machine architecture === | ||
Relative to conventional ] or ] architecture, yet similar to Intel's ] architecture,<ref>{{cite web|url=http://williams.comp.ncat.edu/comp375/RISCprocessors.pdf|title=RISC Processors COMP375 Computer Architecture and Organization|archive-url=https://web.archive.org/web/20171026001316/http://williams.comp.ncat.edu/comp375/RISCprocessors.pdf|archive-date=October |
Relative to conventional ] or ] architecture, yet similar to Intel's ] architecture,<ref>{{cite web|url=http://williams.comp.ncat.edu/comp375/RISCprocessors.pdf|title=RISC Processors COMP375 Computer Architecture and Organization|archive-url=https://web.archive.org/web/20171026001316/http://williams.comp.ncat.edu/comp375/RISCprocessors.pdf|archive-date=October 26, 2017|url-status=dead}}</ref> a temporal register addressing scheme has been proposed by Ivan Godard and company that is intended to greatly reduce the complexity of CPU hardware (specifically the number of internal registers and the resulting huge ] trees).<ref>{{cite web |url=http://ootbcomp.com/docs/belt/ |title=The Belt }}</ref> While somewhat harder to read and debug than general-purpose register names, it aids understanding to view the belt as a moving '']'' where the oldest values ''drop off'' the belt and vanish. It is implemented in the Mill architecture. | ||
== Timeline of events == | == Timeline of events == | ||
* 1964. ] release the 32-bit ] with memory protection. | * 1964. ] release the 32-bit ] with memory protection. | ||
* 1969. ]'s initial design led by Intel's Ted Hoff and ]'s ].<ref name="ieee">], , ''IEEE Solid-State Circuits Magazine'', Winter 2009, ]</ref> | * 1969. ]'s initial design led by Intel's Ted Hoff and ]'s ].<ref name="ieee">], , ''IEEE Solid-State Circuits Magazine'', Winter 2009, ]</ref> | ||
* 1970. Intel 4004's design completed by Intel's ] and Busicom's Masatoshi Shima.<ref name="ieee"/> | * 1970. Intel 4004's design completed by Intel's ] and Busicom's Masatoshi Shima.<ref name="ieee"/> | ||
* 1971. IBM release the ] successor to System/360. | * 1971. IBM release the ] successor to System/360. | ||
Line 210: | Line 212: | ||
* 1972. NEC release single-chip 4-bit microprocessor, μPD700.<ref name="shmj">, </ref><ref name="hart">Jeffrey A. Hart & Sangbae Kim (2001), , International Studies Association, Chicago</ref> | * 1972. NEC release single-chip 4-bit microprocessor, μPD700.<ref name="shmj">, </ref><ref name="hart">Jeffrey A. Hart & Sangbae Kim (2001), , International Studies Association, Chicago</ref> | ||
* 1973. NEC release 4-bit ] (μPD751),<ref name="shmj"/> combining the μPD707 and μPD708 into a single microprocessor.<ref name="antique"/> | * 1973. NEC release 4-bit ] (μPD751),<ref name="shmj"/> combining the μPD707 and μPD708 into a single microprocessor.<ref name="antique"/> | ||
* 1974. Intel release the ], an ] microprocessor, designed by ] and ]. | * 1974. Intel release the ], an ] microprocessor, designed by ] and ]. | ||
* 1975. ] release the 8-bit ], the first integrated processor to have an affordable price of $25 when the 6800 rival was $175. | * 1975. ] release the 8-bit ], the first integrated processor to have an affordable price of $25 when the 6800 rival was $175. | ||
* 1976. ] introduce the 8-bit ], designed by ] and ]. | * 1976. ] introduce the 8-bit ], designed by ] and ]. | ||
* 1977. ] introduced its first ] ] ], the ]/780. | * 1977. ] introduced its first ] ] ], the ]/780. | ||
* 1978. Intel introduces the ] and ], the first x86 chips. | * 1978. Intel introduces the ] and ], the first x86 chips. | ||
* 1978. ] releases the MB8843 microprocessor. | * 1978. ] releases the MB8843 microprocessor. | ||
Line 220: | Line 222: | ||
* 1981. ] introduced, one of the first ] (RISC) designs. | * 1981. ] introduced, one of the first ] (RISC) designs. | ||
* 1982. Intel introduces the ], which was the first Intel processor that could run all the software written for its predecessors, the 8086 and 8088. | * 1982. Intel introduces the ], which was the first Intel processor that could run all the software written for its predecessors, the 8086 and 8088. | ||
* 1984. ] introduces the ], which enabled full 32-bit addressing, and the ] ], which supported demand paging. | * 1984. ] introduces the ], which enabled full 32-bit addressing, and the ] ], which supported demand paging. | ||
* 1985. Intel introduces the ], which adds a 32-bit instruction set to the x86 microarchitecture, and supports demand paging. | * 1985. Intel introduces the ], which adds a 32-bit instruction set to the x86 microarchitecture, and supports demand paging. | ||
* 1985. ] introduced. | * 1985. ] introduced. | ||
Line 231: | Line 233: | ||
* 2000. IBM introduce ], the 64-bit version of their mainframe architecture. | * 2000. IBM introduce ], the 64-bit version of their mainframe architecture. | ||
* 2000. ] announced ] 64-bit extension to the x86 microarchitecture. | * 2000. ] announced ] 64-bit extension to the x86 microarchitecture. | ||
* 2000. AMD hits 1 GHz with its ] microprocessor. | * 2000. AMD hits 1 GHz with its ] microprocessor. | ||
* 2000. Analog Devices introduces the ] architecture. | * 2000. Analog Devices introduces the ] architecture. | ||
* 2002. Intel released a ] with ], the first modern desktop processor to implement ] (SMT). | * 2002. Intel released a ] with ], the first modern desktop processor to implement ] (SMT). | ||
* 2003. AMD released the ], the first ] consumer CPU. | * 2003. AMD released the ], the first ] consumer CPU. | ||
* 2003. Intel introduced the ], a low power mobile derivative of the Pentium Pro architecture. | * 2003. Intel introduced the ], a low power mobile derivative of the Pentium Pro architecture. | ||
* 2005. AMD announced the ], their first x86 ] processor. | * 2005. AMD announced the ], their first x86 ] processor. | ||
Line 241: | Line 243: | ||
* 2010. Intel introduced the ], ], and ], with 2, 4 and 4 cores respectively. | * 2010. Intel introduced the ], ], and ], with 2, 4 and 4 cores respectively. | ||
* 2011. ARM release ], supporting the 64-bit AAarch64 architecture. | * 2011. ARM release ], supporting the 64-bit AAarch64 architecture. | ||
* 2011. AMD announced the world's first ] CPU for ]. | * 2011. AMD announced the world's first ] CPU for ]s. | ||
* 2017. AMD announced ] processors based on the ] architecture, with up to 16 cores. | * 2017. AMD announced ] processors based on the ] architecture, with up to 16 cores. | ||
* 2017. Intel 8th generation Core i3, Core i5, Core i7 and Core i9, increased to approximately 4, 6, 8 and 8 cores respectively. | * 2017. Intel 8th generation Core i3, Core i5, Core i7 and Core i9, increased to approximately 4, 6, 8 and 8 cores respectively. | ||
* 2017. Over 100 billion Arm based CPUs shipped.<ref>{{Cite web|last=Segars|first=Simon|date=2017-02-27|title=Enabling mass IoT connectivity as ARM partners ship 100 billion chips|url=https://www.arm.com/company/news/2017/02/enabling-mass-iot-connectivity-as-arm-partners-ship-100-billion-chips |
* 2017. Over 100 billion Arm based CPUs shipped.<ref>{{Cite web|last=Segars|first=Simon|date=2017-02-27|title=Enabling mass IoT connectivity as ARM partners ship 100 billion chips|url=https://www.arm.com/company/news/2017/02/enabling-mass-iot-connectivity-as-arm-partners-ship-100-billion-chips|access-date=2021-09-06}}</ref> | ||
* 2020. ] |
* 2020. Apple launched their own ] ]-based ] (SoC), significant in that they switched their devices away from Intel CPUs.<ref name=":0">{{cite web | url=https://www.macrumors.com/guide/m1/ | title=Apple M1 Chip: Everything You Need to Know | publisher=MacRumors | date=2022-10-13| access-date=2024-07-21| author=Clover Juli}}</ref> | ||
* 2021. ARM release ] the first major upgrade in a decade, since Armv8 in 2011.<ref>{{Cite web|last=Takahashi|first=Dean|date=2021-03-30|title=Armv9 is Arm's first major architectural update in a decade|url=https://venturebeat.com/2021/03/30/armv9-is-arms-first-major-architectural-update-in-a-decade/ |
* 2021. ARM release ] the first major upgrade in a decade, since Armv8 in 2011.<ref>{{Cite web|last=Takahashi|first=Dean|date=2021-03-30|title=Armv9 is Arm's first major architectural update in a decade|url=https://venturebeat.com/2021/03/30/armv9-is-arms-first-major-architectural-update-in-a-decade/|access-date=2021-09-06|website=VentureBeat}}</ref> | ||
* 2021. Over 200 billion Arm based CPUs shipped.<ref>{{Cite web|last=Shilov|first=Anton|date=2021-10-20|title=Over 200 Billion Arm-Based Chips Shipped|url=https://www.tomshardware.com/news/over-200-billion-of-arm-chips-shipped |
* 2021. Over 200 billion Arm based CPUs shipped.<ref>{{Cite web|last=Shilov|first=Anton|date=2021-10-20|title=Over 200 Billion Arm-Based Chips Shipped|url=https://www.tomshardware.com/news/over-200-billion-of-arm-chips-shipped|access-date=2022-09-16}}</ref> | ||
* 2022 |
* 2022. ] processors power ], the world's most powerful supercomputer.<ref>{{cite web| url=https://top500.org/lists/top500/2022/06/|title=TOP500 List - June 2022|date=June 2022|access-date=2022-05-30}}</ref> | ||
* 2024. Apple launched the ], their first ] adopting the ARMv9 CPU architecture.<ref>{{cite web | url=https://www.phoronix.com/news/Apple-M4-Added-To-LLVM-Clang/ | title=Apple M4 Support Added To The LLVM Compiler, Confirming Its ISA Capabilities | publisher=Phoronix | date=2024-06-15| access-date=2024-07-21| author=Larabel Michael}}</ref> | |||
==See also== | ==See also== | ||
Line 268: | Line 271: | ||
] | ] | ||
] | ] | ||
] | ] |
Latest revision as of 16:20, 15 December 2024
This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages)
|
History of computing |
---|
Hardware |
Software |
Computer science |
Modern concepts |
By country |
Timeline of computing |
Glossary of computer science |
The history of general-purpose CPUs is a continuation of the earlier history of computing hardware.
1950s: Early designs
In the early 1950s, each computer design was unique. There were no upward-compatible machines or computer architectures with multiple, differing implementations. Programs written for one machine would run on no other kind, even other kinds from the same company. This was not a major drawback then because no large body of software had been developed to run on computers, so starting programming from scratch was not seen as a large barrier.
The design freedom of the time was very important because designers were very constrained by the cost of electronics, and only starting to explore how a computer could best be organized. Some of the basic features introduced during this period included index registers (on the Ferranti Mark 1), a return address saving instruction (UNIVAC I), immediate operands (IBM 704), and detecting invalid operations (IBM 650).
By the end of the 1950s, commercial builders had developed factory-constructed, truck-deliverable computers. The most widely installed computer was the IBM 650, which used drum memory onto which programs were loaded using either paper punched tape or punched cards. Some very high-end machines also included core memory which provided higher speeds. Hard disks were also starting to grow popular.
A computer is an automatic abacus. The type of number system affects the way it works. In the early 1950s, most computers were built for specific numerical processing tasks, and many machines used decimal numbers as their basic number system; that is, the mathematical functions of the machines worked in base-10 instead of base-2 as is common today. These were not merely binary-coded decimal (BCD). Most machines had ten vacuum tubes per digit in each processor register. Some early Soviet computer designers implemented systems based on ternary logic; that is, a bit could have three states: +1, 0, or -1, corresponding to positive, zero, or negative voltage.
An early project for the U.S. Air Force, BINAC attempted to make a lightweight, simple computer by using binary arithmetic. It deeply impressed the industry.
As late as 1970, major computer languages were unable to standardize their numeric behavior because decimal computers had groups of users too large to alienate.
Even when designers used a binary system, they still had many odd ideas. Some used sign-magnitude arithmetic (-1 = 10001), or ones' complement (-1 = 11110), rather than modern two's complement arithmetic (-1 = 11111). Most computers used six-bit character sets because they adequately encoded Hollerith punched cards. It was a major revelation to designers of this period to realize that the data word should be a multiple of the character size. They began to design computers with 12-, 24- and 36-bit data words (e.g., see the TX-2).
In this era, Grosch's law dominated computer design: computer cost increased as the square of its speed.
1960s: Computer revolution and CISC
One major problem with early computers was that a program for one would work on no others. Computer companies found that their customers had little reason to remain loyal to a given brand, as the next computer they bought would be incompatible anyway. At that point, the only concerns were usually price and performance.
In 1962, IBM tried a new approach to designing computers. The plan was to make a family of computers that could all run the same software, but with different performances, and at different prices. As users' needs grew, they could move up to larger computers, and still keep all of their investment in programs, data and storage media.
To do this, they designed one reference computer named System/360 (S/360). This was a virtual computer, a reference instruction set, and abilities that all machines in the family would support. To provide different classes of machines, each computer in the family would use more or less hardware emulation, and more or less microprogram emulation, to create a machine able to run the full S/360 instruction set.
For instance, a low-end machine could include a very simple processor for low cost. However, this would require the use of a larger microcode emulator to provide the rest of the instruction set, which would slow it down. A high-end machine would use a much more complex processor that could directly process more of the S/360 design, thus running a much simpler and faster emulator.
IBM chose consciously to make the reference instruction set quite complex, and very capable. Even though the computer was complex, its control store holding the microprogram would stay relatively small and could be made with very fast memory. Another important effect was that one instruction could describe quite a complex sequence of operations. Thus the computers would generally have to fetch fewer instructions from the main memory, which could be made slower, smaller and less costly for a given mix of speed and price.
As the S/360 was to be a successor to both scientific machines like the 7090 and data processing machines like the 1401, it needed a design that could reasonably support all forms of processing. Hence the instruction set was designed to manipulate simple binary numbers, and text, scientific floating-point (similar to the numbers used in a calculator), and the binary-coded decimal arithmetic needed by accounting systems.
Almost all following computers included these innovations in some form. This basic set of features is now called complex instruction set computing (CISC, pronounced "sisk"), a term not invented until many years later, when reduced instruction set computing (RISC) began to get market share.
In many CISCs, an instruction could access either registers or memory, usually in several different ways. This made the CISCs easier to program, because a programmer could remember only thirty to a hundred instructions, and a set of three to ten addressing modes rather than thousands of distinct instructions. This was called an orthogonal instruction set. The PDP-11 and Motorola 68000 architecture are examples of nearly orthogonal instruction sets.
There was also the BUNCH (Burroughs, UNIVAC, NCR, Control Data Corporation, and Honeywell) that competed against IBM at this time; however, IBM dominated the era with S/360.
The Burroughs Corporation (which later merged with Sperry/Univac to form Unisys) offered an alternative to S/360 with their Burroughs large systems B5000 series. In 1961, the B5000 had virtual memory, symmetric multiprocessing, a multiprogramming operating system (Master Control Program (MCP)), written in ALGOL 60, and the industry's first recursive-descent compilers as early as 1964.
1970s: Microprocessor revolution
The first commercial microprocessor, the binary-coded decimal (BCD) based Intel 4004, was released by Intel in 1971. In March 1972, Intel introduced a microprocessor with an 8-bit architecture, the 8008, an integrated pMOS logic re-implementation of the transistor–transistor logic (TTL) based Datapoint 2200 CPU.
4004 designers Federico Faggin and Masatoshi Shima went on to design the 8008's successor, the Intel 8080, a slightly more minicomputer-like microprocessor, largely based on customer feedback on the limited 8008. Much like the 8008, it was used for applications such as terminals, printers, cash registers and industrial robots. However, the more able 8080 also became the original target CPU for an early de facto standard personal computer operating system called CP/M and was used for such demanding control tasks as cruise missiles, and many other uses. Released in 1974, the 8080 became one of the first really widespread microprocessors.
By the mid-1970s, the use of integrated circuits in computers was common. The decade was marked by market upheavals caused by the shrinking price of transistors.
It became possible to put an entire CPU on one printed circuit board. The result was that minicomputers, usually with 16-bit words, and 4K to 64K of memory, became common.
CISCs were believed to be the most powerful types of computers, because their microcode was small and could be stored in very high-speed memory. The CISC architecture also addressed the semantic gap as it was then perceived. This was a defined distance between the machine language, and the higher level programming languages used to program a machine. It was felt that compilers could do a better job with a richer instruction set.
Custom CISCs were commonly constructed using bit slice computer logic such as the AMD 2900 chips, with custom microcode. A bit slice component is a piece of an arithmetic logic unit (ALU), register file or microsequencer. Most bit-slice integrated circuits were 4 bits wide.
By the early 1970s, the 16-bit PDP-11 minicomputer was developed, arguably the most advanced small computer of its day. In the late 1970s, wider-word superminicomputers were introduced, such as the 32-bit VAX.
IBM continued to make large, fast computers. However, the definition of large and fast now meant more than a megabyte of RAM, clock speeds near one megahertz, and tens of megabytes of disk drives.
IBM's System 370 was a version of the 360 tweaked to run virtual computing environments. The virtual computer was developed to reduce the chances of an unrecoverable software failure.
The Burroughs large systems (B5000, B6000, B7000) series reached its largest market share. It was a stack computer whose OS was programmed in a dialect of Algol.
All these different developments competed for market share.
The first single-chip 16-bit microprocessor was introduced in 1975. Panafacom, a conglomerate formed by Japanese companies Fujitsu, Fuji Electric, and Matsushita, introduced the MN1610, a commercial 16-bit microprocessor. According to Fujitsu, it was "the world's first 16-bit microcomputer on a single chip".
The Intel 8080 was the basis for the 16-bit Intel 8086, which is a direct ancestor to today's ubiquitous x86 family (including Pentium and Intel Core). Every instruction of the 8080 has a direct equivalent in the large x86 instruction set, although the opcode values are different in the latter.
Early 1980s–1990s: Lessons of RISC
In the early 1980s, researchers at UC Berkeley and IBM both discovered that most computer language compilers and interpreters used only a small subset of the instructions of complex instruction set computing (CISC). Much of the power of the CPU was being ignored in real-world use. They realized that by making the computer simpler and less orthogonal, they could make it faster and less costly at the same time.
At the same time, CPU calculation became faster in relation to the time for needed memory accesses. Designers also experimented with using large sets of internal registers. The goal was to cache intermediate results in the registers under the control of the compiler. This also reduced the number of addressing modes and orthogonality.
The computer designs based on this theory were called reduced instruction set computing (RISC). RISCs usually had larger numbers of registers, accessed by simpler instructions, with a few instructions specifically to load and store data to memory. The result was a very simple core CPU running at very high speed, supporting the sorts of operations the compilers were using anyway.
A common variant on the RISC design employs the Harvard architecture, versus Von Neumann architecture or stored program architecture common to most other designs. In a Harvard Architecture machine, the program and data occupy separate memory devices and can be accessed simultaneously. In Von Neumann machines, the data and programs are mixed in one memory device, requiring sequential accessing which produces the so-called Von Neumann bottleneck.
One downside to the RISC design was that the programs that run on them tend to be larger. This is because compilers must generate longer sequences of the simpler instructions to perform the same results. Since these instructions must be loaded from memory anyway, the larger code offsets some of the RISC design's fast memory handling.
In the early 1990s, engineers at Japan's Hitachi found ways to compress the reduced instruction sets so they fit in even smaller memory systems than CISCs. Such compression schemes were used for the instruction set of their SuperH series of microprocessors, introduced in 1992. The SuperH instruction set was later adapted for ARM architecture's Thumb instruction set. In applications that do not need to run older binary software, compressed RISCs are growing to dominate sales.
Another approach to RISCs was the minimal instruction set computer (MISC), niladic, or zero-operand instruction set. This approach realized that most space in an instruction was used to identify the operands of the instruction. These machines placed the operands on a push-down (last-in, first out) stack. The instruction set was supplemented with a few instructions to fetch and store memory. Most used simple caching to provide extremely fast RISC machines, with very compact code. Another benefit was that the interrupt latencies were very small, smaller than most CISC machines (a rare trait in RISC machines). The Burroughs large systems architecture used this approach. The B5000 was designed in 1961, long before the term RISC was invented. The architecture puts six 8-bit instructions in a 48-bit word, and was a precursor to very long instruction word (VLIW) design (see below: 1990 to today).
The Burroughs architecture was one of the inspirations for Charles H. Moore's programming language Forth, which in turn inspired his later MISC chip designs. For example, his f20 cores had 31 5-bit instructions, which fit four to a 20-bit word.
RISC chips now dominate the market for 32-bit embedded systems. Smaller RISC chips are even growing common in the cost-sensitive 8-bit embedded-system market. The main market for RISC CPUs has been systems that need low power or small size.
Even some CISC processors (based on architectures that were created before RISC grew dominant), such as newer x86 processors, translate instructions internally into a RISC-like instruction set.
These numbers may surprise many, because the market is perceived as desktop computers. x86 designs dominate desktop and notebook computer sales, but such computers are only a tiny fraction of the computers now sold. Most people in industrialised countries own more computers in embedded systems in their car and house, than on their desks.
Mid-to-late 1980s: Exploiting instruction level parallelism
In the mid-to-late 1980s, designers began using a technique termed instruction pipelining, in which the processor works on multiple instructions in different stages of completion. For example, the processor can retrieve the operands for the next instruction while calculating the result of the current one. Modern CPUs may use over a dozen such stages. (Pipelining was originally developed in the late 1950s by International Business Machines (IBM) on their 7030 (Stretch) mainframe computer.) Minimal instruction set computers (MISC) can execute instructions in one cycle with no need for pipelining.
A similar idea, introduced only a few years later, was to execute multiple instructions in parallel on separate arithmetic logic units (ALUs). Instead of operating on only one instruction at a time, the CPU will look for several similar instructions that do not depend on each other, and execute them in parallel. This approach is called superscalar processor design.
Such methods are limited by the degree of instruction level parallelism (ILP), the number of non-dependent instructions in the program code. Some programs can run very well on superscalar processors due to their inherent high ILP, notably graphics. However, more general problems have far less ILP, thus lowering the possible speedups from these methods.
Branching is one major culprit. For example, a program may add two numbers and branch to a different code segment if the number is bigger than a third number. In this case, even if the branch operation is sent to the second ALU for processing, it still must wait for the results from the addition. It thus runs no faster than if there was only one ALU. The most common solution for this type of problem is to use a type of branch prediction.
To further the efficiency of multiple functional units which are available in superscalar designs, operand register dependencies were found to be another limiting factor. To minimize these dependencies, out-of-order execution of instructions was introduced. In such a scheme, the instruction results which complete out-of-order must be re-ordered in program order by the processor for the program to be restartable after an exception. Out-of-order execution was the main advance of the computer industry during the 1990s.
A similar concept is speculative execution, where instructions from one direction of a branch (the predicted direction) are executed before the branch direction is known. When the branch direction is known, the predicted direction and the actual direction are compared. If the predicted direction was correct, the speculatively executed instructions and their results are kept; if it was incorrect, these instructions and their results are erased. Speculative execution, coupled with an accurate branch predictor, gives a large performance gain.
These advances, which were originally developed from research for RISC-style designs, allow modern CISC processors to execute twelve or more instructions per clock cycle, when traditional CISC designs could take twelve or more cycles to execute one instruction.
The resulting instruction scheduling logic of these processors is large, complex and difficult to verify. Further, higher complexity needs more transistors, raising power consumption and heat. In these, RISC is superior because the instructions are simpler, have less interdependence, and make superscalar implementations easier. However, as Intel has demonstrated, the concepts can be applied to a complex instruction set computing (CISC) design, given enough time and money.
1990 to today: Looking forward
VLIW and EPIC
The instruction scheduling logic that makes a superscalar processor is Boolean logic. In the early 1990s, a significant innovation was to realize that the coordination of a multi-ALU computer could be moved into the compiler, the software that translates a programmer's instructions into machine-level instructions.
This type of computer is called a very long instruction word (VLIW) computer.
Scheduling instructions statically in the compiler (versus scheduling dynamically in the processor) can reduce CPU complexity. This can improve performance, and reduce heat and cost.
Unfortunately, the compiler lacks accurate knowledge of runtime scheduling issues. Merely changing the CPU core frequency multiplier will have an effect on scheduling. Operation of the program, as determined by input data, will have major effects on scheduling. To overcome these severe problems, a VLIW system may be enhanced by adding the normal dynamic scheduling, losing some of the VLIW advantages.
Static scheduling in the compiler also assumes that dynamically generated code will be uncommon. Before the creation of Java and the Java virtual machine, this was true. It was reasonable to assume that slow compiles would only affect software developers. Now, with just-in-time compilation (JIT) virtual machines being used for many languages, slow code generation affects users also.
There were several unsuccessful attempts to commercialize VLIW. The basic problem is that a VLIW computer does not scale to different price and performance points, as a dynamically scheduled computer can. Another issue is that compiler design for VLIW computers is very difficult, and compilers, as of 2005, often emit suboptimal code for these platforms.
Also, VLIW computers optimise for throughput, not low latency, so they were unattractive to engineers designing controllers and other computers embedded in machinery. The embedded systems markets had often pioneered other computer improvements by providing a large market unconcerned about compatibility with older software.
In January 2000, Transmeta Corporation took the novel step of placing a compiler in the central processing unit, and making the compiler translate from a reference byte code (in their case, x86 instructions) to an internal VLIW instruction set. This method combines the hardware simplicity, low power and speed of VLIW RISC with the compact main memory system and software reverse-compatibility provided by popular CISC.
Intel's Itanium chip is based on what they call an explicitly parallel instruction computing (EPIC) design. This design supposedly provides the VLIW advantage of increased instruction throughput. However, it avoids some of the issues of scaling and complexity, by explicitly providing in each bundle of instructions information concerning their dependencies. This information is calculated by the compiler, as it would be in a VLIW design. The early versions are also backward-compatible with newer x86 software by means of an on-chip emulator mode. Integer performance was disappointing and despite improvements, sales in volume markets continue to be low.
Multi-threading
Current designs work best when the computer is running only one program. However, nearly all modern operating systems allow running multiple programs together. For the CPU to change over and do work on another program needs costly context switching. In contrast, multi-threaded CPUs can handle instructions from multiple programs at once.
To do this, such CPUs include several sets of registers. When a context switch occurs, the contents of the working registers are simply copied into one of a set of registers for this purpose.
Such designs often include thousands of registers instead of hundreds as in a typical design. On the downside, registers tend to be somewhat costly in chip space needed to implement them. This chip space might be used otherwise for some other purpose.
Intel calls this technology "hyperthreading" and offers two threads per core in its current Core i3, Core i5, Core i7 and Core i9 Desktop lineup (as well as in its Core i3, Core i5 and Core i7 Mobile lineup), as well as offering up to four threads per core in high-end Xeon Phi processors.
Multi-core
Multi-core CPUs are typically multiple CPU cores on the same die, connected to each other via a shared L2 or L3 cache, an on-die bus, or an on-die crossbar switch. All the CPU cores on the die share interconnect components with which to interface to other processors and the rest of the system. These components may include a front-side bus interface, a memory controller to interface with dynamic random access memory (DRAM), a cache coherent link to other processors, and a non-coherent link to the southbridge and I/O devices. The terms multi-core and microprocessor unit (MPU) have come into general use for one die having multiple CPU cores.
Intelligent RAM
One way to work around the Von Neumann bottleneck is to mix a processor and DRAM all on one chip.
Reconfigurable logic
Main article: Reconfigurable computingAnother track of development is to combine reconfigurable logic with a general-purpose CPU. In this scheme, a special computer language compiles fast-running subroutines into a bit-mask to configure the logic. Slower, or less-critical parts of the program can be run by sharing their time on the CPU. This process allows creating devices such as software radios, by using digital signal processing to perform functions usually performed by analog electronics.
Open source processors
As the lines between hardware and software increasingly blur due to progress in design methodology and availability of chips such as field-programmable gate arrays (FPGA) and cheaper production processes, even open source hardware has begun to appear. Loosely knit communities like OpenCores and RISC-V have recently announced fully open CPU architectures such as the OpenRISC which can be readily implemented on FPGAs or in custom produced chips, by anyone, with no license fees, and even established processor makers like Sun Microsystems have released processor designs (e.g., OpenSPARC) under open-source licenses.
Asynchronous CPUs
Main article: Asynchronous circuitYet another option is a clockless or asynchronous CPU. Unlike conventional processors, clockless processors have no central clock to coordinate the progress of data through the pipeline. Instead, stages of the CPU are coordinated using logic devices called pipe line controls or FIFO sequencers. Basically, the pipeline controller clocks the next stage of logic when the existing stage is complete. Thus, a central clock is unneeded.
Relative to clocked logic, it may be easier to implement high performance devices in asynchronous logic:
- In a clocked CPU, no component can run faster than the clock rate. In a clockless CPU, components can run at different speeds.
- In a clocked CPU, the clock can go no faster than the worst-case performance of the slowest stage. In a clockless CPU, when a stage finishes faster than normal, the next stage can immediately take the results rather than waiting for the next clock tick. A stage might finish faster than normal because of the type of data inputs (e.g., multiplication can be very fast if it occurs by 0 or 1), or because it is running at a higher voltage or lower temperature than normal.
Asynchronous logic proponents believe these abilities would have these benefits:
- lower power dissipation for a given performance
- highest possible execution speeds
The biggest disadvantage of the clockless CPU is that most CPU design tools assume a clocked CPU (a synchronous circuit), so making a clockless CPU (designing an asynchronous circuit) involves modifying the design tools to handle clockless logic and doing extra testing to ensure the design avoids metastability problems.
Even so, several asynchronous CPUs have been built, including
- the ORDVAC and the identical ILLIAC I (1951)
- the ILLIAC II (1962), then the fastest computer on Earth
- The Caltech Asynchronous Microprocessor, the world-first asynchronous microprocessor (1988)
- the ARM-implementing AMULET (1993 and 2000)
- the asynchronous implementation of MIPS Technologies R3000, named MiniMIPS (1998)
- the SEAforth multi-core processor from Charles H. Moore
Optical communication
In theory, an optical computer's components could directly connect through a holographic or phased open-air switching system. This would provide a large increase in effective speed and design flexibility, and a large reduction in cost. Since a computer's connectors are also its most likely failure points, a busless system may be more reliable.
Further, as of 2010, modern processors use 64- or 128-bit logic. Optical wavelength superposition could allow data lanes and logic many orders of magnitude higher than electronics, with no added space or copper wires.
Optical processors
Main article: Optical computingAnother long-term option is to use light instead of electricity for digital logic. In theory, this could run about 30% faster and use less power, and allow a direct interface with quantum computing devices.
The main problems with this approach are that, for the foreseeable future, electronic computing elements are faster, smaller, cheaper, and more reliable. Such elements are already smaller than some wavelengths of light. Thus, even waveguide-based optical logic may be uneconomic relative to electronic logic. As of 2016, most development effort is for electronic circuitry.
Ionic processors
Early experimental work has been done on using ion-based chemical reactions instead of electronic or photonic actions to implement elements of a logic processor.
Belt machine architecture
Relative to conventional register machine or stack machine architecture, yet similar to Intel's Itanium architecture, a temporal register addressing scheme has been proposed by Ivan Godard and company that is intended to greatly reduce the complexity of CPU hardware (specifically the number of internal registers and the resulting huge multiplexer trees). While somewhat harder to read and debug than general-purpose register names, it aids understanding to view the belt as a moving conveyor belt where the oldest values drop off the belt and vanish. It is implemented in the Mill architecture.
Timeline of events
- 1964. IBM release the 32-bit IBM System/360 with memory protection.
- 1969. Intel 4004's initial design led by Intel's Ted Hoff and Busicom's Masatoshi Shima.
- 1970. Intel 4004's design completed by Intel's Federico Faggin and Busicom's Masatoshi Shima.
- 1971. IBM release the IBM System/370 successor to System/360.
- 1971. Intel release the 4-bit Intel 4004, the first commercial microprocessor.
- 1971. NEC release the μPD707 and μPD708, a two-chip 4-bit CPU.
- 1972. IBM announce "System/370 Advanced Function", adding support for virtual memory with demand paging
- 1972. NEC release single-chip 4-bit microprocessor, μPD700.
- 1973. NEC release 4-bit μCOM-4 (μPD751), combining the μPD707 and μPD708 into a single microprocessor.
- 1974. Intel release the Intel 8080, an 8-bit microprocessor, designed by Federico Faggin and Masatoshi Shima.
- 1975. MOS Technology release the 8-bit MOS Technology 6502, the first integrated processor to have an affordable price of $25 when the 6800 rival was $175.
- 1976. Zilog introduce the 8-bit Zilog Z80, designed by Federico Faggin and Masatoshi Shima.
- 1977. Digital Equipment Corporation introduced its first 32-bit VAX superminicomputer, the VAX-11/780.
- 1978. Intel introduces the Intel 8086 and Intel 8088, the first x86 chips.
- 1978. Fujitsu releases the MB8843 microprocessor.
- 1979. Zilog release the Zilog Z8000, a 16-bit microprocessor, designed by Federico Faggin and Masatoshi Shima.
- 1979. Motorola introduce the Motorola 68000, a 16/32-bit microprocessor.
- 1981. Stanford MIPS introduced, one of the first reduced instruction set computing (RISC) designs.
- 1982. Intel introduces the Intel 80286, which was the first Intel processor that could run all the software written for its predecessors, the 8086 and 8088.
- 1984. Motorola introduces the Motorola 68020, which enabled full 32-bit addressing, and the 68851 memory management unit, which supported demand paging.
- 1985. Intel introduces the Intel 80386, which adds a 32-bit instruction set to the x86 microarchitecture, and supports demand paging.
- 1985. ARM architecture introduced.
- 1989. Intel introduces the Intel 80486.
- 1992. Hitachi introduces SuperH architecture, which provides the basis for ARM's Thumb instruction set.
- 1993. Intel launches the original Pentium microprocessor, the first processor with a x86 superscalar microarchitecture.
- 1994. IBM introduce the first IBM mainframe models to use single-chip microprocessors as CPUs, the IBM System/390 9672 series.
- 1994. ARM's Thumb instruction set introduced, based on Hitachi's SuperH instruction set.
- 1995. Intel introduces the Pentium Pro which becomes the foundation for the Pentium II, Pentium III, Pentium M and Intel Core architectures.
- 2000. IBM introduce z/Architecture, the 64-bit version of their mainframe architecture.
- 2000. AMD announced x86-64 64-bit extension to the x86 microarchitecture.
- 2000. AMD hits 1 GHz with its Athlon microprocessor.
- 2000. Analog Devices introduces the Blackfin architecture.
- 2002. Intel released a Pentium 4 with hyper-threading, the first modern desktop processor to implement simultaneous multithreading (SMT).
- 2003. AMD released the Athlon 64, the first 64-bit consumer CPU.
- 2003. Intel introduced the Pentium M, a low power mobile derivative of the Pentium Pro architecture.
- 2005. AMD announced the Athlon 64 X2, their first x86 dual-core processor.
- 2006. Intel introduces the Core line of CPUs based on a modified Pentium M design.
- 2008. Over 10 billion Arm based CPUs shipped.
- 2010. Intel introduced the Core i3, i5, and i7, with 2, 4 and 4 cores respectively.
- 2011. ARM release ARMv8-A, supporting the 64-bit AAarch64 architecture.
- 2011. AMD announced the world's first 8-core CPU for desktop PCs.
- 2017. AMD announced Ryzen processors based on the Zen architecture, with up to 16 cores.
- 2017. Intel 8th generation Core i3, Core i5, Core i7 and Core i9, increased to approximately 4, 6, 8 and 8 cores respectively.
- 2017. Over 100 billion Arm based CPUs shipped.
- 2020. Apple launched their own M1 ARMv8-based system-on-a-chip (SoC), significant in that they switched their devices away from Intel CPUs.
- 2021. ARM release ARMv9 the first major upgrade in a decade, since Armv8 in 2011.
- 2021. Over 200 billion Arm based CPUs shipped.
- 2022. AMD 3rd Generation EPYC 64C processors power Frontier, the world's most powerful supercomputer.
- 2024. Apple launched the M4, their first SoC adopting the ARMv9 CPU architecture.
See also
References
- ^ Nigel Tout. "The Busicom 141-PF calculator and the Intel 4004 microprocessor". Retrieved November 15, 2009.
- Aspray, William (1994-05-25). "Oral-History: Tadashi Sasaki". Engineering and Technology History Wiki. The Institute of Electrical and Electronics Engineers, Inc. Retrieved 2022-09-14.
- Caswell, Wayne (18 February 2008). "Twenty Technology Trends that Affect Home Networking". Home Toys. Archived from the original on March 27, 2016.
- "The Structure of SYSTEM/360". Computer Structures: Principles and Examples.
- "16-bit Microprocessors". CPU Museum. Retrieved 5 October 2010.
- ^ "History". PFU. Retrieved 5 October 2010.
- PANAFACOM Lkit-16, Information Processing Society of Japan
- ^ "Hitachi Releases the SH-4 SH7750 Series, Offering Industry's Highest Performance of 360 MIPS for an Embedded RISC Processor, as Top-End Series in SuperH Family".
- ^ Nathan Willis (June 10, 2015). "Resurrecting the SuperH architecture". LWN.net.
- MiniMIPS
- "SEAforth Overview". Archived from the original on 2008-02-02.
... asynchronous circuit design throughout the chip. There is no central clock with billions of dumb nodes dissipating useless power. ... the processor cores are internally asynchronous themselves.
- "RISC Processors COMP375 Computer Architecture and Organization" (PDF). Archived from the original (PDF) on October 26, 2017.
- "The Belt".
- ^ Federico Faggin, The Making of the First Microprocessor, IEEE Solid-State Circuits Magazine, Winter 2009, IEEE Xplore
- ^ "NEC 751 (uCOM-4)". The Antique Chip Collector's Page. Archived from the original on 2011-05-25. Retrieved 2010-06-11.
- ^ 1970年代 マイコンの開発と発展 ~集積回路, Semiconductor History Museum of Japan
- Jeffrey A. Hart & Sangbae Kim (2001), The Defense of Intellectual Property Rights in the Global Information Order, International Studies Association, Chicago
- ARM7TDMI Technical Reference Manual page ii
- Segars, Simon (2017-02-27). "Enabling mass IoT connectivity as ARM partners ship 100 billion chips". Retrieved 2021-09-06.
- Clover Juli (2022-10-13). "Apple M1 Chip: Everything You Need to Know". MacRumors. Retrieved 2024-07-21.
- Takahashi, Dean (2021-03-30). "Armv9 is Arm's first major architectural update in a decade". VentureBeat. Retrieved 2021-09-06.
- Shilov, Anton (2021-10-20). "Over 200 Billion Arm-Based Chips Shipped". Retrieved 2022-09-16.
- "TOP500 List - June 2022". June 2022. Retrieved 2022-05-30.
- Larabel Michael (2024-06-15). "Apple M4 Support Added To The LLVM Compiler, Confirming Its ISA Capabilities". Phoronix. Retrieved 2024-07-21.
External links
- Great moments in microprocessor history by W. Warner, 2004
- Great Microprocessors of the Past and Present (V 13.4.0) by: John Bayko, 2003
- Bit by Bit: An Illustrated History of Computers, Stan Augarten, 1984. OCR with permission of the author
- Gallery of CPU and related PCBs (in Italian)