• DocumentCode
    3354761
  • Title

    The Transmeta Code Morphing™ Software: using speculation, recovery, and adaptive retranslation to address real-life challenges

  • Author

    Dehnert, James C. ; Grant, Brian K. ; Banning, John P. ; Johnson, Richard ; Kistler, Thomas ; Klaiber, Alexander ; Mattson, Jim

  • Author_Institution
    Transmeta Corp., Santa Clara, CA, USA
  • fYear
    2003
  • fDate
    23-26 March 2003
  • Firstpage
    15
  • Lastpage
    24
  • Abstract
    Transmeta´s Crusoe microprocessor is a full, system-level implementation of the x86 architecture, comprising a native VLIW microprocessor with a software layer, the Code Morphing Software (CMS), that combines an interpreter, dynamic binary translator, optimizer, and run-time system. In its general structure, CMS resembles other binary translation systems described in the literature, but it is unique in several respects. The wide range of PC workloads that CMS must handle gracefully in real-life operation, plus the need for full system-level x86 compatibility, expose several issues that have received little or no attention in previous literature, such as exceptions and interrupts, I/O, DMA, and self-modifying code. In this paper we discuss some of the challenges raised by these issues, and present the techniques developed in Crusoe and CMS to meet those challenges. The key to these solutions is the Crusoe paradigm of aggressive speculation, recovery to a consistent x86 state using unique hardware commit-and-rollback support, and adaptive retranslation when exceptions occur too often to be handled efficiently by interpretation.
  • Keywords
    optimising compilers; parallel architectures; program interpreters; system recovery; Code Morphing Software; Crusoe microprocessor; Transmeta; VLIW microprocessor; dynamic binary translator; x86 architecture; Application software; Collision mitigation; Computer architecture; Design engineering; Hardware; Instruction sets; Microprocessors; Robustness; Runtime; VLIW;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Code Generation and Optimization, 2003. CGO 2003. International Symposium on
  • Print_ISBN
    0-7695-1913-X
  • Type

    conf

  • DOI
    10.1109/CGO.2003.1191529
  • Filename
    1191529