Intel iAPX 432: Difference between revisions
→{{Anchor|8800}}Development: Fix parenthetical |
|||
(215 intermediate revisions by more than 100 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Discontinued Intel microprocessor architecture}} |
|||
{{Infobox CPU |
{{Infobox CPU |
||
|name = Intel iAPX 432 |
|name = Intel iAPX 432 |
||
|image = Intel |
|image = Intel logo (1968).svg |
||
|image_size = 100px |
|||
|caption = Intel Corporation logo, 1968-2005 |
|||
|caption = Intel Corporation logo, 1968–2006 |
|||
|produced-start = 1981 |
|||
|produced- |
|produced-start = late 1981 |
||
|produced-end = ca 1985 |
|||
|slowest = 5 |slow-unit = MHz |
|slowest = 5 |slow-unit = MHz |
||
|fastest = 8 |fast-unit = MHz |
|fastest = 8 |fast-unit = MHz |
||
Line 13: | Line 15: | ||
|sock1 = |
|sock1 = |
||
}} |
}} |
||
[[File:Intel SBC 432 100 board, component side (15162604484).jpg|thumb|Intel SBC 432/100 board]] |
|||
[[File:Intel C43201-5 chip (15597750510).jpg|thumb|''General Data Processor'' 43201]] |
|||
[[File:Intel C43202 chip (15597749830).jpg|thumb|''General Data Processor'' 43202]] |
|||
The '''iAPX 432''' (''Intel Advanced Performance Architecture'') is a discontinued [[computer architecture]] introduced in 1981.<ref name="dvorak">{{cite web|url=http://www.dvorak.org/blog/whatever-happened-to-the-intel-iapx432|access-date=19 July 2012|title=Whatever Happened to the Intel iAPX432?|last1=Dvorak|first1=John C.}}</ref>{{refn|group=NB|Sometimes ''Intel Advanced Processor Architecture''<ref>{{cite book |title=Defining Intel: 25 Years / 25 Events |date=1993 |publisher=Intel |page=14 |url=https://www.intel.com/Assets/PDF/General/25yrs.pdf}}</ref>}} It was [[Intel]]'s first [[32-bit]] [[Microprocessor|processor]] design. The main processor of the architecture, the ''general data processor'', is implemented as a set of two separate integrated circuits, due to technical limitations at the time. Although some early 8086, 80186 and 80286-based systems and manuals also used the [[iAPX]] prefix for marketing reasons, the iAPX 432 and the 8086 processor lines are completely separate designs with completely different instruction sets. |
|||
The project started in 1975 as the '''8800''' (after the [[Intel 8008|8008]] and the [[Intel 8080|8080]]) and was intended to be Intel's major design for the 1980s. Unlike the [[Intel 8086|8086]], which was designed the following year as a successor to the 8080, the iAPX 432 was a radical departure from Intel's previous designs meant for a different market niche, and completely unrelated to the 8080 or [[x86]] product lines. |
|||
Intel's '''iAPX 432''' was a very ambitious multi-chip [[microprocessor]] architecture introduced in 1981. It was unacceptably slow and did not supplant Intel's [[x86]] architecture as planned. |
|||
The iAPX 432 project is considered a commercial failure for Intel, and was discontinued in 1986.<ref name="dvorak"/><ref>{{cite web|last1=Smith|first1=Eric|title=Intel iAPX-432 Micromainframe|url=https://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/|access-date=Dec 6, 2015|archive-date=February 2, 2016|archive-url=https://web.archive.org/web/20160202195456/http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/|url-status=dead}}</ref> |
|||
The project was [[Intel]]'s first 32-bit microprocessor design, and intended to be the company's main product line for the 1980s. Many advanced [[Computer multitasking|multitasking]] and [[memory management]] features were implemented in hardware, leading to the design being referred to as a '''Micromainframe'''. "''iAPX''" stood for '''''i'''ntel '''A'''dvanced '''P'''rocessor ar'''chi'''tecture''. |
|||
==Description== |
|||
Originally designed for clock frequencies of up to 10 MHz, actual devices sold were specified for maximum clock speeds of 4 MHz, 5 MHz, 7 MHz and 8 MHz respectively<ref>[http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/ Intel iAPX-432 Micromainframe]</ref> with a peak performance of 2 million instructions per second at 8 MHz.<ref>[http://www.elecdesign.com/Articles/ArticleID/2839/2839.html]</ref> |
|||
The iAPX 432 was referred to as a "micromainframe", designed to be programmed entirely in high-level languages.<ref name=Intel81>{{Cite book|last=Intel Corporation|title=Introduction to the iAPX 432 Architecture|year=1981|pages=iii|url=http://bitsavers.org/components/intel/iAPX_432/171821-001_Introduction_to_the_iAPX_432_Architecture_Aug81.pdf}}</ref><ref name="i8800">{{Cite journal | doi = 10.1109/MAHC.2010.22 | title = Intel's 8086 | author = Stanley Mazor | journal = IEEE Annals of the History of Computing | volume = 32 | number = 1 | date = January–March 2010 | pages = 75–79| s2cid = 16451604 }}</ref> The [[instruction set architecture]] was also entirely new and a significant departure from Intel's previous [[8008]] and [[8080]] processors as the iAPX 432 programming model is a [[stack machine]] with no visible [[general-purpose register]]s. It supports [[object-oriented programming]],<ref name="i8800" /> [[Garbage collection (computer science)|garbage collection]] and [[computer multitasking|multitasking]] as well as more conventional [[memory management]] directly in hardware and [[microcode]]. Direct support for various [[data structure]]s is also intended to allow modern [[operating system]]s to be implemented using far less program [[machine code|code]] than for ordinary processors. Intel [[iMAX 432]] is a discontinued [[operating system]] for the 432,<ref>{{Cite journal | doi = 10.1145/800216.806601| last1 = Kahn | first1 = Kevin C.| last2 = Corwin | first2 = William M.| last3 = Dennis | first3 = T. Don| last4 = d'Hooge | first4 = Herman| last5 = Hubka | first5 = David E.| last6 = Hutchins | first6 = Linda A.| last7 = Montague | first7 = John T.| last8 = Pollack | first8 = Fred J.| url = https://cs.uwaterloo.ca/~Brecht/courses/702/Possible-Readings/oses/imax-multiprocessor-os-sosp-1981.pdf| title = iMAX: A multiprocessor operating system for an object-based computer| journal = ACM SIGOPS Operating Systems Review| volume = 15| issue = 5| date = December 1981| pages = 127–136| s2cid = 9245960 }}</ref> written entirely in [[Ada (programming language)|Ada]], and Ada was also the intended primary language for application programming. In some aspects, it may be seen as a [[high-level language computer architecture]]. |
|||
These properties and features resulted in a hardware and microcode design that was more complex than most processors of the era, especially microprocessors. However, internal and external buses are (mostly) not wider than [[16-bit]], and, just like in other 32-bit microprocessors of the era (such as the [[Motorola 68000|68000]] or the [[NS320xx|32016]]), 32-bit arithmetical instructions are implemented by a 16-bit ALU, via [[random logic]] and [[microcode]] or other kinds of [[sequential logic]]. The iAPX 432 enlarged address space over the 8080 was also limited by the fact that ''[[linear addressing]]'' of data could still only use 16-bit offsets, somewhat akin to Intel's first [[Intel 8086|8086]]-based designs, including the contemporary [[Intel 80286|80286]] (the new 32-bit segment offsets of the [[Intel 80386|80386]] architecture was described publicly in detail in 1984).<ref group="NB">although the 80386 chip was not mass produced until mid 1986</ref> |
|||
The iAPX 432 was "designed to be programmed entirely in high-level languages"<ref>{{cite book|last=Intel Corporation|title=Introduction to the iAPX 432 Architecture|year=1981|pages=iii|url=http://bitsavers.org/pdf/intel/iAPX_432/171821-001_Introduction_to_the_iAPX_432_Architecture_Aug81.pdf}}</ref>, with [[Ada (programming language)|Ada]] being primary. |
|||
Direct hardware support for various [[data structure]]s was intended to allow modern [[operating system]]s for the 432 to be implemented using far less program [[Computer code|code]] than for ordinary processors; combined with direct support for [[object-oriented programming]] and [[Garbage collection (computer science)|garbage collection]], this made the hardware (mostly the [[microcode]] part) much more complex than most processors of the era, especially microprocessors. |
|||
Using the semiconductor technology of its day, Intel's engineers weren't able to translate the design into a very efficient first implementation. Along with the lack of optimization in a premature [[Ada (programming language)|Ada]] compiler, this contributed to rather slow but expensive computer systems, performing typical benchmarks at roughly 1/4 the speed of the new [[80286]] chip at the same clock frequency (in early 1982).<ref name="performance-effects"/> This initial performance gap to the rather low-profile and low-priced [[8086]] line was probably the main reason why Intel's plan to replace the latter (later known as [[x86]]) with the iAPX 432 failed. Although engineers saw ways to improve a next generation design, the iAPX 432 ''[[Capability-based security|capability architecture]]'' had now started to be regarded more as an implementation overhead rather than as the simplifying support it was intended to be.<ref name="performance-effects">{{Cite journal | doi = 10.1145/45059.214411| last1 = Colwell | first1 = Robert| last2 = Gehringer | first2 = Edward| year = 1988| title = Performance Effects of Architectural Complexity in the Intel 432| journal = ACM Transactions on Computer Systems| volume = 6| issue = 3| pages = 296–339| s2cid = 8314206 | url = http://www.princeton.edu/~rblee/ELE572Papers/Fall04Readings/I432.pdf}}</ref> |
|||
iAPX 432 systems were expensive and very slow. In 1982, simple benchmark tests ran 4 times slower on iAPX 432 than on the conventional [[Intel 80286|80286]] chip at the same clock frequency. The first generation chipset was a total failure in the market. Intel saw ways to improve a second generation design, but it would still be impractical with large overheads for the capability architecture and instruction set.<ref> |
|||
Performance Effects of Architectural Complexity in the Intel 432, Robert P Colwell, Edward F Gehringer, E Douglas Jensen, ACM Trans. Computer Systems, Vol 6 No 3, August 1966. Online at http://www.princeton.edu/~rblee/ELE572Papers/Fall04Readings/I432.pdf |
|||
</ref> The plan to replace the 8086-line (later known as the [[x86]] architecture) with the iAPX 432 was abandoned. |
|||
Originally designed for clock frequencies of up to 10 MHz, actual devices sold were specified for maximum clock speeds of 4 MHz, 5 MHz, 7 MHz and 8 MHz with a peak performance of 2 million instructions per second at 8 MHz.<ref>[http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/ Intel iAPX-432 Micromainframe]</ref><ref>{{cite web|url=http://electronicdesign.com/boards/ten-notable-flops-learning-mistakes|title=Ten Notable Flops: Learning From Mistakes|publisher=Electronic Design|first1=Lisa|last1=Maliniak|date=October 21, 2002}}</ref> |
|||
The iAPX 432 project was a commercial failure for Intel,<ref> |
|||
http://www.dvorak.org/blog/whatever-happened-to-the-intel-iapx432 </ref> to the extent that Intel's corporate website contains no indication there had ever been such a product. Intel's continued development of its x86 line, which the iAPX 432 architecture was meant to replace, was hugely successful. |
|||
==History== |
==History== |
||
===Development=== |
|||
Intel's 432 project started in 1975, a year after the 8-bit [[Intel 8080]] was completed and a year before their 16-bit [[Intel 8086|8086]] project began. The 432 project was initially named the '''8800''', as their next step beyond the existing [[Intel 8008]] and [[Intel 8080|8080]] microprocessors. This became a very big step. The 8-bit microprocessors' instruction sets were too primitive to support compiled programs and large software systems. Intel now aimed to build a sophisticated complete system in a few LSI chips, that was functionally equal to or better than the best 32-bit minicomputers and mainframes requiring entire cabinets of older chips. This system would support multiprocessors, modular expansion, fault tolerance, advanced operating systems, advanced programming languages, very large applications, ultra reliability, and ultra security. Its architecture would address the needs of Intel's customers for a decade.<ref> |
|||
[[Intel iAPX 432 (Computer Science project paper), David King, Liang Zhou, Jon Bryson, David Dickson. Online at http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/cs460]] </ref> |
|||
==={{Anchor|8800}}Development=== |
|||
It soon became clear that it would take several years and many engineers to design all this. And it would similarly take several years of further progress in [[Moore's Law]], before improved [[Semiconductor device fabrication|chip manufacturing]] could fit all this into a few dense chips. Meanwhile, Intel urgently needed a simpler interim product to meet the immediate competition from [[Motorola]], [[Zilog]], and [[National Semiconductor]]. So Intel began a rushed project to design the 8086 as a low-risk incremental evolution from the 8080, using a separate design team. The mass-market 8086 shipped in 1978. It was good enough to begin the IBM PC revolution. |
|||
Intel's 432 project started in 1976, a year after the [[8-bit]] [[Intel 8080]] was completed and a year before their 16-bit [[Intel 8086|8086]] project began. The 432 project was initially named the '''8800''',<ref name="i8800"/> as their next step beyond the existing [[Intel 8008]] and [[Intel 8080|8080]] microprocessors. This became a very big step. The instruction sets of these 8-bit processors were not very well fitted for typical [[ALGOL|Algol]]-like [[compiled language]]s. However, the major problem was their small native addressing ranges, just 16 KB for 8008 and 64 KB for 8080, far too small for many complex software systems without using some kind of [[bank switching]], [[memory segmentation]], or similar mechanism (which was built into the 8086, a few years later on). Intel now aimed to build a sophisticated complete system in a few LSI chips, that was functionally equal to or better than the best 32-bit minicomputers and mainframes requiring entire cabinets of older chips. This system would support multiprocessors, modular expansion, fault tolerance, advanced operating systems, advanced programming languages, very large applications, ultra reliability, and ultra security. Its architecture would address the needs of Intel's customers for a decade.<ref>{{cite web|title=Intel iAPX 432 - Computer Science 460 - Final Project|author1=David King|author2=Liang Zhou|author3=Jon Bryson|author4=David Dickson|date=April 15, 1999|url=http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/cs460}}</ref> |
|||
The iAPX 432 development team was managed by Bill Lattin, with [[Justin Rattner]] (who would later become CTO of Intel) as the lead engineer<ref>{{cite journal |last1=Mazor |first1=Stanley |title=Intel's 8086 |journal=IEEE Annals of the History of Computing |date=2010 |volume=32 |page=75 |doi=10.1109/MAHC.2010.22 |s2cid=16451604 |url=https://ieeexplore.ieee.org/document/5430762}}</ref><ref name="Mayer2012"></ref><ref>{{cite book |title=Defining Intel: 25 years / 25 events |date=1993 |publisher=Intel |page=14 |url=https://www.intel.com/assets/pdf/general/25yrs.pdf}}</ref> (although one source<ref name="dvorak"/> states that [[Fred Pollack]] was the lead engineer). Initially the team worked from Santa Clara, but in March 1977 Lattin and his team of 17 engineers moved to Intel's new site in Portland.<ref name="Mayer2012">{{cite book|author=Heike Mayer|title=Entrepreneurship and Innovation in Second Tier Regions|url=https://books.google.com/books?id=OgUJJPuDvfQC&pg=PA100|year=2012|publisher=Edward Elgar Publishing|isbn=978-0-85793-869-5|pages=100–101}}</ref> Pollack later specialized in [[superscalar]]ity and became the lead architect of the i686 chip [[Intel Pentium Pro]].<ref name="dvorak"/> |
|||
The 8086 was designed to be upward-compatible with existing 8080 DOS software (at assembly source code level). In contrast, the 432 had no software compatibility or migration requirements. The architects had total freedom to do a novel design from scratch, using whatever techniques they guessed would be best for large-scale systems and software. They applied fashionable computer science concepts from universities, particularly [[capability-based addressing|capability machines]], object-oriented programming, high-level CISC machines, Ada, and densely encoded instructions. This ambitious mix of novel features made the target machine bigger and hence later. And also fatally slow. |
|||
It soon became clear that it would take several years and many engineers to design all this. And it would similarly take several years of further progress in [[Moore's Law]], before improved [[Semiconductor device fabrication|chip manufacturing]] could fit all this into a few dense chips. Meanwhile, Intel urgently needed a simpler interim product to meet the immediate competition from [[Motorola]], [[Zilog]], and [[National Semiconductor]]. So Intel began a rushed project to design the 8086 as a low-risk incremental evolution from the 8080, using a separate design team. The mass-market 8086 shipped in 1978. |
|||
The core of the design — the main processor — was termed the General Data Processor ('''GDP''') and built as two chips: one (the 43201) to [[Fetch-execute cycle|fetch and decode]] instructions, the other (the 43202) to execute them. Most systems would also include a third chip: the 43203 Interface Processor ('''IP''') which operated as a [[channel controller]] for [[Input/output|I/O]]. |
|||
The 8086 was designed to be backward-compatible with the 8080 in the sense that 8080 [[assembly language]] could be mapped on to the 8086 architecture using a special [[assembler (computing)|assembler]]. Existing 8080 assembly [[source code]] (albeit no [[executable code]]) was thereby made [[upward compatible]] with the new 8086 to a degree. In contrast, the 432 had no software compatibility or migration requirements. The architects had total freedom to do a novel design from scratch, using whatever techniques they guessed would be best for large-scale systems and software. They applied fashionable computer science concepts from universities, particularly [[capability-based addressing|capability machines]], object-oriented programming, high-level CISC machines, Ada, and densely encoded instructions. This ambitious mix of novel features made the chip larger and more complex. The chip's complexity limited the clock speed and lengthened the design schedule. |
|||
These were some of the largest {{clarify|IC}} designs of the era. The two-chip GDP had a combined count of approximately 97,000 [[transistor]]s while the single chip IP had approximately 49,000. By comparison, the [[Motorola 68000]] (introduced in 1979) had approximately 40,000 transistors. |
|||
The core of the design — the main processor — was termed the General Data Processor ('''GDP''') and built as two [[integrated circuit]]s: one (the 43201) to [[Fetch-execute cycle|fetch and decode]] instructions, the other (the 43202) to execute them. Most systems would also include the 43203 Interface Processor ('''IP''') which operated as a [[channel controller]] for [[Input/output|I/O]], and an Attached Processor ('''AP'''), a conventional Intel 8086 which provided "processing power in the I/O subsystem".<ref name=Intel81 /> |
|||
These were some of the largest {{Clarify|IC|date=October 2012}} designs of the era. The two-chip GDP had a combined count of approximately 97,000 [[transistor]]s{{Citation needed|reason=Another source states 159,000 transistors|date=April 2023}} while the single chip IP had approximately 49,000. By comparison, the [[Motorola 68000]] (introduced in 1979) had approximately 40,000 transistors.{{Citation needed|reason=Other (unreliable) sources say the 68000 had about 70,000 transistors|date=September 2018}} |
|||
In 1983, Intel released two additional integrated circuits for the iAPX 432 Interconnect Architecture: the 43204 Bus Interface Unit ('''BIU''') and 43205 Memory Control Unit ('''MCU'''). These chips allowed for nearly glueless multiprocessor systems with up to 63 nodes. |
In 1983, Intel released two additional integrated circuits for the iAPX 432 Interconnect Architecture: the 43204 Bus Interface Unit ('''BIU''') and 43205 Memory Control Unit ('''MCU'''). These chips allowed for nearly glueless multiprocessor systems with up to 63 nodes. |
||
===The project's failures=== |
===The project's failures=== |
||
Some of the innovative features of the iAPX 432 were detrimental to good performance. In many cases, the iAPX 432 had a significantly slower instruction throughput than conventional microprocessors of the era, such as the [[National Semiconductor 32016]], [[Motorola 68010]] and [[Intel 80286]]. One problem was that the two-chip implementation of the GDP limited it to the speed of the motherboard's electrical wiring. A larger issue was the capability architecture needed large associative caches to run efficiently, but the chips had no room left for that. The instruction set also used bit-aligned variable-length instructions instead of the usual semi-fixed byte or word-aligned formats used in the majority of computer designs. Instruction decoding was therefore more complex than in other designs. Although this did not hamper performance in itself, it used additional transistors (mainly for a large [[barrel shifter]]) in a design that was already lacking space and transistors for caches, wider buses and other performance oriented features. In addition, the BIU was designed to support fault-tolerant systems, and in doing so up to 40% of the bus time was held up in [[wait state]]s. |
|||
Another major problem was its immature untuned [[Ada (programming language)|Ada]] [[compiler]] |
Another major problem was its immature and untuned [[Ada (programming language)|Ada]] [[compiler]]. It used high-cost object-oriented instructions in every case, instead of the faster scalar instructions where it would have made sense to do so. For instance the iAPX 432 included a very expensive inter-module [[procedure call]] instruction, which the compiler used for all calls, despite the existence of much faster branch and link instructions. Another very slow call was enter_environment, which set up the memory protection. The compiler ran this for every single variable in the system, even when variables were used inside an existing environment and did not have to be checked. To make matters worse, data passed to and from procedures was always passed [[Evaluation strategy#Call by copy-restore|by value-return]] rather than by reference. When running the [[Dhrystone]] benchmark, parameter passing took ten times longer than all other computations combined.<ref name="smotherman">Mark Smotherman, [http://people.cs.clemson.edu/~mark/432.html Overview of Intel 432]</ref> |
||
According to the ''New York Times'', "the i432 ran 5 to 10 times more slowly than its competitor, the Motorola 68000".<ref name="MARKOFF">John Markoff, [https://www.nytimes.com/1998/04/05/business/inside-intel-the-future-is-riding-on-a-new-chip.html Inside Intel, The Future Is Riding on A New Chip], April 5, 1998</ref> |
|||
===Impact and similar designs=== |
===Impact and similar designs=== |
||
The iAPX 432 was one of the first systems to implement the new [[IEEE-754]] Standard for Floating-Point Arithmetic.<ref>{{cite web|last1=Vickery|first1=Christopher|title=IEEE-754 Reference Material|url=http://babbage.cs.qc.cuny.edu/IEEE-754.old/References.xhtml|access-date=Dec 5, 2015|archive-date=December 1, 2011|archive-url=https://web.archive.org/web/20111201211023/http://babbage.cs.qc.cuny.edu/IEEE-754.old/References.xhtml|url-status=dead}}</ref> |
|||
An outcome of the failure of the 432 was that microprocessor designers concluded that object support in the chip leads to a complex design that will invariably run slowly, and the 432 was often cited as a counter-example by proponents of [[RISC]] designs. However it is held by some that the OO support was not the primary problem with the 432 and that the implementation shortcomings (especially in the compiler) mentioned above would have made any CPU design slow. Since the iAPX 432 there has been only one other attempt at a similar design, the [[Rekursiv]] processor, although the [[INMOS Transputer]]'s process support was similar — and very fast. |
|||
An outcome of the failure of the 432 was that microprocessor designers concluded that object support in the chip leads to a complex design that will invariably run slowly, and the 432 was often cited as a counter-example by proponents of [[RISC]] designs. However, some hold that the OO support was not the primary problem with the 432, and that the implementation shortcomings (especially in the compiler) mentioned above would have made any CPU design slow. Since the iAPX 432 there has been only one other attempt at a similar design, the [[Rekursiv]] processor, although the [[INMOS Transputer]]'s process support was similar — and very fast.{{Citation needed|date=March 2016}} |
|||
Intel had spent considerable time, money, and [[mindshare]] on the 432, had a skilled team devoted to it, and was unwilling to abandon it entirely after its failure in the marketplace. A new architect—[[Glenford Myers]]—was brought in to produce an entirely new architecture and implementation for the core processor, which would be built in a joint [[Intel]]/[[Siemens]] project (later [[BiiN]]), resulting in the [[Intel i960|i960]]-series processors. The i960 RISC subset became popular for a time in the embedded processor market, but the high-end 960MC and the tagged-memory 960MX were marketed only for military applications. |
|||
According to the ''New York Times'', Intel's collaboration with HP on the [[Itanium|Merced processor (later known as Itanium)]] was the company's comeback attempt for the very high-end market.<ref name="MARKOFF"/> |
|||
Intel had spent considerable time, money and [[mindshare]] on the 432, had a skilled team devoted to it, and were unwilling to abandon it entirely after its failure in the marketplace. A new architect—Glenford Myers—was brought in to produce an entirely new architecture and implementation for the core processor, which would be built in a joint [[Intel]]/[[Siemens AG|Siemens]] project (later [[BiiN]]), resulting in the [[Intel i960|i960]]-series processors. The i960 RISC subset became popular for a time in the embedded processor market, but the high-end 960MC and the tagged-memory 960MX were marketed only for military applications. |
|||
==Architecture== |
==Architecture== |
||
The iAPX 432 instructions have variable length, between 6 and 321 bits.<ref name="IchikawaTsubotani1992">{{cite book|author1=Tadao Ichikawa|author2=H. Tsubotani|title=Language Architectures and Programming Environments|url=https://books.google.com/books?id=3vfbUGp4WfkC&pg=PA127|year=1992|publisher=World Scientific|isbn=978-981-02-1012-0|page=127}}</ref> Unusually, they are not byte-aligned, that is, they may contain odd numbers of bits and directly follow each other without regard to byte boundaries.<ref name="i8800"/> |
|||
===Object-oriented memory and capabilities=== |
===Object-oriented memory and capabilities=== |
||
The iAPX 432 has hardware and microcode support for [[object-oriented programming]] and [[capability-based addressing]].<ref>{{cite book|first=Henry M.|last=Levy|chapter=Chapter 9: The Intel iAPX 432|title=Capability-Based Computer Systems|publisher=[[Digital Press]]|year=1984|url=https://homes.cs.washington.edu/~levy/capabook/|chapter-url=http://www.cs.washington.edu/homes/levy/capabook/Chapter9.pdf}}</ref><ref>{{Cite book |last=Organick |first=Elliott I. |url=https://www.worldcat.org/oclc/9110667 |chapter=Chapter 4: i432 Object Structures for Program Execution |title=A programmer's view of the Intel 432 system |date=1983 |publisher=McGraw-Hill |isbn=0-07-047719-1 |location=New York |oclc=9110667}}</ref> The system uses [[segmented memory]], with up to 2<sup>24</sup> segments of up to 64 [[Kibibyte|KB]] each, providing a total virtual address space of 2<sup>40</sup> bytes. The physical address space is 2<sup>24</sup> bytes (16 [[Megabyte|MB]]). |
|||
The iAPX 432 has hardware and microcode support for [[object-oriented programming]] and [[capability-based addressing]].<ref> |
|||
Henry M Levy, chapter 9 of Capability-Based Computer Systems, Digital Press 1984, online at http://www.cs.washington.edu/homes/levy/capabook/Chapter9.pdf </ref> The system uses [[segmented memory]], with up to 2<sup>24</sup> segments of up to 64 [[Kilobyte|kB]] each, providing a total virtual address space of 2<sup>40</sup> bytes. The physical address space is 2<sup>24</sup> bytes (16 [[Megabyte|MB]]). |
|||
Programs are not able to reference data or instructions by address; instead they must specify a segment and an offset within the segment. Segments are referenced by |
Programs are not able to reference data or instructions by address; instead they must specify a segment and an offset within the segment. Segments are referenced by ''[[Discretionary access control|access descriptors]] (ADs)'', which provide an index into the system object table and a set of rights ([[Capability-based security|capabilities]]) governing accesses to that segment. Segments may be "access segments", which can only contain Access Descriptors, or "data segments" which cannot contain ADs. The hardware and microcode rigidly enforce the distinction between data and access segments, and will not allow software to treat data as access descriptors, or vice versa. |
||
System-defined objects consist of either a single access segment, or an access segment and a data segment. System-defined segments contain data or access descriptors for system-defined data at designated offsets, though the operating system or user software may extend these with additional data. Each system object has a type field which is checked by microcode, such that a Port Object cannot be used where a Carrier Object is needed. User |
System-defined objects consist of either a single access segment, or an access segment and a data segment. System-defined segments contain data or access descriptors for system-defined data at designated offsets, though the operating system or user software may extend these with additional data. Each system object has a type field which is checked by microcode, such that a Port Object cannot be used where a Carrier Object is needed. User programs can define new object types which will get the full benefit of the hardware type checking, through the use of ''type control objects (TCOs)''. |
||
In Release 1 of the iAPX 432 architecture, a system-defined object typically consisted of an access segment, and optionally (depending on the object type) a data segment specified by an access descriptor at a fixed offset within the access segment. |
In Release 1 of the iAPX 432 architecture, a system-defined object typically consisted of an access segment, and optionally (depending on the object type) a data segment specified by an access descriptor at a fixed offset within the access segment. |
||
By Release 3 of the architecture, in order to improve performance, access segments and data segments were combined into single segments of up to 128 kB, split into an access part and a data part of 0–64 |
By Release 3 of the architecture, in order to improve performance, access segments and data segments were combined into single segments of up to 128 kB, split into an access part and a data part of 0–64 KB each. This reduced the number of object table lookups dramatically, and doubled the maximum virtual address space.<ref>{{cite book|author=Glenford J Meyers|title=Advances in Computer Architecture|edition=2nd|publisher=Wiley|year=1982|isbn=978-0-471-07878-4|chapter=Section VI: Overview of the Intel iAPX432 Architecture}}</ref> |
||
Glenford J Meyers, Advances in Computer Architecture, 2nd edition, Wiley 1982, ISBN 0-471-07878-6. Section VI covers the iAPX 432.</ref> |
|||
The iAPX432 recognizes fourteen types of predefined ''system objects'':<ref name=GDPRef>{{cite book|last1=Intel Corporation|title=iAPX432 GENERAL DATA PROCESSOR ARCHITECTURE REFERENCE MANUAL|date=1983|url=http://www.bitsavers.org/components/intel/iAPX_432/171860-004_iAPX_432_General_Data_Processor_Architecture_Reference_Manual_Feb84.pdf|access-date=Nov 16, 2015}}</ref>{{rp|pp.1-11–1-12}} |
|||
* '''instruction object''' contains executable instructions |
|||
* '''domain object''' represents a program module and contains references to subroutines and data |
|||
* '''context object''' represents the context of a process in execution |
|||
* '''type-definition object''' represents a software-defined object type |
|||
* '''type-control object''' represents type-specific privilege |
|||
* '''object table''' identifies the system's collection of active object descriptors |
|||
* '''storage resource object''' represents a free storage pool |
|||
* '''physical storage object''' identifies free storage blocks in memory |
|||
* '''storage claim object''' limits storage that may be allocated by all associated storage resource objects |
|||
* '''process object''' identifies a running process |
|||
* '''port object''' represents a port and message queue for interprocess communication |
|||
* '''carrier''' Carriers carry messages to and from ports |
|||
* '''processor''' contains state information for one processor in the system |
|||
* '''processor communication object''' is used for interprocessor communication |
|||
===Garbage collection=== |
===Garbage collection=== |
||
Software running on the 432 does not need to explicitly deallocate objects that are no longer needed |
Software running on the 432 does not need to explicitly deallocate objects that are no longer needed. Instead, the microcode implements part of the marking portion of [[Edsger Dijkstra]]'s on-the-fly parallel [[Garbage collection (computer science)|garbage collection]] algorithm (a [[mark-and-sweep]] style collector).<ref>{{Cite journal | doi = 10.1145/359642.359655| last1 = Dijkstra | first1 = E. W. | author-link1 = Edsger W. Dijkstra| last2 = Lamport | first2 = L. | author-link2 = Leslie Lamport| last3 = Martin | first3 = A. J. | last4 = Scholten | first4 = C. S.| last5= Steffens | first5 = E. F. M.| title = On-the-fly garbage collection: an exercise in cooperation| journal = [[Communications of the ACM]]| volume = 21| issue = 11| date = November 1978 | pages = 966–975| s2cid = 8017272 | doi-access = free}}</ref> The entries in the system object table contain the bits used to mark each object as being white, black, or grey as needed by the collector. The [[iMAX 432]] operating system includes the software portion of the garbage collector.<ref>{{cite web|url=http://bitsavers.org/components/intel/iAPX_432/172103-002_iMAX_432_Reference_Manual_May82.pdf|title=iMAX 432 Reference Manual|date=May 1982|publisher=[[Intel]]}}</ref> |
||
On-the-fly garbage collection: an exercise in cooperation by Edsger W Dijkstra, Leslie Lamport, A J Martin, C S Scholten, E F M Steffens </ref> The entries in the system object table contain the bits used to mark each object as being white, black, or grey as needed by the collector. |
|||
===Instruction format=== |
|||
The [[iMAX-432]] operating system includes the software portion of the garbage collector. |
|||
Executable instructions are contained within a system "instruction object".<ref name=GDPRef />{{rp|p.7-3}} Due to instructions being bit-aligned, a 16-bit ''bit'' displacement into the instruction object allows the object to contain up to 65,536 bits (8,192 bytes) of instructions. |
|||
Instructions consist of an ''operator'', consisting of a ''class'' and an ''opcode'', and zero to three ''operand references''. "The fields are organized to present information to the processor in the sequence required for decoding". More frequently used operators are encoded using fewer bits.<ref name=GDPRef />{{rp|p.7-6}} The instruction begins with the 4 or 6 bit class field which indicates the number of operands, called the ''order'' of the instruction, and the length of each operand. This is optionally followed by a 0 to 4 bit ''format'' field which describes the operands (if there are no operands the format is not present). Then come zero to three operands, as described by the format. The instruction is terminated by the 0 to 5 bit opcode, if any (some classes contain only one instruction and therefore have no opcode). "The Format field permits the GDP to appear to the programmer as a zero-, one-, two-, or three-address architecture." The format field indicates that an operand is a data reference, or the top or next-to-top element of the operand stack.<ref name=GDPRef />{{rp|pp.7-3–7-5}} |
|||
===Multitasking and interprocess communication=== |
|||
The iAPX 432 microcode implements multitasking, using objects in memory to represent the processor, processes, communication ports, and dispatching ports. Each processor is associated with a dispatching port, and when it is idle will attempt to dispatch a process from that dispatching port. When the process blocks or its time quantum expires, the processor re-enqueues that process at its dispatching port, then dispatches a new process from the dispatching port. |
|||
==See also== |
|||
Interprocess communication is supported through the use of communication ports. A communication port is essentially a [[FIFO]] that can enqueue either messages waiting to be received by a process, or processes waiting to receive a message (but never both). A program can use the Send, Receive, Conditional Send, Conditional Receive, Surrogate Send, or Surrogate Receive instructions to communicate with other processes by sending messages to or receiving messages from communication ports. If there is no message enqueued at a communication port, a normal Receive instruction on that port will block the current process until a message is available. Similarly, a normal Send instruction will block the current process if the port is full. The Conditional Send and Conditional Receive instructions do not block, instead returning a [[Boolean data type|Boolean]] result indicating whether the operation succeeded. The Surrogate Send and Surrogate Receive instructions provide a Carrier object that can block in place of the process. |
|||
* [[iAPX]], for the iAPX name |
|||
==Notes== |
|||
One of the elegant aspects of the iAPX 432 architecture is that a dispatching port is actually just a communication port whose messages are process objects, thus unifying the operation of process dispatching and interprocess communication and simplifying the underlying implementation. |
|||
{{Reflist|group='NB'}} |
|||
===Multiprocessing=== |
|||
The iAPX 432 has hardware support for [[multiprocessing]], using up to 64 processors (combination of GDPs and IPs). Usually, all GDPs share a common workload by using a single system-wide dispatching port, though it is possible to partition the workload by assigning some processors to different dispatching ports. With suitably designed hardware, processors can be added to or removed from the system on the fly. |
|||
===Fault tolerance=== |
|||
From the outset, the iAPX 432 included support for [[Fault-tolerant design|fault tolerance]]. All of the 432's chips could be configured in pairs for ''Functional [[Redundancy (engineering)|Redundancy]] Checking ('''FRC''')'', in which one component, the master, operated normally, and a second, the checker, carried out the same internal operations in parallel and verified its results against those of the master. |
|||
FRC provides for failure detection, but full fault tolerance requires a recovery mechanism. Systems based on the Interconnect Architecture supported automatic failure recovery by combining pairs of FRC modules for ''Quad Modular Redundancy ('''QMR''')''. In a QMR configuration, at any given time one FRC module is a primary and the other is a shadow. The two modules operate in [[Lockstep (computing)|lockstep]], but the roles alternate to detect latent faults. The shadow module does not drive the bus. If a fault is detected in either FRC module, that module is disabled while the nonfaulted module can continue operation. The software is notified, and can choose to let the system continue operating (without fault tolerance for that module), pair the module with a spare, or take the module offline (shifting its workload to other processors in the system for [[Fault-tolerant system|graceful performance degradation]]). |
|||
===I/O=== |
|||
The 43203 Interface Processor ('''IP''') allows a more conventional microprocessor to be interfaced as an Attached Processor ('''AP''') to an iAPX 432 system. The AP acts as an intelligent [[Input/output|I/O]] controller. The IP allows the AP to access objects in the iAPX 432 memory through the use of memory-mapped windows, but enforces the access rights applicable to the objects. |
|||
The IP provides five memory windows. Four are used to map objects for I/O operations; the fifth is the control window and is used by the AP to perform control operations such as requesting changes to the mapping of the other windows. |
|||
The IP also offers a special "physical" mode in which the AP has unrestricted access to the entire iAPX 432 address space. Physical mode is intended to be used only for system startup and debugger support. |
|||
==References== |
==References== |
||
{{ |
{{Reflist|30em}} |
||
==External links== |
==External links== |
||
*[http://www.bitsavers.org/ |
* [http://www.bitsavers.org/components/intel/iAPX_432/ IAPX 432 manuals at Bitsavers.org] |
||
*[http://www.computerhistory.org/exhibits/microprocessors/up2.shtml Computer History Museum] |
* [https://web.archive.org/web/20070702083957/http://www.computerhistory.org/exhibits/microprocessors/up2.shtml Computer History Museum] |
||
*[http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/ Intel iAPX432 Micromainframe] contains a list of all the Intel documentation associated with the iAPX 432, a list of hardware part numbers and a list of more than 30 papers. |
* [http://www.brouhaha.com/~eric/retrocomputing/intel/iapx432/ Intel iAPX432 Micromainframe] contains a list of all the Intel documentation associated with the iAPX 432, a list of hardware part numbers and a list of more than 30 papers. |
||
{{Intel processors}} |
{{Intel processors|discontinued}} |
||
{{Object-capability security}} |
|||
{{Authority control}} |
|||
[[Category:Capability systems]] |
|||
[[Category:High-level language computer architecture]] |
|||
[[Category:Intel microprocessors]] |
[[Category:Intel microprocessors]] |
||
[[de:Intel iAPX 432]] |
|||
[[es:Intel iAPX 432]] |
|||
[[ko:인텔 iAPX 432]] |
|||
[[it:Intel iAPX 432]] |
|||
[[ja:Intel iAPX 432]] |
|||
[[no:Intel iAPX 432]] |
|||
[[pl:Intel iAPX 432]] |
|||
[[pt:Intel iAPX 432]] |
|||
[[ru:IAPX 432]] |
|||
[[tr:Intel iAPX 432]] |
Latest revision as of 19:33, 1 October 2024
General information | |
---|---|
Launched | late 1981 |
Discontinued | ca 1985 |
Common manufacturer |
|
Performance | |
Max. CPU clock rate | 5 MHz to 8 MHz |
The iAPX 432 (Intel Advanced Performance Architecture) is a discontinued computer architecture introduced in 1981.[1][NB 1] It was Intel's first 32-bit processor design. The main processor of the architecture, the general data processor, is implemented as a set of two separate integrated circuits, due to technical limitations at the time. Although some early 8086, 80186 and 80286-based systems and manuals also used the iAPX prefix for marketing reasons, the iAPX 432 and the 8086 processor lines are completely separate designs with completely different instruction sets.
The project started in 1975 as the 8800 (after the 8008 and the 8080) and was intended to be Intel's major design for the 1980s. Unlike the 8086, which was designed the following year as a successor to the 8080, the iAPX 432 was a radical departure from Intel's previous designs meant for a different market niche, and completely unrelated to the 8080 or x86 product lines.
The iAPX 432 project is considered a commercial failure for Intel, and was discontinued in 1986.[1][3]
Description
[edit]The iAPX 432 was referred to as a "micromainframe", designed to be programmed entirely in high-level languages.[4][5] The instruction set architecture was also entirely new and a significant departure from Intel's previous 8008 and 8080 processors as the iAPX 432 programming model is a stack machine with no visible general-purpose registers. It supports object-oriented programming,[5] garbage collection and multitasking as well as more conventional memory management directly in hardware and microcode. Direct support for various data structures is also intended to allow modern operating systems to be implemented using far less program code than for ordinary processors. Intel iMAX 432 is a discontinued operating system for the 432,[6] written entirely in Ada, and Ada was also the intended primary language for application programming. In some aspects, it may be seen as a high-level language computer architecture.
These properties and features resulted in a hardware and microcode design that was more complex than most processors of the era, especially microprocessors. However, internal and external buses are (mostly) not wider than 16-bit, and, just like in other 32-bit microprocessors of the era (such as the 68000 or the 32016), 32-bit arithmetical instructions are implemented by a 16-bit ALU, via random logic and microcode or other kinds of sequential logic. The iAPX 432 enlarged address space over the 8080 was also limited by the fact that linear addressing of data could still only use 16-bit offsets, somewhat akin to Intel's first 8086-based designs, including the contemporary 80286 (the new 32-bit segment offsets of the 80386 architecture was described publicly in detail in 1984).[NB 2]
Using the semiconductor technology of its day, Intel's engineers weren't able to translate the design into a very efficient first implementation. Along with the lack of optimization in a premature Ada compiler, this contributed to rather slow but expensive computer systems, performing typical benchmarks at roughly 1/4 the speed of the new 80286 chip at the same clock frequency (in early 1982).[7] This initial performance gap to the rather low-profile and low-priced 8086 line was probably the main reason why Intel's plan to replace the latter (later known as x86) with the iAPX 432 failed. Although engineers saw ways to improve a next generation design, the iAPX 432 capability architecture had now started to be regarded more as an implementation overhead rather than as the simplifying support it was intended to be.[7]
Originally designed for clock frequencies of up to 10 MHz, actual devices sold were specified for maximum clock speeds of 4 MHz, 5 MHz, 7 MHz and 8 MHz with a peak performance of 2 million instructions per second at 8 MHz.[8][9]
History
[edit]Development
[edit]Intel's 432 project started in 1976, a year after the 8-bit Intel 8080 was completed and a year before their 16-bit 8086 project began. The 432 project was initially named the 8800,[5] as their next step beyond the existing Intel 8008 and 8080 microprocessors. This became a very big step. The instruction sets of these 8-bit processors were not very well fitted for typical Algol-like compiled languages. However, the major problem was their small native addressing ranges, just 16 KB for 8008 and 64 KB for 8080, far too small for many complex software systems without using some kind of bank switching, memory segmentation, or similar mechanism (which was built into the 8086, a few years later on). Intel now aimed to build a sophisticated complete system in a few LSI chips, that was functionally equal to or better than the best 32-bit minicomputers and mainframes requiring entire cabinets of older chips. This system would support multiprocessors, modular expansion, fault tolerance, advanced operating systems, advanced programming languages, very large applications, ultra reliability, and ultra security. Its architecture would address the needs of Intel's customers for a decade.[10]
The iAPX 432 development team was managed by Bill Lattin, with Justin Rattner (who would later become CTO of Intel) as the lead engineer[11][12][13] (although one source[1] states that Fred Pollack was the lead engineer). Initially the team worked from Santa Clara, but in March 1977 Lattin and his team of 17 engineers moved to Intel's new site in Portland.[12] Pollack later specialized in superscalarity and became the lead architect of the i686 chip Intel Pentium Pro.[1]
It soon became clear that it would take several years and many engineers to design all this. And it would similarly take several years of further progress in Moore's Law, before improved chip manufacturing could fit all this into a few dense chips. Meanwhile, Intel urgently needed a simpler interim product to meet the immediate competition from Motorola, Zilog, and National Semiconductor. So Intel began a rushed project to design the 8086 as a low-risk incremental evolution from the 8080, using a separate design team. The mass-market 8086 shipped in 1978.
The 8086 was designed to be backward-compatible with the 8080 in the sense that 8080 assembly language could be mapped on to the 8086 architecture using a special assembler. Existing 8080 assembly source code (albeit no executable code) was thereby made upward compatible with the new 8086 to a degree. In contrast, the 432 had no software compatibility or migration requirements. The architects had total freedom to do a novel design from scratch, using whatever techniques they guessed would be best for large-scale systems and software. They applied fashionable computer science concepts from universities, particularly capability machines, object-oriented programming, high-level CISC machines, Ada, and densely encoded instructions. This ambitious mix of novel features made the chip larger and more complex. The chip's complexity limited the clock speed and lengthened the design schedule.
The core of the design — the main processor — was termed the General Data Processor (GDP) and built as two integrated circuits: one (the 43201) to fetch and decode instructions, the other (the 43202) to execute them. Most systems would also include the 43203 Interface Processor (IP) which operated as a channel controller for I/O, and an Attached Processor (AP), a conventional Intel 8086 which provided "processing power in the I/O subsystem".[4]
These were some of the largest [clarification needed] designs of the era. The two-chip GDP had a combined count of approximately 97,000 transistors[citation needed] while the single chip IP had approximately 49,000. By comparison, the Motorola 68000 (introduced in 1979) had approximately 40,000 transistors.[citation needed]
In 1983, Intel released two additional integrated circuits for the iAPX 432 Interconnect Architecture: the 43204 Bus Interface Unit (BIU) and 43205 Memory Control Unit (MCU). These chips allowed for nearly glueless multiprocessor systems with up to 63 nodes.
The project's failures
[edit]Some of the innovative features of the iAPX 432 were detrimental to good performance. In many cases, the iAPX 432 had a significantly slower instruction throughput than conventional microprocessors of the era, such as the National Semiconductor 32016, Motorola 68010 and Intel 80286. One problem was that the two-chip implementation of the GDP limited it to the speed of the motherboard's electrical wiring. A larger issue was the capability architecture needed large associative caches to run efficiently, but the chips had no room left for that. The instruction set also used bit-aligned variable-length instructions instead of the usual semi-fixed byte or word-aligned formats used in the majority of computer designs. Instruction decoding was therefore more complex than in other designs. Although this did not hamper performance in itself, it used additional transistors (mainly for a large barrel shifter) in a design that was already lacking space and transistors for caches, wider buses and other performance oriented features. In addition, the BIU was designed to support fault-tolerant systems, and in doing so up to 40% of the bus time was held up in wait states.
Another major problem was its immature and untuned Ada compiler. It used high-cost object-oriented instructions in every case, instead of the faster scalar instructions where it would have made sense to do so. For instance the iAPX 432 included a very expensive inter-module procedure call instruction, which the compiler used for all calls, despite the existence of much faster branch and link instructions. Another very slow call was enter_environment, which set up the memory protection. The compiler ran this for every single variable in the system, even when variables were used inside an existing environment and did not have to be checked. To make matters worse, data passed to and from procedures was always passed by value-return rather than by reference. When running the Dhrystone benchmark, parameter passing took ten times longer than all other computations combined.[14]
According to the New York Times, "the i432 ran 5 to 10 times more slowly than its competitor, the Motorola 68000".[15]
Impact and similar designs
[edit]The iAPX 432 was one of the first systems to implement the new IEEE-754 Standard for Floating-Point Arithmetic.[16]
An outcome of the failure of the 432 was that microprocessor designers concluded that object support in the chip leads to a complex design that will invariably run slowly, and the 432 was often cited as a counter-example by proponents of RISC designs. However, some hold that the OO support was not the primary problem with the 432, and that the implementation shortcomings (especially in the compiler) mentioned above would have made any CPU design slow. Since the iAPX 432 there has been only one other attempt at a similar design, the Rekursiv processor, although the INMOS Transputer's process support was similar — and very fast.[citation needed]
Intel had spent considerable time, money, and mindshare on the 432, had a skilled team devoted to it, and was unwilling to abandon it entirely after its failure in the marketplace. A new architect—Glenford Myers—was brought in to produce an entirely new architecture and implementation for the core processor, which would be built in a joint Intel/Siemens project (later BiiN), resulting in the i960-series processors. The i960 RISC subset became popular for a time in the embedded processor market, but the high-end 960MC and the tagged-memory 960MX were marketed only for military applications.
According to the New York Times, Intel's collaboration with HP on the Merced processor (later known as Itanium) was the company's comeback attempt for the very high-end market.[15]
Architecture
[edit]The iAPX 432 instructions have variable length, between 6 and 321 bits.[17] Unusually, they are not byte-aligned, that is, they may contain odd numbers of bits and directly follow each other without regard to byte boundaries.[5]
Object-oriented memory and capabilities
[edit]The iAPX 432 has hardware and microcode support for object-oriented programming and capability-based addressing.[18][19] The system uses segmented memory, with up to 224 segments of up to 64 KB each, providing a total virtual address space of 240 bytes. The physical address space is 224 bytes (16 MB).
Programs are not able to reference data or instructions by address; instead they must specify a segment and an offset within the segment. Segments are referenced by access descriptors (ADs), which provide an index into the system object table and a set of rights (capabilities) governing accesses to that segment. Segments may be "access segments", which can only contain Access Descriptors, or "data segments" which cannot contain ADs. The hardware and microcode rigidly enforce the distinction between data and access segments, and will not allow software to treat data as access descriptors, or vice versa.
System-defined objects consist of either a single access segment, or an access segment and a data segment. System-defined segments contain data or access descriptors for system-defined data at designated offsets, though the operating system or user software may extend these with additional data. Each system object has a type field which is checked by microcode, such that a Port Object cannot be used where a Carrier Object is needed. User programs can define new object types which will get the full benefit of the hardware type checking, through the use of type control objects (TCOs).
In Release 1 of the iAPX 432 architecture, a system-defined object typically consisted of an access segment, and optionally (depending on the object type) a data segment specified by an access descriptor at a fixed offset within the access segment.
By Release 3 of the architecture, in order to improve performance, access segments and data segments were combined into single segments of up to 128 kB, split into an access part and a data part of 0–64 KB each. This reduced the number of object table lookups dramatically, and doubled the maximum virtual address space.[20]
The iAPX432 recognizes fourteen types of predefined system objects:[21]: pp.1-11–1-12
- instruction object contains executable instructions
- domain object represents a program module and contains references to subroutines and data
- context object represents the context of a process in execution
- type-definition object represents a software-defined object type
- type-control object represents type-specific privilege
- object table identifies the system's collection of active object descriptors
- storage resource object represents a free storage pool
- physical storage object identifies free storage blocks in memory
- storage claim object limits storage that may be allocated by all associated storage resource objects
- process object identifies a running process
- port object represents a port and message queue for interprocess communication
- carrier Carriers carry messages to and from ports
- processor contains state information for one processor in the system
- processor communication object is used for interprocessor communication
Garbage collection
[edit]Software running on the 432 does not need to explicitly deallocate objects that are no longer needed. Instead, the microcode implements part of the marking portion of Edsger Dijkstra's on-the-fly parallel garbage collection algorithm (a mark-and-sweep style collector).[22] The entries in the system object table contain the bits used to mark each object as being white, black, or grey as needed by the collector. The iMAX 432 operating system includes the software portion of the garbage collector.[23]
Instruction format
[edit]Executable instructions are contained within a system "instruction object".[21]: p.7-3 Due to instructions being bit-aligned, a 16-bit bit displacement into the instruction object allows the object to contain up to 65,536 bits (8,192 bytes) of instructions.
Instructions consist of an operator, consisting of a class and an opcode, and zero to three operand references. "The fields are organized to present information to the processor in the sequence required for decoding". More frequently used operators are encoded using fewer bits.[21]: p.7-6 The instruction begins with the 4 or 6 bit class field which indicates the number of operands, called the order of the instruction, and the length of each operand. This is optionally followed by a 0 to 4 bit format field which describes the operands (if there are no operands the format is not present). Then come zero to three operands, as described by the format. The instruction is terminated by the 0 to 5 bit opcode, if any (some classes contain only one instruction and therefore have no opcode). "The Format field permits the GDP to appear to the programmer as a zero-, one-, two-, or three-address architecture." The format field indicates that an operand is a data reference, or the top or next-to-top element of the operand stack.[21]: pp.7-3–7-5
See also
[edit]- iAPX, for the iAPX name
Notes
[edit]References
[edit]- ^ a b c d Dvorak, John C. "Whatever Happened to the Intel iAPX432?". Retrieved 19 July 2012.
- ^ Defining Intel: 25 Years / 25 Events (PDF). Intel. 1993. p. 14.
- ^ Smith, Eric. "Intel iAPX-432 Micromainframe". Archived from the original on February 2, 2016. Retrieved Dec 6, 2015.
- ^ a b Intel Corporation (1981). Introduction to the iAPX 432 Architecture (PDF). pp. iii.
- ^ a b c d Stanley Mazor (January–March 2010). "Intel's 8086". IEEE Annals of the History of Computing. 32 (1): 75–79. doi:10.1109/MAHC.2010.22. S2CID 16451604.
- ^ Kahn, Kevin C.; Corwin, William M.; Dennis, T. Don; d'Hooge, Herman; Hubka, David E.; Hutchins, Linda A.; Montague, John T.; Pollack, Fred J. (December 1981). "iMAX: A multiprocessor operating system for an object-based computer" (PDF). ACM SIGOPS Operating Systems Review. 15 (5): 127–136. doi:10.1145/800216.806601. S2CID 9245960.
- ^ a b Colwell, Robert; Gehringer, Edward (1988). "Performance Effects of Architectural Complexity in the Intel 432" (PDF). ACM Transactions on Computer Systems. 6 (3): 296–339. doi:10.1145/45059.214411. S2CID 8314206.
- ^ Intel iAPX-432 Micromainframe
- ^ Maliniak, Lisa (October 21, 2002). "Ten Notable Flops: Learning From Mistakes". Electronic Design.
- ^ David King; Liang Zhou; Jon Bryson; David Dickson (April 15, 1999). "Intel iAPX 432 - Computer Science 460 - Final Project".
- ^ Mazor, Stanley (2010). "Intel's 8086". IEEE Annals of the History of Computing. 32: 75. doi:10.1109/MAHC.2010.22. S2CID 16451604.
- ^ a b Heike Mayer (2012). Entrepreneurship and Innovation in Second Tier Regions. Edward Elgar Publishing. pp. 100–101. ISBN 978-0-85793-869-5.
- ^ Defining Intel: 25 years / 25 events (PDF). Intel. 1993. p. 14.
- ^ Mark Smotherman, Overview of Intel 432
- ^ a b John Markoff, Inside Intel, The Future Is Riding on A New Chip, April 5, 1998
- ^ Vickery, Christopher. "IEEE-754 Reference Material". Archived from the original on December 1, 2011. Retrieved Dec 5, 2015.
- ^ Tadao Ichikawa; H. Tsubotani (1992). Language Architectures and Programming Environments. World Scientific. p. 127. ISBN 978-981-02-1012-0.
- ^ Levy, Henry M. (1984). "Chapter 9: The Intel iAPX 432" (PDF). Capability-Based Computer Systems. Digital Press.
- ^ Organick, Elliott I. (1983). "Chapter 4: i432 Object Structures for Program Execution". A programmer's view of the Intel 432 system. New York: McGraw-Hill. ISBN 0-07-047719-1. OCLC 9110667.
- ^ Glenford J Meyers (1982). "Section VI: Overview of the Intel iAPX432 Architecture". Advances in Computer Architecture (2nd ed.). Wiley. ISBN 978-0-471-07878-4.
- ^ a b c d Intel Corporation (1983). iAPX432 GENERAL DATA PROCESSOR ARCHITECTURE REFERENCE MANUAL (PDF). Retrieved Nov 16, 2015.
- ^ Dijkstra, E. W.; Lamport, L.; Martin, A. J.; Scholten, C. S.; Steffens, E. F. M. (November 1978). "On-the-fly garbage collection: an exercise in cooperation". Communications of the ACM. 21 (11): 966–975. doi:10.1145/359642.359655. S2CID 8017272.
- ^ "iMAX 432 Reference Manual" (PDF). Intel. May 1982.
External links
[edit]- IAPX 432 manuals at Bitsavers.org
- Computer History Museum
- Intel iAPX432 Micromainframe contains a list of all the Intel documentation associated with the iAPX 432, a list of hardware part numbers and a list of more than 30 papers.