Motorola 68881

The Motorola 68881 and Motorola 68882 are floating-point coprocessor (FPU) devices that were used in some computer systems in conjunction with the 68020 or 68030 microprocessors. The Motorola 68881 was introduced in 1984.[1] The addition of one of these devices added substantial cost to a computer, but added a floating-point unit that could rapidly perform floating point mathematical calculations. In the mid 1980s, this feature was useful mostly for scientific and mathematical software.

A Motorola 68881 FPU

Overview

A Motorola 68882 FPU

The 68020 and 68030 CPUs were designed with the separate 68881 chip in mind. Their instruction sets reserved the "F-line" instructions – that is, all opcodes beginning with the hexadecimal digit "F" could either be forwarded to an external coprocessor or be used as "traps" which would throw an exception, handing control to the computer's operating system. If an FPU is not present in the system, the OS would then either call an FPU emulator to execute the instruction's equivalent using 68020 integer-based software code, return an error to the program, terminate the program, or crash and require a reboot.

Architecture

Die of Motorola 68881

The 68881 has eight 80-bit data registers[2][3] (a 64-bit mantissa plus a sign bit, and a 15-bit signed exponent). It allows seven different modes of numeric representation, including single-precision, double-precision, and extended-precision, as defined by the IEEE floating-point standard, IEEE 754. It was designed specifically for floating-point math and is not a general-purpose CPU. For example, when an instruction requires any address calculations, the main CPU handles them before the 68881 takes control.

The CPU/FPU pair are designed such that both can run at the same time. When the CPU encounters a 68881 instruction, it hands the FPU all operands needed for that instruction, and then the FPU releases the CPU to go on and execute the next instruction.

68882

Die of Motorola 68882

The 68882 is an improved version of the 68881, with better pipelining, and eventually available at higher clock speeds. Its instruction set is exactly the same. Motorola claimed in some marketing literature that it executes some instructions 40% faster than a 68881 at the same clock speed, though this did not reflect typical performance, as seen by its more modest improvement in the table below. The 68882 is pin compatible with the 68881 and can be used as a direct replacement in most systems. The most important software incompatibility is that the 68882 uses a larger FSAVE state frame, which affects UNIX and other preemptive multitasking OSes that had to be modified to allocate more space for it.

Usage

The 68881 or 68882 were used in the Sun Microsystems Sun-3 workstations, IBM RT PC workstations, Apple Computer Macintosh II family, NeXT Computer, Sharp X68000, Amiga 3000, and Atari Mega STE, TT, and Falcon030. Some third-party Amiga and Atari products used the 68881 or 68882 as a memory-mapped peripheral to the 68000.

Versions

68881

  • 155 000 transistors on-chip
  • 12 MHz version
  • 16 MHz version ran at 160 kFLOPS
  • 20 MHz version ran at 192 kFLOPS
  • 25 MHz version ran at 240 kFLOPS

68882

  • 176 000 transistors on-chip
  • 25 MHz version ran at 264 kFLOPS
  • 33 MHz version ran at 352 kFLOPS
  • 40 MHz version ran at 422 kFLOPS
  • 50 MHz version ran at 528 kFLOPS

These statistics came from the comp.sys.m68k FAQ. No statistics are listed for the 16 MHz and 20 MHz 68882, though these chips were indeed produced.

Legacy

Starting with the Motorola 68040, floating point support was included in the CPU itself.

gollark: That *would* still require them to manually go over them in every category, and there are a lot of categories and subcategories. It would be nice if they actually explained what "amazon's choice" means, though, and had a separate one for "known good" stuff
gollark: They have quite a lot of categories, though. I suppose for broader ones they could probably have a few featured products, perhaps with video reviews and extra docs and stuff.
gollark: Especially locks and stuff, where telling if it's bad is hard.
gollark: I don't think you could reasonably expect them to have specialists review every (popular) product in every category to find good ones.
gollark: I bet they just pick those at random.

References

  1. Sterling, Thomas; Anderson, Matthew; Brodowicz, Maciej (2017). High Performance Computing: Modern Systems and Practices. Morgan Kaufmann. p. 459. ISBN 978-0-12-420158-3.
  2. http://www.freescale.com/webapp/sps/site/prod_summary.jsp?code=MC68882
  3. http://www.cpu-world.com/CPUs/68882/
Notes
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.