Ultrasparc Architecture 2005
Total Page:16
File Type:pdf, Size:1020Kb
UltraSPARC Architecture 2005 One Architecture ... Multiple Innovative Implementations Draft D0.9.3b, 20 Oct 2009 Privilege Levels: Privileged and Nonprivileged Distribution: Public Part No.No: 8xx-xxxx-xx 950-5554-14 ReleaseRevision: 1.0, Draft 2002 D0.9.3b, 20 Oct 2009 Sun Microsystems, Inc. 4150 Network Circle Santa Clara, CA 95054 U.S.A. 650-960-1300 ii UltraSPARC Architecture 2005 • Draft D0.9.3b, 20 Oct 2009 Copyright 2002-2005 Sun Microsystems, Inc., 4150 Network Circle • Santa Clara, CA 950540 USA. All rights reserved. This product or document is protected by copyright and distributed under licenses restricting its use, copying, distribution, and decompilation. No part of this product or document may be reproduced in any form by any means without prior written authorization of Sun and its licensors, if any. Third-party software, including font technology, is copyrighted and licensed from Sun suppliers. Parts of the product may be derived from Berkeley BSD systems, licensed from the University of California. UNIX is a registered trademark in the U.S. and other countries, exclusively licensed through X/Open Company, Ltd. For Netscape Communicator™, the following notice applies: Copyright 1995 Netscape Communications Corporation. All rights reserved. Sun, Sun Microsystems, the Sun logo, Solaris, UltraSPARC, and VIS are trademarks, registered trademarks, or service marks of Sun Microsystems, Inc. in the U.S. and other countries. All SPARC trademarks are used under license and are trademarks or registered trademarks of SPARC International, Inc. in the U.S. and other countries. Products bearing SPARC trademarks are based upon an architecture developed by Sun Microsystems, Inc. The OPEN LOOK and Sun™ Graphical User Interface was developed by Sun Microsystems, Inc. for its users and licensees. Sun acknowledges the pioneering efforts of Xerox in researching and developing the concept of visual or graphical user interfaces for the computer industry. Sun holds a non-exclusive license from Xerox to the Xerox Graphical User Interface, which license also covers Sun’s licensees who implement OPEN LOOK GUIs and otherwise comply with Sun’s written license agreements. RESTRICTED RIGHTS: Use, duplication, or disclosure by the U.S. Government is subject to restrictions of FAR 52.227-14(g)(2)(6/87) and FAR 52.227-19(6/87), or DFAR 252.227-7015(b)(6/95) and DFAR 227.7202-3(a). DOCUMENTATION IS PROVIDED “AS IS” AND ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT, ARE DISCLAIMED, EXCEPT TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD TO BE LEGALLY INVALID . Copyright 2002–2005 Sun Microsystems, Inc., 4150 Network Circle • Santa Clara, CA 950540 Etats-Unis. Tous droits réservés. Des parties de ce document est protégé par un copyright 1994 SPARC International, Inc. Ce produit ou document est protégé par un copyright et distribué avec des licences qui en restreignent l’utilisation, la copie, la distribution, et la décompilation. Aucune partie de ce produit ou document ne peut être reproduite sous aucune forme, par quelque moyen que ce soit, sans l’autorisation préalable et écrite de Sun et de ses bailleurs de licence, s’il y en a. Le logiciel détenu par des tiers, et qui comprend la technologie relative aux polices de caractères, est protégé par un copyright et licencié par des fournisseurs de Sun. Sun, Sun Microsystems, le logo Sun, Solaris, UltraSPARC et VIS sont des marques de fabrique ou des marques déposées, ou marques de service, de Sun Microsystems, Inc. aux Etats-Unis et dans d’autres pays. Toutes les marques SPARC sont utilisées sous licence et sont des marques de fabrique ou des marques déposées de SPARC International, Inc. aux Etats-Unis et dans d’autres pays. Les produits portant les marques SPARC sont basés sur une architecture développée par Sun Microsystems, Inc. L’interface d’utilisation graphique OPEN LOOK et Sun™ a été développée par Sun Microsystems, Inc. pour ses utilisateurs et licenciés. Sun reconnaît les efforts de pionniers de Xerox pour la recherche et le développement du concept des interfaces d’utilisation visuelle ou graphique pour l’industrie de l’informatique. Sun détient une licence non exclusive de Xerox sur l’interface d’utilisation graphique Xerox, cette licence couvrant également les licenciés de Sun qui mettent en place l’interface d’utilisation graphique OPEN LOOK et qui en outre se conforment aux licences écrites de Sun. CETTE PUBLICATION EST FOURNIE "EN L’ETAT" ET AUCUNE GARANTIE, EXPRESSE OU IMPLICITE, N’EST ACCORDEE, Y COMPRIS DES GARANTIES CONCERNANT LA VALEUR MARCHANDE, L’APTITUDE DE LA PUBLICATION A REPONDRE A UNE UTILISATION PARTICULIERE, OU LE FAIT QU’ELLE NE SOIT PAS CONTREFAISANTE DE PRODUIT DE TIERS. CE DENI DE GARANTIE NE S’APPLIQUERAIT PAS, DANS LA MESURE OU IL SERAIT TENU JURIDIQUEMENT NUL ET NON AVENU. Comments and "bug reports” regarding this document are welcome; they should be submitted to email address: [email protected] iv UltraSPARC Architecture 2005 • Draft D0.9.3b, 20 Oct 2009 Contents Preface. i 1 Document Overview . 1 1.1 Navigating UltraSPARC Architecture 2005 . 1 1.2 Fonts and Notational Conventions . 2 1.2.1 Implementation Dependencies . 3 1.2.2 Notation for Numbers. 3 1.2.3 Informational Notes . 3 1.3 Reporting Errors in this Specification . 4 2 Definitions . 5 3 Architecture Overview. 13 3.1 The UltraSPARC Architecture 2005. 13 3.1.1 Features. 13 3.1.2 Attributes . 14 3.1.2.1 Design Goals . 15 3.1.2.2 Register Windows . 15 3.1.3 System Components . 15 3.1.3.1 Binary Compatibility. 15 3.1.3.2 UltraSPARC Architecture 2005 MMU . 15 3.1.3.3 Privileged Software . 15 3.1.4 Architectural Definition . 16 3.1.5 UltraSPARC Architecture 2005 Compliance with SPARC V9 Architecture 16 3.1.6 Implementation Compliance with UltraSPARC Architecture 2005 16 3.2 Processor Architecture . 16 3.2.1 Integer Unit (IU) . 16 3.2.2 Floating-Point Unit (FPU). 17 3.3 Instructions. 17 3.3.1 Memory Access . 17 3.3.1.1 Memory Alignment Restrictions . 18 3.3.1.2 Addressing Conventions . 18 3.3.1.3 Addressing Range . 18 3.3.1.4 Load/Store Alternate . 18 3.3.1.5 Separate Instruction and Data Memories . 19 3.3.1.6 Input/Output (I/O) . 19 3.3.1.7 Memory Synchronization . 19 3.3.2 Integer Arithmetic / Logical / Shift Instructions . 19 3.3.3 Control Transfer . 20 3.3.4 State Register Access . 20 3.3.4.1 Ancillary State Registers. 20 3.3.4.2 PR State Registers . 20 i 3.3.5 Floating-Point Operate. 21 3.3.6 Conditional Move . 21 3.3.7 Register Window Management. 21 3.3.8 SIMD. 21 3.4 Traps. .21 4 Data Formats. 23 4.1 Integer Data Formats . 24 4.1.1 Signed Integer Data Types . 24 4.1.1.1 Signed Integer Byte, Halfword, and Word. 25 4.1.1.2 Signed Integer Doubleword (64 bits) . 25 4.1.1.3 Signed Integer Extended-Word (64 bits) . 25 4.1.2 Unsigned Integer Data Types . 25 4.1.2.1 Unsigned Integer Byte, Halfword, and Word . 26 4.1.2.2 Unsigned Integer Doubleword (64 bits). 26 4.1.2.3 Unsigned Extended Integer (64 bits) . 26 4.1.3 Tagged Word (32 bits). 26 4.2 Floating-Point Data Formats . 27 4.2.1 Floating Point, Single Precision (32 bits) . 27 4.2.2 Floating Point, Double Precision (64 bits) . 27 4.2.3 Floating Point, Quad Precision (128 bits). 28 4.2.4 Floating-Point Data Alignment in Memory and Registers . 29 4.3 SIMD Data Formats . 29 4.3.1 Uint8 SIMD Data Format . 30 4.3.2 Int16 SIMD Data Formats . 30 4.3.3 Int32 SIMD Data Format . 30 5 Registers . 31 5.1 Reserved Register Fields . 32 5.2 General-Purpose R Registers. 32 5.2.1 Global R Registers. 33 5.2.2 Windowed R Registers. 34 5.2.3 Special R Registers . 37 5.3 Floating-Point Registers . 38 5.3.1 Floating-Point Register Number Encoding . 40 5.3.2 Double and Quad Floating-Point Operands . 41 5.4 Floating-Point State Register (FSR) . 42 5.4.1 Floating-Point Condition Codes (fcc0, fcc1, fcc2, fcc3). 42 5.4.2 Rounding Direction (rd) . 43 5.4.3 Trap Enable Mask (tem) . 43 5.4.4 Nonstandard Floating-Point (ns) . ..