Jump to content

Millicode

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by Dsimic (talk | contribs) at 06:34, 13 October 2015 (top: Small cleanups). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

In computer architecture, Millicode is a higher level of microcode used to implement the instruction set of a computer. Millicode runs on top of the microcoded instructions and uses those instructions to implement more complex instructions visible to the user of the system.

IBM invented both the concept and the term Millicode for the System/390 9672-G4 processor in 1997.[1]

Implementation of Millicode requires a special processor mode called millimode that provides its own set of registers, and possibly its own special instructions invisible to the user.[1]

The following are cited as advantages of Millicode:[1]

  • More complex instructions can easily be constructed from several millicode instructions.
  • Construction of a compatible line of computer models with different performance is simplified.
  • Millicode instructions can bypass CPU cache to improve performance.
  • Instructions can update multiple storage locations without concern for being interrupted.
  • Millicode can execute instructions at a higher privilege level without involving the operating system.
  • Millicode can provide a complex instruction as if it were a subroutine, making user code smaller.

See also

References

  1. ^ a b c Rogers, Bob (Sep–Oct 2012). "The What and Why of zEnterprise Millicode". IBM Systems Magazine.