
Eindhoven University of Technology MASTER US4A : universal, super scalable superscalar architecture : a preliminary study van Hekezen, A.H. Award date: 1996 Link to publication Disclaimer This document contains a student thesis (bachelor's or master's), as authored by a student at Eindhoven University of Technology. Student theses are made available in the TU/e repository upon obtaining the required degree. The grade received is not published on the document as presented in the repository. The required complexity or quality of research of student theses may vary by program, and the required minimum study period may vary in duration. General rights Copyright and moral rights for the publications made accessible in the public portal are retained by the authors and/or other copyright owners and it is a condition of accessing publications that users recognise and abide by the legal requirements associated with these rights. • Users may download and print one copy of any publication from the public portal for the purpose of private study or research. • You may not further distribute the material or use it for any profit-making activity or commercial gain eb 519 Technische Universiteit tu) Eindhoven Faculty of Electrical Engineering Digital Information Systems Group Master's Thesis: US4A: universal, super scalable superscalar architecture A preliminary study A.H. van Hekezen Coach : Dr. ir. A.C. Verschueren Supervisor : Prof. ir. M.PJ. Stevens Period : September 1993 - June 1994 The Fa<;ulty of Electrical Engineering of Eindhoven University of Technology does not accept any responsibility regarding the contents of Master's theses. Sequential computers are approaching a fundamental physical limit on their potential computational power. Such a limit is the speed of light. A.L. DeCegama (The Technology of Parallel Processing, Volume 1, 1989) Summary A superscalar microprocessor is a microprocessor that can execute multiple instructions concurrently. Such a processor changes the instruction order to achieve a better performance. Register renaming is a technique that makes this so called out-of-order execution possible by cancelling register storage conflicts and by keeping true data dependencies. A buffer of instructions between the decode and the update stage, called an instruction window, is necessary to make the schedule of instructions. To reduce branch penalties, branches can be predicted. Instructions can be fetched and executed speculatively in the pre­ dicted directions. However, special precautions are necessary to cancel results of incorrect predictions. Additional logic is necessary for making interrupts precise, that is the same as in a scalar processor. A preliminary study to a Universal Super Scalable SuperScalar Architecture (US~) has been done. Universal refers to instruction set independency (both RISe and eISC), super scalable refers to the great amount of scalability without a significant increase in clock cycle time. It also refers to the high performance potential. US~ is only a processor core, not a complete processor. A target parameter setting for high performance (more than three instructions per clock cycle using a RISC instruction set) has been defined. US~ consist of out-of-order execution with full register renaming using an instruction window based on the reorder buffer with future file principle. For every instruction, the instruction window contains the opcode, source- and destination operands, dependency information, and some status bits. Every instruction in the window has a unique label, called a tag. Register renaming has been implemented by replacing a register number with a tag. This tag refers to the instruction that generates the required result. Instructions are executed using the storage in the window for source- and destination operands instead of the normal registers. Whenever no trap or interrupt has occurred, results are copied from the instruction window to the register file in program order. Therefore, incorrect speculative executed instructions can easily be cancelled by marking those instructions invalid, which prevents them from updating the register file. Furthermore, multi-path speculative execution can be implemented using a simple extension. A speculative register file or future file has been used to implement the dependency checks. Multiple speculative register files have been used for implementing multi-path speculative execution. Shifting an instruction early in the cycle and updating operands late in the cycle is the key to have the instruction window do multiple actions in a cycle. This technique has been used for both the instruction window and the speculative register file. An interesting way of combining priority encoders has been used to find a sub-optimal schedule of instructions within one cycle. US~ is feasible but hardware counts show that it uses a lot of hardware. 3 Contents Preface 7 1. Introduction 1.1 Speeding up microprocessors 9 1.2 Project description " 12 1.3 How to read this thesis ............................. .. 14 2. Superscalar concepts 2.1 Introduction 17 2.2 Pipelining ......................... .. 18 2.2.1 Introduction to pipelining 2.2.2 Pipeline stalls 2.2.3 Out-oi-order execution 2.2.4 Preventing and reducing pipeline stalls due to data dependencies 2.3 Instruction Windows. .............................. .. 27 2.4 State recovery because of traps and speculative execution " 32 2.5 Theoretical performance of superscalar processors 35 2.5.1 Instruction level parallelism 2.5.2 The real performance limit: basic block size and fetch limits 2.6 Conclusion 39 3. Description of US4A 3.1 Introduction 41 3.2 Starting-points.. .................................. .. 42 3.2.1 Architectural starting-points 3.2.2 Current target parameter settings 3.2.3 Logic design rules 3.2.4 Layout considerations 3.2.5 Memory considerations 3.3 Overview of US4A................................. .. 45 3.4 Description of a non speculative window version. ........ .. 48 3.4.1 Description of a window entry 5 3.4.2 Example of a simplified window 3.4.3 Intermezzo: Reducing storage in the instruction window by sharing tag and register value storage 3.4.4 Implementing data dependency checks and register ren­ aming: the speculative register file 3.4.5 Intermezzo: Reducing storage in the instruction window by sharing source and destination operand storage 3.4.6 Dealing with the flag register 3.5 State recovery " 61 3.5.1 State recovery due to traps 3.5.2 State recovery due to speculative execution 3.5.3 Dealing with interrupts 3.6 Multi-path speculative version of US4A................. .. 65 3.7 Future directions .................................. .. 72 3.7.1 Problems and remaining design issues 3.7.2 Further research 3.7.3 Possible reductions 3.8 Conclusion 75 4. Implementation of the hardware 4.1 Introduction 77 4.2 Moving the instructions through the instruction window 77 4.3 Result bus monitoring .............................. .. 80 4.4 Speculative register file (SRF) 80 4.5 Flushing paths 81 4.6 Dispatch unit 82 4.7 Turn around time ........................... .. 85 4.8 Hardware counts. ................................. .. 86 4.9 Conclusion 88 5. Conclusions and recommendations 5.1 Conclusions ...................................... .. 89 5.2 Recommendations. ................................ .. 90 References .......................................... .. 91 Index .............................................. .. 95 Appendix A. Related publications .... .. 97 Appendix B. Hardware counts 105 6 Preface Faster, faster, faster. Computers are always too slow, no matter how expensive. Therefore, computer users are always looking for new and faster computers. Once the new computer has arrived, old programs do run much faster and new programs come within reach. However, they only run too slow. So again there is a need for faster computers... a never ending story? Part of this never ending story is the design of superscalar micropro­ cessors. This is one way among others to speed up program execution time. Superscalar microprocessors are processors that execute several instructions at the same time. With the same clock frequency, the superscalar processor will therefore be faster than his non-superscalar equivalent. This Master's thesis describes a preliminary study to US~: Universal Super Scalable SuperScalar Architecture. Goal of this study was to define a superscalar processor core which is highly adoptable: the architecture must not depend on a specific instruction set and all architectural parameters must be changeable. Whenever process technology improves and more transistors can be put on a chip, more performance can be achieved by increasing the architectural parameters. Because of this complexity, a lot of time has been spent at learning the concepts of superscalar microprocessors. Examining the literature has consumed a lot of time too; one does not want to design things that are already there. However, the literature was disappointing in several ways. A lot has been written about the subject superscalar microprocessors but only little is really essential. A lot has been written about the architectural concepts but only little about implementations. Many researchers prefer to use their own terms and unfortunately little of them try to comply 7 with established terms; no doubt that this will increase the time needed for literature examinations. I found several papers that had abstract nor title containing the word 'superscalar' though their main theme was about with superscalar pro­
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages108 Page
-
File Size-