### Instituto Politécnico Nacional ### Centro de Investigación en Computación Laboratorio de Microtecnología y Sistemas Embebidos Design of a Load/Store Queue with Out-of-Order Execution ### TESIS Que para obtener el grado de: Maestría en Ciencias en Ingeniería de Cómputo con opción en Sistemas Digitales PRESENTA: Ing. Abraham Josafat Ruiz Ramírez Directores de Tesis: Dr. Marco Antonio Ramírez Salinas Dr. Adrián Cristal Kestelman ## INSTITUTO POLITÉCNICO NACIONAL SECRETARÍA DE INVESTIGACIÓN Y POSGRADO #### ACTA DE REVISIÓN DE TESIS | En la Ciudad de | México, D.F. | siendo las | 14:00 | horas del día | 8 del n | nes de | |---------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------|--------------|---------| | enero de | 2016 se reunieron los | miembros de la | Comisión F | Revisora de la Tesis | s, designada | à | | por el Colegio de | Profesores de Estudios | de Posgrado e I | nvestigació | n del: | | | | | Centro | de Investigación | en Comp | utación | | | | para examinar la | tesis titulada: | | | | | | | | "Design of a Load | //Store Queue wi | ith Out-of- | Order Execution" | <u> </u> | | | Presentada por el a | alumno(a): | | | | | | | Ruiz | : | Ramírez | | Abraham | n Josafat | | | Apellido pa | aterno | Apellido materno | | No | mbre(s) | | | | | Со | n registro: | B 1 3 | 0 0 | 9 1 | | aspirante de: MA | ESTRÍA EN CIENCIAS EN | I INGENIERÍA DE | CÓMPUTO | CON OPCIÓN EN S | SISTEMAS DI | GITALES | | | tercambiar opiniones<br>d de que satisface lo | | | | | | | | LA | COMISIÓN RE | | | | | | | | Directores de Te | esis | | | | | Xi | ining | | | Civiliz. | | | | Dr. Marco | Antonio Ramírez Salinas | | Dr. Ac | drián Cristal Kestelma | an | | | 4 | A Month | | | O final series | | | | Dr. Luis | s Alfonso Villa Vargas | | Dr. l | Herón Molina Lozano | ) | | | MonCo | Osvaldo Espinosa Sosa | | Dr. Via | tor Hugo Ponce Pon | | | | IVI. EIT C. | Osvaido Espiriosa Sosa | CONTRACTOR IN | DI. VIC | to rugo(Fonce Fon | Ce | | | | | NEADLY OF THE PARTY PART | CO NACIONAL<br>TICACTORAL | | | | | | . / | DIRECC | 1011 | | | | ## INSTITUTO POLITÉCNICO NACIONAL SECRETARÍA DE INVESTIGACIÓN Y POSGRADO ### CARTA CESIÓN DE DERECHOS En la Ciudad de México, D.F. el día 8 del mes Enero del año 2016, el (la) que suscribe Abraham Josafat Ruiz Ramírez alumno (a) del Programa de Maestría en Ciencias en Ingeniería de Cómputo con opción en Sistemas Digitales con número de registro B130091, adscrito a Centro de Investigación en Computación, manifiesta que es autor (a) intelectual del presente trabajo de Tesis bajo la dirección de Marco Antonio Ramírez Salinas y Adrián Cristal Kestelman y cede los derechos del trabajo intitulado Design of a Load/Store Queue with Outof-Order Execution, al Instituto Politécnico Nacional para su difusión, con fines académicos y de investigación. Los usuarios de la información no deben reproducir el contenido textual, gráficas o datos del trabajo sin el permiso expreso del autor y/o director del trabajo. Este puede ser obtenido escribiendo a la siguiente dirección <u>abraham.ruiz1990@yahoo.com</u>. Si el permiso se otorga, el usuario deberá dar el agradecimiento correspondiente y citar la fuente del mismo. Nombre y firma ### Resumen El procesador súper-escalar trata de explotar el paralelismo a nivel de instrucción (ILP) presente en el código; la clave es ejecutar la mayor cantidad de instrucciones por cada ciclo de reloj (IPC). Para alcanzar esta meta es necesario implementar algunas técnicas de planificación dinámica para identificar instrucciones en vuelo que no tengan dependencia de datos entre ellas y que puedan ser ejecutadas en paralelo, técnicas como Predicción de Saltos, Renombrado de registros, Ejecución fuera de orden, así como la implementación de colas de instrucciones clasificadas por tipo de instrucción (enteros, punto flotante, acceso a memoria, vectoriales, etc.). Las instrucciones de acceso a memoria están dividas en dos categorías, "Load" y "Store", y tienen acceso directo a la memoria cache de datos de nivel uno; a causa de que las direcciones de memoria son calculadas hasta la etapa de ejecución (una vez emitida la instrucción a la unidad de generación de direcciones), es necesario tener un mayor control sobre las dependencias entre las instrucciones de acceso a memoria en vuelo, de otra forma la ejecución del programa producirá errores. El objetivo de esta tesis es el diseño e implementación de la Cola de instrucciones de acceso a memoria para un procesador RISC súper-escalar con ejecución fuera de orden, así como implementar un diseño eficiente para la técnica de desambiguación de direcciones de memoria. ### **Abstract** Superscalar processors exploit the instruction level parallelism (ILP) present in the code; the key is to execute the maximum amount of instructions per clock cycle (IPC). In order to reach this goal are needed to implement several schedule techniques to discover in-Flight instructions without data dependencies that can be executed in parallel inside of the execution window, techniques such as Branch prediction, Register rename, and out-of-order execution as well as to implement special execution engines classified by their kind of instruction (integer, floating point, memory access, vector, etc.). Memory access instructions are split into two categories, Load, and Store instructions and they have direct access with the L1 Cache Memory; because the memory addresses are computed in the execution stage, it is needed to have a greater control with the dependencies between the In-Flight instructions, otherwise the executed program will have failures. The objective of this thesis is the design and implementation of the Load Store Queue for a Superscalar RISC processor with an out-of-order execution and to design an efficient memory addresses disambiguation technique. # Acknowledgments I'm glad to say that this thesis wouldn't be achieved without the help and motivation of several people, friends and family. First of all, I'd like to thank my advisors Marco Antonio Ramírez Salinas and Adrián Cristal Kestelman, who guided me through the achievement of this thesis project, also thanking their motivation and patience. For all my friends that provided me so much support in this stage of my life, I'm really happy to have you in my life... Cesar Cervantes Cazales, you're like that brother who I can always rely on, thank you for all your faith in me, for always telling me that I'm able to do whatever I aim to do in my life, I really hope you stay as my best friend for a really long time. Elsa Dorantes Merino, thank you for all those nights which I needed to have an ear for my heart and concerns, as one of my best friends I'm glad to have you by my side whenever something shows up. Lidia Rico García, although we don't have too much time since we know each other, I'm so glad that our life-paths crossed each other, you have made me to trust in myself again, something that I lost a few years ago, and that has helped me in such a grateful way with the realization of my thesis, thank you so much for entering my life, you're amazing. Laura Fabila, you're one of that friends who tells the very truth of things, even though it hurts sometimes, it is so helpful and meaningful, everytime I talk with you, I discover something else of myself, please don't leave. Shadia Hernandez Andrade, you moved so much things in my life that I'm so thankful of, even though we have moved apart from each other's life, you'll always be part of this life event of mine, I'll always remind you with dearness. I want to say thank you to all my partners who made of this life-stage of mine easier to handle, Cristobal Ramírez Lazo, thank you for your company it that year in Barcelona. Cesar Hernandez, you have been my teacher, my friend and now my brother, thank you for all you advise and friendship through the years, I'm happy to think that we'll be working as teammates for a long time. Also, I'd like to say sorry for my friends that I forgot to name in this Acknowledgments page, but that doesn't mean that I'm not thankful with all of you, without you I may be lost sleeping beneath a bridge by now, thank you so much. To my confident, my best friend, my life partner and sister Cintia Elisa Ruiz Ramírez, you 're my favourite person in the world, thank you for your company and love, I'm really proud of you and so happy that I have been a good brother/father/friend for you, I really love you. To my precious mom, María de Jesús Ramírez Huerta, thank you so so much for your patience and love, I'm the product of your hardworking as an excellent mother, you really inspired me in so many levels that I can't imagine what I should be without you, thank you for always taking care of us, you're a beautiful person-model to follow, I love you. To my dad··· You made of me a good person, my whole will is dedicated to you··· ## Contents | List of | Figur | es | vii | |---------|--------|--------------------------------------------------|-----| | List of | Table | s | x | | Chapt | er 1 – | Introduction | 1 | | 1.1 | Pr | oblematic Approach | . 2 | | 1.2 | Ju | stification | . 3 | | 1.3 | Co | onsiderations | . 4 | | 1.4 | Ol | ojectives | . 4 | | 1 | .4.1 | Main objective | . 4 | | 1 | .4.2 | Specific objectives | . 4 | | 1.5 | Sc | ope of this thesis project and contributions | . 5 | | 1.6 | Or | ganization of this thesis | . 5 | | Chapt | er 2 – | Background | 6 | | 2.1 | RI | SC and CISC architectures | . 7 | | 2.2 | Ge | eneral concepts of a memory access instruction | . 9 | | 2.3 | Su | perscalar Processor | 11 | | 2 | .3.1 | Dependencies | 13 | | 2 | .3.2 | Main pipeline stages of a superscalar processor | 14 | | 2 | .3.3 | Address, Load and Store Queues | 26 | | 2.4 | Ca | che Memory and Memory Hierarchy | 28 | | 2 | .4.1 | Cache Memory Parameters | | | 2.5 | Ta | g and Data Array Accesses | 36 | | 2 | .5.1 | Parallel Tag and Data Array Access | 37 | | | .5.2 | Serial Tag and Data Array Access | | | Chapt | er 3 – | State of the Art | 39 | | 2 1 | R c | search Proposals for LSO & Memory Disamhiguation | 41 | | 3.1.1 | TRIPS | 41 | |---------------|--------------------------------------------------------------------------|----| | 3.1.2 | TRIPS (Unordered, Late-Binding LSQ Design) | 44 | | 3.1.3 | Store Sets | 46 | | 3.1.4 | Store Vectors | 47 | | 3.1.5 | Store-to-Load Forwarding via Store Queue index Prediction | 49 | | 3.1.6 | Address Indexed Memory Disambiguation and Store-to-Load Forwarding | 50 | | Chapter 4 – P | roposed Load/Store Queue Design | 52 | | 4.1 Loa | d/Store Unit with In-Order Execution | 52 | | 4.1.1 | In-Order Address Computation Pipeline | 53 | | 4.1.2 | In-Order Memory Access Pipeline | 55 | | 4.2 Loa | d/Store Unit with Out-of-Order Execution | 58 | | 4.2.1 | Unknown/Known Memory Address, Block Mapping Table & Address Generation . | 59 | | 4.2.2 | Out-of-Order Select Logic | 63 | | 4.2.3 | Memory Disambiguation & Store-to-Load Data Forwarding Mechanism | 65 | | 4.2.5 | Store-to-Load Forwarding Mechanism and Delayed Source Data Forwarding | 70 | | Chapter 5 – R | esults | 72 | | Chapter 6 – C | onclusions and Future Work | 82 | | 6.1 Con | clusions | 82 | | 6.2 Fut | ure Work | 83 | | Appendix-A | | 84 | | Appendix-B | | 90 | | References | | a | # List of Figures | Figure 2-1. Core and its interfaces with caches | 7 | |-------------------------------------------------------------------------------------------------------------|----| | Figure 2-2. x86 Instruction fields | 8 | | Figure 2-3. CISC architecture | 8 | | Figure 2-4. RISC Instruction fields | 9 | | Figure 2-5. General memory access instruction data path | 10 | | Figure 2-6. Scalar vs Superscalar Execution in Pipeline Processors | 12 | | Figure 2-7. Superscalar Processor Architecture | 13 | | Figure 2-8. True and False Data Dependencies | 14 | | Figure 2-9. Fetch stage | 15 | | Figure 2-10. Decoder ROMs | 16 | | Figure 2-11. Typical RISC decode stage | 17 | | Figure 2-12. Register renaming example | | | Figure 2-13. Register Renaming building blocks | 19 | | Figure 2-14. Reorder Buffer | 20 | | Figure 2-15. Instruction's tracking inside the ROB | 21 | | Figure 2-16. Recovery Logic in Front-End and Back-End | | | Figure 2-17. Dispatch Logic | | | Figure 2-18. INT and FP Queues with Mapper | | | Figure 2-19. Organization of the CAM Section in the Instruction Queue | | | Figure 2-20. Two-Issue INT Queue's Payload RAM Logic | 24 | | Figure 2-21. Timing of the wake-up signal to support back-to-back execution | 25 | | Figure 2-22. An execution engine with two functional units, without (left) and with (right) value bypassing | | | Figure 2-23. Recycling Physical Registers at Commit Time | | | Figure 2-24. Conventional LSQ design | | | Figure 2-25. SRAM cell | 29 | | Figure 2-26. DRAM cell | | | Figure 2-27. The Cache Memory concept | | | Figure 2-28. Memory hierarchy | | | Figure 2-29. Fully-Associative Cache Organization | | | Figure 2-30. Direct-Mapped Cache Organization | | | Figure 2-31. Two-Way Set-Associative Cache Organization | | | Figure 2-32. Parallel Tag and Data Array Access | | | Figure 2-33. Serial Tag and Data Array Access | | | Figure 3-1. TRIPS prototype microarchitecture | | | Figure 3-2. TRIPS Processor's Data Tile | | | Figure 3-3. The Age-Indexed LSQ | 44 | | Figure 3-4. The ULB-LSQ Microarchitecture | 45 | |--------------------------------------------------------------------------------------------------------|----| | Figure 3-5. BFP Search Filtering | 46 | | Figure 3-6. Implementation of Store Sets Memory Dependence Prediction | 47 | | Figure 3-7. (a) Store-address tracking of dependencies, and (b) Age-tracking of dependencies | 48 | | Figure 3-8. Store vectors data structures and interaction with a conventional load queue | | | Figure 3-9. Example store vectors operation | | | Figure 3-10. Store queues: (a) associative, (b) indexed | 50 | | Figure 3-11. Processor pipeline, store forwarding cache (SFC), memory disambiguation table (MDT) and S | | | FIFO | | | Figure 4-1. Lagarto II Microarchitecture | 53 | | Figure 4-2. Ready Bit Assignment Example | | | Figure 4-3. Head Pointer and Tail Pointer | | | Figure 4-4. Select Logic and Address Generation Unit | 55 | | Figure 4-5. Forward Logic Example | | | Figure 4-6. Memory Access (Load) | | | Figure 4-7. Memory Access (Store) | | | Figure 4-8. Proposed LSQ General Pipeline | | | Figure 4-9. Block Mapping Table Functionality Example | | | Figure 4-10. Address Queue (inside the L/S Unit) & the Block Mapping Table | | | Figure 4-11. Queue's Ready Bit Logic | | | Figure 4-12. Leading Zero Counter as a Priority Selector (oldest-first) – 32bits | | | Figure 4-13. Non/Possible dependencies vector generation | | | Figure 4-14. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (a) | | | Figure 4-15. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (b) | | | Figure 4-16. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (c) | | | Figure 4-17. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (d) | | | Figure 4-18. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (e) | | | Figure 4-19. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (f) | | | Figure 4-20. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (g) | | | Figure 4-21. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (h) | | | Figure 4-22. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (i) | | | Figure 4-23. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (j) | | | Figure 4-24. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (k) | | | Figure 4-25. Example for the Memory Disambiguation & Store-to-Load data forwarding using the propos | | | Non/Possible Dependencies Vectors & Hash Table (I) | | | Figure 5-1. Maximum Overall Frequency | | | Figure 5-2. Decoder | | | Figure 5-3. Integer Ready Bit Register - Test 1 | | | | | | Figure 5-4. Integer Ready Bit Register - Test 2 | <i>75</i> | |------------------------------------------------------------------------------|-----------| | Figure 5-5. Floating Point Ready Bit Register - Test | 76 | | Figure 5-6. Pointer Control Logic - Test 1 | 77 | | Figure 5-7. Recovery Mechanism | 77 | | Figure 5-8. Selection Logic - Test 1 | <i>77</i> | | Figure 5-9. Selection Logic - Test 2 | 78 | | Figure 5-10. Selection Logic - Test 3 | 78 | | Figure 5-11. Address Queue's Write/Read Test | 78 | | Figure 5-12. Block Mapping Table Test | 79 | | Figure 5-13. Possible dependencies vector - Desk evaluation 1 | 79 | | Figure 5-14. Possible Dependencies Vector - Test 1 | 80 | | Figure 5-15. Possible dependencies vector - Desk evaluation 2 | 80 | | Figure 5-16. Possible Dependencies Vector - Test 2 | 80 | | Figure 5-17. Store-to-Load Data Forwarding - Test | 81 | | Figure 7-1. Front-End | 85 | | Figure 7-2. Store-to-Load Forwarding Logic including the Delayed Source Data | 86 | | Figure 7-3. Load/Store Queue with In-Order Execution | 87 | | Figure 7-4. Incorporation of the proposed Load/Store Unit to the processor | 88 | | Figure 7-5. Select Logic, Address Generation & PDVs pipeline | 89 | ## List of Tables | Table 1. Memory disambiguation schemes | 27 | |-----------------------------------------------------------------------------------------|----| | Table 2. Cache memory parameters | 32 | | Table 3. Memory Address Fields | 37 | | Table 4. Load Execution Scenarios (X=Don't care) | 43 | | Table 5. Entries Organization inside the Queue | 61 | | Table 6. 4 Blocks-RAM/CAM write enables and multiplexers between two input instructions | 61 | ### "Design of a Load/Store Queue with Out-of-Order Execution" by #### Abraham Josafat Ruiz Ramírez A thesis submitted in partial fulfillment of the requirements for the degree of Maestría en Ciencias en Ingeniería de Cómputo and Master in Innovation and Research in Informatics at the "Instituto Politécnico Nacional" Centro de Investigación en Computación – Mexico and "Universitat Politècnica de Catalunya" Facultat d'Informàtica de Barcelona – Spain January 2016 under the supervision of PhD. Marco Antonio Ramírez Salinas PhD. Adrián Cristal Kestelman # Chapter 1 #### INTRODUCTION Lagarto II, is a Processor architecture still in development by some students, researchers, and lecturers from the Microtechnology and Embedded Systems research group (MICROSE) which belongs to the *Centro de Investigación en Computación* of the *Instituto Politécnico Nacional* of Mexico. The objective of this MICROSE's project is to design a 64-bits Superscalar RISC processor with a dynamic scheduling and out-of-order execution. The design is modeled at RTL level in HDL code using some EDA tools, such as Mentor Graphics ModelSim and Altera Quartus II. Though most of the Lagarto II processor's design is already finished, it still does not have a working Load Store Queue, so this thesis project will be the first design of its corresponding memory access building block. The memory access engine in a superscalar processor is commonly separated into three functional blocks (address queue, load queue, and store queue), which houses some specific logic for memory access instructions. The Address Queue: the issuing and computation of memory addresses, the Load Queue: the logic to read data from the L1 Cache Memory and to write this data to the Register Files, and finally, the Store Queue: the logic to read from the Register Files and to write this data to the L1 Cache Memory. Because a superscalar processor executes the instructions in an out-of-order fashion, the identification of data hazards created by the dependencies between the in-flight LOAD and STORE instructions becomes a necessity. So, a memory disambiguation technique is used, which checks the ordering age and memory address of each of the issued instructions inside both the Load and Store queues, it also does some data forwarding for those instructions that have the same memory address (taking care of their age ordering inside the queue). The out-of-order execution takes advantage of the speculation technique, permitting an early execution of instructions that do not have a dependency with younger instructions. Forwarding some data, such as a Load that (speculatively) has the same memory address of an earlier Store, the data that would be written to the L1 Cache Memory by that Store instruction can be forwarded to the dependent Load instruction, thus, completing it beforehand. In order to do this speculative execution, a predictor must be used. There are two major kinds of predictors, those that use a "naive" or "blind" prediction which always says that the Load instructions don't have any dependency with earlier Stores, and those that are "dynamic" which update their dependencies tables as long as there are wrong speculations, so, later with these dependencies tables updated a better decision would be made. #### 1.1 PROBLEMATIC APPROACH The problematic appointed in this thesis is to design a Load-Store queue able to execute the memory access instructions in an out-of-order fashion. The design of this complete queue will be simulated in Mentor Graphics ModelSim software and evaluated in an FPGA board. For a first approach, the design will be only a simple Load Store Queue, without a predictor but with an age ordering memory disambiguation, the design will be able to support the store-to-load data forwarding logic as well as some energy saving techniques. This store-to-load data forwarding can be done whenever there is a Load instruction with the same memory address as an earlier Store instruction in the queue (the memory address isn't known until execution stage) but in order to achieve a high performance IPC, these memory access instructions must be executed in an out-of-order manner, thus, the memory disambiguation must be included in the design in order to ensure their correct execution. #### 1.2 **JUSTIFICATION** Nowadays in Mexico there is a huge foreign technological dependence, this dependence is reflected in obsolete solutions purchased at high costs in areas as health, food, education, energy and security. But most important is the knowledge dependence, most of the intellectual property belong to EEUU and this carries big security issues as well as low-end given technology. Because of that, some countries such as China have broken this barrier and fabricated their own trustworthy processors, they also promoted the foreign technology investment in their country and nowadays they have acquired a great amount of IT fabs as well as "Research and Development" (R&D) centres. The first Chinese processor version was called "Loongson 1", a 32bit MIPS compatible processor and it was working at 266MHz, later on, they achieved a second processor called "Loongson 2", it was a 64bit superscalar processor with out-of-order execution working at 1GHz, and it also included a graphic accelerator, after this approach, they continued with multicore technology achieving in 2009 an 8-core multiprocessor working at 1GHz, subsequently, and in 2011 they built a 6 and 8-core multiprocessors working at 1.2GHz. With this effort they created their own low-cost PCs, servers, High-performance PCs, industrial control equipment, and most important, their national security applications. Taking into account this important fact, the "Lagarto II" will be the first Mexican superscalar processor, and it will carry big efforts in the national security area, as well as trying to diminish this actual technology dependence; it is cleared that the goal for this big project is inspired by the mentioned Chinese success and the design of this processor's block, the Load Store Queue, will enforce the national technological advance. #### 1.3 Considerations In a high-performance superscalar processor, the energy consumption is a really important challenge to solve, thus, there are a lot of energy saving techniques included in vendor's processors, but these techniques are kept in patents so that they can't be used by another processor vendor. A sort of important processor's building blocks that should be using these power saving techniques are the Register Renaming stage, the Wake-Up logic in the Instruction Queues (integer, floating point, memory access) and the memory disambiguation for the memory accesses executed in an out-of-order fashion. As I have already stated, the energy saving in a high-performance superscalar processor is a very important fact to achieve, thus, this thesis is also focused in these energy saving techniques, such as disabling some unnecessary comparisons done by every entry on each of the queues included in the LS Queue (address queue, load queue, and store queue). For research and educational purposes, the Lagarto II architecture uses the MIPS64 Instruction Set Architecture, thus, to evaluate this design the MIPS64 ISA's memory access instructions will be used. #### 1.4 OBJECTIVES #### 1.4.1 MAIN OBJECTIVE To design and implement a Load-Store Queue for a superscalar processor with out-of-order execution and to design its memory disambiguation method using power saving techniques. #### 1.4.2 Specific objectives - I. To define the requirements for the memory access instructions execution. - II. To identify the differents kinds of memory access instructions, to design a digital logic to decode those instructions and generate the necessary control signals. III. To design the logic for the different blocks included in the Load Store engine (Address Queue, Load Queue, and Store Queue) and the selection logic in order to execute the memory access instructions in an out-of-order fashion. - IV. To design a memory disambiguation scheme and to do a desk evaluation for every combination between three consecutive memory access instructions (Load or Store), results must be presented. - V. To use microarchitectural energy saving techniques, trying not to decrease the overall performance. #### 1.5 Scope of this thesis project and contributions At the end of this thesis, the Lagarto II processor will feature a Load-Store queue able to receive two instructions per cycle and to issue one instruction per cycle in an out-of-order fashion, this will be approachable with the help of the memory disambiguation scheme designed, also, it will have a reduced power consumption taking into account a previous Instruction queue design [1], this novel design will be adapted to the Address queue, and it motivated the design for both the Load queue and Store queue. #### 1.6 ORGANIZATION OF THIS THESIS This thesis is organized as follows, in the second chapter, all the background information needed to explain this thesis approach is described, as well as how the processor works and the functionality of its main building blocks, it is also explained some terminology. In the third chapter, several papers and research proposals in the state of the art for the Load/Store Queue and Memory Disambiguation are described. Then, the proposed design for the Load/Store Queue is explained in the fourth chapter presenting some results in the fifth chapter. Conclusions are stated in the last chapter. ## Chapter 2 #### BACKGROUND Programs are normally written in a high-level programming language, such as C and C++, so these programs need to be transferred to a specific machine language using their corresponding compiler tool (such as ICC or GCC) configured for that specific microarchitecture. This code that is already in machine language represents the instructions that the processor can understand [2] [3], these instructions are read from instruction cache memory (via the Fetch mechanism) [4] and executed by that processor (making use of the data cache memory) (*Figure 2-1*). It is clear that every architecture (such as x86, MIPS, Alpha, etc.) has its own Instruction Set Architecture (ISA) which represents the way that the instructions are decoded and executed by that processor, but there are two major kinds of ISA, the Complex Instruction Set Computing (CISC) and the Reduced Instruction Set Computing (RISC), both of them with their own advantages and disadvantages. Figure 2-1. Core and its interfaces with caches #### 2.1 RISC AND CISC ARCHITECTURES Instructions of RISC ISA are smaller and simpler than CISC ISA as well as easier to decode because the length of their instructions is the same, this feature also require a bigger amount of instructions in order to do the same job as a fewer CISC instructions, this is because the complex instructions do not have the same length for every instruction (normally vary from 1 byte to 15 bytes) nor have the same structure. The CISC ISA instructions are more specialized (*Figure 2-2*) [5]. Normally, the CISC processors have a specialized Decoder which transforms each instruction into several simpler RISC instructions with the help of a "Micro-Code ROM" (*Figure 2-3*) [6]. Figure 2-2. x86 Instruction fields Figure 2-3. CISC architecture In another hand, the RISC architectures have a few instruction formats, support a few addressing memory modes, and lack of instructions that operate directly on memory operands. The most common fields in the RISC architectures instructions are the "base register", "destination register", "source register", "immediate value", "function", "opcode" and "index (in some architectures)". The three main instruction encodings in the RISC ISA are: The "Register Encoding (R-Instruction)", the "Immediate Encoding (I-Instruction)" which has a 16-bit (18-bit with 2-bit left shift) immediate signed value, and the "Jump Encoding (J-Instruction)" which has a 26-bit immediate value used to calculate the branch target address in order to jump unconditionally. In *Figure 2-4* there are shown these RISC instruction encodings. | R-Instruction | | | | | | |---------------|----------|----------|-------------|--------|----------| | OPCODE | BASE | SOURCE | DESTINATION | SHIFT | FUNCTION | | OPCODE | REGISTER | REGISTER | REGISTER | AMOUNT | FUNCTION | | 31-26 | 25-21 | 20-16 | 15-11 | 10-6 | 5-0 | | | | l-Instr | uction | |--------|----------|-------------|---------------------| | OPCODE | BASE | DESTINATION | IMMEDIATE VALUE | | OFCODE | REGISTER | REGISTER | IIVIIVILDIATE VALUE | | 31-26 | 25-21 | 20-16 | 15-0 | | J-Instruction | | | | |---------------|--------|--|--| | OPCODE | OFFSET | | | | 31-26 | 25-0 | | | Figure 2-4. RISC Instruction fields Memory access instructions (Load or Store) use the I-Instruction encoding, [20:26] bits encode the destination register for Load Instructions or the source register for Store Instructions, [25:21] bits encode the base register, and [15:0] encode a 16-bit offset. LW \$t0, 0x0200(\$gp) # Load Word Instruction Load word from \$gp + 0x0200 to \$t0 SW \$t1, 0x0204(\$gp) # Store Word Instruction - Store word from \$t1 to \$gp + 0x0204 #### 2.2 GENERAL CONCEPTS OF A MEMORY ACCESS INSTRUCTION This subsection describes a general execution process of a memory access instruction in a scalar processor in order to understand how the memory address is generated and either a read or write operation to the L1 Data Cache Memory is accomplished. Then, next subsection describes same instruction execution in a superscalar processor model and the utility of the Load Store Queue. Figure 2-5 shows the basic data path of a memory access instruction in a scalar processor. In the first stage, the Load / Store instruction is read from the Instruction Memory addressed by the Program Counter, later on, this instruction is decoded and identified as either a Load or a Store so that the control bits can be generated, in each of the memory access instructions, there are two register tag fields, the Base Register (RS) and the Source or Destination Register (RT), in both cases (Load and Store) the memory address is generated by adding the Data from the Base Register and the Immediate value sign extended (this memory address is either for Reading or Writing the L1 Data Cache Memory) and the RT register tag is used to read the source data that will be written to the L1 Cache Memory (in a store instruction) or to write the data read from the L1 Cache Memory to the Register File (in a load instruction), the second stage is for reading the Register File with these register tags and for sign extending the immediate value, the third stage is the execution stage, where the memory address is computed by adding the base register and the immediate value sign extended, the fourth stage is the Memory Access stage, here the L1 Data Cache Memory is either read or written, and the last stage, the Write Back stage, is only used where there is a Load instruction executed, here the Data read from the L1 Data Cache Memory is written to the Register File addressed by the Destination Register Tag, which had flowed through the stages as the instruction was being executed. Figure 2-5. General memory access instruction data path #### 2.3 SUPERSCALAR PROCESSOR The main purpose or goal of a superscalar processor is to exploit the parallelism within the instructions stream, it means that whenever there are independent instructions, they should be executed in parallel, and of course, there must be extra careful with those instructions that are dependent. There exist two implementations of superscalar processors regarding the way they execute their instructions, the one with an in-order execution and the other one with an out-of-order execution, due to the scope of this thesis, the in-order scheme won't be explained but the Superscalar Processor with out-of-order execution. It is divided into two main blocks, called the Back-End and the Front-End, the main difference between these blocks is that in the Front-End the instructions are flowing in order (sequentially) through its stages (Fetch, Decode, Rename, and Dispatch), whereas in the Back-End, the instructions can flow in an out-of-order fashion (Issue, Execution, and Write Back), except for the Commit stage, which is always executed in order ensuring correctness in the program execution. In the Front-End, the instructions are flowing sequentially through the stages, but after they are dispatched (entering the Back-End) and sent to its corresponding queue, the execution of each instruction can be made out-of-order and in parallel whenever there are sufficient structural resources (adders, bus, register file ports, memory ports, etc.). There are seven main stages along this superscalar processor, which are: - Fetch - Decode - Rename and Dispatch - Issue - Execution - Write Back - Commit Also, there are some main structures involved in the superscalar processor core (Reorder Buffer, Integer Queue, Floating Point Queue, Address Queue, Load Queue, Store Queue, Branch Predictor, Bypass, Register File, Free Register List, Register Alias Table, etc.). In order to understand how the parallelism is exploited, in *Figure 2-6* [7] is shown the comparison Chapter 2 between the amount of in-flight instructions in a scalar processor and a superscalar processor, here is shown that the amount of in-flight instructions inside a superscalar processor (for this example) is doubled as well as its execution is twice the number of executed instructions in the scalar processor in the same number of clock cycles. A dynamic scheduling [8] must be integrated along the data path in order to exploit the instruction level parallelism existent in the code in execution, this dynamic scheduling ensures correctness within the dependencies and takes advantage of parallel execution techniques. Figure 2-6. Scalar vs Superscalar Execution in Pipeline Processors Figure 2-7 illustrates the building blocks inside a superscalar processor. Figure 2-7. Superscalar Processor Architecture $PC = Program \ Counter; \ IFQ = Instruction \ Fetch \ Queue; \ ROB = Reorder \ Buffer; \ IIQ = Instruction \ Integer \ Queue; \ IFQ = Instruction \ Floating \ Point \ Queue; \ LSQ = Load \ Store \ Queue; \ Int. \ Reg. \ File = Integer \ Register \ File; \ FP \ Reg. \ File = Floating \ Point \ Register \ File; \ Integer \ FUs = Integer \ Functional \ Units; \ FP \ FUs = Floating \ Point \ Functional \ Units$ #### 2.3.1 Dependencies There are three different categories for dependencies: "Data dependencies", "Control dependencies" and "Structural dependencies". Because the main objective of a superscalar processor is to exploit the instruction level parallelism and to execute the maximum amount of instructions in parallel, most of its logic is dedicated in identifying and solving these dependencies. Inside the *Data Dependencies* category, there are two kind of data dependencies and the dependencies can be either within memory locations or CPU registers, the "*True data dependency*", which can be defined as a *RAW* (read-after-write) dependency, happens when the result of one instruction is needed as an input operand in another younger instruction, in order to do the correct execution for this sequence, the younger instruction must wait to the first instruction to be executed, after the first instruction has generated the result, the younger instruction can proceed, otherwise, it will have erroneous values. The other data dependencies are called the "False data dependencies" (also known as "artificial dependencies" or "name dependencies"), although these dependencies are cleared with the Renaming logic, for memory access instructions these dependencies are not resolved until their memory addresses are known, these are the *WAR* (write-after-read) and the *WAW* (write-after-write) dependencies, the first one happens when an older instruction is trying to read an operand from the Register file or from data from memory location, and it is going to be updated by another younger instruction. In order to ensure correctness, the older instruction must read this location before the younger instruction writes in it. The other dependency, WAW, happens when two instructions are trying to write to the same register or memory location, in order to keep the most actual value, they have to update this value in order, it means that the younger instruction must wait to the older instruction to write in this location (*Figure 2-8*). Figure 2-8. True and False Data Dependencies The *Control Dependencies* are present in conditional branch instructions inside the program in execution, it is because the conditional value is not known until the execution stage, then, there must be decided either to take the branch or not, in advance to this stage. The last dependencies, the *Structural Dependencies* occur when two or more instructions are requiring the same architectural resource, it can be an adder, multiplier, register port, etc., if there are no available resources, the instructions have to be executed sequentially. #### 2.3.2 Main pipeline stages of a superscalar processor Fetch is the stage (*Figure 2-9*) where the instructions are brought from the L1 Instruction Cache Memory and stored in a structure called Instruction fetch queue, in this structure are housed the instructions already read in advance from the Instruction Cache (in order to preserve good performance and low memory access traffic, these instructions have to be read faster than the time they take to execute). The Instruction Cache is read with the Fetch address, which can be the Program Counter value (next sequential value), Branch target value, Return-address value read from the stack, etc., this fetch address is computed every cycle, and thus, there must be extra considerations with the conditional branches, jumps and any instruction that goes to a specific instruction memory address. Furthermore, because in conditional branch the next fetch address isn't known until the execution stage, A *Branch Predictor* is needed working in parallel with the fetch engine. This Branch Predictor is often build of two primary blocks, the Branch Target Buffer (BTB) which gives the last address where the branch has jumped, and the Branch History Table (BHT) where the branch condition is predicted with the help of its "taken" or "not taken" history records, owing to the fact that branch mispredictions can occur, this branch predictor is updated with any wrong or correct prediction. A mechanism for recovery must be launched whenever this happens, instructions-stream of the wrong path needs to be flushed of the pipeline and the correct path has to be re-established by fetching the correct execution path. There must be a recovery logic inside the processor for this correction. Figure 2-9. Fetch stage EPC Registers = Exception Program Counter Registers; ACU = Address Computation Unit; Spec-PC: Speculative PC Decode is the stage where instructions are read from the Instruction fetch queue and are identified by their instruction opcode and function field, both opcode and function address the ROMs (*Figure 2-10*) which bring the operation control bits as well as flags indicating if it is a branch instruction, a jump, and link instruction, etc., this control bit packet is called "resource vectors". The register tags and immediate value for every instruction are read in this stage. Figure 2-10. Decoder ROMs It is needed a decoder for each instruction read from the Instruction Fetch Queue in the same clock cycle (*Figure 2-11*). Figure 2-11. Typical RISC decode stage Rename is the stage where the logic registers are linked to physical registers in order to solve false dependencies (also known as "artificial dependencies" or "name dependencies"), this allows the instructions (not memory access instructions) to be executed freely without any data hazards whenever they have their source operands ready to be read from the register files. If two or more instructions do not have dependencies, then the ILP can be exploited by executing them in parallel and out-of-order. In order to illustrate how the renaming process takes place, a simple renaming operation is shown in *Figure 2-12* [7] (L=Logical Registers, P=Physical Registers), here the L3 is renamed to P6 and in the second version of L3 is renamed to P9, because it was sharing the same location with another instruction that should not be dependent (name dependency), it has to be renamed in both the first and second instructions in order to have the last updated value for this register. In this same cycle, the first version of L3(P6) becomes old with the second version of L3(P9), then the value of P6 isn't needed anymore in the program execution, thus, it can be freed. Instructions 3 and 4 must preserve the true dependencies with the last version link of the register L3(P9). It has to be considered that the logical registers L3, L4, and L5 were previously renamed to the physical register P3, P4 and P5 respectively, and that the new physical registers P6, P7, P8 and P9 are available for renaming the logical destination registers tags. Figure 2-12. Register renaming example Regardless of register renaming, the true dependencies must be kept, for example, within instructions 2 and 4, P7 must be kept with its true dependency. The same happens between the instructions 1 and 2 with L3 (renamed to P6). This is accomplished by the dependency check logic. This register renaming algorithm can be stated with these steps: - 1) Look for all instruction inputs (Src) and outputs (Dest). - 2) Check for true dependencies (Dest; ∩ Src;). - 3) Detect early old destinations (Dest; ∩ Dest;). - 4) Rename new destination (PDest). - 5) Save the actual registers assignation (Context saving). Four structures are necessary to implement this register renaming logic (Figure 2-13): - 1) Register Alias Table (RAT): It has the record of all the renamed registers assignation. - 2) Dependency Check Logic (DCL): Identifies all the dependencies inside a group of instructions being renamed. - 3) Free List Register (FLR): It has the record of all the unassigned physical registers. - 4) Shadow Register Map (SRM): It saves the state of all the assignations in order to perform a precise context recovery whenever it is necessary. Figure 2-13. Register Renaming building blocks There are three main renaming schemes used in contemporary processors [9], the first one is the "Renaming through the Reorder Buffer", where the non-committed instructions results are stored in a Reorder Buffer, and only when the instruction is committed this result is written to the Register File changing the architectural state of the processor. The second one is the "Renaming through a Rename Buffer", it is very similar to the first scheme, but it has a separate buffer for only those in-flight instructions that generates a result value, it saves storage and energy in comparison with the first scheme. And the third scheme is the "Merged Register File" scheme, here, the Register File stores both speculative and committed values, its main advantage is that there is no data transfer from the Reorder Buffer to the Register File. Also in this stage, each instruction is assigned to an entry in the Reorder Buffer (ROB), if there isn't any empty entry in the ROB, the instruction fetch has to be stalled and wait for an empty entry. In order to identify which physical register can be freed (it means that its stored value isn't needed anymore and can be reused by another un-renamed register), the Reorder Buffer has two special entries for that purpose, the current destination register tag and the old destination register tag, so that, when the instruction in that ROB entry is committed, its old destination register is freed to the free register list (at this point) and the most actual value for that logical destination is the current destination register. The ROB (also known as the "active list") keeps track of every dispatched instruction inside the Back-End block of the processor, it is used to save the ordering of the instructions, even if they are executed out-of-order, at commit time, every instruction must be resolved in order (*Figure 2-14*). Whenever there is an exception or branch misprediction, the recovery logic read the modified variables using the In-Flight Tag given by the ROB and bring these variables back, then the execution of the program can continue. *Figure 2-15* shows the organization of the ROB (as a circular FIFO buffer) [10]. The Context Recovery is different between the Front-End and the Back-End blocks of the processor, for the Front-End, all the in-flight instructions have to be flushed and the fetch mechanism must take the right path immediately (the flush logic is simpler), whether in the Back-End (taking more clock cycles than in the Front-End), only the in-flight instructions that were dispatched after that recovery point have to be flushed, also, the renaming tables have to be modified with the correct entries stored at that recovery point, and the queues entries that were modified by the wrong path have to be recovered (Figure 2-16) [9]. Figure 2-14. Reorder Buffer Figure 2-15. Instruction's tracking inside the ROB Figure 2-16. Recovery Logic in Front-End and Back-End Dispatch is the stage where each instruction is sent to its corresponding queue (Integer Instruction queue, Floating point queue, Load store queue, etc.) (*Figure 2-17*). The Mapper is in charge of selecting the instructions by their kind of operation (integer, floating point, memory access, etc.), the selected instruction information is written in its assigned entry in the RAM-CAM queue structure, in the payload RAM are written the complete operation bits of the instruction, its source operands, destination register tags, and its resource vector, whether in the CAM are written the source operands tag to perform the dependent instructions wake-up by effectuating comparisons between results tags and source operands tags of instructions waiting in the queue (stored in the reservation stations) (*Figure 2-18*). Figure 2-17. Dispatch Logic Figure 2-18. INT and FP Queues with Mapper Issue stage is where the instructions that are ready to be selected (that is to say, that values of their source operands have been generated by older instructions and these values can be read from the Register Files or bypassed across the value forwarding network), can be issued in an out-of-order fashion, but there must be extra care with the memory access instructions (because the memory address is still uncertain). In this logic are involved the Wake-up logic, Ready logic, Selection logic (with a priority order logic) and Context recovery logic. The Wake-up logic is in charge of "waking up" these instructions by doing comparisons between the source operands tags stored in the CAM and the destination registers tags sent through the tag bus by the functional units, whenever there is a match, the Ready bit of the source operand is set to "1" because its value has been produced, then, when all the source operands are ready, the Select logic indicates which instructions can be issued to the next stage. *Figure 2-19* illustrates a CAM organization inside an Instruction queue, with "k" Destination Tags and "n" entries in the queue [1]. Figure 2-19. Organization of the CAM Section in the Instruction Queue The destination register tags, the source operands register tags and the resource vector of the selected instruction are read from the payload RAM and sent to the next stage (*Figure* 2-20). The cycles required by an instruction to do its operation depend on which resource is requesting (i.e. an adder will take fewer cycles than a multiplier or a divisor), thus, the wake-up signal for those instructions that take one cycle to complete has to be sent at the same time it is issued (by the select logic) in order to efficiently do the bypassing with consecutive consumer instructions, with the instructions that take longer number of cycles to complete, the wake-up signal needs to be scheduled to be sent a few cycles before the end of the ALU's computation. In *Figure 2-21* [9] is shown a comparison between two pipelines, one pipeline with this wake-up signal is sent at the end of Execution stage and another pipeline sends this signal at Select time, it is illustrated that without sending this signal at Select stage, it generates (for this example) three bubble cycles for the next consumer instruction, thus, it decreases the overall IPC, whether in the second pipeline the data bypassing is performed. Figure 2-20. Two-Issue INT Queue's Payload RAM Logic Figure 2-21. Timing of the wake-up signal to support back-to-back execution The Execution stage is where the issued instructions read their source operands from their corresponding Register Files or get the data bypassed from the Destination Bus and are sent to their requested ALU resources (adder, multiplier, divider, etc.), here, any arithmetic or logic operation is computed as well as memory addresses are calculated. The Integer functional units consist of adders, logical functional units, shift functional units, conditional branch solvers, multipliers, and dividers. The Floating Point functional units are more complex than the Integer ones, at first, the values in the FP Register File have to be encoded as the IEEE 754 Standard format for single and double precision, the operands go through a decompression operation after being read from the FP Register File and get compressed before writing in it (encoded according to the single or double precision format), except for FP load/store operations, the FP functional units consist of an adder, a multiplier, and divider/square root logic unit, the adders can execute several operations such as additions, subtractions, comparisons and format conversions. After finishing execution phase, in the Write-Back stage, the result values from the functional units are written back to the Register files (integer or floating point) as well as sent to the Bypass Network in order to perform a data bypassing to younger issued instructions (*Figure 2-22*) [9], also, the data read from the L1 Data Cache Memory (in a load instruction) is written to the Register files, the data in store instructions remains in the Store queue until commit stage (then the Data cache can be updated). Figure 2-22. An execution engine with two functional units, without (left) and with (right) value bypassing Commit stage, also known as Retire stage or Completion Stage, is in charge to modify the speculative state of the processor to an architectural state, the structure in charge of committing the instructions is the ROB (it has the instructions order stored in its entries), in order for an instruction to commit it must have all its pipeline flags set to "1" (valid-bit, issue-bit, execution-bit, no-speculative-bit), also, the previous older instructions must have committed in order to guarantee the ordering correctness of the program. When an instruction commits, its old destination register is freed so that it can be used again in the register renaming process (*Figure 2-23*), the current destination register changes its status to no speculative value and the Branch predictor tables are updated if it is the case. Figure 2-23. Recycling Physical Registers at Commit Time # 2.3.3 Address, Load and Store Queues Conventionally, the Load/Store queue is divided into three different building blocks, the Address queue (AQ), Load queue (LQ) and the Store queue (SQ). The LQ houses load instructions with their memory address computed and ready to read the Data Cache, similarly the SQ houses store instructions that have already computed their memory address but waiting to commit in order to update the Data cache with the source data read from the Register file, whether the AQ has the memory access instructions mixed (loads and stores) and without their memory address computed, here the memory access instructions are waiting for their source operand to be ready in order to be sent to Execution stage in order to compute their memory address (Address = Base register + Offset). Because the memory addresses aren't known until execution stage, the issuing logic for memory access instructions is a little more complex, this AQ remains organized as a FIFO buffer in order to maintain the program order so that the dependencies can be computed easily, also, these instructions are kept in the queues until they commit. Due to the fact that the rename mechanism used for integer and floating point instruction is not feasible for memory addresses (there are a lot more memory locations than physical registers) [11], there must be a mechanism in charge of ensuring that the data hazards are properly resolved in order to permit an out-of-order execution, this mechanism in charge of detecting all dependence violations is called the "Memory Disambiguation Policy". There are two kinds of memory disambiguation schemes, the non-speculative scheme, and the speculative scheme, the non-speculative scheme practically issues the memory access instructions in order, whether the speculative uses a dependency predictor to issue those instructions that are predicted as co-dependent of an older memory access instruction. Although the non-speculative issues in order, there are three kinds of non-speculative issuing, some with an out-of-order execution, in Table 1 [9] are shown these different kinds of memory disambiguation schemes. Table 1. Memory disambiguation schemes | Name | Speculative | Description | | | | |---------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Total Ordering | No | All memory accesses are processed in order. | | | | | Partial<br>Ordering | No | All stores are processed in order, but loads execute out-of-order as long as all previous stores have computed their addresses. | | | | | Load Ordering<br>Store Ordering | No | Execution between loads and stores is out of order, but all loads execute in-order among them, and all stores execute in-order among them. | | | | | Store Ordering | Yes | Stores execute in-order, but loads execute completely out-of-order | | | | Figure 2-24 [11] shows a conventional Load Store queue design separated for loads and stores in two different queues, in this scheme, a load associatively searches the Store queue in order to forward the data from an older in-flight store, whether a store searches for loads that have executed speculatively (wrong) in order to squash them by its re-execution. Figure 2-24. Conventional LSQ design #### 2.4 CACHE MEMORY AND MEMORY HIERARCHY Due to the variation with the memory access latency depending on the capacity of the memory, the cache memory subsystem is hierarchically divided into cache levels (normally up to three levels), being the L1 the closer one to the processor and with the smaller access latency. Also, there are two kinds of cache organizations, the inclusive caches, and the exclusive caches, in the inclusive caches the lower level caches have portion of data (trying to be the portions currently in use) copied from the upper level caches, whether in the exclusive caches it is to say that there is only one copy of that portion of data within all the cache levels (is more complex to handle). The cache hierarchical levels use different memory technologies, for the internal cache memory L1, L2, and L3 are always implemented using an SRAM (Static Random Access Memory) because of its small access latency, whether for the rest of the memory subsystem levels are normally implemented with DRAMs (Dynamic Random Access Memory). An SRAM cell (it stores one bit) is normally made of six CMOS transistors (6T SRAM cell), these transistors are composed of two access transistors and a pair of inverters (using two transistors each), whether the DRAM cell is a lot simpler within its structure, it is made of one or three transistors and a capacitor (needing to be refreshed every certain period of time in order to maintain its stored value). In *Figure 2-25* and *Figure 2-26* are shown these different memory technologies. Figure 2-25. SRAM cell Figure 2-26. DRAM cell Though the SRAM access is a lot faster than the DRAM, using only SRAMs for the whole memory is unfeasible because of cost, also, this memory technology wastes more energy, occupies more hardware space and its latency is long. In order to concealment the overall memory access latency, the data that is being accessed constantly is stored in the high-speed L1, L2, and L3 cache memory and whenever there is a cache miss (the requested data is not found in the L1 cache memory), there is an exchange of data within upper cache levels. It is normally for the L1 caches to be separated into Instruction Cache and Data Cache, whether, for the upper cache levels, they are usually composed of mixed instruction and data information (unified cache). The cache memory controller [4] is in charge of the tracking of all this stored information in the different cache levels, whenever there is a request from the processor, this cache memory controller checks if the data is stored in the high-speed cache, if effectively it is in L1, this location can be accessed immediately and there won't be any waiting cycles, but, if it is not, it results in a miss cache and the requested data is taken from upper memory levels L2, L3 or Main Memory (DRAMs) leading to wait cycles (*Figure 2-27*) [4]. Figure 2-27. The Cache Memory concept Memory hierarchies only work if the levels closer to the processor have stored data that the program will be reusing, if not, there will be a lot of wait cycles provoked by the long latency memories. Memory hierarchies work by taking into account the two aspects of the locality property inside an address space, the first aspect is the Temporal Locality which says that "The information that is already in use is likely to be used in the near future", and the second aspect is the Spatial Locality, it says that "The portions of the address space which are in use, generally consist of a fairly small number of individually contiguous segments of that address space" [12]. Normally, the instruction cache memory addresses as well as the data cache memory addresses, are virtual addresses, there must be performed a prior translation in order to obtain the physical addresses. This physical address is the range of memory locations that can be generated and driven by the address bus, whether the virtual memory address is the range of memory locations that a program can make use of. The whole address space is divided into pages, and the operating system is in charge of mapping them with the help of its page table data structure stored in main memory (*Figure 2-28*). Figure 2-28. Memory hierarchy #### 2.4.1 CACHE MEMORY PARAMETERS The cache memory can be classified by some parameters within its architecture and by its write policy, these parameters are noted in $Table\ 2$ . Table 2. Cache memory parameters | Bus<br>Utilization | ASSOCIATIVITY | Line Size | CACHE SIZE | WRITE POLICY | |----------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------| | Look-through<br>Look-aside | Fully-associative Direct-mapped N-Way set-associative | (Also known as<br>block size), these<br>are the number<br>of bytes per line,<br>normally<br>32bytes or<br>64bytes | KB of data in the<br>Memory, normally<br>these are 32KB for<br>L1 cache and<br>512KB for L2 cache | Write-through<br>Buffered write-through<br>Write-back | #### **Bus Utilization** The cache can be organized and implemented as a Look-through cache or a Look-aside cache, each one with its own advantages and disadvantages. Whenever the Look-through architecture searches for the requested data in the L1 cache it uses the local bus, and if it wasn't found, then it goes to an upper-level cache to search that data, thus, it will be using the system bus at this point, it has to be noted that the bus utilization for the upper-level caches is only required whenever there is a cache miss, by this way it saves unnecessary searches to these long-latency, it also saves power-wasting upper-level cache memories as well as unnecessary system bus utilization. In the other hand, the Look-aside searches in the L1 cache memory as well as in the upper-level caches, that is to say, it does not isolate the local bus searches from the system bus searches, this wastes more power and does more utilization of the bus (this can drive to memory access overhead), by the way, an advantage is that whenever there is a cache miss it gets the requested data faster than with another scheme, while the Look-through first searches in the closer level cache and then to the other level caches, the Look-aside searches all at the same time, thus it does not waste time in waiting for a cache miss. ## Write Policy There are two concepts for outdated data problems within the cache consistency, the first one happens when some memory location has been modified or updated (it is called to be "dirty" data) in a level cache but the outdated data in the another level cache hasn't (it is called to be "stall" data), thus, an updating operation must be driven in order to ensure cache consistency. The most common case is when the cache has been updated (now is a dirty memory location) with a store operation, while the copy in main memory is outdated (has stall data for that memory location). The way the processor solves the cache consistency problem is called the "Write Policy", the easiest implementation is the Write-Through policy, and this is because, whenever a store operation has been selected to update the architectural state of the processor's data cache, it also updates the copy of that memory location in its upper-level cache, it is simpler to implement but it results in lower overall performance because it has to access a long-latency main memory. A modification of this scheme is the Buffered Write-Through policy, this is one of the most used, it has a buffer where the store operations are saved, and simulates that there was a cache hit, but actually the operation will take place a little later, this policy is an improvement of the write-through policy. The Write-Back policy only updates the upper-level cache whenever it is necessary (just the locations that are marked to be dirty), the upper level is updated only when the cache location that contains "dirty" data is about to be overwritten by another memory location, then the upper-level cache has to be updated with this modified data. #### **Associativity** Remembering that the main memory is organized by pages and that the cache is divided by cache lines (also known as blocks or sets), there are three main concepts within the organization and addressing inside the cache, this organization can be a Fully-Associative, Direct-Mapped or an *N*-Way Set-Associative cache. With the Fully-Associative cache organization, the main memory is seen as a huge only "page", so that it is only divided by blocks, in this organization every block in main memory can be located (or not) in any of the L1 cache blocks, thus, when a memory location is accessed, this memory address is searched in each of the cache directory entries in order to know if this memory location copy is actually in the L1 cache or if it may need to be taken from upper-level caches, this drives to long-latency waiting cycles in the case of a big L1 cache (more than 4KB), it also consumes more power energy because of all the comparisons inside this CAM directory. This model increases the cache hit rate as well as overall performance for those processors that use small L1 caches. In *Figure 2-29* is shown a simple diagram of this cache organization. Figure 2-29. Fully-Associative Cache Organization Contrary to the fully-associative cache is the Direct-Mapped cache organization, only one entry has to be checked in the cache directory in order to indicate if the memory location copy is in cache or in main memory (cache hit or cache miss), in this organization the main memory is divided into pages, so that every set in the cache can map to that set of any of the pages in main memory, thus, it is simpler to implement and the latency in checking the cache directory is smaller than with the other schemes, the disadvantage with this organization is that there is only one permitted entry in the cache per set in the main memory, then it forces that whenever it has to be accessed the same set but from another page, that set has to be overwritten (in the hypothetic case where there are various consecutive accesses to set 0 but from different pages, every access will incur in page miss) (*Figure 2-30*). Figure 2-30. Direct-Mapped Cache Organization In order to make it possible to have in cache more sets of the same set in main memory but from different pages, an improvement of the last cache organization, is the *N*-way set-associative cache, it can be 2-Way Set-Associative, 4-Way Set-Associative, etc., as it increases the number of "ways", its associativity increases. Each "way" is one more portion of cache memory of the size of a single page (4KB, 8KB, etc.), which can store the same set but from a different page in main memory, that is to say, if there is already a set stored in "Way A" and an access to the same set but from a different page occurs, it isn't necessary to be overwritten the already stored set in "Way A", it is stored in another way (i.e. "Way B"). This scheme increases the cache hit rate compared to the Direct-Mapped cache organization. *Figure 2-31* illustrates a simple diagram for this cache organization (a two-way set-associative cache organization). Figure 2-31. Two-Way Set-Associative Cache Organization # 2.5 TAG AND DATA ARRAY ACCESSES Each memory address has three fields of information, the K least significant bits are the offset bits, with these bits a specific byte along the cache line (set) can be accessed, the next field is the index field, it determines which set in the page is being addressed, and the last field (in the most significant bits) is the tag, which is used to identify the page inside the memory subsystem. The size of these fields is noted in Table 3. Table 3. Memory Address Fields | Taking into<br>account | Block Size (in bytes) | = | Q | |------------------------|-----------------------|---|------------| | | Number of sets | = | S | | | Tag bits | = | T | | Offset bits (K) | | = | $log_2(Q)$ | | Index bits (M) | | = | $log_2(S)$ | | Page Size (in bytes) | | | S * Q | | Memory address length | | | T + M + K | Because different addresses can map to the same set inside the cache (but it belongs to a different page, though), there is a Tag Array that serves as a mechanism to "reverse-map" these indexes to addresses. It has the same organization as the Data Array, and for each block inside the data array, the tag array has stored both the Tag bits and the state bits of that block (whether it is valid, dirty, cached, uncached, etc.). There are two kinds of tag and data array accesses, the parallel access and serial access. # 2.5.1 PARALLEL TAG AND DATA ARRAY ACCESS In this scheme, the tag and data arrays are accessed in a parallel manner, the access process is the following: The tag bits from the memory address are compared with the tag bits found in all the "ways" of the tag array addressed by the index field of the memory address, if there is a hit, then it says that the memory location copy is in cache (it indicates in which "way" of the data cache blocks can be found), owing to the fact that all the "ways" of the data cache are read, the correct "way" has to be selected with the help of a multiplexor (the selected "way" is indicated by the tag array hit). If the tag is not found in the tag array, then it is said that the memory location copy isn't in the L1 cache and it has to be brought from upper-level memory. This scheme is fast by the fact that it read in parallel both the tag array and the data array, but it unnecessary wastes power energy in reading all the "ways" of the data array (*Figure 2-32*) [9]. Figure 2-32. Parallel Tag and Data Array Access #### 2.5.2 SERIAL TAG AND DATA ARRAY ACCESS In the other hand, with the serial tag and data array access, an extra cycle is introduced but some energy is saved, also, the access frequency increases because the "Way-Mux" is not necessary anymore. The Tag array is accessed firstly indicating if there is a cache hit or miss (if there is a cache hit, in this phase it is already known in which "way" of the Data array the data can be found). If a hit, the data array is accessed directly, if not, then the data is brought from the upper-level memory (*Figure 2-33*) [9]. Figure 2-33. Serial Tag and Data Array Access # Chapter 3 ## STATE OF THE ART In contemporary superscalar processors almost all designs include techniques such as store-to-load data forwarding [13], memory dependence prediction, speculated execution, etc., the conventional design is the one where the Load queue and the Store queue are two separated CAM queues searching associatively each other in order to perform either a data forwarding or a squashing in those load instructions executed prematurely (*Figure 2-24*), leading to unnecessary wasted energy, thus, there has been some Load Store queue design proposals which offer a low latency and a reduced power consumption [13] [14] [15] [16] [17] [18]. Due to the necessity in identifying any data dependency between a younger and an older in-flight memory access instruction, these research proposals use filtering techniques to reduce the number of associative searches. Despite of this restriction, there are a lot of models which offer speculated execution for these load instructions freeing them from waiting for the younger store instruction to have their memory address computed, this is done via a memory address dependence predictor, and it can be a "naive" predictor or a more sophisticated "dynamic" predictor, this last one can actually offer a very accurate prediction ( $\pm$ 96%), it achieves this accuracy because it goes learning the memory address dependency patterns as long as the program is executing, when the program starts its execution, the predictor will take "naive" decisions and fail occasionally but after some cycles the accuracy increase considerably. Normally, it is necessary for a load instruction to wait for any older store instruction to have already computed its memory address in order to ensure any memory dependency with these older store instructions. If a load has a data dependency with an earlier store, the load either has to wait for the store instruction to commit or a store-to-load forwarding can be done in order to forward the speculative data from the uncommitted store to the load. Store-to-load data forwarding occurs when the load virtual address matches with a store virtual address and the store size is greater than or equal to the load size [19]. Normally, a load instruction is more urgent to be executed than a store [20], it is because the data read from cache memory is more probable to be needed by a close younger instruction, because of that, load instructions may have preference over store instructions, but there must be extra careful with their un-computed memory addresses, executing out-of-order dependent memory access instructions may lead to incorrect results. The memory disambiguation is the mechanism that identifies any dependencies between memory access instructions, allowing these instructions to be executed in parallel. Any processor should have an efficient memory disambiguation scheme if the Instruction Level Parallelism is wanted to be achieved with memory access instructions. There is no dependency conflict when load instructions execute out-of-order, the conflict is generated when a load instruction executes before of a dependent older store, also, in order to maintain the memory semantically, it is necessary an in-order execution with those store instructions addressing to the same memory location, that is why modern out-of-order processors execute stores at commit time. In first memory disambiguation implementations this was made at compile-time [21] (called "static") but it is more suitable if it is made via a combined hardware/software implementation or an only hardware implementation, that is at run-time ("dynamic" memory disambiguation). Because the architectural state of the processor (talking about the data cache) is only changed at commit time, a store instruction has its source data stored in the store queue or written in a store buffer, allowing a store-to-load data forwarding by detecting whenever there is a load dependency with an older store. Some early implementations of dynamic hardware disambiguation [20] are: • The IBM System / 360 Model [22] – It has a store queue which can detect store-load dependencies. If it is detected a dependency between a load and an earlier store, the data is forwarded from the store to the load instruction. - The HPS Model [23] It uses a dependency matrix which blocks all the younger loads ongoing an unresolved store. - The Address Resolution Buffer (ARB) [24] It allows speculative execution for load instructions and it detects if this execution was successful (without any dependence) or not. Stores do not update data cache memory until commit time, this implementation is more complex than the IBM System 360 model and the HPS model. # 3.1 RESEARCH PROPOSALS FOR LSQ & MEMORY DISAMBIGUATION ## 3.1.1 TRIPS The TRIPS (Tera-op, Reliable, Intelligently adaptive Processing System) microarchitecture was designed and implemented by a research group in the Department of Computer Sciences at the University of Texas at Austin. This distributed, tiled microarchitecture prototype (*Figure 3-1*) offers higher instruction-level concurrency than current industrial processors, each core can execute up to 16 out-of-order operations per cycle and it is composed of multiple copies of five different types of tiles interconnected via microarchitectural networks [25]. Figure 3-1. TRIPS prototype microarchitecture Each data tile (DT) partition manages memory (load and store) instructions, performs address translation and protection with the help of its Data TLB, has a Miss-Handling Unit which can handle up to 64 cache misses, tracks and resolves memory dependencies between load and store instructions using its Load Store queues (*Figure 3-2*), it uses load/store dependency prediction in order to permit an out-of-order execution, and updates the data cache when the results become non-speculative. Figure 3-2. TRIPS Processor's Data Tile Each load/store instruction can be mapped into any of the 16 execution units, it issues when all its source operands are available and then it is sent to the DT through the network. [26] When a load enters the data tile, it accesses the TLB to do an address translation, checks protection attributes, checks the Dependence Predictor (DPR) for a store dependency, identifies older matching uncommitted stores to perform a store-to-load data forwarding and it also checks the tag array for a cache hit/miss. There are four possible scenarios depending on the hit/miss responses as shown in *Table 4*, and thus, an operation to be performed in every scenario. Table 4. Load Execution Scenarios (X=Don't care) | TLB | DPR | Cache | LSQ | Action | |------|------|-------|------|------------------------------------------------------| | Miss | X | X | X | Report TLB Exception | | Hit | Hit | Х | X | Defer load until all prior stores are received | | Hit | Miss | Hit | Miss | Forward data from cache | | Hit | Miss | Miss | Х | Forward data from L2 cache, issue cache fill request | | Hit | Miss | Hit | Hit | Forward data from LSQ and cache | This architecture supports different sizes for store-to-load data forwarding (8, 16, 32 and 64 bits), thus, whenever there is a "hit" in the LSQ indicating that a store-load data forwarding is possible, the matching bytes are taken from the LSQ whether the remaining bytes are taken from the data cache. When a store is sent to a data tile it is buffered in the LSQ and notifies to the other DTs that it has been issued, it checks for any dependence violation inside the DTs and if a younger load with the same memory address is found in the queue, then a recovery process is initiated. The dependence predictor is updated with this dependence misprediction. In order for a store to update the architectural state of the processor, it has to commit, then its store data is taken from the LSQ, the cache tags are checked in TLB and tag array (it is also updated the LRU algorithm mechanism), and if there is a hit, the cache/memory system is updated with the store data, then the corresponding cache line is marked as dirty. # 3.1.2 TRIPS (Unordered, Late-Binding LSQ Design) [15] [27] Unordered, Late-Binding LSQs (ULB-LSQs) sizes are smaller than traditional LSQs, this is because it allocates the memory instructions at issue time, and thus, it requires a different allocation mechanism. The allocation entry is taken from a pool of free LSQ slots in comparison with the traditional LSQs which is age-indexed, this un-links the age of the instruction from its occupied slot. The age of every L/S instruction is stored in a separate special CAM which output can indicate the result of a "greater, lesser or equal" operation instead of a "match" operation. *Figure 3-3* and *Figure 3-4* show the contrast between the traditional LSQ design and the ULB-LSQ design. Figure 3-3. The Age-Indexed LSQ Figure 3-4. The ULB-LSQ Microarchitecture When a store instruction arrives, it checks the address CAM for matching loads, and the special age CAM for younger loads, then using an OR operation between these two results, a violation is detected. With the store-load data forwarding mechanism, there is no conflict when there is only one match, but when there are multiple matches, in this case, the age of every match are read from the ULB-LSQ (one per cycle) and encoded into a per-byte bit vector (taking multiple cycles to generate this vector), these bits indicate which bytes should be forwarded to the load, multiple store forwarding is uncommon in many benchmarks, though. This proposal also includes LSQ filtering optimizations [28], in conventional LSQs, as the number of in-flight instructions increases, the number of entries that have to be searched increases as well, so the number of searches can be reduced with the help of hash tables and bloom filters [29] [30], every load/store address is hashed to a single bit (with the help of these bloom filters), it is written (incremented) in a hash table, later, when a filtered load/store address checks this hash table and it is already set that bit, then there is likely to be a match in the LSQ, if it isn't set, then it is certain that there is not any possible match inside the LSQ, this search elimination technique is called Bloom filter predictor (BFP) (*Figure 3-5*). When a load/store instruction retires, then the BFP entry is reduced by one. Figure 3-5. BFP Search Filtering ## 3.1.3 STORE SETS [31] In order to achieve a maximum performance in out-of-order processors, the load instructions must issue as soon as possible, this can be achieved with the help of memory dependency predictors which indicate whether a load instruction may have memory dependence with some of the in-flight store instructions or it should be issued freely, if a dependence violation occurs, then a recovery process must be taken and the memory dependence predictor is updated (dynamic predictors), the simplest memory dependence predictor is the "naïve" one (also known as "static" or "blind" predictor), this predictor indicates either that any load instruction may be dependent of any earlier store forcing it to wait for all the memory addresses of earlier stores to be known, or that non load instructions are dependent of any uncommitted store and they should issue as soon as possible. In this research proposal, they achieved an improved memory dependence predictor which uses "store sets", a store set is the set of the stores (identified by their PC) upon which a load has ever been dependent. They take as a baseline the assumption that historic behavior of memory-order violations servers is a good prediction for future memory dependencies. The algorithm is the following: whenever a program begins, the store sets of all the load are cleared and a naïve prediction is temporally used, every time a dependence violation occurs, the store PC is saved in the store set of the implicated load, if another dependence violation occurs with the same load, that store PC is saved in that store set as well, then, the next time the load has to wait until those store instructions included in its store set issue. If the load has no occupied entries in its store set, it should issue as soon as possible. Because the implementation for this store sets mechanism is hardware expensive, the modified implementation is achieved using two tables (*Figure 3-6*), a Store Set ID Table (SSIT) and a Last Fetched Store Table (LFST). Both load and store instructions access the SSIT based on their PC and get a store set identifier (SSID), when the SSID is valid it means that the load/store has a valid store set and with this SSID the LFST is accessed, an "inum" (hardware pointer which identifies an in-flight instruction) of the most recently fetch store instruction belonging to that store set is taken, then the memory access instruction must wait for that store instruction to issue. When a store accesses an entry in the LFST, it updates that entry with its own "inum", later on, when it issues, it accesses again the LFST and if it is still its own "inum" then, it clears that entry. Figure 3-6. Implementation of Store Sets Memory Dependence Prediction When a recovery process (branch misprediction, jump misprediction or memory order violation) is taken, the aborted stores are simply marked as done in the LFST. #### 3.1.4 Store Vectors [18] It is proposed an improved algorithm for memory dependence prediction (8.1% better performance than store-sets) based on store vectors, rather than tracking the program counters of dependent stores, the load-store dependencies are tracked based on the relative age of a store. Each store vector for any load has the relative positions of all the stores that enforced memory ordering violations in the past (*Figure 3-7*). There are three steps: "lookup/prediction", "scheduling" and "update due to ordering violations". The load-store dependencies are recorded in a data structure called "Store Vector Table", it is indexed with the least significant bits of the load's PC, then the store vector taken from the table is rotated and copied into the load scheduling matrix (LSM). The store vector is rotated such that the least significant bits are aligned to the most recent store (resolved stores are cleared in order to prevent deadlocks), then, it is written into the LSM. Figure 3-7. (a) Store-address tracking of dependencies, and (b) Age-tracking of dependencies The position of the bits in the store vectors indicate which stores are predicted to have a memory dependency with each load, thus, every load has to wait for their predicted dependent stores to be resolved. When a store is resolved its bit is cleared from the store vectors (its corresponding column), and once a load has all its store vector's bits cleared, it is considered as ready, then it can be issued (*Figure 3-8*). Initially, the vectors are full of zeros and a naïve prediction is used, the memory ordering violations will fill the corresponding bits in these vectors, the contents of the SVT are periodically reset in order to clear possible inexistent predicted dependencies due to changes in program phases, dynamic data values, etc. In *Figure 3-9* is shown an example of the store vectors operation steps. Figure 3-8. Store vectors data structures and interaction with a conventional load queue Figure 3-9. Example store vectors operation #### 3.1.5 Store-to-Load Forwarding via Store Queue index Prediction [16] In this store-load data forwarding proposal, rather than doing associative searches within the store queue, they incorporate a speculative indexed access. The address CAM is replaced by a simple decoder (*Figure 3-10*), in order to avoid this associative search (a power saving technique), they use a forwarding index predictor (based on store sets) to predict the most likely store index to be dependent with a load, then forward data from this store entry. For those loads that had a memory ordering violation, a delay index predictor is used, this delays the execution of a load until all non-predicted stores that may have a memory dependency have committed. The predicted SQ index is generated during the decode/rename pipeline stages, in this stage is either identified a dependency between a store or predicted a non-dependency, load issues only when its input registers are ready and when the store corresponding to its forwarding index has executed. In order to ensure memory ordering correctness, a load re-execution prior to committing may be made [14] (a violation is detected when a load's re-executed value is not equal as the first executed value) for those loads that executed with older unresolved stores. Figure 3-10. Store queues: (a) associative, (b) indexed #### 3.1.6 Address Indexed Memory Disambiguation and Store-to-Load Forwarding [17] Because store-to-load data forwarding and memory disambiguation require fully-associative, age-ordered searches, this yields to high latency as well as high dynamic power consumption. In this proposal, the store-to-load forwarding is done with help of a store-forwarding cache (SFC) and the memory disambiguation is resolved with a memory disambiguation table (MDT), both of them are not CAM structures, the SFC is accessed as a cache, speculatively and out-of-order, and the MDT requires sequence numbers in order to identify and recover from memory dependence violations. The SFC stores the values of the store instructions as they complete, the loads may forward their values from this SFC (it is accessed in parallel with the L1 data cache) because SFC is accessed speculatively and out-of-order, memory ordering violations can occur, thus, MDT identifies all these memory ordering violations, if exist a memory ordering violations, the memory unit initiates a recovery mechanism. There is also a store FIFO which retires store instructions in order when they are dispatched, their data is written to the FIFO, as they execute, their address is written to their address field in this FIFO, and when they commit, its entry is cleared (*Figure 3-11*). Figure 3-11. Processor pipeline, store forwarding cache (SFC), memory disambiguation table (MDT) and Store FIFO Because there can be memory ordering violations due to the out-of-order accesses in the SFC, the MDT tracks the sequence numbers (in-flight tags) of loads and stores to each inflight address, whenever it is identified a violation, a recovery mechanism is triggered. In this proposal, the store set predictor [31] is modified in order to reduce the pipeline flushed caused by memory ordering violations, the store set id table is replaced by a producer table and a consumer table, and the last-fetched store table is replaced by a last-fetched producer table. The updating process of this predictor table is: "When the MDT notifies the producer set predictor of a dependence violation, the predictor inserts a dependence between the earlier instruction (the producer) and the later instruction (the consumer) by placing the two instructions in the same producer set". Merging producer sets is very similar to merging store sets. The MDT is address-indexed, if a load/store's sequence number is later than the one found in the MDT entry, or if there is no valid load sequence number, then the entry takes the sequence number from this load/store. Otherwise, if it is earlier, then a memory ordering violation is identified. # Chapter 4 # Proposed Load/Store Queue design The main contribution of the thesis is the design of a LSQ for the Lagarto II processor which fetches two instructions per clock cycle (*Figure 4-1*), a conventional Load/Store Queue with in-order execution design was used as a base model and is described in detail in the first subsection of this chapter, then a modified design with an out-of-order execution and the energy saving techniques implemented is described in the second subsection. # 4.1 Load/Store Unit with In-Order Execution This first design of a LSQ with in-order execution was taken as a base model in order to be modified to the out-of-order design, both designs get from Dispatch stage up to two instructions per cycle and can issue up to one instruction per cycle. The main building blocks in this first design are the "Ready Bit Register", "WakeUp Logic", "Select Logic", "Register Files", "Address Computation Unit", "Tag Bus", "Destination Bus", "Bypass Logic", "Forward Logic", "Reorder Buffer (Dispatch, Issue & Execution flags)" and the "Memory Access mechanism" (Figure 7-3). Figure 4-1. Lagarto II Microarchitecture #### 4.1.1 In-Order Address Computation Pipeline The whole pipeline of this Load/Store Unit is divided into Address Computation (also known as the Address Queue) and Memory Access (also known as the Load/Store Queue), the Address Computation section is where the instructions wait for their source operands to be ready in order to either bypass their source operands values from the Bypass network or read them from the Register Files, then the Address Computation Unit can calculate their memory addresses adding a base operand and a signed immediate value. An instruction is written into the LSQ when its entry has been assigned in the queue (the Tail Pointer assigns this entry in the ROB) and is dispatched (its flag in the Dispatch-ROB entry is then set to "1") from the Front-End, its source registers check the Ready bit vector register (a building block which keeps track of the value generation for every register) in order to know if their values have been already generated by earlier instructions, the Ready Bits for the ready registers are set to "1" and written in its corresponding instruction queue entry, if their values aren't generated yet, then a "0" is written (*Figure 4-2*). Also, the Immediate value, the control bits and the physical register tags are stored in the queue (the source and destination tags are written in the Memory Access section). Figure 4-2. Ready Bit Assignment Example The associative WakeUp is done by comparing the un-ready base register tag from each entry in the queue with the register tags sent through the Tag Bus every cycle, if there are any matches, the corresponding ready bits for those registers are then set to "1" (Figure 2-19). The Select Logic waits until the queue entry pointed by the Head Pointer (Figure 4-3) has its base register "ready" in order to issue that instruction (the Head Pointer is incremented in order to point to the next instruction and its flag in the Issue-ROB entry is set to "1"), the Integer Register File is read and the Bypass network is accessed, then the memory address is computed by adding the base register data with the sign-extended immediate value (Figure 4-4). The generated memory address is then stored in its corresponding entry in the Memory Access section of the LSQ. Figure 4-3. Head Pointer and Tail Pointer Figure 4-4. Select Logic and Address Generation Unit #### 4.1.2 IN-ORDER MEMORY ACCESS PIPELINE In this section of the LSQ are stored the memory address, the Load/Store bit (it serves as a read/write enable for the Cache Memory), the Source data (the data to be written to cache memory by a store instruction), the Destination register tag (the register to be updated with the data read from cache memory by a load instruction) and the Destination data (the data read from the cache memory by a load instruction) for every dispatched memory access instruction; also, the cache memory is accessed by the memory access instructions selected to be executed. When a store instruction is dispatched and enters the LSQ, its source register tag (it points to the physical register containing the data that will be written to cache memory) accesses the Register File, the Bypass Network and the Ready bit Register in order to know if it has been already generated, if it has, the data taken from the Register File (Integer or Floating Point) or the Bypass network has the newest value for that physical register, then it is written to its corresponding entry in the Memory Access section of the queue, if it hasn't been generated, a "0" is written in the ready bit field of that source register and the source tag is stored in the Forward Logic CAM, this CAM is similar to the WakeUp CAM, the un-ready register tags in the Forward Logic CAM are compared with the tags sent through the Destination Bus, and, when there is a match, the source data is forwarded to its corresponding data field entry of the queue (*Figure 4-5*). Figure 4-5. Forward Logic Example The memory addresses generated in the Address Computation section of the queue are stored in the "memory address" field of this Memory Access Queue section, the select logic checks the entry pointed by the Head Pointer and sends to execution a load if it has its memory address already computed, the stores are sent to execution only at commit cycle and it is also needed its source data to be already forwarded, taken from the Register Files or bypassed. In order to access the cache memory, the L/S Bit serves as a Read/Write enable for the cache memory, in the case of a load, the data loaded is sent through the Destination Bus and written in the corresponding Register File (accessed by its Destination Register tag), and for a store, the Source Data is stored in cache memory accessed by its memory address (it is written first in the store buffer in order to don't generate waiting cycles due to cache hit misses). *Figure 4-6* and *Figure 4-7* show the memory access for both Load and Store instructions. Figure 4-6. Memory Access (Load) Figure 4-7. Memory Access (Store) # 4.2 Load/Store Unit with Out-of-Order Execution In-order LSQ designs requires less complex logic due to the in-order select mechanism which only checks the entry pointed by the Head Pointer, and since there is no out-of-order execution, memory dependency violations can't occur (a memory disambiguation scheme isn't necessary), but, the drawback is that ready non-dependent instructions can't issue nor execute if there are earlier instructions that haven't issued/executed yet, leading to an overall low performance. This proposed LSQ design comprises a power-efficient memory disambiguation scheme using a Hash table and Bloom filters [30] as well as a novel low dynamic power consumption store-to-load data forwarding and memory address disambiguation using "Non/Possible Dependencies Vectors", the LSQ is divided into three logical queues, the Address Queue, the Load Queue and the Store Queue (*Figure 4-8*), being the Address Queue the section (Address Computation section) where the instructions remains in their reservation units until their base registers are ready in order to compute its memory addresses in the Address Computation Unit (ACU) (also known as the Address Generation Unit), whether the Load Queue and Store Queue belong to the Memory Access section, in the Load and Store Queues are carried the memory accesses, the store-to-load data forwarding and the memory disambiguation mechanism. The Instruction Queue using a Block Mapping Table [1] was adapted to the Address Queue in order to reduce the number of comparisons carried by the WakeUp Logic, it also inspired the idea of the Non/Possible Dependencies Vectors design reducing the amount of comparisons carried by the Memory Disambiguation Scheme and the Store-to-Load Forwarding Logic. Figure 4-8. Proposed LSQ General Pipeline ## 4.2.1 UNKNOWN/KNOWN MEMORY ADDRESS, BLOCK MAPPING TABLE & ADDRESS GENERATION Every memory access instruction is classified into any of these two memory address-status categories, a *known address* or an *unknown address*, being the Address Queue the logical structure with the unknown address instructions stored in it, whether the instructions are stored in either the Load or the Store Queue. Since a memory address isn't known until being computed by the Address Generation Unit (each instruction waits in its reservation stations until it has its base register "ready" to be read from the Integer Register File or to be bypassed from the Destination Bus), there must be extra careful with the memory access instructions executed out-of-order, thus, a memory disambiguation scheme must be used in out-of-order designs. The Address Queue implemented in this thesis project uses an adaption of the "Low-Energy Instruction Wakeup Mechanism" [1], the whole queue is divided into four blocks and the comparisons carried out between every base register tag of the "unready" entries and the register tags sent through the tag bus, are directly enabled or disabled by a Block Mapping Table (BMT). *Figure 4-9* shows an example of the Block Mapping Table functionality, the "unready" source operands for the three instructions are marked in the BMT (a, b, c) in the moment they are stored in the CAM-Blocks and the value for their source operands are "unready", this BMT indicates which blocks require the physical registers sent through the Tag Bus, then, whenever a register tag is received, the BMT enables only the required comparisons and disables the remaining blocks (d). *Figure 4-10* illustrates how the Address Queue's CAMs & RAMs are organized along the BMT. Figure 4-9. Block Mapping Table Functionality Example When an instruction first enters the Load/Store Unit (Address Queue, Load Queue & Store Queue), it still does not have its memory address calculated, thus, it is sent to the Address Queue, belonging to the unknown address status, it is assigned an entry in the Load or Store Queue as well. In order to implement (for both CAM & RAM) four single-port memories, the entries along the queue are organized as shown in *Table 5*, needed to be included some write enabling control and multiplexers intended for supporting the logical two-input ports for the two input instructions (*Table 6*). This logic control makes use of the Tail Pointer in order to determine in which block the instructions are stored, avoiding to implement multi-port memories. Table 5. Entries Organization inside the Queue | LSB | MSB | DECIMAL | # BLOCK | |-----|-----|---------|--------------------------------------------------| | | 000 | 0 | | | | 001 | 4 | | | | 010 | 8 | 0 | | _ | 011 | 12 | × | | 00 | 100 | 16 | Block 0 | | | 101 | 20 | Bl | | | 110 | 24 | | | | 111 | 28 | | | | | | | | | 000 | 1 | | | | 001 | 5 | | | | 010 | 9 | Block 1 | | 0.1 | 011 | 13 | 쏭 | | ° | 100 | 17 | Ö | | | 101 | 21 | B | | | 110 | 25 | | | | 111 | 29 | | | | | | | | | 000 | 2 | | | | 001 | 6 | | | | 010 | 10 | 2 | | 10 | 011 | 14 | <del>- </del> | | | 100 | 18 | Block 2 | | | 101 | 22 | B | | | 110 | 26 | | | | 111 | 30 | | | | | | | | | 000 | 3 | | | | 001 | 7 | | | | 010 | 11 | 3 | | 11 | 011 | 15 | <del>\</del> | | 1 | 100 | 19 | ŏ | | | 101 | 23 | Block 3 | | | 110 | 27 | | | | 111 | 31 | | Table 6. 4 Blocks-RAM/CAM write enables and multiplexers between two input instructions | Tail<br>Pointer | Enable<br>Block 0 | Enable<br>Block 1 | Enable<br>Block 2 | Enable<br>Block 3 | Instruction 0/1<br>Block 0 | Instruction 0/1<br>Block 1 | Instruction 0/1<br>Block 2 | Instruction 0/1<br>Block 3 | |-----------------|-------------------|-------------------|-------------------|-------------------|----------------------------|----------------------------|----------------------------|----------------------------| | 00 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | | 01 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | | 10 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | | 11 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | BASE<br>POINTER | | ENA | BLES | | | М | UX | | In the BMT are marked only the "unready" operand tags needed by every block, and are cleared every time the operand tags are received from the Tag Bus. Figure 4-10. Address Queue (inside the L/S Unit) & the Block Mapping Table The implemented design for the Queue's Ready Bit Logic is shown in *Figure 4-11*. It reduces the dynamic power by setting the unnecessary comparison's register tags to "0" so that it won't change until the ready bit is updated with a new dispatched load/store instruction. Figure 4-11. Queue's Ready Bit Logic #### 4.2.2 Out-of-Order Select Logic In order to prevent deadlocks and to support an out-of-order selection, it was adapted a Leading Zero Counter [32], achieving a fast low power priority order selector (*Figure 4-12*). This circuit is implemented for both "oldest first" and "youngest first" required priority order selectors, the "oldest first" mechanism is used in the Select Logic for the Address Queue and Load Queue (the Select Logic for the Store Queue is carried by the Commit mechanism), whether the "youngest-first" mechanism is used in the Store-to-Load Data Forwarding, this is because it is needed to forward the most updated data value (load instruction-relative) for every memory location whenever this mechanism is used. The circuit used in order to perform this out-of-order selection is illustrated in *Figure 4-12*, and the whole selection pipeline (incorporating the Address Queue, the Address Generation Unit, and the Possible Dependencies generation) is shown in *Figure 7-5 in Appendix-A*. Figure 4-12. Leading Zero Counter as a Priority Selector (oldest-first) – 32bits #### 4.2.3 Memory Disambiguation & Store-to-Load Data Forwarding Mechanism The memory disambiguation and store-to-load data forwarding mechanism proposed in this thesis are constituted by "non/possible dependencies vectors", "hash table and bloom filters" [29] [30]. ### A) Non/Possible Dependencies Vectors The non/possible dependencies vectors are dynamic vectors used to enable/disable several memory address comparisons carried between the issued loads and stores, the "unrotated" selection bits given by the Select Logic in the Address Queue are used to index a Possible Dependencies Memory, this memory's output is a vector mask which after a combinational logic operation between the valid/busy bits and the load/store bits, generates the Non/Possible Dependencies Vector. *Figure 4-13* shows the generation of this vector. Figure 4-13. Non/Possible dependencies vector generation A table test is illustrated in *Figure 4-14..25*, it shows how the non/possible dependencies vectors along with the hash table mechanism identifies memory order violations while it reduces the amount of memory addresses comparisons carried between the loads and stores achieving a store-to-load data forwarding effectively. For every memory order violation, the memory dependence predictor has to be updated. When a store issues, its memory address is written (incremented the counter in "1" after the bloom filter reduction) in the hash table, the un-issued load instructions found from its entry position in the queue to the head pointer are marked as "1" in its non-dependencies vector, these marked loads disables the comparisons between this issued store. In the other hand, when a load issues, it searches the hash table for a possible memory address dependency, if it matches, then the store queue is accessed, if not, it is written directly to the load queue without executing any comparison, the un-issued store instructions found in the queue from the load's entry and the head pointer are marked as "1" in its possible dependencies vector", these marked stores enables the comparisons between that load and the un-issued marked stores. When a store issues, if a match has occurred with any younger load, the load's possible dependencies vector is updated and all the bits from that store's position are cleared to "0", if there isn't any match, just the entry of the store is cleared in the vectors. A load is solved (it means that it has no more memory dependencies left) when the bits in its possible dependencies vectors are all set to "0". Figure 4-14. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (a) Figure 4-15. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (b) Figure 4-16. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (c) Figure 4-17. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (d) Figure 4-18. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (e) Figure 4-19. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (f) Figure 4-20. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (g) Figure 4-21. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (h) Figure 4-22. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (i) Figure 4-23. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (j) Figure 4-24. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (k) Figure 4-25. Example for the Memory Disambiguation & Store-to-Load data forwarding using the proposed Non/Possible Dependencies Vectors & Hash Table (I) A desk evaluation for every Load/Store combination between three consecutive load/store instructions and its memory disambiguation scheme is provided in Appendix-B. ### **Hash Table & Bloom Filters** The Bloom filters along with the hash table function as a reduction filter operation, taking the 40 LSB bits of each load/store's memory address, it is applied this reduction in order to turn it into only 5 bits incrementing one of the 32 counters found in the hash table. When a memory address is known just after the issuing stage, it passes through a bloom filter which uses a three-phase XOR operation within its 40 less significant bits $\rightarrow$ 40 ÷ 2 ÷ 2 ÷ 2 = 5 bits, then with these bits the hash table is accessed (32 locations), for every location there is a 5 bit counter (counting from 0 to 32, one for every queue entry), if a store accesses these counters a "+1" operation is executed in the accessed counter, whether a load only reads these counters and if a "[1-32]" is read, then it means that it is possible to be the complete 40 bits memory address in the store queue, thus it enters to the Store-to-Load Forwarding Logic Mechanism. ### 4.2.5 STORE-TO-LOAD FORWARDING MECHANISM AND DELAYED SOURCE DATA FORWARDING Due to the fact that a store can compute its memory address before its data value is generated by an earlier instruction, a "waiting cam table" containing the waiting store queue's entries is included in the load queue, when a Forwarding mechanism is executed but this source data is not ready, the entry of the required store's source data is stored in this waiting CAM, then a forwarding is performed whenever the Store Queue's Source Data Forward Logic (*Figure 4-5*) sends the forwarded data through the "Delayed Source Data Local Bus", the design is shown in *Figure 7-2*. # Chapter 5 ## RESULTS This design has been implemented and simulated using the Altera's Quartus II EDA software getting an overall working frequency of 88.79MHz (*Figure 5-1*) making use of the Altera's DE2-115 FPGA board, the Front-End data path also is included in order to perform these simulations. The results are presented as follows, the simulation of the Front-end, the generation of the Possible Dependencies Vectors, the selection logic, the tests within the Block Mapping Table and the whole RTL diagram for the implementation. Figure 5-1. Maximum Overall Frequency Figure 5-2. Decoder The Decoding circuit reads the base, source and destination registers, it also generates the control bits-vector used to execute the load/store instruction through the whole datapath. In this simulation two instructions ( $Intruction_In\ 0$ and $Instruction_In\ 1$ ) are dispatched, they correspond to: $LB\ R1<-4(R0)$ and $SWC1\ R1->8(R0)$ respectively. Figure 5-3. Integer Ready Bit Register - Test 1 An implementation and simulation of the Ready Bit Registers (INT & FP) is done in order to check at dispatch time if a source physical register is ready to be read from the Register Files or to bypassed from the Bypass network, in the test 1 (*Figure 5-3*) a physical register 24 is checked and it is found in the Destination Bus, so a ready bit set to "1" is sent to the Address Queue. In the test 2 (*Figure 5-4*), a 4 is required and it is also found in the Destination Bus. Figure 5-4. Integer Ready Bit Register - Test 2 Some simulations are made for the FP Ready Bit Register (Figure 5-5). Figure 5-5. Floating Point Ready Bit Register - Test The control logic of the Head Pointer and Tail Pointer is implemented and simulated, in test 1 (*Figure 5-6*), it was expected to get a "Queue Full" signal in order to stall the pipeline and in the context recovery mechanism test (*Figure 5-7*), the Recovered Tail Pointer is being taken from a Recovery Memory and it updates the actual Tail Pointer after the recovery mechanism. Figure 5-6. Pointer Control Logic - Test 1 Figure 5-7. Recovery Mechanism For an out-of-order issuing, a priority order selection logic is implemented, the "test simulation 1" (*Figure 5-8*) initiates with a Head Pointer of "29", expecting to be selected no entry (that is to say that a Valid Selection Bit is set to "0") because there are no ready instructions to be issued, in "test 2" (*Figure 5-9*), the next available instruction to be issued is the "entry 3", similarly, in "test 3" (*Figure 5-10*), the selected instruction is the "entry 6". Figure 5-8. Selection Logic - Test 1 Figure 5-9. Selection Logic - Test 2 Figure 5-10. Selection Logic - Test 3 A write/read operation to the Address Queue is simulated in *Figure 5-11*, it is checked if the 4-blocked Address Queue is actually storing the corresponding data in its corresponding blocks, as well as the reading of the blocks throws the correct issued instruction. Figure 5-11. Address Queue's Write/Read Test The Block Mapping Table for the Address Queue's wake-up mechanism is tested in *Figure 5-12*, it is tested expecting a Register Tag 28, it is gotten from the fourth register sent through the Tag Bus, thus, the comparison is enabled for that Tag Bus's input. Figure 5-12. Block Mapping Table Test Figure 5-13. Possible dependencies vector - Desk evaluation 1 Figure 5-14. Possible Dependencies Vector - Test 1 Figure 5-15. Possible dependencies vector - Desk evaluation 2 Figure 5-16. Possible Dependencies Vector - Test 2 For the Store-to-Load data forwarding implementation is tested in *Figure 5-17*, due to the limitation in inputs/outputs, some delayed store-to-load forwarding bus lanes were generated inside the code simulating them, the second lane was an addition of the first lane plus 10, the third was an addition of the first lane plus 20 and goes on. In the simulation, the entry 5 of the Load Queue has a memory-dependency with the issued store corresponding to the entry 2 of the Store Queue (the value is not generated yet, thus, the entry of the dependent store is written in the waiting table), at the same time this store has a memory-dependency with the entry 0 of the Load Queue but the memory-dependency for this entry found in the store-to-load data forwarding belonging to an associative access from a previous issued load (memory-dependent with the entry 4 of the Store Queue) has the most updated value for that memory-dependency, thus, the memory-dependency with the entry 2 is ignored and the store-to-load data forwarding with the entry 4 is executed (forwarding the data "654"). The Store Queue's entry 2 is sent through the bus in the following clock cycles letting the Load Queue's entry 5 to forward this data ("102"). The loads (entries 5 and 0) are sent to execution in order to ensure that their data values have been forwarded (in "Data\_Sent"). Figure 5-17. Store-to-Load Data Forwarding - Test Chapter 6 82 # Chapter 6 CONCLUSIONS AND FUTURE WORK ## 6.1 Conclusions The main contribution of the project thesis, which is an Out-of-Order Load/Store Queue, is successfully achieved supporting up to three accesses to the Data cache (one load and two stores), and it is shown that the proposed design of the Non/Possible Dependencies Vectors along with the bloom filters and hash table, resulted in an efficient way to reduce a big amount of unnecessary comparisons done by the Memory Disambiguation Mechanism and the Store-to-Load Data Forwarding Logic, reducing a lot of dynamic power consumption in their operation. The Load Queue is supporting up to four dispatched Load/Store instructions per cycle, but it is permitting only one instruction to be issued per cycle due to the complexity of the memory disambiguation process. Chapter 6 83 ### 6.2 Future Work For future work, it is planned to include a memory dependence predictor, this will increase the performance because each predicted-free dependent load won't wait to be solved (no possible stores left to be issued), thus, some load entries can be sent to execution (accessing the data cache or sending the forwarded data to the destination bus) in advance. Also, a replacement of the source data CAM is planned to be replace for a RAM, this will decrease a little the performance of the design because the source data memory won't be updated whole every cycle, thus, two stores could get its source data every cycle, the advantage of this replacement is the reduction of the implementation because FPGA's logic elements will be replaced for memory bits. Another future work is to include miss-status handle registers in order to support in-flight data cache misses. After this work done, for future implementations, it will be added the support for multiprocessor technology, and more power saving techniques will be included to the design. Figure 7-1. Front-End Figure 7-2. Store-to-Load Forwarding Logic including the Delayed Source Data Figure 7-3. Load/Store Queue with In-Order Execution Figure 7-4. Incorporation of the proposed Load/Store Unit to the processor Figure 7-5. Select Logic, Address Generation & PDVs pipeline Appendix-B Appendix-B Memory Disambiguation Test: LSL (Load-Store-Load) | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load C | ueue Entries | Store Queue | Entries Solved Loads | |---------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------------------------------------------------------------------------------| | | 0 | LD | 0x00 | 1 | 1 | × | 0 | | 000 | | | 0 | 0 | 0 | 0x00 | 0 0 | 1 | | | 1 2 | SD<br>LD | 0x00<br>0x01 | 1 | 0 | 0 | 1 | 0×01 | : | r | ٥ | 0 | 0 | 2 | 0 | 2 0 | 0 | | | | | | - | | | | | | | | | | | | | | | 0 | Position | Instructions<br>LD | L / S Queue Allocation<br>0x00 | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | Load C | 0x00 | O O | Entries Solved Loads | | PATH | 1 | SD | 0x00 | 1 | 0 | ô | 1 | 0×01 | * | r | 0 | 0 | 0 | 1 | 0 | 1 0 | 0 | | - | 2 | LD | 0x01 | 1 | 0 | 0 | 1 | | • | | | 0 | 0 | 2 | 0 | 2 0 | 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load C | Queue Entries | Store Queue | Entries Solved Loads | | | 0 | LD | 0x00 | 1 | 1 | × | 0 | | 000 | | | 0 | 0 | 0 | 0x00 | 0 0 | <b>I</b> | | | 1 2 | SD<br>LD | 0x00<br>0x01 | 1 1 | 0 | 0 | 1 | 0x01 | • | r | ۰ | 0 | 0 | 2 | 0 | 2 0 | 0 | | | | | | _ | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | l Load C | Queue Entries | Store Queue | Entries Solved Loads | | | 0 | LD | 0×00 | 1 | 0 | 0 | 1 | New Head Fornier | (Non) Possible Dependencies Vector | neady write cor | THE III COI | 0 | 0 | 0 | 0 | 0 0x0 | | | | 1 | SD | 0x00 | 1 | 1 | x | 0 | 0×00 | 001 | w | 0 | 0 | 0 | 2 | 0 | 2 0 | I | | | | LD | 0x01 | 1 | 0 | 0 | 1 | | | | | 0 | 0 | | 0 | 2 0 | 0 | | - | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | + | ueue Entries | Store Queue | | | АТН | 1 | LD<br>SD | 0x00<br>0x00 | 1 | 1 | o<br>x | 0 | 0x00 | 001 | w | 0 | 0 | 0 | 1 | 0 | 0 0x0<br>1 0 | 0 0 | | _ | 2 | LD | 0×01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 | 0 | 2 0 | 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load C | Queue Entries | Store Queue | Entries Solved Loads | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | · | | 0 | 0 | 0 | 0 | 0 0x0 | 0 0 | | | 2 | SD<br>LD | 0x00<br>0x01 | 1 1 | 0 | × | 0 | 0x00 | 001 | w | ٥ | 0 | 0 | 2 | 0 | 2 0 | 0 | | | | | | _ | | | | | | | | | - | 1-1 | | 1-1 | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Pond / Write EDE | Uit in EDE | Forwarded | Dependence Detection | Lload C | ueue Entries | Store Queue | Entries Solved Loads | | | 0 | LD | 0x00 | 1 | 0 | o<br>0 | 1 | New Head Pointer | (NOII) Possible Dependencies Vector | Read / Write EDF | HIC III EDF | o o | o<br>o | 0 | 0 | 0 0 | _ | | | 1 | SD | 0x00<br>0x01 | 1 | 0 | 0 | 1 | 0x00 | * | r | 0 | ٥ | 0 | 1 | 0x01 | 1 0 | | | 1 | 2 | LD | | | | | | | | | | | | | | | | | | | | 0.01 | - | _ | × | 0 | | 010 | | | 0 | 0 | 2 | 0 | 2 0 | 0 | | 2 | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | | O Dependence Detection | | (ueue Entries | Store Queue | | | уАТН 2 | Position<br>0<br>1 | | | Valid Instructions 1 1 | State 0<br>0<br>0 | Selected<br>0 | | New Head Pointer | | Read / Write EBF | Hit in EBF | | | | | | Entries Solved Loads | | | Position 0 1 2 | Instructions<br>LD | L / S Queue Allocation<br>0x00 | Valid Instructions 1 1 1 | 0 | 0 | | | (Non) Possible Dependencies Vector | | | Forwarded<br>0 | Dependence Detection | | Queue Entries | Store Queue I | Entries Solved Loads | | | 0<br>1 | Instructions<br>LD<br>SD | L / S Queue Allocation<br>0x00<br>0x00 | Valid Instructions 1 1 1 1 Valid Instructions | 0 | 0<br>0<br>X | Valid Instructions 1 1 | | (Non) Possible Dependencies Vector * * | | | Forwarded<br>0<br>0 | Dependence Detection 0 0 | 0 1 2 | Queue Entries<br>0<br>0x01 | Store Queue | Entries Solved Loads 0 0 0 | | | 0<br>1<br>2 | Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 | 1<br>1<br>1 | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | Valid Instructions 1 1 0 | 0x00 | (Non) Possible Dependencies Vector * 010 (Non) Possible Dependencies Vector * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded o o o o Forwarded | Dependence Detection O O O O Dependence Detection O | 0 1 2 | 0 0x01 0 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads | | | 0<br>1<br>2 | Instructions LD SD LD Instructions | L / S Queue Allocation 0×00 0×00 0×01 L / S Queue Allocation | 1<br>1<br>1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x<br>Selected | Valid Instructions 1 1 0 | 0x00 | (Non) Possible Dependencies Vector * * 010 | r | 0 | Forwarded o o o | Dependence Detection O O O O Dependence Detection | 0 1 2 | Queue Entries 0 0×01 0 | Store Queue 0 0 1 0 2 0 Store Queue | Entries Solved Loads 0 0 0 0 Entries Solved Loads | | | 0<br>1<br>2 | Instructions LD SD LD Instructions LD SD SD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 | 1<br>1<br>1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x<br>Selected<br>o | Valid Instructions 1 1 0 Valid Instructions 1 1 | 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O | 1 Load 0 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0x01<br>0<br>Queue Entries<br>0<br>0x01 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads | | | 0<br>1<br>2 | Instructions LD SD LD Instructions LD SD LD LD LD LD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 | 1<br>1<br>1 | 0<br>0<br>1<br><b>State 0</b><br>0<br>0 | o<br>o<br>x<br>Selected<br>o | Valid Instructions 1 1 0 Valid Instructions 1 1 | 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O Dependence Detection O O O | 1 Load 0 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 | 0<br>0x01<br>0<br>Queue Entries<br>0<br>0x01 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads 0 0 0 | | | 0<br>1<br>2<br>Position<br>0<br>1<br>2 | Instructions LD SD LD Instructions LD SD LD Instructions LD LD LD | L / S Queue Allocation 0×00 0×00 0×01 L / S Queue Allocation 0×00 0×00 0×01 L / S Queue Allocation 0×00 | 1<br>1<br>1<br>Valid Instructions<br>1<br>1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected O X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 2 0 1 | Queue Entries 0 0x01 0 Queue Entries 0 0x01 0 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads 0 0 0 0 Entries Solved Loads | | 3 РАТН | Position O 1 2 Position O 1 2 | Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0×00 0×00 0×01 L / S Queue Allocation 0×00 0×00 0×01 L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | 1 Load 0 0 1 2 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries 0 0x01 0 Queue Entries 0 0x01 0 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads 0 0 0 0 Entries Solved Loads | | 3 РАТН | 0 1 2 Position 0 1 2 Position 0 1 2 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 0 1 State 0 0 0 1 1 State 0 1 1 0 0 | Selected O X Selected O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF | Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 1 2 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries O 0x01 O 0x01 O 0x01 O 0x01 O 0x00 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads 0 0 0 0 Entries Solved Loads 1 0 0 0 | | РАТН | Position O 1 2 Position O 1 2 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 State 0 0 0 1 1 State 0 1 1 0 0 | Selected O X Selected V Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF | Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 1 2 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries 0 0x01 0 Queue Entries 0 0x01 0 | Store Queue 0 | Entries Solved Loads 0 0 0 0 Entries Solved Loads 0 0 0 0 Entries Solved Loads 1 0 0 0 | | 3 РАТН | 0 1 2 Position 0 1 2 Position 0 1 2 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 0 1 1 State 0 0 0 1 1 1 0 State 0 1 1 1 1 1 1 1 | Selected Selected Selected Selected X Selected X O Selected X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries O 0x01 O 0x01 O 0x01 O 0x01 O 0x01 O 0x001 O 0x000 | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 3 РАТН | Position 0 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 | Selected Selected X Selected X Selected X Selected X Selected X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 2 1 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox01 O Queue Entries Ox00 O Queue Entries | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 3 РАТН | Position 0 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 | Selected O O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 1 1 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries O 0x01 O 0x01 O 0x01 O 0x01 O 0x00 O 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 3 РАТН | Position 0 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 1 State 0 0 0 1 1 1 0 State 0 1 1 1 1 1 1 1 | Selected O O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries O 0x01 O 0x01 O 0x01 O 0x01 O 0x01 O 0x001 O 0x000 | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | РАТН 3 | Position 0 | Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 | Selected Selected X Selected X O Selected X O Selected X X Selected X X X X X X X X X X X X X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 2 1 1 Load 0 0 1 2 1 2 1 1 Load 0 0 1 2 1 2 1 1 Load 0 0 1 1 2 1 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 1 1 Load 0 0 1 1 1 Load 0 0 1 1 1 Load 0 0 1 1 1 Load 0 0 | Queue Entries Ox01 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 4 РАТНЗ | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 | Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | РАТН 3 | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | State 0 0 1 1 | Selected Selected Selected Selected Selected Selected X O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 1 2 1 1 1 1 2 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries | Store Queue | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 4 РАТНЗ | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions | State 0 0 1 | Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 | Queue Entries O 0x01 O 0x01 O 0x001 O 0x000 O 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 4 РАТНЗ | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 0 1 1 | Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector 000 + + (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 1 2 1 1 1 1 2 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries Ox00 O Queue Entries | Store Queue | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 4 РАТНЗ | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x00 0x00 0x00 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 0 1 | Selected Selected Selected Selected Selected Selected Selected Selected X O O Selected X O Selected X O Selected X O Selected X O Selected X O Selected X O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 2 1 1 Load 0 0 1 2 1 2 1 1 Load 0 0 1 2 1 2 1 1 Load 0 0 1 2 1 1 2 1 1 Load 0 0 1 1 2 1 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 2 1 Load 0 0 1 1 1 1 Load 0 0 1 1 1 Load 0 0 | Queue Entries Ox01 O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries | Store Queue 0 | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 5 РАТН 3 РАТН | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x00 0x00 0x00 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 0 1 | Selected Selected Selected Selected Selected Selected Selected Selected Selected O Selected O Selected O O Selected O O Selected O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries Ox00 O O Queue Entries | Store Queue | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | 5 РАТН 3 РАТН | Position 0 | Instructions LD SD LD | L S Queue Allocation | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 0 1 1 | Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 2 0 1 2 2 1 Load 0 0 0 1 2 2 1 Load 0 0 0 1 2 2 1 Load 0 0 0 1 2 2 1 Load 0 0 0 1 2 2 1 Load 0 0 0 1 1 2 2 1 Load 0 0 0 1 1 2 2 1 Load 0 0 0 1 1 2 2 1 Load 0 0 0 1 1 2 2 1 Load 0 0 0 1 1 2 2 1 Load 0 0 0 1 1 2 1 Load 0 0 0 1 1 2 1 Load 0 0 0 1 1 2 1 Load 0 0 0 1 1 2 1 Load 0 0 0 1 1 2 1 Load 0 0 0 1 Load 0 0 0 1 1 2 1 2 1 Load 0 0 0 1 1 1 1 Load 0 0 0 1 1 1 1 Load 0 0 0 1 1 1 1 Load 0 0 0 1 1 1 1 Load 0 0 1 1 1 1 Load 0 0 | Queue Entries Ox01 O Queue Entries Ox00 | Store Queue | Entries Solved Loads O O O O O O O O O O O O O O O O O O | | РАТН 4 РАТН 3 | Position 0 | Instructions LD SD LD | L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 0 1 1 | Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 Load 0 0 1 2 1 2 1 1 2 1 1 1 2 1 1 1 1 2 1 1 1 1 2 1 1 1 1 2 1 1 1 1 1 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Queue Entries Ox01 O Queue Entries Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox0 | Store Queue | Solved Loads | Appendix-B Memory Disambiguation Test: LSL (Load-Store-Load) | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | | | re Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | New Head Pointer | |----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | 1 | o<br>x | 0 | 0x02 | 000<br>000 | w | 0 | 0 | 0 | 0 0x00 | 0 1 | 0x00<br>o | 1<br>0 | : | 0 | 0 | 0x03 | | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 | 0 | 0 | 1 | х | 0 | | | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection | 0 0x0 | $\overline{}$ | re Queue Entries | Solved Loads | State 2 Se | elected<br>o | Valid Instructions | New Head Pointer | | 0 | 0 | 1 | 0x01 | * | r | 0 | 0 | 0 | 1 0x0: | | 0 | 0 | 1 | × | 0 | 0x03 | | 1 | X | 0 | | 010 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | , | 0 | 0 | | | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | 0 0x0 | $\overline{}$ | re Queue Entries<br>0x00 | Solved Loads | State 2 Se | elected<br>0 | Valid Instructions | New Head Pointer | | 1 | × | 0 | 0x02 | 000 | w | 0 | 0 | 0 | 1 0 | 1 2 | 0 | 0 | : | 0 | 0 | 0x03 | | 1 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 | 0 | 0 | 1 | х | 0 | | | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | n Load Queue E | ntries Sto | re Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | New Head Pointer | | 1 | x<br>o | 0 | 0x02 | 000<br>001 | r | × | 0 | 0 | 0 0x00 | 0 1 | 0x00<br>o | 1 | | 0 | 0<br>0 | 0x03 | | 0 | 0 | 1 | 0x02 | * | , | * | 0 | 0 | 2 0 | 2 | 0 | 0 | 1 | x | 0 | 0x03 | | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | n Load Queue E | ntries Sto | re Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | New Head Pointer | | 0 | 0 | 1 | 0×00 | 000<br>001 | r | × | o<br>x | 0 | 0 0<br>1 0x0: | 0 | 0×00 | 0<br>1 | 1 * | x<br>o | 0 0 | 0×03 | | 1 | x | 0 | | * | | - | 0 | 0 | 2 0 | 2 | 0 | 0 | • | 0 | 0 | | | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | | | re Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | New Head Pointer | | * | x<br>o | 0 | 0x02 | 000<br>001 | r | × | 0 | 0 | 0 0x00 | 0 1 | 0x00<br>o | 1<br>0 | : | 0 | 0 | 0x03 | | 1 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 | 0 | 0 | 1 | x | 0 | | | | | | | | | | | | 1 | | | | | | | | | State 1 | Selected<br>× | Valid Instructions 0 | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | 0 0x0 | | re Queue Entries | Solved Loads<br>1 | State 2 Se | o elected | Valid Instructions 0 | New Head Pointer | | 0 | 0 | 1<br>0 | 0x01 | * | r | 0 | 0 | 0 | 1 0x0: | | 0 | 0 | 1 | × | 0 | 0×03 | | | | 0 | | 010 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | - | 0 | 0 | | | State 1 | | | New Head Pointer | (Non) Possible Dependencies Vector | Pond / Write ERE | Hit in ERE | 0 Forwarded | | | | | | State 2 Se | | | New Head Dointer | | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | | Forwarded<br>0 | Dependence Detection | n Load Queue E | ntries Sto | re Queue Entries<br>0x00 | Solved Loads | State 2 Se | elected × | Valid Instructions | New Head Pointer | | State 1 0 1 + | Selected | | New Head Pointer | | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | n Load Queue E | ntries Sto | re Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | New Head Pointer | | State 1 0 1 + | Selected<br>0<br>x<br>0 | Valid Instructions 1 0 | | (Non) Possible Dependencies Vector * 001 | | | Forwarded<br>0<br>0 | Dependence Detection | 0 0 0 1 0x0 2 0 | ntries Sto | ore Queue Entries 0x00 0 | Solved Loads 0 1 | 1 * | elected<br>× | Valid Instructions 0 0 | | | 0 1 * | Selected O X O Selected X | Valid Instructions 1 0 0 | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * 001 010 | w | O<br>Hit in EBF | Forwarded O O O Forwarded O | Dependence Detection O O X Dependence Detection O | 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | ntries Sto | ove Queue Entries 0×00 0 0 overe Queue Entries | Solved Loads 0 1 0 Solved Loads | State 2 Se | elected × 0 0 | Valid Instructions 0 0 0 Valid Instructions 0 | 0x03 | | 0 1 * | Selected O X O Selected | Valid Instructions 1 0 0 Valid Instructions | 0x00 | (Non) Possible Dependencies Vector * 001 010 (Non) Possible Dependencies Vector 000 | w | 0 | Forwarded 0 0 0 Forwarded | Dependence Detection O O X Dependence Detection | Don Load Queue E O O O O O O O O D O O O D O O O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O D O | ntries Sto | ore Queue Entries 0x00 0 0 ore Queue Entries | Solved Loads 0 1 0 | 1 * | elected x o o | Valid Instructions 0 0 0 Valid Instructions | 0x03 | | 0 1 * | Selected O X O Selected X O | Valid Instructions 1 0 0 Valid Instructions 0 1 | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * 001 010 (Non) Possible Dependencies Vector 000 * | w | O<br>Hit in EBF | Forwarded O O O O Forwarded O O O | Dependence Detection O O X Dependence Detection O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | ntries Sto | over Queue Entries 0×00 0 0 over Queue Entries | Solved Loads 0 1 0 Solved Loads | State 2 Se | elected x 0 0 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 | 0x03 | | 0<br>1<br>* | Selected O X O Selected X O | Valid Instructions 1 0 0 Valid Instructions 0 1 | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * 001 010 (Non) Possible Dependencies Vector 000 * | w | O<br>Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O | 0 1 0x0<br>2 0 0x0<br>0 1 0x0<br>1 0x0<br>2 0 0x0<br>1 0x0<br>2 0 | 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 1 | over Queue Entries 0×00 0 0 over Queue Entries | Solved Loads 0 1 0 Solved Loads | State 2 Se | elected x 0 0 elected x x 0 0 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 | 0x03 | | 0<br>1<br>* | Selected O X O Selected X O O Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions | 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector | W Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O O Forwarded O O O O Forwarded | Dependence Detection O X Dependence Detection O O O Dependence Detection O Dependence Detection | | ntries Sto ntries Sto ntries Sto ntries Sto ntries Sto | re Queue Entries 0x00 0 ore Queue Entries 0 0 ore Queue Entries | Solved Loads O 1 0 Solved Loads 1 0 0 Solved Loads | 1<br>*<br>*<br>State 2 Se | elected x 0 0 elected x x 0 0 elected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | 0x03 New Head Pointer 0x03 | | 0<br>1<br>*<br>State 1<br>1<br>1<br>1<br>*<br>State 1 | Selected Selected Selected Selected Selected Selected O Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 0 010 (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O O | on Load Queue E | 1 2 | ore Queue Entries occupation of the Company | Solved Loads 0 1 0 Solved Loads 1 0 0 Solved Loads 1 0 0 0 | 1 * * * * * * * * * * * * * * * * * * * | elected x 0 0 elected x 0 0 x 0 x 0 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 0 0 0 0 0 | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | 0<br>1<br>* | Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF w | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O Dependence Detection O O O O Dependence Detection O O O Dependence Detection O O Dependence Detection O | Load Queue E | 1 2 | re Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads O 1 0 Solved Loads 1 0 0 Solved Loads 1 0 0 Solved Loads 1 0 0 Solved Loads | 1 * * * * * * * * * * * * * * * * * * * | elected x 0 0 elected x 0 0 x 0 x 0 elected 0 x 0 x elected 0 x | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | 0<br>1<br>*<br>State 1<br>1<br>1<br>1<br>*<br>State 1 | Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 000 * | Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection | | 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 1 | re Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 0 1 0 Solved Loads 1 0 0 Solved Loads 1 0 0 0 | 1 * * * * * * * * * * * * * * * * * * * | elected x 0 0 elected x 0 0 x 0 x 0 elected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | 0<br>1<br>*<br>State 1<br>1<br>1<br>1<br>*<br>State 1 | Selected Selected Selected Selected Selected Selected X Selected X X X | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF r Read / Write EBF w | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O | Load Queue E O O O O O O O O O | 1 2 2 | re Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads | 1 * * * * * * * * * * * * * * * * * * * | elected X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 0 Valid Instructions | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | 0<br>1<br>*<br>State 1<br>1<br>1<br>1<br>*<br>State 1 | Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF r Read / Write EBF w | Hit in EBF O Hit in EBF O | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O | Load Queue E | | re Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads O 1 0 Solved Loads 1 0 0 Solved Loads 1 0 0 Solved Loads 1 0 0 Solved Loads | State 2 Se | elected x 0 0 elected x 0 0 x 0 elected 0 x 0 x 0 x elected 0 x elected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 * State 1 * State 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Selected X O Selected X O Selected O X O Selected O X O O | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 * | Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue E | | re Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o o ore Queue Entries | Solved Loads | State 2 Se | elected color col | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 * State 1 * 1 0 State 1 1 1 | Selected Selected Selected Selected Selected Selected Selected Selected Selected X O Selected X O Selected X O Selected X O Selected X O Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | | | re Queue Entries Ox00 o o o o o o o o o o o o o o o o o o | Solved Loads | State 2 Se | elected continue and a selected selecte | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 * State 1 * 1 0 State 1 1 1 | Selected Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 * | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O O | | 1 2 2 2 2 2 2 2 2 2 | re Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o ore Queue Entries Ox00 o o ore Queue Entries | Solved Loads | State 2 Se | elected color col | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 1 1 0 State 1 1 1 1 | Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 1 Valid Instructions 1 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | | | re Queue Entries occupation of the Queue Entries occupation occu | Solved Loads | State 2 Se 1 * State 2 Se 1 * State 2 Se 1 State 2 Se 1 State 2 Se 1 State 2 Se 1 State 3 Se | elected X | Valid Instructions O O O O O O O O O O O O O O O O O O | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 * State 1 * 1 0 State 1 1 1 | Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 1 0 0 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 001 000 001 | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection O O Dependence Detection | Load Queue E | | re Queue Entries Ox00 o o o o o o o o o o o o o o o o o o | Solved Loads | State 2 Se 1 * State 2 Se 1 * State 2 Se 1 State 2 Se 1 State 2 Se 1 State 2 Se 1 State 3 Se | elected continue to the conti | Valid Instructions 0 0 0 0 Valid Instructions | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 * State 1 * 1 0 State 1 1 1 | Selected O X O Selected O X O Selected O O Selected O O O Selected O O O Selected O O O Selected O O O O Selected | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 1 0 0 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 001 000 001 | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | | | re Queue Entries occupation of the Queue Entries occupation occu | Solved Loads | State 2 Se | elected X | Valid Instructions O O O O O O O O O O O O O O O O O O | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | | State 1 1 1 1 1 0 State 1 1 1 1 State 1 1 1 State 1 1 1 State 1 1 1 | Selected O X O Selected O X O Selected O O Selected O O O Selected O O O Selected O O O O O O Selected O O O O O O O O O O O O O | Valid Instructions 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions 0 0 1 Valid Instructions 0 0 1 Valid Instructions 1 0 0 0 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | | 1 2 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 2 | re Queue Entries Ox00 o o o o o o o o o o o o o o o o o o | Solved Loads | State 2 Se | elected color col | Valid Instructions O O O O O O O O O O O O O O O O O O | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | Appendix-B Memory Disambiguation Test: LSL (Load-Store-Load) | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | 000 | Read / WITTE LDI | THE III COI | o | o | 0 0x00 | 0 | 0x00 | 1 | | 000 | r | × | × | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | 0 | 2 o | 2 | 0 | 0 | | | | | | | | | | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | _ | ore Queue Entries | Solved Loads | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | 000<br>010 | w | 0 | 0 | o<br>x | 1 0x01<br>2 0 | 2 | 0 | 1 | | 010 | | | 0 | × | 2 0 | | 0 | 0 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | I Sto | ore Queue Entries | Solved Loads | | 000 | Read / Write Lbi | THE III COI | o | o<br>o | 0 0x00 | 0 | 0x00 | 1 | | 000 | r | × | × | | 1 0x01 | 1 | 0 | 1 | | 000 | | | | 0 | 2 0 | 2 | 0 | 0 | | | | | | | | _ | | | | | | | | | | | | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | 001 | r | × | × | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | 0 | 2 o | 2 | 0 | 0 | | (N. 15. 71. 5. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. | | | | | Load Queue Entries | I co | O F-1-i I | | | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | | 0 | 0x00 | Solved Loads | | 001 | r | x | 0 | 0 | 0 0x00<br>1 0x01 | 1 | 0.000 | 1 | | 000 | | , | | | 2 0 | 2 | 0 | 0 | | | | | | | <u> </u> | | , | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0×00 | 1 | | 001 | r | × | × | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | 0 | 2 o | 2 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | _ | ore Queue Entries | Solved Loads | | 000 | | | ٥ | ٥ | 0 0x00 | 0 | 0x00 | 1 | | 000<br>010 | w | ۰ | ٥ | o<br>× | 1 0x01 | 2 | 0 | 1 | | 010 | | | 0 | × | 2 0 | | 0 | U | | | | | | | | | | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries<br>0x00 | Solved Loads | | | Read / Write EBF | Hit in EBF | | | | - | | | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | 000<br>001 | r | | 0 | 0 0 | 0 0x00<br>1 0x01<br>2 0 | 0<br>1<br>2 | 0x00<br>o | 1<br>1 | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector | | | o<br>o<br>o<br>Forwarded | o<br>o<br>O<br>Dependence Detection | 0 0x00<br>1 0x01<br>2 0 | 0<br>1<br>2 | 0x00<br>o<br>o<br>ore Queue Entries | 1<br>1<br>0<br>Solved Loads | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector | Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0x01<br>2 0<br>Load Queue Entries<br>0 0x00 | 0<br>1<br>2<br><b>St</b> c | 0x00<br>0<br>0<br>ore Queue Entries<br>0x00 | 1<br>1<br>0<br>Solved Loads | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | r | × | Forwarded | Dependence Detection | 0 0x00<br>1 0x01<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0x01 | 0<br>1<br>2<br><b>St</b> c | 0x00<br>0<br>0<br>ore Queue Entries<br>0x00<br>0 | 1<br>1<br>0<br>Solved Loads | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector | Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0x01<br>2 0<br>Load Queue Entries<br>0 0x00 | 0<br>1<br>2<br><b>St</b> c | 0x00<br>0<br>0<br>ore Queue Entries<br>0x00 | 1<br>1<br>0<br>Solved Loads | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | X<br>Hit in EBF | Forwarded | Dependence Detection | 0 0x00<br>1 0x01<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0x01 | 0<br>1<br>2<br><b>St</b> c | 0x00<br>0<br>0<br>ore Queue Entries<br>0x00<br>0 | 1<br>1<br>0<br>Solved Loads<br>1<br>1 | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | Hit in EBF | Forwarded O O | Dependence Detection | 0 0x00<br>1 0x01<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0x01 | 0<br>1<br>2<br><b>Sto</b><br>0<br>1<br>2 | 0x00<br>o<br>o<br>ore Queue Entries<br>0x00<br>o | 1<br>1<br>0<br>Solved Loads | | 000<br>001<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000<br>010 | Read / Write EBF | Hit in EBF | Forwarded O O | Dependence Detection | 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 | 0<br>1<br>2<br>Stc<br>0<br>1<br>2 | 0x00<br>o<br>o<br>ore Queue Entries<br>0x00<br>o | 1<br>1<br>0<br>Solved Loads<br>1<br>1<br>0 | | (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded X | Dependence Detection O O X Dependence Detection O O O O | 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 1 0x01 1 0x00 1 0x00 | 0<br>1<br>2<br><b>Sto</b><br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 010 | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O X Dependence Detection O O O | 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 1 0x01 2 0 Load Queue Entries 0 0x00 | 0<br>1<br>2<br>Stc<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 0 Solved Loads | | 000 001 010 (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O X Dependence Detection O O O O O | O | 0<br>1<br>2<br>0<br>1<br>2<br>Stc<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O X Dependence Detection O O O O | O | Sto 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 0 Solved Loads | | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O O Forwarded O O Forwarded O X O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O Dependence Detection | 0 | Sto 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O X Dependence Detection O O O O O | O | State | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 0 Solved Loads | | 000 | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O | O | Sto 0 1 2 | 0x00 o o o o o o o o o o o o | Solved Loads Solved Loads Solved Loads Solved Loads Solved Loads 1 1 0 Solved Loads | | 000 | Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF x Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O | O | Sto O 1 2 O 1 2 Sto O O O O O O O O O | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads Solved Loads Solved Loads Solved Loads Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded C C C C C C C C C C C C C C C C C C | Dependence Detection O O X Dependence Detection O O O Dependence Detection O O Dependence Detection O O Dependence Detection | O | Store | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries | Solved Loads Solved Loads Solved Loads Solved Loads 1 1 0 Solved Loads 1 0 Solved Loads | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O O Forwarded O X O Forwarded O Forwarded O Forwarded O O | Dependence Detection O O O X Dependence Detection O O O O O O Dependence Detection O O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ox00 | 1 | | (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF x Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O X Dependence Detection O O O O O O Dependence Detection O O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O O Forwarded O X O Forwarded O Forwarded O Forwarded O O | Dependence Detection O O O X Dependence Detection O O O O O O Dependence Detection O O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ox00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF r Read / Write EBF r | Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O O O O O Forwarded O X O Forwarded O X O Forwarded O X O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Oxo0 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF r Read / Write EBF r | Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O Forwarded O Forwarded O Forwarded O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ox00 Ox0 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | Sto 0 1 2 | Ox00 Ore Queue Entries Ox00 Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries Ox00 O Ore Queue Entries | Solved Loads | | O00 | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded O Forwarded O X O Forwarded O Forwarded O Forwarded O Forwarded O X O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | Sto 0 1 2 | Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 | 1 | | O00 | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded O Forwarded O X O Forwarded O Forwarded O Forwarded O Forwarded O X O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | Sto 0 1 2 | Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | Sto 0 1 2 | Ox00 Ore Queue Entries | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O Forwarded O X O Forwarded O X O Forwarded O Forwarded O O Forwarded O Forwarded O Forwarded O Forwarded O Forwarded O O Forwarded O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | Sto 0 1 2 0 1 2 Sto 0 0 1 2 Sto 0 0 1 2 Sto 0 0 0 Sto 0 0 0 0 0 Sto 0 0 0 0 0 0 0 Sto 0 0 0 0 0 0 0 0 0 | Ox00 Ore Queue Entries | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF A Hit in EBF A Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | Sto 0 1 2 | Ox00 Ore Queue Entries | 1 | Appendix-B Memory Disambiguation Test: LLL (Load-Load-Load) | | | | T | | T. | 1 | | Taxana and a | | T = | T | T - | | T | | |---------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | _ | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | <del>- - - - - - - - - - </del> | | | 0 1 | LD<br>LD | 0x00<br>0x01 | 1 1 | 1 0 | X | 0 | 0x01 | 000<br>* | r | | 0 | 0 | 0 0x00<br>1 0 | 0 0 | | | 2 | LD LD | 0x01<br>0x02 | 1 | l ů | 0 | 1 | 0x01 | * | l ' | " | | Ů | 2 0 | 2 0 | | | | <del></del> | | - | | | - | • | | • | | | - | | 1-1 - | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entries | | 🛓 | 0 | LD | 0x00 | 1 | 1 | Х | 0 | | 000 | | | 0 | 0 | 0 0x00 | 0 0 | | РАТН | 1 2 | LD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | r | 0 | 0 | 0 | 1 0 | 1 0 | | | | LD | 0x02 | 1 | U | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entries | | | 0 | LD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0x00 | 0 0 | | | 1 | LD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | r | 0 | 0 | 0 | 1 0 | 1 0 | | | 2 | LD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | LD | 0x01 | 1 | 1 | х | 0 | 0x00 | 000 | r | 0 | 0 | О | 1 0x01 | 1 0 | | | 2 | LD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entries | | 1 I | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | THE WITH COURT OF THE CO | * | Reddy Wille EBI | 1110 1111 221 | 0 | 0 | 0 0 | 0 0 | | РАТН | 1 | LD | 0x01 | 1 | 1 | х | 0 | 0x00 | 000 | r | 0 | 0 | 0 | 1 0x01 | 1 0 | | | 2 | LD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | D=-''' | Lucature et en | 1 / 6 0 4 !! : : | Welled Land Control | | L calculate | Walled Land | Name de la | (New) Provide Press lead to Ve | Deed Assessed | | I rannontat | Banandan - Barani | Land Owner France | ina Cham Course Finkeries | | | Position<br>0 | Instructions<br>LD | L/S Queue Allocation<br>0x00 | Valid Instructions | State 0 | Selected<br>o | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | Load Queue Entr | ies Store Queue Entries | | | 1 | LD | 0x00 | 1 | 1 | x | 0 | 0x00 | 000 | r | 0 | 0 | 0 | 1 0x01 | 1 0 | | | 2 | LD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | I n | Location 12 | 1 / 0 0 | V-Balance et | I ou · · · | I colored I | V-Bd ( | I Name to 15 to 1 | (New) Bestlele Be | I n 1 /24 % ==== | I 105 1 55- | Leann C. | | I 140 | in | | | Position<br>() | Instructions<br>LD | L/S Queue Allocation<br>0×00 | Valid Instructions | State 0 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection o | Load Queue Entr | ies Store Queue Entries | | | 1 | LD | 0x00 | 1 | 0 | 0 | 1 | 0x00 | * | r | | 0 | 0 | 1 0 | 1 0 | | | 2 | LD | 0x02 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 2 0x02 | 2 0 | | 1 | I | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | T | | | ~ | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | _ | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | | | АТН 2 | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | (Non) Possible Dependencies Vector * * | Read / Write EBF | Hit in EBF | 0 | 0 | 0 0 | 0 0 | | РАТН 2 | | | | Valid Instructions 1 1 1 | _ | _ | | New Head Pointer | * | | | | | 1 - 1 | | | PATH 2 | 0 | LD<br>LD | 0x00<br>0x01<br>0x02 | 1<br>1<br>1 | 0<br>0<br>1 | o<br>x | 1<br>1<br>0 | 0x00 | *<br>*<br>000 | r | 0 | 0<br>0<br>0 | 0<br>0<br>0 | 0 0<br>1 0<br>2 0x02 | 0 0 1 0 2 0 | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>LD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation | 1 | 0<br>0<br>1<br>State 0 | o<br>X<br>Selected | 1<br>1<br>0<br>Valid Instructions | | * | | | o<br>o<br>o | O<br>O<br>O<br>Dependence Detection | 0 0<br>1 0<br>2 0x02 | 0 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>LD | 0x00<br>0x01<br>0x02<br>L / S Queue Allocation<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | O<br>O<br>X<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | *<br>*<br>000 | Read / Write EBF | O<br>Hit in EBF | 0<br>0<br>0<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 2 0x02 Load Queue Entr 0 0 | 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | РАТН 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>LD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation | 1<br>1<br>1 | 0<br>0<br>1<br>State 0 | o<br>X<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | * * 000 (Non) Possible Dependencies Vector * | r | 0 | o<br>o<br>o | O<br>O<br>O<br>Dependence Detection | 0 0<br>1 0<br>2 0x02 | 0 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | РАТН 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>LD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br><b>State 0</b> | O<br>O<br>X<br>Selected | 1 1 0 Valid Instructions 1 1 | 0x00 | * * 000 (Non) Possible Dependencies Vector * * | Read / Write EBF | O<br>Hit in EBF | 0<br>0<br>0<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1<br>2 | LD<br>LD<br>LD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00<br>0x01<br>0x02 | 1<br>1<br>1<br>Valid Instructions<br>1<br>1<br>1 | 0<br>0<br>1<br><b>State 0</b><br>0<br>0 | O<br>O<br>X<br>Selected<br>O<br>O<br>X | 1<br>1<br>0<br>Valid Instructions<br>1<br>1<br>0 | 0x00 New Head Pointer 0x00 | * * 000 (Non) Possible Dependencies Vector * * 000 | r<br>Read / Write EBF | O Hit in EBF | Forwarded 0 0 | O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | PATH 2 | Position Position Position | Instructions LD LD LD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected Selected | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 | * * 000 (Non) Possible Dependencies Vector * 000 (Non) Possible Dependencies Vector | r<br>Read / Write EBF | O Hit in EBF | Forwarded O Forwarded | Dependence Detection O O Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | ies Store Queue Entries 0 0 1 0 1 0 2 0 | | PATH 2 | 0 1 2 Position 0 1 2 Position 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Instructions LD | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br><b>State 0</b><br>0<br>0 | Selected O X Selected X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 | * * 000 (Non) Possible Dependencies Vector * * 000 | Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O Dependence Detection O O O | 0 0 1 0 2 0x02 | ies Store Queue Entries 0 0 0 1 0 0 1 0 0 1 0 0 2 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 | | РАТН | Position Position Position | Instructions LD LD LD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected Selected | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O Hit in EBF | Forwarded O Forwarded | Dependence Detection O O Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | ies Store Queue Entries 0 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 | | РАТН | 0 1 2 Position 0 1 2 Position 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Instructions LD LD LD LD LD LD SD | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected O X Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Column C | 0 | | РАТН 3 | Position | Instructions LD LD LD LD LD Instructions LD LD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x01 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 | Selected O X Selected O X Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 000 (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entr | ies Store Queue Entries O O O O O O O O O O O O O O O O O O O | | РАТН | Position | Instructions LD LD LD LD LD Instructions LD LD LD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0 | Selected Selected X Selected X O Selected X X | Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entr | 0 | | РАТН | Position | Instructions LD LD LD LD Instructions LD LD LD SD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 | Selected Selected X Selected X Selected X Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 000 (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entr | 0 | | РАТН | Position | Instructions LD LD LD LD LD Instructions LD LD LD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 Valid Instructions | 0 | Selected Selected X Selected X O Selected X O Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * | Read / Write EBF | Hit in EBF | Forwarded O Forwarded O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Company Comp | 0 | | РАТН | Position | Instructions LD LD LD LD Instructions LD LD LD SD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 Valid Instructions | State 0 | Selected O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * | Read / Write EBF | Hit in EBF | Forwarded O Forwarded O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Column C | 0 | | РАТН | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * | Read / Write EBF | Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Column C | 0 | | РАТН | Position | Instructions LD | 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O Selected X O Selected X O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Column C | 0 | | РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * 000 (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Column C | 0 | | РАТН 3 | Position | Instructions LD | 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Company Com | 0 | | РАТН | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O O Selected X O Selected X O O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Company Com | 0 | | РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | Dx00 Dx01 Dx00 Dx01 Dx00 Dx01 Dx00 Dx01 Dx00 Dx00 Dx01 Dx00 Dx01 Dx00 Dx00 Dx01 Dx00 | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O O Selected X O Selected X O O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Column | 0 | | РАТН 3 | Position O 1 2 Position O 1 2 Position O 1 2 Position O 1 2 Position O 1 2 Position O 1 2 | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L/S Queue Allocation | Valid Instructions Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X Selected X O O X Selected X O O X Selected X O O X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Column | 0 | | РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | Dx00 Dx01 Dx00 Dx01 Dx00 Dx01 Dx00 Dx01 Dx00 Dx00 Dx01 Dx00 Dx01 Dx00 Dx00 Dx01 Dx00 | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Column | 0 | | РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L/S Queue Allocation | Valid Instructions Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X Selected X O O X Selected X O O X Selected X O O X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Column | 0 | | РАТН 4 РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L/S Queue Allocation | Valid Instructions Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X O O X Selected X O O O Selected X O O O Selected X O O O Selected O X O O Selected O X O O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Column | O | | РАТН 4 РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L/S Queue Allocation | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | State 0 | Selected X O O X Selected X O O O Selected X O O O Selected X O O O Selected O X O O Selected O X O O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * | Read / Write EBF r Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Company Com | O | | РАТН 3 | Position | Instructions LD LD LD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions LD SD LD Instructions | L/S Queue Allocation | Valid Instructions 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X O O X Selected X O O O Selected X O O O Selected X O O O Selected O X O O Selected O X O O Selected O X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Company Com | O | Appendix-B Memory Disambiguation Test: LLL (Load-Load-Load) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | |----------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | # | 0 | 0 | | 000 | | | 0 | 0 | | | 0 0 | 1 | 1 ‡ [ | 0 | 0 | | 0 | 0 | x o | 0<br>1 | 0x01 | 000<br>* | r | 0 | 0 | 0 | 2 | 0x01 : | 0 0 | 1<br>0 | 1 1 | o<br>x | 0 | | | | | | | | | | | | | | | | 1 | | | | Solved Loads | State 1 | Selected<br>0 | Valid Instructions O | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection<br>o | Load Que | OxOO ( | Store Queue Entries O o | Solved Loads | State 2 | Selected<br>0 | Valid Instructions O | | О | 0 | 0 | 1 | 0x01 | <b>*</b> | r | 0 | 0 | ٥ | 1 | 0 | 1 0 | 0 | 1 | x | О | | 0 | 1 | х | 0 | | 000 | | | 0 | 0 | 2 | Ox02 : | 2 0 | 1 | | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 1<br>0 | 1 1 | 0<br>x | 0 | 0x02 | 000<br>000 | r | 0 | 0 | 0 | _ | 0x00<br>0x01 : | 0 0 | 1<br>1 | * | 0 | 0 | | 0 | 1 | 0 | 1 | | + | | | 0 | 0 | 2 | 0 | 2 <b>o</b> | ō | 1 | х | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | x | 0 | 0.00 | 000 | | | 0 | 0 | _ | 0x00 (<br>0x01 ( | 0 0 | 1<br>1 | | 0 | 0 | | 0 | 0 | 0 | 1 | 0x02 | 000<br>* | r | 0 | 0 | o<br>o | 2 | 0x01 : | 1 0<br>2 0 | 0 | 1 | o<br>x | 0<br>0 | | | 1 | | | | | L | | | | 110 | 5-4-1 1 | St | | lass al | | | | Solved Loads O | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>* | Read / Write EBF | HIT IN EBF | Forwarded<br>o | Dependence Detection<br>o | Load Que | o ( | Store Queue Entries O O | Solved Loads O | State 2 | Selected<br>X | Valid Instructions O | | 1 | + | 0 | 0 | 0x00 | 000 | r | o | 0 | ٥ | | 0x01 | 1 0 | 1 | + | 0 | О | | 0 | 1 1 | X | 0 | | 000 | <u> </u> | | 0 | 0 | 2 | 0x02 : | 2 0 | 1 | | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | S <i>o</i> lved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | X<br>o | 0 | 0x02 | 000<br>000 | r | 0 | 0 | 0 | | 0x00 (<br>0x01 : | 0 0 | 1<br>1 | # | 0 | o<br>o | | 0 | 1 | 0 | 1 | 5.102 | * | · | Ů | 0 | 0 | 2 | 0 : | 2 0 | 0 | 1 | x | ō | | | | | | | | - | | | | | - | | | - | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | x | 0 | 0.01 | <u> </u> | _ | _ | 0 | 0 | 0 ( | 0x00 ( | 0 0 | 1 | # | 0 | 0 | | 0 1 | 0 | 0 0 | 0 | 0x01 | 000 | <b> </b> | 0 | 0 | 0 | 2 | OxO2 | 0 0 | 0<br>1 | + | x<br>o | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - | | | | | | | | Solved Loads | State 1 | _ | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | Solved Loads O O | 9tate 1<br>0<br>1 | Selected<br>o<br>x | Valid Instructions 1 0 | New Head Pointer 0x00 | 000 | Read / Write EBF | Hit in EBF | Forwarded<br>O | Dependence Detection o o | 0 | 0<br>0x01 | Store Queue Entries O O 1 O | Solved Loads<br>O<br>1 | State 2 | Selected X | Valid Instructions O O | | 0 | | _ | 1 | | <b>‡</b> | Read / Write EBF | | 0 | 0 | 0 | 0 ( | 0 0 | _ | State 2 1 | х | 0 | | 0 | 0<br>1<br>* | o<br>x | 1<br>0 | | 000 | Read / Write EBF | 0 | 0 | 0 | 0 | o (<br>0x01 :<br>0x02 : | 0 0 | _ | 1 + + | x<br>o | 0<br>0 | | 0<br>0<br>1<br>Solved Loads | 0<br>1<br>* | 0<br>X<br>0 | 1<br>0<br>0 | 0x00 | 000 | r | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | O<br>1<br>2 | 0 (<br>0x01 :<br>0x02 :<br>ue Entries ( | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>1<br>Solved Loads | 1 + + | x<br>o<br>o<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b> | | 0<br>0<br>1<br>Solved Loads | 0<br>1<br>* | 0<br>X<br>0 | 1<br>0<br>0<br><b>Valid Instructions</b> | 0x00 | * 000 000 (Non) Possible Dependencies Vector 000 | r | 0 | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2<br>Load Que | 0 (0x01 :: 0x02 :: : : : : : : : : : : : : : : : : : | 0 0 0 0 1 0 2 0 0 Store Queue Entries | 0<br>1<br>1 | 1 + + | x<br>o<br>o | 0<br>0<br>0<br><b>Valid Instructions</b> | | O O O D O O O O O O O O O O O O O O O O | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected x | 1<br>0<br>0<br>Valid Instructions<br>0<br>1 | 0x00 | * 000 000 (Non) Possible Dependencies Vector 000 * | r | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>Load Que | 0 (00000000000000000000000000000000000 | 0 | 0<br>1<br>1<br><b>Solved Loads</b><br>1<br>0 | 1 + + | x<br>o<br>o<br>Selected<br>o<br>x | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | O O O D O O O O O O O O O O O O O O O O | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected x | 1<br>0<br>0<br>Valid Instructions<br>0<br>1 | 0x00 | * 000 000 (Non) Possible Dependencies Vector 000 * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 0 | O O O O O O O O O O O O O O O O O O O | 0 1 2 Coad Queen 0 1 2 Coad Queen 0 1 2 Coad Queen 0 1 Coad Queen 0 1 Coad Queen 0 | 0 (0x01 :: 0xx02 :: 0xx00 (0 :: 0xx02 : | 0 | 0<br>1<br>1<br><b>Solved Loads</b><br>1<br>0 | 1 + + | X<br>O<br>O<br>Selected<br>O<br>X<br>O | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | Solved Loads O 1 Solved Loads O 1 Solved Loads | O 1 * State 1 1 1 * State 1 * | Selected X O O | Valid Instructions O Valid Instructions O Valid Instructions O | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 000 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 | r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O | Dependence Detection O O Dependence Detection O Dependence Detection O | Coad Queen Coa | 0 (0x01 : 0x02 : : : : : : : : : : : : : : : : : : : | Store Queue Entries O | 0<br>1<br>1<br>Solved Loads<br>1<br>0 | 1<br>*<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O O | | Solved Loads O 1 | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected X 0 0 Selected X 0 0 | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions | 0x00 New Head Pointer 0x01 | * 000 000 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 0 Forwarded Forwarded | Dependence Detection O O Dependence Detection O Dependence Detection O | Coad Queen Coa | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | Store Queue Entries O | 0<br>1<br>1<br>Solved Loads<br>1<br>0 | 1<br>*<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected Selected Selected | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | O O O O O O O O O O | O | Selected X O O Selected X O O O | Valid Instructions O Valid Instructions O Valid Instructions O 1 O Valid Instructions | OxOO New Head Pointer OxO1 New Head Pointer OxO2 | * 000 000 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector 000 000 + | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quee<br> O 1 2 1 1 1 1 1 1 1 1 | 0 (0x01 : 0x02 : : : : : : : : : : : : : : : : : : : | O O O | O | 1 | Selected O Selected O X O Selected X X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 | | O O D | O 1 # State 1 1 1 | Selected X O O Selected X O O O | Valid Instructions O Valid Instructions O Valid Instructions O | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 000 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quee<br> Coad Quee<br> Coad Quee<br> Coad Quee<br> Coad Quee<br> Coad Quee | 0 (0x01 : 0x02 : : : : : : : : : : : : : : : : : : : | O O O | Solved Loads 1 0 1 Solved Loads 1 Solved Loads 1 | 1 | Selected Selected Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O O | | O O O O O O O O O O | O | Selected Selected Selected Selected Selected X O X X X X X X X X X X X | Valid Instructions O Valid Instructions O Valid Instructions O 1 Valid Instructions | OxOO New Head Pointer OxO1 New Head Pointer OxO2 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queen Coa | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O | O 1 1 1 | 1 | Selected Selected Selected Selected Selected O O O O O O O O O O O O O | Valid Instructions O O Valid Instructions O O Valid Instructions O O Valid Instructions O O O | | O O O O O O O O O O | O 1 * State 1 1 1 * State 1 1 0 | Selected Selected O Selected O Selected O Selected O Selected O Selected | Valid Instructions O Valid Instructions O 1 O Valid Instructions O 1 Valid Instructions O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queen Coa | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O | Solved Loads Solved Loads Solved Loads Solved Loads Solved Loads | 1 | Selected Selected Selected Selected Selected Selected O X Selected | Valid Instructions O O Valid Instructions O O Valid Instructions O O Valid Instructions O O | | O O O O O O O O O O | State 1 | Selected X O O Selected X O O Selected O X O O | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O O 1 Valid Instructions O O 1 | OxOO New Head Pointer OxO2 New Head Pointer OxO2 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Que: Coad | 0 (0x01 0x02 0x00 (0x00 0x00 (0x00 0x00 (0x00 0x00 (0x00 0x00 (0x00 (0x0 (0x00 (0x0 (0x00 (0x00 (0x00 (0x00 (0x0) (0x00 (0x00 (0x0) (0x00 (0x00 (0x00 (0x0) | O O O 2 | O 1 1 1 | 1 | Selected O X O Selected O X O Selected O X X O X Selected O X Selected O X Selected O X Selected | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O O Selected O X O Selected O Selected O Selected O Selected O Selected | Valid Instructions O Valid Instructions O 1 O Valid Instructions O 1 Valid Instructions O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Que: Coad | 0 (0x01 0x02 0x00 (0x00 0x00 (0x00 0x00 (0x01 0 0x00 (0x01 0 0x00 (0x01 0 0x00 (0x01 0 0x00 (0x01 0 0x00 (0x01 0 0x00 (0x01 | O O O 2 | O 1 1 1 | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O O | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 | OxOO New Head Pointer OxO2 New Head Pointer OxO2 | (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O O | Solved Loads | 1 | Selected O X O Selected O X O Selected O X X O X Selected O X Selected O X Selected O X Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X O O Selected | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O O 1 Valid Instructions O Valid Instructions | OxOO New Head Pointer OxO2 New Head Pointer OxO2 New Head Pointer OxO2 | # 000 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0x01 0x02 0x00 0 (0x02 0 (0x02 0 (0x01 (0 | O O O O | Solved Loads | 1 | Selected Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X O O Selected | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 | OxOO New Head Pointer OxO2 New Head Pointer OxO2 New Head Pointer OxO2 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O | Solved Loads | State 2 | Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected Selected Selected X O Selected X Selected X Selected X X X | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O | O 1 1 1 | State 2 | Selected O Selected O Selected O Selected O Selected Selected Selected Selected X O O X | Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions | | Solved Loads | State 1 | Selected X 0 0 Selected X 0 0 Selected X 0 Selected O X 0 Selected O X 0 Selected O X Selected O X Selected O X Selected | Valid Instructions O Valid Instructions O O I Valid Instructions O O 1 Valid Instructions O O O Valid Instructions O O O Valid Instructions Valid Instructions | New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox02 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O | O 1 1 1 | State 2 | Selected O Selected O Selected O Selected O Selected O Selected Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected Selected X O X O Selected X O Selected X O Selected X O Selected O X O Selected O X O | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 (0 | O O O O O O O O O | O 1 1 1 | State 2 | Selected O Selected O Selected O Selected O Selected Selected Selected Selected X O O X | Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected Selected X O X O Selected X O Selected X O Selected X O Selected O X O Selected O X O | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O Forwarded O O Forwarded O O Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | 0 (0x01 0x02 0x00 (0x00 0x00 (0x01 0 0x00 (0x01 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O O O O O O O O O | O 1 1 1 | State 2 * | Selected O Selected O Selected O Selected O Selected Selected Selected Selected X O O X | Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected O X O Selected O O O O O O O O O O O O O | 1 | New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox02 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | O ( O XO O XO O O O O O | O O O | Solved Loads | State 2 * | Selected O Selected O Selected O Selected O Selected O Selected O S O S Selected O O S Selected O O S Selected O O O X | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O Valid Instructions O O Valid Instructions | New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox02 New Head Pointer Ox00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quee O | O ( | O O O | Solved Loads | State 2 * | Selected O Selected O Selected O Selected O Selected O Selected Selected X Selected X Selected Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions | Appendix-B Memory Disambiguation Test: LLL (Load-Load-Load) | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | Ste | ore Queue Entries 📗 | Solved Loads | |------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------| | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0 | 1 | | 0x03 | 000 | r | 0 | 0 | 0 | 1 | -1 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | 2 | 0x02 | 2 | 0 | 1 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lie | oad Queue Entries | Str | ore Queue Entries | Solved Loads | | recorrect Forner | 000 | Reddy Wille EBI | 1110 1111 1111 | 0 | 0 | 0 | 0x00 | 0 | 0 | 1 | | 0x03 | 000 | r | 0 | 0 | 0 | 1 | -1 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | 2 | 0x02 | 2 | 0 | 1 | | | | | | | | _ | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | oad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0×03 | 000<br>000 | r | 0 | 0 | 0 | 1 | 0x00<br>0x01 | 1 | 0 | 1 | | 0.00 | 000 | | ľ | 0 | 0 | 2 | 0x02 | 2 | 0 | 1 | | | 355 | | <u> </u> | , , | | | 0.02 | | , i | - | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | St | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0 | 1 | | 0x03 | 000 | r | 0 | 0 | 0 | 1 | -1 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | 2 | 0x02 | 2 | 0 | 1 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | Sto | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0 | 1 | | 0x03 | 000 | r | 0 | 0 | 0 | 1 | 0x01 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | 2 | 0x02 | 2 | 0 | 1 | | | | | | 1 - | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | oad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0x03 | 000<br>000 | r | 0 | 0 | 0 | 1 | 0x00<br>0x01 | 1 | 0 | 1<br>1 | | 0,03 | 000 | l ' | | 0 | 0 | 2 | 0x02 | 2 | l 。 | 1 | | | | | | | | | 0.00 | | | - | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | St | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0×00 | 0 | 0 | 1 | | 0x03 | 000 | r | 0 | 0 | 0 | 2 | -1 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | | 0x02 | 2 | 0 | 1 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | Sto | ore Queue Entries | Solved Loads | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | Lo | oad Queue Entries | <b>St</b> : | ore Queue Entries | Solved Loads | | New Head Pointer 0x03 | 000<br>000 | Read / Write EBF | Hit in EBF | | | 0 | 0x00<br>0x01 | 0 | | | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0 | 1 | | 0x03 | 000<br>000<br>000 | r | 0 | 0<br>0 | 0 0 | 0<br>1<br>2 | 0x00<br>0x01<br>0x02 | 0<br>1<br>2 | o<br>o<br>o | 1<br>1<br>1 | | | 000<br>000<br>000<br>(Non) Possible Dependencies Vector | | | o<br>o<br>o<br>Forwarded | o<br>o<br>Dependence Detection | 1<br>2 | 0x00<br>0x01<br>0x02<br>oad Queue Entries | 0<br>1<br>2 | o<br>o<br>ore Queue Entries | 1 | | 0x03 | 000<br>000<br>000 | r | 0 | 0<br>0 | 0 0 | 0<br>1<br>2 | 0x00<br>0x01<br>0x02<br>oad Queue Entries<br>0x00 | 0<br>1<br>2 | o<br>o<br>o | 1<br>1<br>1<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000 | r<br>Read / Write EBF | O<br>Hit in EBF | 0<br>0<br>0<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2 | 0x00<br>0x01<br>0x02<br>oad Queue Entries<br>0x00 | 0<br>1<br>2<br><b>St</b> | o<br>o<br>ore Queue Entries | 1<br>1<br>1<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000 | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded | O O O O Dependence Detection O O | 0<br>1<br>2<br>Lt | 0x00<br>0x01<br>0x02<br>oad Queue Entries<br>0x00<br>0x01 | 0<br>1<br>2<br><b>St</b> c<br>0 | o<br>o<br>ore Queue Entries | 1<br>1<br>1<br>Solved Loads<br>1<br>1 | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | r Read / Write EBF | Hit in EBF | Forwarded 0 0 | Dependence Detection | 0<br>1<br>2<br>0<br>1<br>2 | 0x00<br>0x01<br>0x02<br>coad Queue Entries<br>0x00<br>0x01<br>0x02 | 0<br>1<br>2<br><b>St</b> 0<br>1<br>2 | ore Queue Entries | 1<br>1<br>1<br>Solved Loads<br>1<br>1 | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O Forwarded | Dependence Detection O O Dependence Detection | 0<br>1<br>2<br>0<br>1<br>2 | 0x00<br>0x01<br>0x02<br>coad Queue Entries<br>0x00<br>0x01<br>0x02 | 0<br>1<br>2<br>Sto<br>0<br>1<br>2 | ore Queue Entries o o ore Queue Entries | 1 1 1 Solved Loads 1 1 1 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector | r Read / Write EBF | Hit in EBF | Forwarded O Forwarded O Forwarded | Dependence Detection O Dependence Detection O Dependence Detection | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 | 0<br>1<br>2<br><b>St</b> 0<br>1<br>2 | ore Queue Entries | 1<br>1<br>1<br>Solved Loads<br>1<br>1 | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded O Forwarded | Dependence Detection O O Dependence Detection | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 | 0<br>1<br>2<br>Sto<br>0<br>1<br>2 | ore Queue Entries o o ore Queue Entries | Solved Loads 1 1 1 1 Solved Loads 1 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 | 0<br>1<br>2<br><b>St</b> (0<br>1<br>2<br><b>St</b> (0<br>1 | ore Queue Entries o o o | 1<br>1<br>1<br>Solved Loads<br>1<br>1<br>Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | C | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries | 0<br>1<br>2<br>Str<br>0<br>1<br>2<br>Str<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | Solved Loads Solved Loads Solved Loads 1 1 1 1 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O Forwarded O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | C | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 | St. | ore Queue Entries o o o o o o o o o o o o o o o o o o o | 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | CC CC CC CC CC CC CC C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | Str | ore Queue Entries ore Queue Entries ore Queue Entries | 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O Forwarded O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | C | 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 coad Queue Entries 0x00 0x01 0x02 | St. | ore Queue Entries o o o o o o o o o o o o o o o o o o o | 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | CC CC CC CC CC CC CC C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | Str | ore Queue Entries ore Queue Entries ore Queue Entries | 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St St | ore Queue Entries ore Queue Entries ore Queue Entries | 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Le C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | Str | ore Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 1 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) OOO (Non) OOO | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | Str | ore Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 1 1 1 1 1 Solved Loads 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Le C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | Str | ore Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 1 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc 0 1 2 | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St. St. | ore Queue Entries o o o o o o o o o o o o o o o o o o | 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) OOO (Non) OOO | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc 0 1 2 | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St. St. | ore Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 1 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 1 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | State | ore Queue Entries o o o o o o o o o o o o o o o o o o | 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc 0 1 2 | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | State | ore Queue Entries o o o o o o o o o o o o o o o o o o | Solved Loads 1 1 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads 1 1 1 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector 000 000 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | State | ore Queue Entries o o o o o o o o o o o o o o o o o o | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 | Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St. | ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 | St. St. | ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St. | ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lc C C C C C C C C C | 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 oad Queue Entries 0x00 0x01 0x02 | St. St. | ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries ore Queue Entries | 1 | Appendix-B Memory Disambiguation Test: LLS (Load-Load-Store) | | I nestates | I to a | 1 / 0 0 0 !! +! | Malial Instrumentaria | I c c | I 6-141 I | V-list to store the con- | L Name United British and | (Name) Describbe Described Version | L n 1 / \\ / \\ - = - EDE | Lucia Enc | I = | D | Load Queue Entries | Store Queue Entries | |-----------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Position | Instructions<br>LD | L / S Queue Allocation<br>0x00 | Valid Instructions | State U | Selected<br>× | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection o | 0 0x00 | otore Queue Entries | | | 1 | LD | 0x01 | 1 | 0 | ^ | 1 | 0x01 | * | r | 0 | 0 | 0 | 1 0 | | | | 2 | SD SD | 0x00 | 1 | 0 | | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | 🖁 | 0 | LD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0x00 | 0 0 | | РАТН | 1 | LD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | r | 0 | 0 | 0 | 1 0 | 1 0 | | | 2 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | T | <del></del> . | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | _ | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | · | Load Queue Entries | + | | | 0 1 | LD<br>LD | 0x00<br>0x01 | 1 | | x o | 0<br>1 | 0x01 | 000<br>* | r | | 0 | 0 | 0 0x00 | 1 0 | | | 2 | SD SD | 0x00 | 1 | ľů | I ຶ I | 1 | 0.01 | * | l ' | | 0 | 0 | 2 0 | 2 0 | | | | 95 | 0,000 | - | <u> </u> | | - | | | | | | | - | 1-1 - | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | LD | 0x01 | 1 | 1 | Х | 0 | 0x00 | 000 | r | 0 | 0 | 0 | 1 0x01 | 1 0 | | | 2 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | I 1 | 1/00: 40 :: | velid · · | l | I 6.1 <sup>1</sup> | v-hd · · | I Name of the second | (NI) P | I n1/142 to === | 104 | le. | B | L tand 0 7 | | | | Position | Instructions | L / S Queue Allocation<br>0x00 | Valid Instructions | State 0 | <del> </del> | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | <del> </del> | | РАТН | 0 1 | LD<br>LD | 0x00 | 1 | " | o x | 1<br>0 | 0x00 | 000 | r | | 0 | 0 | 0 0<br>1 0x01 | | | = | 2 | SD SD | 0x00 | 1 | l . | | 1 1 | | * | I ' | | | o | 2 0 | 2 0 | | | | | | | | | | | | • | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State O | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | LD | 0x01 | 1 | 1 | х | 0 | 0x00 | 000 | r | 0 | 0 | 0 | 1 0x01 | 1 0 | | | 2 | \$D | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | | | | | | | | | | | | | | | | | | I Davisian | l Instancetions | L / C Ourse Allegation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Naw) Passible Danaudansias Vartau | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | | Position | Instructions<br>LD | L / S Queue Allocation<br>0x00 | valid instructions | 0 | 0 | valid instructions | New Head Pointer | (Non) Possible Dependencies Vector | Kead / Write EBF | HIT IN EBF | o | o Dependence Detection | 0 o | 0 0x00 | | | 1 | LD | 0x01 | 1 | ľ | | 1 | 0x00 | * | w | | | 0 | 1 0 | 1 0 | | | 2 | SD. | 0x00 | 1 | 1 | x | 0 | | 011 | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State O | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | 7 E | Position<br>0 | Instructions<br>LD | L / S Queue Allocation<br>0x00 | Valid Instructions<br>1 | State 0 | Selected<br>o | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | Load Queue Entries | Store Queue Entries 0 0x00 | | РАТН 2 | 0<br>1 | LD<br>LD | 0x00<br>0x01 | Valid Instructions 1 1 | _ | <del></del> | 1<br>1 | New Head Pointer | * | Read / Write EBF | Hit in EBF | • | · · · · · · · · · · · · · · · · · · · | - | <del> </del> | | PATH 2 | 0 | LD | 0×00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0x00 | | PATH 2 | 0<br>1<br>2 | LD<br>LD<br>SD | 0x00<br>0x01<br>0x00 | 1<br>1<br>1 | 0<br>0<br>1 | о<br>О<br>Х | 1<br>1<br>0 | 0x00 | *<br>*<br>011 | w | 0 | 0<br>0 | 0<br>0 | 0 0<br>1 0<br>2 0 | 0 0x00<br>1 0<br>2 0 | | РАТН 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>SD | 0x00<br>0x01<br>0x00<br>0x00 | 1 | 0<br>0<br>1<br>State 0 | o<br>x<br><b>Selected</b> | 1<br>1<br>0<br>Valid Instructions | | * | | | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00<br>1 0<br>2 0 | | РАТН 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>SD<br>Instructions | 0x00<br>0x01<br>0x00<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1 | 0<br>0<br>1<br><b>State 0</b> | O<br>X<br>Selected | 1<br>1<br>0 | 0x00 | *<br>*<br>011 | w | 0 | 0<br>0<br>0<br>Forwarded | Dependence Detection | 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00<br>1 0<br>2 0 | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>LD<br>SD | 0x00<br>0x01<br>0x00<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br>State 0 | o<br>x<br><b>Selected</b> | 1<br>1<br>0<br>Valid Instructions | 0x00 | *<br>*<br>011 | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00<br>1 0<br>2 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1 | LD<br>LD<br>SD<br>Instructions | 0x00<br>0x01<br>0x00<br>L/S Queue Allocation<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br><b>State 0</b> | O<br>X<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 | * * 011 (Non) Possible Dependencies Vector * * | W<br>Read / Write EBF | O<br>Hit in EBF | O<br>O<br>O<br>Forwarded | Dependence Detection | 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entries 0 0x00 1 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1 | LD<br>LD<br>SD<br>Instructions<br>LD<br>LD<br>SD | 0x00<br>0x01<br>0x00<br>L/S Queue Allocation<br>0x00<br>0x01<br>0x00 | 1<br>1<br>1<br>Valid Instructions<br>1<br>1 | 0<br>0<br>1<br>State 0<br>0<br>0 | Selected O X | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 New Head Pointer 0x00 | * 011 (Non) Possible Dependencies Vector * * 011 | W Read / Write EBF | Hit in EBF | Forwarded 0 0 | Dependence Detection 0 0 0 | 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entries 0 0x00 1 0 2 0 | | PATH 2 | Position Position Position | Instructions LD LD SD Instructions | 0x00<br>0x01<br>0x00<br>L/S Queue Allocation<br>0x00<br>0x01<br>0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 | Selected O X Selected O X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 | * * * * * * * * * * * * * * * * * * * | W Read / Write EBF | Hit in EBF | Forwarded O Forwarded | Dependence Detection O O Dependence Detection | Load Queue Entries O O O 1 O 2 O Load Queue Entries Load Queue Entries | O Ox00 1 O Ox00 Ox | | PATH 2 | 0 1 2 Position 0 1 2 Position 0 0 1 0 | Instructions LD LD SD Instructions LD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected X Selected X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF | Forwarded O Forwarded O O Forwarded | Dependence Detection O O Dependence Detection O O O | 0 0 1 2 0 0 1 1 0 0 1 1 0 1 1 0 1 1 1 1 | 0 0x00 1 0 2 0 Store Queue Entries 0 0x00 1 0 2 0 Store Queue Entries 0 0 0x00 | | РАТН | O | Instructions LD LD SD Instructions LD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected O X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | W Read / Write EBF | Hit in EBF | Forwarded O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 3 РАТН | 0 1 2 Position 0 1 2 Position 0 0 1 0 | Instructions LD LD SD Instructions LD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected X Selected X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF | Forwarded O Forwarded O O Forwarded | Dependence Detection O O Dependence Detection O O O | 0 0 1 2 0 0 1 1 0 0 1 1 0 1 1 0 1 1 1 1 | 0 0x00 1 0 2 0 Store Queue Entries 0 0x00 1 0 2 0 Store Queue Entries 0 0 0x00 | | РАТН | O | Instructions LD LD SD Instructions LD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected Selected X Selected X O O X | 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF | Forwarded O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | 0 | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD SD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 | 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected Selected X Selected X O O X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O | Load Queue Entries | 0 | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 0x01 0x00 | 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected Selected X Selected X Selected X Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O Dependence Detection O O Dependence Detection O O Dependence Detection | Coad Queue Entries | O | | 3 РАТН | Position | Instructions LD LD SD Instructions LD SD Instructions LD | 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 0x01 0x00 | 1 | O | Selected X Selected X Selected X Selected X Selected | Valid Instructions 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O Forwarded O Forwarded O O Forwarded | Dependence Detection O Dependence Detection O O Dependence Detection O Dependence Detection | Coad Queue Entries | 0 | | 3 РАТН | Position | Instructions LD LD SD Instructions LD | 0x00 0x01 0x00 L/\$Queue Allocation 0x00 0x01 0x00 L/\$Queue Allocation 0x00 0x01 0x00 L/\$Queue Allocation 0x00 0x01 0x00 | 1 | O | Selected X Selected X Selected X Selected X C Selected X C | Valid Instructions 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O Forwarded O O Forwarded O O O Forwarded | Dependence Detection O Dependence Detection O O Dependence Detection O O O O O O O O O O O O O | Load Queue Entries 0 | O | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD SD Instructions | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected X Selected X Selected X Selected X O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD SD Instructions LD SD Instructions | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 | 1 | O | Selected X Selected X Selected X Selected X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF | Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD LD SD | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected X Selected X Selected X O Selected X O Selected | Valid Instructions Valid Instructions Valid Instructions O 1 1 1 Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD SD Instructions LD SD Instructions | 0x00 0x01 0x00 L/S Queue Allocation 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected X Selected X Selected X Selected X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O Ox00 1 O Ox00 Ox | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD LD SD Instructions | 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected X Selected X O O X Selected X O O Selected X O O Selected X X O O X | Valid Instructions Valid Instructions Valid Instructions O 1 1 1 Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O Dependence Detection O O O Dependence Detection O O Dependence Detection O O O Dependence Detection | Coad Queue Entries | O | | 3 РАТН | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD LD SD Instructions | 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 0x00 0x01 0x00 0x01 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected X Selected X O O X Selected X O O Selected X O O Selected X X O O X | Valid Instructions Valid Instructions Valid Instructions O 1 1 1 Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions | 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 | 1 | O | Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD LD SD | 0x00 0x01 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 | 1 | O | Selected X Selected X Selected X Selected X Selected X Selected X Selected Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions | 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O | Selected X Selected X Selected X Selected X Selected X Selected X Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD LD SD | 0x00 0x01 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O | Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD SD Instructions LD SD Instructions | 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | State 0 | Selected X Selected X O O O Selected X O O O Selected X O O Selected X O O O Selected X O O O Selected O X O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 5 PATH 4 PATH 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD | 0x00 0x01 0x00 0x01 0x00 L/\$ Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O | Selected X Selected X O O O Selected X O O O Selected X O O Selected X O O O Selected X O O O Selected O X O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 5 PATH 4 PATH 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD SD Instructions LD SD Instructions | Ox00 Ox01 Ox00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | State 0 | Selected X Selected X O X Selected X O Selected X O Selected X O Selected Selected Selected Selected Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Store Queue Entries | | РАТН 4 РАТН 3 | Position | Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD LD SD Instructions LD SD Instructions LD SD Instructions LD SD Instructions | Ox00 Ox01 Ox00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | State 0 | Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | O | Appendix-B Memory Disambiguation Test: LLS (Load-Load-Store) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | | | Load Queue Entrie: | + | s Solved Loads | State 2 Selected | Valid Instructions | |---------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | * | 0 | 0 | 000 | 000 | _ | _ | 0 | 0 | 0 0x00 | 0 | 1 | * • | 0 | | 0 | 1 1 | × | 1 | 0x02 | 000<br>* | r | 0 | 0 | 0 | 1 0x01 | 0 | 1 0 | * ° | n | | | | Ů | <u> </u> | | | | | | · · | 2 0 | 121 0 | • | 1 1 ^ 1 | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie: | Store Queue Entrie | s Solved Loads | State 2 Selected | Valid Instructions | | 0 | * | 0 | 0 | | 000 | | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | * 0 | 0 | | 0 | 0 | 0 | 1 | 0x01 | * | W | 0 | 0 | 0 | 1 0 | 1 0 | 0 | 1 x | 0 | | 0 | 1 | Х | 0 | | 010 | | | 0 | 0 | 2 0 | 2 0 | 0 | * 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie: | Store Queue Entrie | s Solved Loads | State 2 Selected | Valid Instructions | | 0 | * | 0 | 0 | New Head Folliter | 000 | Read / Write Lbi | 1110 1111 1111 | 0 | o Dependence Detection | 0 0x00 | 0 0 | 1 | * 0 | 0 | | 0 | 1 | х | 0 | 0x02 | 000 | r | 0 | 0 | 0 | 1 0x01 | 1 0 | 0 | * 0 | 0 | | 0 | 1 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 0 | 0 | 1 x | 0 | | | | | | | | | | | | | | | | | | 0-111- | I c 1 | l 6-141 | V-1:-1: | Novelland Balatan | (Non) Boothle Boomedonic Western | L paral / Maritan EDE | Lua III EDE | l e | | Land Overva Futuia | . I Stano Overna Embria | • I c-ld- | | V-li-li | | Solved Loads | State 1 | Selected<br>× | Valid Instructions ∩ | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entrie | s Solved Loads | State 2 Selected | Valid Instructions | | 1 | * | 0 | 0 | 0x02 | 000 | r | 0 | | | 1 0x01 | 1 0 | 1 | * 0 | 0 | | 0 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | 0 | 1 x | 0 | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie: | <del></del> | | State 2 Selected | Valid Instructions | | 0 | 0 * | 0 | 1 0 | 0.00 | * | | _ | 0 | 0 | 0 0 | 0 0x00 | 0 | 1 x | 0 | | 1 | 1 1 | O<br>Y | U<br>n | 0x00 | 000<br>001 | W | 0 | 0 | ° . | 1 0x01<br>2 o | 1 0 | 1 0 | * ° | 0 | | | 1 * | ^ | | 1 | | | | | | <u>-1 </u> | 1-1 × | <u> </u> | <u> </u> | <u>_</u> | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie: | Store Queue Entrie | s Solved Loads | State 2 Selected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0x00 | 0 0 | 1 | * 0 | 0 | | 1 | * | 0 | 0 | 0x02 | 000 | r | 0 | 0 | ۰ . | 1 0x01 | 1 0 | 1 | * 0 | 0 | | 0 | 1 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | 0 | 1 x | 0 | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie | Store Queue Entrie | s Solved Loads | State 2 Selected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | | | 0 | . 0 | 0 0x00 | 0 0x00 | 1 | * 0 | 0 | | 0 | 0 | 0 | 1 | 0x01 | * | r | х | 0 | 0 | 1 0 | 1 0 | 0 | 1 x | 0 | | 0 | * | 0 | 0 | | 011 | | | 0 | 0 | 2 0 | 2 o | 0 | * 0 | 0 | | | | | | | | | | | | | | | | | | Calmad Lands | C+-+- 1 | Calamad | Malial Instructions | Nov. Hand Bainton | (New) Bessible Demondensies Vester | Band / Muita EBE | Uia in EDE | I Famurandad | Danaudana Batastian I | Lond Ougus Entries | Store Oueue Entrie | c Cabined Lands | State 2 Calcated | Malia Instructions | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | <del> </del> | Dependence Detection | Load Queue Entrie | <del>+</del> | | State 2 Selected | Valid Instructions | | Solved Loads<br>0<br>0 | 9 State 1 0 1 | Selected<br>o<br>x | Valid Instructions 1 0 | New Head Pointer | (Non) Possible Dependencies Vector * 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection 0 0 | | Store Queue Entrie | Solved Loads 0 1 | State 2 Selected 1 x * 0 | Valid Instructions 0 0 | | 0 | 0 | 0 | Valid Instructions 1 0 0 | | * | | | 0 | 0 | 0 0 | 0 0x00 | 0 | 1 x | 0 | | 0<br>0<br>0 | 0<br>1<br>* | 0<br>X<br>0 | 1<br>0<br>0 | 0x00 | *<br>000<br>011 | r | х | o<br>o<br>o | 0 | 0 0<br>1 0x01<br>2 0 | 0 0x00<br>1 0<br>2 0 | 0<br>1<br>0 | 1 x v v v v v v v v v v v v v v v v v v | 0<br>0<br>0 | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | 0 | 1<br>0<br>0<br>Valid Instructions | | *<br>000<br>011<br>(Non) Possible Dependencies Vector | | | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0<br>1 0x01<br>2 0 | 0 0x00<br>1 0<br>2 0 | 0<br>1<br>0 | 1 | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br><b>Solved Loads</b> | 0<br>1<br>* | Selected | 1<br>0<br>0<br>Valid Instructions | 0x00 | *<br>000<br>011 | Read / Write EBF | X<br>Hit in EBF | O<br>O<br>O<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0x01 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00<br>1 0<br>2 0 | 0<br>1<br>0 | 1 | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | 0<br>X<br>0 | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 000 011 (Non) Possible Dependencies Vector 000 * | r | х | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0<br>1 0x01<br>2 0 | 0 0x00<br>1 0<br>2 0 | 0<br>1<br>0 | 1 | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | 0<br>1<br>* | Selected | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 000 011 (Non) Possible Dependencies Vector 000 | Read / Write EBF | X<br>Hit in EBF | Forwarded | Dependence Detection | 0 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 | 0 0x00<br>1 0<br>2 0<br>Store Queue Entrie | 0<br>1<br>0<br><b>Solved Loads</b><br>1<br>0 | 1 | 0<br>0<br>0<br><b>Valid Instructions</b><br>0 | | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected X 0 | 1<br>0<br>0<br><b>Valid Instructions</b><br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 000 011 (Non) Possible Dependencies Vector 000 * 011 | Read / Write EBF | Hit in EBF | Forwarded 0 0 | Dependence Detection | 0 0x01<br>2 0<br>Load Queue Entrie:<br>0 0x00<br>1 0<br>2 0 | 0 0x00 1 0 2 0 Store Queue Entrie 0 0x00 1 0 2 0 | 5 Solved Loads 1 0 0 1 0 0 0 0 | 1 | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | Solved Loads 0 0 0 0 Solved Loads | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected X 0 0 Selected | 1<br>0<br>0<br><b>Valid Instructions</b><br>0<br>1<br>0 | 0x00 | * 000 011 (Non) Possible Dependencies Vector 000 * 011 | Read / Write EBF | Hit in EBF | Forwarded 0 0 0 Forwarded Forwarded | Dependence Detection O O O Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entrie 0 0x00 1 0 2 0 | Solved Loads 1 0 0 5 Solved Loads 0 0 0 Solved Loads | 1 | 0<br>0<br>0<br>Valid Instructions<br>0<br>0 | | Solved Loads Solved Loads | 0 | Selected X 0 Selected | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * 011 (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O Dependence Detection O O O | 0 0 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entrie 0 0x00 1 0 2 0 Store Queue Entrie 0 0 0x00 | 5 Solved Loads 1 0 0 5 Solved Loads 1 0 0 1 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads 0 0 0 0 Solved Loads | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected X 0 0 Selected | 1<br>0<br>0<br><b>Valid Instructions</b><br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 000 011 (Non) Possible Dependencies Vector 000 * 011 | Read / Write EBF | Hit in EBF | Forwarded 0 0 0 Forwarded Forwarded | Dependence Detection O O O Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entrie 0 0x00 1 0 2 0 | Solved Loads 1 0 0 5 Solved Loads 0 0 0 Solved Loads | 1 | 0<br>0<br>0<br>Valid Instructions<br>0<br>0 | | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0<br><b>Solved Loads</b> | 0 1 * State 1 1 1 * State 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Selected X 0 Selected | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O Dependence Detection O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0x00 1 0 2 0 Store Queue Entrie 0 0x00 1 0 2 0 | Solved Loads 1 0 5 Solved Loads 1 0 0 1 1 1 1 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0<br><b>Solved Loads</b> | 0 1 * State 1 1 1 * State 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Selected X O O Selected X O O O | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded O O Forwarded O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | 0 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | O O O O O O O O O O | State 1 | Selected X O O Selected X O O O | Valid Instructions O Valid Instructions O 1 0 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O Forwarded O O O O O O O O O O O O O | Dependence Detection O O Dependence Detection O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions O Valid Instructions O O Valid Instructions O O Valid Instructions | | O | State 1 | Selected X O O Selected X O O Selected Selected | Valid Instructions Valid Instructions Valid Instructions 0 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection Dependence Detection Dependence Detection Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | O O O O O O O O O O | State 1 | Selected Selected Selected Selected | Valid Instructions O Valid Instructions O 1 0 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | 0 | 1 | Valid Instructions O Valid Instructions O O Valid Instructions O O Valid Instructions | | O | State 1 | Selected Selected Selected Selected | Valid Instructions O Valid Instructions O 1 0 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection Dependence Detection Dependence Detection Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | O | State 1 | Selected Selected Selected Selected | Valid Instructions O Valid Instructions O 1 0 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection Dependence Detection Dependence Detection Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | O O O O O O O O O O | State 1 | Selected X O O Selected X O O Selected X O O X O O | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O Valid Instructions | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 1 2 0 0 1 2 0 0 1 2 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions O O Valid Instructions O O Valid Instructions O O Valid Instructions O O Valid Instructions O O | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected O X O Selected | Valid Instructions O 1 0 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | O O O O O O O O O O | State 1 | Selected X O O Selected X O O Selected Selected O X O O Selected O X O O Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O Valid Instructions | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 1 2 0 0 1 2 0 0 1 2 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected X O X O Selected X O X O X O X O X O X O X O X O X O X | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | State 2 Selected | Valid Instructions O O O O O O Valid Instructions O O O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected X O X O Selected X O X O X O X O X O X O X O X O X O X | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O Valid Instructions | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | 1 | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected X O X O Selected X O X O X O X O X O X O X O X O X O X | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | 0 | State 2 Selected | Valid Instructions O O O O Valid Instructions O O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected Selected Selected X O X O Selected X O X Selected X Selected X Selected X Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | O | State 2 Selected | Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected Selected Selected Selected X O X O Selected X O X Selected X Selected X Selected X Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | O | State 2 Selected | Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected O X O O Selected | 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | O | State 2 Selected | Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected O X O O Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | O | State 2 Selected | Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions I O Valid Instructions Valid Instructions Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entrie | O | State 2 Selected | Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O 1 O Valid Instructions O 1 Valid Instructions O 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions O Valid Instructions O Valid Instructions O O | New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF Read / Write EBF Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entrie | O | State 2 Selected * | Valid Instructions O O O O O O O O O O O O O O O O O O | Appendix-B Memory Disambiguation Test: LLS (Load-Load-Store) | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 001 (Non) Possible Dependencies Vector 000 000 000 000 000 000 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 1 | Sto | ore Queue Entries 0x00 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------|-----------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------| | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 000 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF | Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc | ore Queue Entries 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 001 (Non) Possible Dependencies Vector 000 001 001 | Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc 0 1 2 | ore Queue Entries Ox00 O O O O O O O O O O O O | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 | | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 001 | Read / Write EBF Read / Write EBF | Hit in EBF x Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc 0 1 2 | ore Queue Entries Ox00 O O O O O O O O O O O O | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 1 | | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 001 | Read / Write EBF Read / Write EBF | Hit in EBF x Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc 0 1 2 | ore Queue Entries Ox00 O O O O O O O O O O O O | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 1 | | (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 | Read / Write EBF Read / Write EBF | Hit in EBF x Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc 0 1 2 | ore Queue Entries Ox00 O O O O O O O O O O O O | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc | ore Queue Entries Ox00 O O O O O O O O O O O O | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue Entries | Stc | ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 | | 000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>001 | Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded O O O | Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue Entries | 9tc 0 1 2 | ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 | Solved Loads 1 1 0 Solved Loads 1 1 | | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 | Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O O O O Dependence Detection O | Load Queue Entries | Stc 0 1 2 | 0x00<br>0<br>0<br>0 | Solved Loads 1 1 0 Solved Loads | | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded | Dependence Detection O O O Dependence Detection | Load Queue Entries | 9tc 0 1 2 | 0x00<br>0x00<br>0<br>0 | Solved Loads 1 1 0 Solved Loads | | 000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000 | Read / Write EBF | Hit in EBF | Forwarded 0 0 | Dependence Detection O O O | Load Queue Entries | 9tc | ore Queue Entries 0x00 0 | Solved Loads 1 1 0 | | 000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | Hit in EBF | Forwarded 0 | Dependence Detection | 2 0 Load Queue Entries 0 0x00 1 0x01 | 2 Sto | ore Queue Entries 0x00 | Solved Loads 1 1 | | 000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | Hit in EBF | Forwarded 0 | Dependence Detection | 2 0 Load Queue Entries 0 0x00 1 0x01 | 2 Sto | ore Queue Entries 0x00 | Solved Loads 1 1 | | 000<br>000<br>(Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | 2 0 Load Queue Entries 0 0x00 1 0x01 | 2 Sto | ore Queue Entries | Solved Loads | | 000<br>000<br>(Non) Possible Dependencies Vector | | | o<br>Forwarded | O Dependence Detection | 2 o Load Queue Entries | 2<br>Sto | ore Queue Entries | Solved Loads | | 000<br>000 | | | 0 | О | 2 0 | 2 | | | | 000 | W | 0 | | | <del></del> | - | 0 | 0 | | 000 | w | 0 | | | <del></del> | - | | | | | | | | | | | 0 | 1 | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | | — | ore Queue Entries | Solved Loads | | | | | | | | | | | | 011 | | | Ü | U U | <u> </u> | - | U | U | | 000<br>011 | r | х | 0 | 0 | 1 0x01<br>2 o | 2 | 0 | 1<br>0 | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | - | ore Queue Entries | Solved Loads | | | | | | | | _ | | | | 011 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | | 000 | r | х | 0 | 0 | 1 0x01 | 1 | 0 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | Load Queue Entries 0 0x00 | 0 | ore Queue Entries | Solved Loads | | (Non) Bessible Dependenting Vest | Pand / Martin | Uie in EBE | Farmeded | Danandanas Data atia | Load Oueue Entries | Cu- | ora Ouava Entrica I | Calmad Lands | | 011 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | | 000 | r | х | 0 | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | | | | | | | | | | | 000 | | | 0 | 0 | 2 0 | | 0 | U | | 000 | W | 0 | 0 | 0 | 1 0x01<br>2 o | 2 | 0 | 1<br>0 | | 000 | | | 0 | 0 | 0 0x00 | | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | - | ore Queue Entries | Solved Loads | | | | | | | | | | | | 000 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | | 001 | r | х | | 0 | 0x01 | 1 | 0.000 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection o | Load Queue Entries 0 0x00 | 0 | ore Queue Entries | Solved Loads | | (Non) Bessible Dansudansias Vestar | Pand / With EDS | Uis in EDF | Engage and a d | Denondone - Detection | Load Ouerra Entries | | ore Oueue Entries | Caluad I de | | 000 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | | 000 | w | 0 | 0 | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | re Queue Entries | Solved Loads | | | | | | | | | | | | 000 | | | 0 | 0 | 2 0 | 2 | 0 | 0 | | 000 | w | 0 | 0 | 0 | 1 0x01 | 1 | 0 | 1 | | 000 | | | 0 | | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | UUU | ı | l | 0 | 0 | 2 0 | 1 4 | 0 | U | | 000<br>000 | r | Х | 0 | 0 | 1 0x01<br>2 o | 2 | 0 | 1<br>0 | | 000 | | | 0 | 0 | 0 0x00 | 0 | 0x00 | 1 | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Sto | ore Queue Entries | Solved Loads | | | | | | <u> </u> | | | | <del>-</del> | | 000 | ** | Ů | o | 0 | 2 0 | 2 | 0 | 0 | | | w | 0 | | | — | - | | 1 | | | Kead / Write Cor | HITINEBE | | | | - | | 1 | | (Nan) Bassible Dependencies Vester | Pand / Write EBE | Wit in ERE | Forwarded | Dependence Detection | Load Queue Entries | I Sto | re Oueue Entries | Solved Loads | | (No | on) Possible Dependencies Vector 000 000 | 000 | 000 | 000 0 | 000 0 | 000 0 0 000 | 000 | 000 0 0 000 0 000 | Appendix-B Memory Disambiguation Test: SSS (Store-Store-Store) | | | | | | I a a | | | I | (N. 15 H. 5 H. 1 H. 1 H. 1 | | | | | I | 10.0.5. | |----------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------|-------------------------------| | | Position<br>0 | Instructions<br>SD | L / S Queue Allocation<br>0x00 | Valid Instructions | State U | Selected | Valid Instructions 0 | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | ies Store Queue Entri 0 0x00 | | | 1 | SD | 0x00<br>0x01 | 1 | 0 | × | 1 | 0x01 | * | w | o | 0 | 0 | | 1 0,000 | | | 2 | SD | 0x02 | 1 | l ő | | 1 | 1 | * | " | Ŭ | Ö | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | _ | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entri | | 0 H | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0 | 0 0x00 | | PATH | 1 | SD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | w | o | 0 | 0 | 1 0 | 1 o | | | 2 | SD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | <del></del> | | | 0 | SD<br>SD | 0x00<br>0x01 | 1 | 0 | x<br>o | 0<br>1 | 0×01 | 000<br>* | w | o | ° | 0 | 0 0 | 0 0x00<br>1 0 | | | 2 | SD | 0x02 | 1 | l ő | | 1 | 0,01 | * | • | | ° | 0 | | 2 0 | | | | 55 | ONUL | - | | | - | | | | | | | | 1-1 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entri | | | 0 | SD | 0x00 | 1 | 0 | ٥ | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | SD | 0x01 | 1 | 1 | x | 0 | 0x00 | 000 | w | 0 | 0 | 0 | 1 0 | 1 0x01 | | | 2 | SD | 0x02 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 o | | | Desition | I In a true at i ama | L / S Queue Allocation | Valid Instructions | I stata o | Calantad I | Valid Instructions | Nove Hood Dainton | (Non) Possible Dependencies Vester | Dood / Write EDE | Littin EDE | Commonded | Dependence Detection | Load Queue Entri | ies Store Queue Entri | | 11 | Position<br>0 | Instructions<br>SD | 0x00 | Valid Instructions | State 0 | Selected<br>o | Valid instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>o | о о | 0 o | 0 0 | | ¥ | 1 | SD | 0x01 | 1 | 1 | × | 0 | 0x00 | 000 | w | o | | 0 | 1 0 | 1 0x01 | | <u> </u> | 2 | SD | 0x02 | 1 | 0 | 0 | 1 | | ж | | | 0 | o | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entri | | | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 2 | SD<br>SD | 0x01<br>0x02 | 1<br>1 | 1 0 | × | 0<br>1 | 0x00 | 000<br>* | w | 0 | 0 | 0 | 2 0 | 1 0x01 0 | | | | 30 | 0,02 | <u> </u> | | | | | | | | 0 | | <u> </u> | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entri | | | 0 | SD | 0x00 | 1 | 0 | ٥ | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | SD | 0x01 | 1 | 0 | 0 | 1 | 0x00 | * | w | 0 | 0 | o | 1 0 | 1 0 | | | 2 | SD | 0x02 | 1 | 1 | × | 0 | | 000 | | | l 0 | o | <b>1</b> 2 <b>1</b> 0 | 2 0x02 | | | | | | | | | | | | | | | | | 1 - 1 | | | n | | L / C | 16 11 1 11 | I s a | 161.11 | 16 P. L | | (N ) D 11 D 1 1 1 1 1 | D 1/14/11 EDE | 100 - 505 | | | Land Ourse Enter | | | 1.2 | Position 0 | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entr | ies Store Queue Entri | | | Position 0 1 | SD | 0x00 | Valid Instructions 1 1 | State 0<br>0<br>0 | ۰ | Valid Instructions 1 1 | | (Non) Possible Dependencies Vector * * | | Hit in EBF | ٥ | 0 | 0 0 | ies Store Queue Entri | | PATH 2 | 0 | | | 1 | 0 | | 1 | New Head Pointer | (Non) Possible Dependencies Vector * * 000 | Read / Write EBF | | <del> </del> | • | 0 0 | ies Store Queue Entri | | | 0<br>1 | SD<br>SD | 0x00<br>0x01 | 1<br>1 | 0 | ۰ | 1<br>1 | | * | | | o<br>0 | 0 | 0 0 | ies Store Queue Entri 0 0 1 0 | | | 0<br>1 | SD<br>SD<br>SD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation | 1<br>1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x | 1<br>1<br>0<br>Valid Instructions | | * | | | o<br>0 | 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri<br> 0 | | | 0<br>1<br>2<br>Position | SD<br>SD<br>SD<br>Instructions | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | *<br>*<br>000 | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0 0 0 1 0 2 0 0 1 1 0 0 0 1 1 0 0 0 1 1 1 1 | Store Queue Entri<br> 0 | | | 0<br>1<br>2<br>Position<br>0<br>1 | SD<br>SD<br>SD<br>Instructions<br>SD<br>SD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 | * * 000 (Non) Possible Dependencies Vector * * | W | o | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri<br> 0 | | | 0<br>1<br>2<br>Position | SD<br>SD<br>SD<br>Instructions | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | *<br>*<br>000 | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0 0 0 1 0 2 0 0 1 1 0 0 0 1 1 0 0 0 1 1 1 1 | Store Queue Entri<br> 0 | | | 0<br>1<br>2<br>Position<br>0<br>1 | SD<br>SD<br>SD<br>Instructions<br>SD<br>SD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 | * * 000 (Non) Possible Dependencies Vector * * | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri<br> 0 | | | 0<br>1<br>2<br>Position<br>0<br>1 | SD<br>SD<br>SD<br>Instructions<br>SD<br>SD | 0x00<br>0x01<br>0x02<br>L/S Queue Allocation<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 | * * * * * * * * * * * * * * * * * * * | W<br>Read / Write EBF | O<br>Hit in EBF<br>O | o<br>o<br>o<br>Forwarded<br>o<br>o | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri | | | 0 1 2 Position 0 1 2 Position 0 0 0 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 0 1 1 State 0 0 0 1 1 State 0 1 | Selected O X | Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 New Head Pointer | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | o Hit in EBF o Hit in EBF | o<br>o<br>o<br>Forwarded<br>o<br>o | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri | | РАТН | O | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected V Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | W Read / Write EBF | O<br>Hit in EBF<br>O | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entri O | Store Queue Entri | | 3 РАТН | 0 1 2 Position 0 1 2 Position 0 0 0 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 0 1 1 State 0 0 0 1 1 State 0 1 | Selected O X Selected O X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 New Head Pointer | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | o Hit in EBF o Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Store Queue Entri | | РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O O X Selected O O O X Selected O O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 3 РАТН | O | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected V Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | 0x00 New Head Pointer 0x00 New Head Pointer | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entri O | Store Queue Entri | | 3 РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 State 0 | Selected O O X Selected Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O Dependence Detection O O O O O O Dependence Detection | Load Queue Entri 0 | Store Queue Entri | | 3 РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x01 0x00 0x01 L/S Queue Allocation 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 O State 0 1 O O O O O O O O O | Selected Selected Selected X Selected X Selected X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 0 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entri O | Store Queue Entri | | 3 РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O O O O O O O O | Selected Selected X Selected X O Selected X O Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 3 РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 | Selected O O X Selected X O O Selected X O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 3 РАТН | Position 0 | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 | O O 1 | Selected Selected X Selected X O Selected X O Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 3 РАТН | Position | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 | Selected O O X Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position | SD S | 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x01 0x02 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected O O X Selected X O O Selected X O O Selected X O O Selected X O O O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position 0 | SD S | 0x00 0x01 0x02 L / S Queue Allocation 0x00 0x01 0x02 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | РАТН 3 | Position 0 | Instructions SD | 0x00 0x01 0x02 L / S Queue Allocation 0x00 0x01 0x02 L / S Queue Allocation 0x00 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 L / S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position 0 | Instructions SD | 0x00 0x01 0x02 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 0 1 | Selected X Selected X O O Selected X O O Selected X O O Selected O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position 0 | Instructions SD SD SD SD Instructions SD SD SD SD SD SD SD Instructions SD SD SD SD SD Instructions | 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position 0 | Instructions SD | 0x00 0x01 0x02 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 0 1 | Selected X Selected X O O X N Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 4 PATH 3 PATH | Position 0 | Instructions SD | 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 0 1 | Selected X Selected X O O X N Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | РАТН 4 РАТН 3 | Position 0 | Instructions SD | 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 0 1 1 | Selected X Selected X O O X N Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | 5 РАТН 4 РАТН 3 РАТН | Position 0 | Instructions SD | Dx00 Dx01 Dx02 Dx02 Dx02 Dx02 Dx00 | 1 | State 0 0 1 1 | Selected X Selected X O O | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | | РАТН 4 РАТН 3 | Position 0 | Instructions SD | 0x00 | 1 | State 0 0 1 1 | Selected X Selected X O O O Selected X O O O Selected X O O Selected O X O O Selected O X O O Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected O X Selected O X Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entri | Appendix-B Memory Disambiguation Test: SSS (Store-Store-Store) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | |---------------------------------------------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------| | 0 | * | 0 | 0 | | 000 | , | | 0 | 0 | | | 0 0x00 | 0 | * | 0 | 0 | | 0 | 1 | x | 0 | 0x01 | 000<br>* | w | ٥ | 0 | 0 | | - | 1 0x01 | 0 | * | 0 | 0 | | 0 | 0 | 0 | 1 | | ··· | | | 0 | 0 | 2 | 0 | 2 0 | 0 | 1 1 | x | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 | * | ٥ | 0 | 0.01 | 000 | | | 0 | 0 | | ۰ | 0 0x00 | 0 | * | 0 | 0 | | 0 | 0 | o | 0 | 0x01 | 000 | w | 0 | 0 | 0 | _ | ° - | 1 o<br>0x02 | 0 | * | × | 0 | | | | | | | • | | | | Ţ | | | - 0.02 | , , , | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 0 | * | 0<br>v | 0 | 0x02 | 000<br>000 | w | 0 | 0 | 0 | | ° - | 0 0x00<br>1 0x01 | 0 | * | 0 | 0 | | 0 | 1 | ô | 1 | 0,02 | * | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | 0 | 0 | | · F | 2 0 | o o | 1 | × | 0 | | | | | | | | | | | | | | • | | | • | | | | 10 | | ) ( 1 1 1 1 1 1 1 1 1 | I w | (1) \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | L n . 1/14/11 Enc | Luni ene | | | 110 | - F T | Store Orono Entrino | | In ala | | 37 li 11 | | Solved Loads | State 1 | Selected<br>× | Valid Instructions 0 | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection<br>o | Load Queu<br>0 | o Entries | Store Queue Entries 0 0x00 | Solved Loads<br>0 | State 2 Se | elected<br>o | Valid Instructions 0 | | 0 | * | 0 | 0 | 0x02 | 000 | w | 0 | 0 | 0 | | _ | 1 0x01 | 0 | * | 0 | 0 | | 0 | 0 | 0 | 1 | | * | | | o | o | 2 | 0 | 2 o | 0 | 1 | х | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 | 0 | o | 1 | izew neau romiter | * | Read / WIILE EDF | I III LIII LIBF | o | o Dependence Detection | . 1 | o | 0 o | 0 | 1 | × | 0 | | 0 | * | 0 | 0 | 0x00 | 000 | w | 0 | o | ٥ | 1 | • | 1 0x01 | 0 | * | 0 | 0 | | 0 | 1 | х | 0 | | 000 | | | 0 | 0 | 2 | 0 | 2 0x02 | 0 | * | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | | | О | . 0 | 0 | 0 | 0 0x00 | 0 | * | 0 | 0 | | 0 | * | ٥ | 0 | 0x02 | 000 | w | 0 | o | 0 | _ | ٥ | 1 0x01 | 0 | * | 0 | 0 | | 0 | 1 | ٥ | 1 | | <u> </u> | | | 0 | 0 | 2 | 0 | 2 0 | 0 | 1 | х | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 | 1 | × | 0<br>1 | 0×01 | 000<br>* | | | 0 | 0 | | ° | 0 0x00<br>1 0 | 0 | * | 0 | 0 | | 0 | 0<br>* | 0 | 0 | 0x01 | 000 | w | ٥ | 0 | 0 | _ | ° - | 1 o<br>0x02 | 0 | * | x<br>o | 0 | | | • | | - | | | ! | | | | | | | - | | | - | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queu | | Store Queue Entries | Solved Loads | State 2 Se | elected | Valid Instructions | | 0 0 | 0 1 | ° | 1 | 0x00 | * 000 | w | | 0 | 0 | | ° - | 0<br>1 0x01 | 0 | 1 * | ×<br>o | 0 | | 0 | * | 0 | 0 | | 000 | | | 0 | 0 | _ | _ F | 2 0x02 | 0 | * | 0 | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads<br>0 | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection<br>o | Load Queu | e Entries | Store Queue Entries 0 0x00 | Solved Loads<br>0 | State 2 Se | elected<br>o | Valid Instructions 0 | | 0 | 1 | ô | 1 | 0x01 | * | w | o | 0 | 0 | _ | ° | 1 0 | o o | 1 | x | 0 | | 0 | * | 0 | 0 | | 000 | | | o | 0 | 2 | 0 | 2 0x02 | 0 | * | 0 | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | | | | | | | | Valid Instructions | | 0 | * | <del></del> | | | , ,p | | | | Dependence Detection | Load Queu | e Entries | Store Queue Entries | Solved Loads | State 2 Se | elected I | vallu ilisu uctions i | | 1 | | ° | 0 | | 000 | | | o | Dependence Detection<br>o | - | | O 0x00 | Solved Loads 0 | State 2 Se | o | 0 | | 0 | 1 | x | 0 | 0x02 | 000<br>000<br>* | w | o | o<br>o | 0 | 0 1 | 0 | 0 0x00<br>1 0x01 | 0<br>0 | State 2 Se | 0 | 0<br>0 | | 0<br>0 | 1<br>0 | l I | 0<br>0<br>1 | 0x02 | | W | | o | 0 | 0 1 | 0 | 0 0x00 | 0 | State 2 Se | 0 | 0 | | | 1<br>0<br>State 1 | x<br>o | 0<br>0<br>1<br>Valid Instructions | 0x02 | | w<br>Read / Write EBF | o | o<br>o | 0 | 0 1 | o<br>o | 0 0x00<br>1 0x01 | 0<br>0 | *<br>*<br>1 | 0 | 0<br>0 | | Solved Loads | State 1 | x<br>o | 0<br>1 | New Head Pointer | 000<br>*<br>(Non) Possible Dependencies Vector<br>000 | Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2<br>Load Queu | o<br>o<br>o<br>e Entries | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00 | 0<br>0<br>0<br>Solved Loads | *<br>*<br>1 | o<br>o<br>x<br>elected | 0<br>0<br>0<br>Valid Instructions | | 0<br>Solved Loads | 0 | x<br>o<br>Selected | 0<br>1 | | 000<br>*<br>(Non) Possible Dependencies Vector | | o | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>Load Queu<br>0<br>1 | o<br>o<br>e Entries | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01 | 0<br>0<br>0 | *<br>*<br>1 | o<br>o<br>x | 0<br>0<br>0<br>Valid Instructions | | Solved Loads 0 0 | State 1 | Selected O x | 0<br>1 | New Head Pointer | 000<br>*<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2<br>Load Queu<br>0<br>1 | e Entries | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00 | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | *<br>*<br>1 | o<br>o<br>x<br>elected<br>o | 0<br>0<br>0<br><b>Valid Instructions</b><br>0 | | Solved Loads 0 0 0 | 0<br> State 1<br> *<br> 1 | Selected O X O | Valid Instructions 0 0 1 | New Head Pointer<br>0x02 | 000<br>*<br>(Non) Possible Dependencies Vector<br>000<br>000<br>* | Read / Write EBF | O Hit in EBF | o<br>o<br>o<br>Forwarded<br>o<br>o | Dependence Detection o o | 0<br>1<br>2<br>Load Queu<br>0<br>1 | e Entries | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01<br>2 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | ** 1 State 2 Se* * 1 | o o x | 0<br>0<br>0<br>Valid Instructions<br>0<br>0 | | Solved Loads 0 0 | State 1 | Selected O X O | 0<br>1 | New Head Pointer | 000<br>*<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | O Hit in EBF | o<br>o<br>o<br>Forwarded<br>o<br>o<br>o | Dependence Detection O O Dependence Detection | Load Queu Load Queu Load Queu | e Entries o o | 0 0x00 1 0x01 2 0 Store Queue Entries 0 0x00 1 0x01 2 0 Store Queue Entries | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | ** 1 State 2 Se* * 1 | o o x elected o o x | 0<br>0<br>0<br><b>Valid Instructions</b><br>0 | | Solved Loads 0 0 0 0 Solved Loads | 0 | Selected O X O | Valid Instructions 0 0 1 Valid Instructions | New Head Pointer<br>0x02 | 000<br>*<br>(Non) Possible Dependencies Vector<br>000<br>000<br>* | Read / Write EBF | O Hit in EBF | o<br>o<br>o<br>Forwarded<br>o<br>o | Dependence Detection o o | Load Queu 0 1 2 Load Queu 0 1 2 | e Entries o o e Entries o o | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01<br>2 0 | 0<br>0<br>0<br>Solved Loads<br>0<br>0 | State 2 Se | o o x | 0<br>0<br>0<br>Valid Instructions<br>0<br>0 | | Solved Loads 0 0 0 0 Solved Loads | 0 | Selected O X O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 1 Valid Instructions 1 | New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O Dependence Detection O O O O O | 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 1 | e Entries o o e Entries o o | 0 | O O O O O O O O O O O O O O O O O O O | State 2 Se | elected o x elected x elected x | 0<br>0<br>0<br>Valid Instructions<br>0<br>0<br>0 | | Solved Loads 0 0 0 0 Solved Loads 0 0 0 0 | State 1 | Selected O X O Selected O X X X X X X X X X X X X X X X X X X | Valid Instructions 0 0 1 Valid Instructions 1 0 0 0 0 1 | New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu<br> 0 | e Entries c c c c c c c c c c c c c c c c c c | 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | * * 1 State 2 Se * * 1 State 2 Se 1 * * * * 1 | elected o x elected x o o x | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 | | Solved Loads 0 0 0 0 Solved Loads 0 0 0 | 0 | Selected O X O Selected O X X X X X X X X X X X X X X X X X X | Valid Instructions 0 0 1 Valid Instructions 1 0 | New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu Load Queu Load Queu Load Queu Load Queu Load Queu | e Entries c c c e Entries c c c c c c c c c c c c c c c c c c c | 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0<br><b>Solved Loads</b> | * * 1 | elected x elected x c | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads 0 0 0 0 Solved Loads 0 0 0 Solved Loads 0 0 0 | State 1 | Selected O X O Selected O X Selected O X Selected | Valid Instructions 0 0 1 Valid Instructions 1 0 0 Valid Instructions | New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 | e Entries c c c c c c c c c c c c c c c c c c | 0 | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0<br>0 | * * 1 | elected x elected x o x elected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads O O O Solved Loads O O Solved Loads O O O O Solved Loads | State 1 | Selected Selected Selected Selected X Selected X | Valid Instructions 0 0 1 Valid Instructions 1 0 0 0 Valid Instructions 1 0 0 | New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 | e Entries e Entries o o e Entries o o o e Entries | 0 | Solved Loads O Solved Loads O O O Solved Loads O O O O O O O O O O O O O O O O O O | * * 1 | elected x elected x c c c c c c c c c c c c c c c c c | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads 0 0 0 0 Solved Loads 0 0 0 Solved Loads 0 0 0 | State 1 | Selected Selected Selected Selected X Selected X O | Valid Instructions 0 0 1 Valid Instructions 1 0 0 0 Valid Instructions 1 0 0 | New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 | e Entries c c c c c c c c c c c c c c c c c c | 0 | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0<br>0 | * * 1 | elected x elected x c c c c c c c c c c c c c c c c c | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads O O O Solved Loads O O O Solved Loads O O O O O O O O O O O O O O O O O O | State 1 | Selected Selected Selected Selected X Selected X O | Valid Instructions 0 0 1 Valid Instructions 1 0 0 0 Valid Instructions 1 0 0 | New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O Forwarded O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 | e Entries c c c c c c c c c c c c c c c c c c | 0 | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0<br>0 | * | elected x elected x c c c c c c c c c c c c c c c c c | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads O O O Solved Loads O O O Solved Loads O O O Solved Loads O O O O O O O O O O O O O O O O O O | State 1 | Selected O X O Selected O X O Selected O X O O O X O O O O O O O O O O O O | Valid Instructions 0 0 1 Valid Instructions 1 0 0 Valid Instructions 1 0 0 Valid Instructions 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x00 New Head Pointer 0x02 | (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 0 1 | e Entries c c c c c c c c c c c c c c c c c c | 0 | O O O O O O O O O O | * | elected x o o x elected x o o x elected o x o o x | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads O O O Solved Loads O O O Solved Loads O O O Solved Loads O O Solved Loads | State 1 | Selected O X O Selected O X O Selected O O X Selected O O X Selected | Valid Instructions 0 0 1 Valid Instructions 1 0 0 Valid Instructions 1 0 0 1 | New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * 000 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 2 Load Queu 0 1 1 2 | e Entries c c c c c c c c c c c c c c c c c c | 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | * | elected x elected x o x elected x o x elected x o x elected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | Appendix-B Memory Disambiguation Test: SSS (Store-Store-Store) | | (Non) Possible Dependencies Vector<br>000 | | | 0 | Dependence Detection<br>o | 0 | 0 | 0 | 0x00 | 0 | |-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | 0x03 | 000 | w | o | 0 | 0 | 1 | | 1 | 0x01 | 0 | | 0.00 | 000 | " | Ĭ | | 0 | 2 | - | 2 | 0x02 | 0 | | | 660 | | | <u> </u> | Ů | | Ů | | 0,02 | ű | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Li | oad Queue Entries | S+ | ore Queue Entries | Solved Loads | | ivew nead Folliter | 000 | Read / Write EBF | THE III EDI | o | o | 10 | o o | 0 | 0x00 | 0 | | 0x03 | 000 | w | o | | 0 | 1 | - | 1 | 0x01 | 0 | | 0.03 | 000 | " | | | 0 | 2 | - | 2 | 0x02 | 0 | | | 000 | | | 0 | 0 | | 0 | | 0,02 | Ů | | Name that the later of | (Nan) Barrilla Barra dan dan Martan | D1 /24/ | LULE - EDE | l e | D | 1 . | oad Queue Entries | C+ | ore Queue Entries | 6-1 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | | - | | Solved Loads | | 0.00 | 000<br>000 | | _ | 0 | 0 | 1 | 0 | 0 | 0x00 | 0 | | 0x03 | 000 | W | 0 | 0 | 0 | 2 | | 2 | 0x01 | 0 | | | 000 | | | 0 | 0 | | 0 | | 0x02 | 0 | | | | | | | | | | | | | | | (11.) 11.1 1.1 1.1 1.1 1.1 1.1 1.1 1.1 1. | l n 1 () ( ) = n= | | | | | 10 5.11 | <u> </u> | 0 5 | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | oad Queue Entries | | ore Queue Entries | Solved Loads | | 002 | 000 | | _ | 0 | 0 | 0 | 0 | 0 | 0x00 | 0 | | 0x03 | 000 | w | 0 | 0 | 0 | 1 | | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0x02 | 0 | | | (n. ) = n. = 1 | I = 1 tour :: === | | | | | 10 511 | <u></u> | 0 5 | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | oad Queue Entries | | ore Queue Entries | Solved Loads | | 0.00 | 000 | | | ٥ | 0 | 1 | ٥ | 0 | 0x00 | 0 | | 0x03 | 000 | W | 0 | ٥ | 0 | 1 | - | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0x02 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | oad Queue Entries | _ | ore Queue Entries | Solved Loads | | | 000 | | | ٥ | 0 | ╚ | ۰ | 0 | 0x00 | 0 | | 0x03 | 000 | w | 0 | ٥ | 0 | 1 | | 1 | 0x01 | 0 | | | 000 | | | ٥ | 0 | 2 | 0 | 2 | 0x02 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | <u> </u> | oad Queue Entries | | ore Queue Entries | Solved Loads | | | 000 | | | ٥ | 0 | <u> </u> | ٥ | 0 | 0x00 | 0 | | 0x03 | 000 | w | 0 | ٥ | 0 | 1 | ۰ | 1 | 0x01 | 0 | | | 000 | | | 0 | o | 2 | 0 | 2 | 0x02 | 0 | | | | | | | | | | | | | | | | | | | | | | _ | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | L | oad Queue Entries | _ | ore Queue Entries | Solved Loads | | | 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection<br>o | 0 | 0 | 0 | 0x00 | 0 | | New Head Pointer | 000<br>000 | Read / Write EBF | Hit in EBF<br>o | | | 0 | 0 | 0 | 0x00<br>0x01 | 0<br>0 | | | 000 | | | 0 | 0 | 0 | 0 | 0 | 0x00 | 0 | | 0x03 | 000<br>000 | w | | 0 | 0 | 0<br>1<br>2 | o<br>o<br>o | 0<br>1<br>2 | 0x00<br>0x01<br>0x02 | 0<br>0<br>0 | | | 000<br>000<br>000<br>(Non) Possible Dependencies Vector | | | 0 | 0 | 0<br>1<br>2 | 0 | 0<br>1<br>2 | 0x00<br>0x01 | 0<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000 | w | o | o<br>o<br>o | o<br>o<br>o | 0<br>1<br>2 | o<br>o<br>o<br>oad Queue Entries | 0<br>1<br>2<br><b>St</b> | 0x00<br>0x01<br>0x02<br>ore Queue Entries<br>0x00 | 0<br>0<br>0<br><b>Solved Loads</b> | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | w | o | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2<br>Lu<br>0<br>1 | o<br>o<br>o<br>oad Queue Entries<br>o | 0<br>1<br>2<br>St | 0x00<br>0x01<br>0x02<br>ore Queue Entries<br>0x00<br>0x01 | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000 | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | o<br>o<br>o<br>oad Queue Entries<br>o | 0<br>1<br>2<br><b>St</b> | 0x00<br>0x01<br>0x02<br>ore Queue Entries<br>0x00 | 0<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>Lu<br>0<br>1 | o<br>o<br>o<br>oad Queue Entries<br>o | 0<br>1<br>2<br>St | 0x00<br>0x01<br>0x02<br>ore Queue Entries<br>0x00<br>0x01 | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | W Read / Write EBF | O<br>Hit in EBF<br>O | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o | 0<br>1<br>2<br><b>St</b> :<br>0<br>1 | 0x00<br>0x01<br>0x02<br>ore Queue Entries<br>0x00<br>0x01<br>0x02 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000 | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>Str<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | o Hit in EBF o Hit in EBF | o<br>o<br>o<br>Forwarded<br>o<br>o | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | W Read / Write EBF | O<br>Hit in EBF<br>O | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | o Hit in EBF o Hit in EBF | Forwarded O O Forwarded O O O | Dependence Detection O O Dependence Detection O O O | 0<br>1<br>2<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 | O O O O O O O O O O O O O O O O O O O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>Solved Loads<br>0<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | o Hit in EBF o Hit in EBF | Forwarded O Forwarded O Forwarded O Forwarded | Dependence Detection O O O O O O O Dependence Detection O O O O Dependence Detection | Lu 0 1 2 Lu 0 1 2 Lu 1 2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 Ld 0 1 2 Ld | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>0<br>Solved Loads<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 1 1 1 1 1 1 1 1 1 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 Ld 0 1 2 Ld | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>0<br>Solved Loads<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 1 1 1 1 1 1 1 1 1 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 Lo 1 2 Lo 1 2 | o o o o o o o o o o o o o o o o o o o | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 0 1 2 Lu 0 0 0 1 2 Lu 0 0 0 1 2 Lu 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | o o o o o o o o o o o o o o o o o o o | St St O 1 2 St O 1 2 St O 1 2 St O C St O O C St O O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo O 1 2 Lo O 1 2 Lo O 1 2 Lo O 1 2 Lo O 1 2 Lo O 1 2 Co D The state of | o o o o o o o o o o o o o o o o o o o | O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | O O O O O O O O O O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 1 2 Lu 0 0 1 2 Lu 0 0 0 1 2 Lu 0 0 0 1 2 Lu 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | o o o o o o o o o o o o o o o o o o o | St St O 1 2 St O 1 2 St O 1 2 St O C St O O C St O O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Li 0 1 2 2 Li 0 1 2 2 Li 0 1 2 2 Li 0 1 2 2 Li 0 1 2 2 Li 0 1 2 2 Constant Con | o o o o o o o o o o o o o o o o o o o | St St O 1 2 O 1 2 O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 2 0 1 2 2 | o o o o o o o o o o o o o o o o o o o | O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | O | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 0 1 2 Ld 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | o o o o o o o o o o o o o o o o o o o | St St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | o o o o o o o o o o o o o o o o o o o | St St O 1 2 1 St O 1 1 St O 1 St O 1 O D O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 1 2 Ld 0 0 1 2 Ld 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | o o o o o o o o o o o o o o o o o o o | St St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | o o o o o o o o o o o o o o o o o o o | St St O 1 2 1 St O 1 1 St O 1 St O 1 O D O O O O O O O O | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | L | o o o o o o o o o o o o o o o o o o o | St O 1 2 D D D D D D D D D | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | L C C C C C C C C C | o o o o o o o o o o o o o o o o o o o | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St St St St St St S | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu | o o o o o o o o o o o o o o o o o o o | St St St St St St St St | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo O 1 2 1 2 Co D 1 1 Co D 1 1 Co D 1 1 Co D 1 1 Co D 1 1 Co D 1 Co D 1 Co D 1 Co D 1 Co D 1 Co D D 1 Co D 1 Co D D 1 Co D D 1 Co D D D Co D D D D D D D D D | o o o o o o o o o o o o o o o o o o o | St St St St St St St St | 0x00 0x01 0x02 ore Queue Entries | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lu | o o o o o o o o o o o o o o o o o o o | St St St St St St St St | 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 ore Queue Entries 0x00 0x01 0x02 | Solved Loads | Appendix-B Memory Disambiguation Test: LSS (Load-Store-Store) | | I = | T | | I v. n. i. ii | 1 | | 37 lt 11 | I a | (2) ) = 11 = 1 + 1/4 | I = 1600 0 === | I | | | | | |----------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------| | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | <del> </del> | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie | 1 . 1 | | | 0 | LD | 0x00 | 1 | 1 1 | × | 0 | | 000<br>* | | | ° | 0 | 0 0x00 | 0 0 | | | 1 | SD | 0x00 | 1 | 0 | ٥ | 1 | 0x01 | * | r | 0 | ° | 0 | 1 0 | <u> 1</u> | | | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 0 | | | | 1 | | | 1 | 1 1 | | 1 | /n 15 dl 5 d 1 d 2 | I = 1707 to === | I | | | l | I s. o | | 0 | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie | 1.1 | | РАТН | 0 | LD | 0x00 | 1 | | × | 0 | | 000<br>* | | | ° | 0 | 0 0x00 | 0 0 | | ≴ | 1 | SD | 0x00 | 1 | 0 | ٥ | 1 | 0x01 | * | r | 0 | ° | 0 | 0 | 0 | | | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | | Ψ | | | ٥ | 0 | 2 o | 2 0 | | | | 1 | | I | 1 | 1 1 | | 1 | (1) 1 | I | I | | | | 1 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | <del>† †</del> | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie | <del> </del> | | | 0 | LD | 0x00 | 1 | | × | 0 | | 000 | | | ° | o | 0 0x00 | 0 0 | | | 1 2 | SD<br>SD | 0x00 | 1 | 0 0 | 0 | 1<br>1 | 0x01 | <br>* | r | 0 | 0 | 0 | 2 0 | | | | | 30 | 0x01 | 1 | , <sub>0</sub> | 0 | 1 | | " | | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entrie | es Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | o | 1 | New rieda i omitei | * | nedd / Winte Ebi | 1110 111 001 | o | 0 | 0 0 | 0 0x00 | | | 1 | SD | 0x00 | 1 | 1 | l × | 0 | 0x00 | 001 | w | o | | o | 1 0 | 1 000 | | | 2 | SD | 0x01 | 1 1 | l . | Ô | 1 | 0.00 | * | . " | " | | ő | 2 0 | 2 0 | | | | 35 | 0,01 | <u> </u> | <u> </u> | | - | | | | | | Ů | <u> </u> | 1-1 - | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | H 1 | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | , | | 0 | 0 | 0 0 | 0 0x00 | | РАТН | 1 | SD | 0x00 | 1 | 1 | × | 0 | 0x00 | 001 | w | o | 0 | 0 | 1 0 | 1 0 | | _ <u>~</u> | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | | • | | | • | | | • | | • | • | | | <u> </u> | | | | Position | Instructions | L/S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0x00 | | | 1 | SD | 0x00 | 1 | 1 | х | 0 | 0x00 | 001 | w | 0 | 0 | o | 1 0 | 1 0 | | | 2 | SD | 0x01 | 1 | 0 | o | 1 | | * | | | 0 | o | 2 0 | 2 0 | | | • | | | | • | • | | • | | • | • | • | | <u> </u> | | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | | 0 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 | SD | 0x00 | 1 | 0 | 0 | 1 | 0x00 | * | w | 0 | 0 | o | 1 0 | 1 0x01 | | | 2 | SD | 0x01 | 1 | 1 | × | 0 | | 001 | | | 0 | 0 | 2 o | 2 o | | | | | | _ | | | | | | | | | | | | | i | | | | | | | | | | | | | | | | | 7 | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | 표 5 | Position<br>0 | LD | 0x00 | Valid Instructions | State 0 | Selected<br>o | Valid Instructions | | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection<br>o | Load Queue Entrie | 0 0 | | РАТН 2 | 0<br>1 | LD<br>SD | 0x00<br>0x00 | 1<br>1 | + | t | 1<br>1 | New Head Pointer | * | Read / Write EBF | Hit in EBF | <del></del> | · | 0 o<br>1 o | + - 1 | | РАТН 2 | 0 | LD | 0x00 | | 0 | ۰ | 1 | | (Non) Possible Dependencies Vector * * 001 | | | 0 | 0 | 0 0 | 0 0 | | PATH 2 | 0<br>1<br>2 | LD<br>SD<br>SD | 0x00<br>0x00<br>0x01 | 1<br>1<br>1 | 0<br>0<br>1 | о<br>о<br>х | 1<br>1<br>0 | 0×00 | *<br>*<br>001 | w | o | o<br>o<br>o | o<br>o | 0 0 0 1 0 0 2 0 0 | 0 0<br>1 0x01<br>2 0 | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>SD<br>SD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation | 1<br>1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x | 1<br>1<br>0<br>Valid Instructions | | * | | | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0x01 2 0 0 Store Queue Entries | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>SD<br>SD<br>Instructions | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | * * * * * * * * * * * * * * * * * * * | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 1 0 0 0 1 2 0 0 0 0 0 0 0 0 0 | | РАТН 2 | 0<br>1<br>2<br>Position<br>0<br>1 | LD<br>SD<br>SD<br>Instructions<br>LD<br>SD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0×00 | * * 001 (Non) Possible Dependencies Vector * * | w | o | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position | LD<br>SD<br>SD<br>Instructions | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions | 0x00 | * * * * * * * * * * * * * * * * * * * | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 1 0 0 0 1 2 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1 | LD<br>SD<br>SD<br>Instructions<br>LD<br>SD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 | * * 001 (Non) Possible Dependencies Vector * * | W<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1<br>2 | LD<br>SD<br>SD<br>Instructions<br>LD<br>SD<br>SD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0 | Selected O X | 1<br>0<br>Valid Instructions<br>1<br>1 | 0x00 New Head Pointer 0x00 | * * 001 (Non) Possible Dependencies Vector * * 001 | W Read / Write EBF | O<br>Hit in EBF | O<br>O<br>O<br>Forwarded<br>O<br>O | Dependence Detection O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | Position O 1 2 Position O 1 2 | LD SD SD Instructions LD SD SD SD Instructions | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected Selected | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 | * * * * * * * * * * * * * * * * * * * | W Read / Write EBF | O<br>Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O O Dependence Detection | 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | PATH 2 | 0 1 2 Position 0 1 2 Position 0 0 0 0 | LD SD SD Instructions LD SD SD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 | 1 1 1 Valid Instructions 1 1 1 | 0 0 1 1 State 0 0 0 1 1 State 0 1 | Selected O X Selected O X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 New Head Pointer | * * 001 (Non) Possible Dependencies Vector * * 001 | W Read / Write EBF | O Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | 3 РАТН | Position O 1 2 Position O 1 2 | LD SD SD Instructions LD SD SD SD Instructions | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00<br>0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected Selected | 1 1 0 Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | Read / Write EBF | O<br>Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O O Dependence Detection | 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | 3 РАТН | O | LD SD SD Instructions LD SD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected O X Selected X O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | РАТН | O | LD SD SD Instructions LD SD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected O X Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | 3 РАТН | Position 0 1 2 | LD SD SD Instructions LD SD SD SD SD SD SD SD SD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 0 1 1 State 0 0 0 1 1 State 0 1 1 0 0 | Selected O X Selected O X Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | W Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | 0 | | 3 РАТН | O | Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 | Selected O X Selected X Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | W Read / Write EBF W Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | 0 | | 3 РАТН | Position | Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD LD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | 0 | Selected Selected Selected X Selected X Selected X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 0 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | * * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | 0 | | 3 РАТН | Position 0 | Instructions LD SD SD SD Instructions LD SD LD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 1 O O O O O O O | Selected Selected X Selected X O Selected X O Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | 0 | | 3 РАТН | Position 0 | Instructions LD SD SD SD Instructions LD SD LD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 1 O O O O O O O | Selected Selected X Selected X O Selected X O Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | 0 | | 3 РАТН | Position 0 | Instructions LD SD SD SD Instructions LD SD LD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 1 O O O O O O O | Selected O O X Selected X O O Selected X O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 3 РАТН | Position 0 | Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD LD LD SD SD LD LD SD SD LD SD SD LD LD LD SD LD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O O O O O O O O | Selected O O X Selected X O O Selected X O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position | Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O O O O O O O O | Selected O O X Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | 0 | | РАТН 3 | Position 0 | Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD LD LD SD SD LD LD SD SD LD SD SD LD LD LD SD LD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected O O X Selected X O O Selected X O O Selected X O O Selected X O O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | 0 | | РАТН 3 | Position | Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O O Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF r Read / Write EBF w | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 3 РАТН | Position | Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected X Selected X O O Selected X O O Selected X O O Selected O X O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position 0 | Instructions LD SD SD LD SD LD SD LD SD LD SD LD SD LD LD SD LD LD SD LD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected O Selected O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position 0 | Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 | Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected X Selected X O O O Selected X O O O Selected X O O Selected X O X O O Selected X O O O X O O Selected O X O Selected O X O X O O O Selected O X O X O O O Selected O X O X O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 0 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | O | | РАТН 3 | Position 0 | Instructions LD SD SD LD SD LD SD LD SD LD SD LD SD LD LD SD LD LD SD LD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected O Selected O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position 0 | Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 | Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O O Selected X O O O Selected X O O Selected X O X O O Selected X O O O X O O Selected O X O Selected O X O X O O O Selected O X O X O O O Selected O X O X O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 0 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | O | | РАТН 3 | Position 0 | Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O O X Selected X O O O Selected X O O O Selected O X O O O Selected O X O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions 1 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entrie O | O | | S PATH 4 PATH 3 PATH | Position | Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O O Selected X O O O Selected X O O Selected O X O O Selected O X O O Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X O Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | S PATH 4 PATH 3 PATH | Position 0 | Instructions LD SD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O X Selected X O O Selected X | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 4 РАТН 3 | Position | Instructions LD SD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions LD SD SD SD Instructions LD SD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 | State 0 | Selected X Selected X O O O Selected X O O O Selected X O O Selected O X O O Selected O X O O Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X O Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF r Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | Appendix-B Memory Disambiguation Test: LSS (Load-Store-Store) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | |---------------------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 0 | * | 0 | 0 | 0x02 | 000<br>000 | w | o | 0 | o<br>o | 0 ( | 0x00 | 0 0x00 | 1<br>0 | * | 0 | 0<br>0 | | 0 | 0 | x<br>o | 1 | 0.02 | * | W | Ů | o<br>o | 0 | 2 | 0 | 2 0 | 0 | 1 | o<br>x | 0 | | Sahad Laads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ua Entrias | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | Solved Loads 1 | * | o | 0 | New Head Pointer | 000 | Read / Write EBF | HIT IN EBF | o | Dependence Detection<br>o | | 0x00 | 0 o | Solved Loads | * | o | 0 | | 0 | 0 | О | 1 | 0x01 | 000 | w | О | О | o | 1 | 0 | 1 0x01 | 0 | 1 | x | 0 | | 0 | 1 | Х | 0 | | 000 | | | 0 | 0 | 2 | 0 | 2 o | 0 | <u> </u> | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 1 0 | 1 * | o<br>x | 0 | 0x02 | 000<br>000 | l w | o | 0 | o<br>o | 0 1 | 0x00<br>o | 0 0x00<br>1 o | 1<br>0 | * | 0 | 0<br>0 | | 0 | 1 | О | 1 | | * | | | o | o | 2 | - | 2 o | 0 | 1 | х | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | x | 0<br>0 | 0.403 | 000 | | | 0 | 0 | 0 ( | 0x00 | 0 0x00 | 1 | * | 0 | 0 | | 0 | 0 | 0 | 1 | 0x02 | 001<br>* | r | X | 0 | o<br>o | 2 | 0 | 1 o o | 0<br>0 | 1 | o<br>x | 0<br>0 | | | 1 | | | | | | | | | | 1 | | | | | | | Solved Loads<br>0 | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection<br>o | Load Queu | ue Entries<br>o | Store Queue Entries 0 0x00 | Solved Loads<br>0 | State 2 | Selected<br>x | Valid Instructions | | 0 | * | 0 | 0 | 0x00 | 001 | w | o | o | 0 | 1 | 0 | 1 0x01 | 0 | * | 0 | 0 | | 0 | 1 | х | 0 | | 001 | | | О | 0 | 2 | 0 | 2 0 | 0 | * | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | х | 0 | 0x02 | 000 | _ | ,, | 0 | 0 | 0 ( | 0x00 | 0 0x00 | 1<br>0 | * | 0 | 0<br>0 | | 0 | 0 | 0 | 1 | 0x02 | 001<br>* | r | х | 0 | o<br>o | 2 | 0 | 1 o o | 0 | 1 | o<br>x | 0 | | | | | | | | | | | | - | • | | | | • | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | | | 0 | 0 | | | 0 0 | 1 | * | 0 | 0 | | 0 | 0 | 0 | 1 | 0x01 | *<br>001 | r | x | 0 | o<br>o | 1 | ĭ ⊢ | 1 0x01 | 0<br>0 | 1 | x<br>o | 0 | | | | | | | | | | | | | | | 0 | | | | | | | | <u> </u> | | | • | | | Ü | 2 | 0 | 0 | | • | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Que | ue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | Solved Loads<br>0<br>0 | State 1 0 1 | | Valid Instructions 1 0 | New Head Pointer | | Read / Write EBF | Hit in EBF | | | Load Queu | ue Entries | | Solved Loads<br>0<br>0 | State 2 | Selected x o | Valid Instructions 0 0 | | 0 | 0 | Selected<br>0 | 1 | | (Non) Possible Dependencies Vector | | | Forwarded<br>0 | Dependence Detection | Load Queu | ue Entries | Store Queue Entries 0 0x00 | 0 | State 2 1 * * | х | 0 | | 0<br>0 | 0 | Selected<br>o<br>x<br>o | 1<br>0 | | (Non) Possible Dependencies Vector * 001 | | | Forwarded<br>O<br>O | Dependence Detection o o | Load Queu | o o | Store Queue Entries 0 0x00 1 0x01 | 0<br>0 | State 2 1 * * State 2 | x<br>o | 0<br>0 | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | Selected O X O Selected | 1<br>0<br>0<br>Valid Instructions | 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 | W Read / Write EBF | O<br>Hit in EBF | Forwarded O O O Forwarded O | Dependence Detection O O O O Dependence Detection O | 0<br>1<br>2 | o o o o o o o o o o o o o o o o o o o | Store Queue Entries | 0<br>0<br>0<br>Solved Loads | 1<br>*<br>* | X<br>O<br>O<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b> | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | Selected<br>o<br>x<br>o | 1<br>0<br>0 | 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector | w | o | Forwarded O O O Forwarded | Dependence Detection O O O O Dependence Detection | 0<br>1<br>2 | ue Entries O O O O ue Entries | Store Queue Entries | 0<br>0<br>0 | 1<br>*<br>* | x<br>o<br>o | 0<br>0<br>0 | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | Selected O X O Selected X O | 1<br>0<br>0<br>Valid Instructions<br>0<br>1 | 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * | W Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O Forwarded O O O | Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2 | ue Entries o o o o ue Entries o o o o | Store Queue Entries | 0<br>0<br>0<br><b>Solved Loads</b><br>1<br>0 | 1<br>*<br>* | X<br>O<br>O<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b><br>0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected O X O Selected X O O | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 | W Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 1 2 Load Quet 0 1 2 2 | ue Entries 0 0 0 0 0 0 ue Entries 0x00 0 | Store Queue Entries | 0<br>0<br>0<br><b>Solved Loads</b><br>1<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O | 0<br>0<br>0<br>Valid Instructions<br>0<br>0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected O X O Selected X O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 | W Read / Write EBF | O Hit in EBF | Forwarded O O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet | o o o o o o o o o o o o o o o o o o o | Store Queue Entries | 0<br>0<br>0<br>Solved Loads<br>1<br>0<br>Solved Loads | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | X<br>O<br>O<br>Selected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>1<br>0 | 0 | Selected O X O Selected X O O Selected X X X X X X X X X X X X X X X X X X | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector | W Read / Write EBF | O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0<br>0<br>0<br>Solved Loads<br>1<br>0<br>0<br>Solved Loads<br>1<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected O X O Selected X O O Selected O Selected O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | O Hit in EBF X Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet | o o o o o o o o o o o o o o o o o o o | Store Queue Entries | 0<br>0<br>0<br>Solved Loads<br>1<br>0<br>Solved Loads | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O O Selected O X O O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | Selected O X O Selected X O O Selected X O O Selected Selected Selected Selected | Valid Instructions Valid Instructions Valid Instructions Valid Instructions Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 ** (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet Load Quet Load Quet Load Quet Load Quet Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0<br>0<br>0<br>Solved Loads<br>1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O Selected O X O Selected O X Selected O X Selected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>1<br>0 | O | Selected O X O Selected X O O Selected X O O O | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions 0 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | O Hit in EBF X Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet Load Quet Load Quet Load Quet Load Quet Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0<br>0<br>0<br><b>Solved Loads</b> 1<br>0<br>0 <b>Solved Loads</b> 1<br>0 | 1 * * * * * * * * * * * * * * * * * * * | Selected O X O Selected O X O Selected X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 | | O | State 1 | Selected O X O Selected X O O Selected O X O Selected O X O Selected O X O O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 ** (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF X Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet Load Quet Load Quet Load Quet Load Quet Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0<br>0<br>0<br>Solved Loads 1<br>0<br>0 Solved Loads 1<br>0 0 | 1 * * * * * * * * * * * * * * * * * * * | Selected O X O Selected O X O Selected O X O Selected O O X | Valid Instructions 0 0 0 Valid Instructions 0 0 Valid Instructions 0 0 Valid Instructions | | O O O O O O O O O O | State 1 | Selected O X O Selected O O Selected O X O O Selected O X O O Selected O X O O | Valid Instructions 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF X Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet Load Quet Load Quet Load Quet Load Quet Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 * * * * * * * * * * * * * * * * * * * | Selected O Selected O X O Selected O X Selected O O X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O Selected O X O Selected O Selected O Selected O Selected O Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF X Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet Load Quet Load Quet Load Quet Load Quet Load Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 * * * * * * * * * * * * * * * * * * * | Selected O X O O Selected O X O Selected O X Selected O X Selected O X Selected O X Selected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O Selected O X O O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O O Selected O X O Selected O X X O X Selected O X X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 O | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O Selected | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Quet O O O O O O O O O | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | O O O O O O O O O O | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected O X Selected O X X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O O Selected O X O Selected O X O O Selected O X O O Selected O X O O Selected O X O O Selected O X O O Selected | 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries Oxo0 O O O Oxo Oxo Oxo Oxo Oxo | Store Queue Entries | O O O O O O O O O O | 1 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected O Selected O X O Selected O X O Selected O X O Selected O X O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries Oxo0 O o ue Entries Oxo0 O o ue Entries Oxo0 O o ue Entries Oxo0 o o ue Entries Oxo0 o o ue Entries Oxo0 o o ue Entries | Store Queue Entries | O O O O O O O O O O | 1 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O X O | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O O 1 Valid Instructions O O Valid Instructions O Valid Instructions O Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries Oxo0 O O O O O O O O O O O O O | Store Queue Entries | Solved Loads | 1 | Selected O X O O Selected O X O O X Selected O X Selected O O X Selected O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O Selected O X O Selected O X O Selected X O Selected X O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O Selected | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 1 0 1 Valid Instructions 0 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries Oxo0 O O O O O O O O O O O O O | Store Queue Entries | O | 1 | Selected O X O O Selected O X O O Selected O X Selected O O X Selected O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected O X O Selected O X O O Selected O X O O Selected O X O Selected O X O O Selected O X O O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 001 (Non) Possible Dependencies Vector * 001 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF X | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | Solved Loads | State 2 | Selected O Selected O Selected O Selected O Selected O Selected O X Selected X O O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected X O O Selected O X O X O | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O O 1 Valid Instructions O O Valid Instructions O Valid Instructions O Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF X | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries O O O O O O O O O O O O O O O O O O | Store Queue Entries | Solved Loads | 1 | Selected O Selected O Selected O Selected O Selected O Selected O X Selected X O O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected O X O Selected O X O O Selected O X O O Selected O X O Selected O X O O Selected O X O O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O Selected Selected Selected Selected X O O Selected | 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 * 000 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 001 * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF X | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Quet | ue Entries Ox00 O O O O O O O O O O O O | Store Queue Entries | Solved Loads | State 2 | Selected O Selected O Selected O Selected O Selected O Selected O Selected X O O Selected X O O Selected Selected X O O Selected | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | Appendix-B Memory Disambiguation Test: LSS (Load-Store-Store) | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | |------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 000 | | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | | 0x03 | 000 | w | o | 0 | o | 1 0 | 1 0x01 | 0 | | | 000 | | | 0 | o | 2 0 | 2 o | 0 | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | | 000 | | | 0 | О | 0 0x00 | 0 0x00 | 1 | | 0x03 | 000 | w | 0 | 0 | 0 | 1 0 | 1 0x01 | 0 | | | 000 | | | 0 | 0 | 2 0 | 2 0 | 0 | | Name Up and Datastan | (Nan) Parailela Danan danaian Vantan | D / / / / / EDE | Hit in EBF | | D | Load Queue Entries | Store Queue Entries | Calmad Lands | | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | HIT IN EBF | Forwarded | Dependence Detection | 0 0x00 | 0 0x00 | Solved Loads<br>1 | | 0x03 | 000 | w | o | 0 | 0 | 1 0 | 1 0x01 | 0 | | 0.05 | 000 | " | | ő | 0 | 2 0 | 2 0 | 0 | | | | | | | | | 1-1 - | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | | 0x03 | 001 | w | o | 0 | О | 1 0 | 1 0x01 | 0 | | | 000 | | | o | o | 2 0 | 2 o | 0 | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | | 0x03 | 001 | r | х | ٥ | o | 0 | 1 0x01 | 0 | | | 001 | | | 0 | 0 | 2 0 | 2 0 | 0 | | Name 15 - 15 to 1 | (Nam) Describe Describe State | n1/24 " === | 1841 555 | F 1 1 | Daniel Diriri | Lood Onero France | Store Cueue Fatal | 6-1111 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | 0x03 | 000 | | | 0 | 0 | 0 0x00<br>1 0 | 0 0x00<br>1 0x01 | 1<br>0 | | 0x05 | 001<br>000 | w | 0 | 0 | o<br>o | 2 0 | 1 0x01 o | 0 | | | 000 | | | | 0 | 2 0 | 2 0 | 0 | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | iten neda i emite. | 000 | Tieda / Wille 22: | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | | 0x03 | 000 | w | 0 | 0 | o | 1 0 | 1 0x01 | 0 | | | 001 | | | 0 | О | 2 0 | 2 0 | o | | | | • | | | | | • | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | Solved Loads | | | 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | 0 | 0 0x00 | 0 0x00 | 1 | | New Head Pointer | 000<br>001 | Read / Write EBF | Hit in EBF<br>× | o<br>o | 0 | 0 0x00<br>1 o | 0 0x00<br>1 0x01 | 1<br>0 | | | 000 | | | 0 | 0 | 0 0x00 | 0 0x00 | 1 | | 0x03 | 000<br>001<br>001 | r | х | o<br>o<br>o | o<br>o<br>o | 0 0x00<br>1 0<br>2 0 | 0 0x00<br>1 0x01<br>2 0 | 1<br>0<br>0 | | | 000<br>001<br>001<br>(Non) Possible Dependencies Vector | | | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0 0x00<br>1 0<br>2 0 | 0 0x00<br>1 0x01<br>2 0 | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000 | r<br>Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00 | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000<br>000 | r | х | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000 | r<br>Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00 | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000<br>000 | r<br>Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000<br>000<br>001 | r<br>Read / Write EBF | X<br>Hit in EBF | o<br>o<br>o<br>Forwarded | Dependence Detection o o | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | 0x03 New Head Pointer 0x03 | 000<br>001<br>001<br>(Non) Possible Dependencies Vector<br>000<br>000 | r<br>Read / Write EBF | X<br>Hit in EBF | O<br>O<br>O<br>Forwarded<br>O<br>O | O O O O O O O O O O O O O O O O O O O | 0 0x00<br>1 0<br>2 0<br>Load Queue Entries<br>0 0x00<br>1 0<br>2 0 | 0 0x00<br>1 0x01<br>2 0<br>Store Queue Entries<br>0 0x00<br>1 0x01<br>2 0 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector | r<br>Read / Write EBF | X<br>Hit in EBF | Forwarded O O O Forwarded | Dependence Detection o o Dependence Detection | 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 0x00 1 0 0x00 1 0 0x00 | 0 | Solved Loads 1 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 | 0 0x00 1 0x01 2 0 Store Queue Entries 0 0x00 1 0x01 2 0 Store Queue Entries 0 0x00 | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 | 0 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O Dependence Detection O O O O O O Dependence Detection | 0 | 0 | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 0 0x00 | 0 | 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O Forwarded O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 1 0 2 0 Load Queue Entries 0 0x00 0 0x00 | 0 | 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 001 001 (Non) Possible Dependencies Vector 000 000 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF A Hit in EBF | Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF X Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | Solved Loads | Appendix-B Memory Disambiguation Test: SLL (Store-Load-Load) | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | |-----------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------| | | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0 | 0 0x00 | | | 1 | LD | 0x00 | 1 | 0 | О | 1 | 0x01 | * | w | 0 | 0 | О | 1 0 | 1 o | | | 2 | LD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | ° | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | <u> </u> | | 0 | 0 | 0 0 | 0 0x00 | | РАТН | 1 | LD | 0x00 | 1 | 0 | o | 1 | 0x01 | * | w | 0 | 0 | О | 1 o | 1 o | | | 2 | LD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | , | | 0 | 0 | 0 0 | 0 0x00 | | | 1 | LD | 0x00 | 1 | 0 | o | 1 | 0x01 | * | w | 0 | О | О | 1 0 | 1 o | | | 2 | LD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | О | 0 0x00 | 0 0 | | | 1 2 | LD<br>LD | 0x00<br>0x01 | 1 | 1 0 | x<br>o | 0<br>1 | 0x00 | 001<br>* | r | 0 | 0 | o<br>o | 1 o | 1 o o | | | | LD | 0.01 | <u> </u> | · | · · | 1 | | | | | Ü | | 2 0 | 2 0 | | = | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | PATH | 0 | SD | 0x00 | 1 | 0 | О | 1 | 0.00 | * | | | 0 | О | 0 0x00 | 0 0 | | ₫ | 1 2 | LD<br>LD | 0x00<br>0x01 | 1 | 1 0 | x<br>o | 0<br>1 | 0x00 | 001<br>* | r | 0 | 0 | 0 | 1 o | 2 0 | | | | | 5,101 | <u> </u> | | | | <b>.</b> | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | 1 | 0 | SD | 0x00 | 1 | 0 | 0 | 1<br>0 | 0,00 | *<br>001 | _ | _ | 0 | 0 | 0 0x00 | 0 0 | | 1 | 1 2 | LD<br>LD | 0x00<br>0x01 | 1 | 0 | x<br>o | 0<br>1 | 0x00 | * | r | 0 | 0 | o<br>o | 2 0 | 1 0 | | | | | | | | | | | | | | | <u> </u> | 1-1 | | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | <u> </u> | | | 0 1 | SD<br>LD | 0x00<br>0x00 | 1 | 0 | 0<br>0 | 1<br>1 | 0x00 | * | r | o | 0 | 0 | 0 0<br>1 0x01 | | | | 2 | LD | 0x01 | 1 | 1 | x | 0 | 0.00 | 001 | | | 0 | 0 | 2 0 | 2 0 | | | | | | - | | | | | | | | | - | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | 2 | | | | 1 | _ | | _ | | * | , | | | | 1 - 1 | - 1 | | АТН 2 | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | 0x00 | * | r | 0 | 0 | o<br>o | 0 0 | 0 0 | | РАТН 2 | | | | 1 | _ | | 1 | 0x00 | *<br>*<br>001 | , | | | o<br>o | 0 0 | 0 0 | | PATH 2 | 0<br>1<br>2 | SD<br>LD<br>LD | 0x00<br>0x00<br>0x01 | 1<br>1<br>1 | 0<br>0<br>1 | o<br>o<br>x | 1<br>1<br>0 | | * * * 001 | r | o | 0<br>0<br>0 | 0 | 0 0<br>1 0x01<br>2 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position | SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation | 1<br>1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x<br>Selected | 1<br>1 | 0x00 | * | , | | o<br>o<br>o<br>Forwarded | O O Dependence Detection | 0 0 0 1 0x01 2 0 Load Queue Entries | 0 0 0 1 0 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position | SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00 | 1<br>1<br>1 | 0<br>0<br>1 | o<br>o<br>x<br>Selected | 1<br>1<br>0 | New Head Pointer | * * * 001 | r | o | o<br>o<br>o<br>Forwarded | O O O Dependence Detection O | 0 0 0 1 0x01 2 0 Codd Queue Entries 0 0 0 | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position | SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation | 1<br>1<br>1<br>Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions | | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O Dependence Detection | 0 0 0 1 0x01 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1 | SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation<br>0x00<br>0x00 | 1 1 1 Valid Instructions 1 1 | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | New Head Pointer | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | Dependence Detection | 0 0 0 1 0x01 2 0 0 0 0 0 0 1 0x01 | 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1<br>2 | SD<br>LD<br>LD<br>Instructions<br>SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L/S Queue Allocation<br>0x00<br>0x00<br>0x01 | 1<br>1<br>1<br>Valid Instructions<br>1<br>1 | 0<br>0<br>1<br>State 0<br>0<br>0 | O O X Selected O O X | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 | Dependence Detection O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | PATH 2 | 0<br>1<br>2<br>Position<br>0<br>1<br>2 | SD<br>LD<br>LD<br>Instructions<br>SD<br>LD<br>LD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation<br>0x00<br>0x00 | 1<br>1<br>1<br>Valid Instructions<br>1<br>1 | 0<br>0<br>1<br>State 0<br>0<br>0 | o<br>o<br>x<br>Selected | 1<br>1<br>0<br>Valid Instructions<br>1<br>1 | New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 | Dependence Detection | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | | РАТН | O | SD<br>LD<br>LD<br>Instructions<br>SD<br>LD<br>LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | O O X Selected O O X Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | New Head Pointer 0x00 | * * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O O O Dependence Detection | O O O O O O O O O O | 0 | | 3 РАТН | 0 1 2 Position 0 1 2 Position 0 0 0 0 | SD<br>LD<br>LD<br>Instructions<br>SD<br>LD<br>LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected O X Selected X | 1 1 0 Valid Instructions 1 1 0 0 Valid Instructions 0 | New Head Pointer 0x00 New Head Pointer | * * * * * * * * * * * * * * * * * * * | r Read / Write EBF | O Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O Dependence Detection O O O O | 0 | 0 | | 3 РАТН | O | SD<br>LD<br>LD<br>Instructions SD<br>LD LD Instructions SD LD LD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x01 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>1<br>State 0 | Selected O X Selected O X Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | O O O O O O O O O O | 0 | | РАТН | O | SD<br>LD<br>LD<br>Instructions<br>SD<br>LD<br>LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 | 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1<br>State 0 | Selected O X Selected O X Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 | New Head Pointer 0x00 New Head Pointer | * * * * * * * * * * * * * * * * * * * | r Read / Write EBF | O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | O O O O O O O O O O | 0 | | 3 РАТН | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 1 O O State 0 1 1 1 O O O O O O O | Selected O X Selected X O Selected X O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | | 3 РАТН | O | Instructions SD LD LD LD Instructions SD LD LD Instructions SD LD LD SD LD SD SD SD SD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x00 0x00 0x01 | 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 0 1 State 0 0 0 1 1 State 0 1 0 0 1 1 0 0 State 0 1 1 | Selected O X Selected O X Selected X Selected X | Valid Instructions Valid Instructions Valid Instructions 0 1 1 1 Valid Instructions 0 0 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O | Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | O | O | | 3 РАТН | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 1 O O State 0 1 1 1 O O O O O O O | Selected O X Selected X O Selected X O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | | 3 РАТН | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 1 O O State 0 1 1 1 O O O O O O O | Selected O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | O | O | | 3 РАТН | Position 0 | SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD SD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O State 0 O O O O O O O O O | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O Forwarded O O O O O Forwarded O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position 0 | Instructions SD LD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O O O O O O O O | Selected O X Selected X O O Selected X O O Selected X O X O Selected X O X O X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 4 РАТН 3 | Position 0 | SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD SD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O State 0 O O O O O O O O O | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O Forwarded O O O O O Forwarded O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН 3 | Position 0 | Instructions SD LD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O State 0 O O O O O O O O O | Selected Selected X Selected X O Selected X O Selected X O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 * (Non) Possible Dependencies Vector 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 4 РАТН 3 | Position | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O Selected X O Selected X O Selected O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 4 РАТН 3 | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD Instructions SD LD LD LD Instructions SD LD LD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O O O O O O O O O | Selected Selected X Selected X O O Selected X O O Selected X O O Selected X O X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 4 РАТН 3 | Position | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O Selected X O Selected X O Selected O Selected O Selected O Selected O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 4 РАТН 3 | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD LD Instructions SD LD LD LD Instructions SD LD LD LD LD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected O X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 5 PATH 4 PATH 3 | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions | 0x00 | Valid Instructions Valid Instructions Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 0 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | 5 PATH 4 PATH 3 | Position | Instructions SD LD LD | 0x00 | Valid Instructions Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O | 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | | РАТН РАТН З | Position 0 | Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions SD LD LD Instructions | 0x00 | Valid Instructions Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 0 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Coad Queue Entries | O | Appendix-B Memory Disambiguation Test: SLL (Store-Load-Load) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | e Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | |-----------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | * 1 | o<br>x | 0 | 0x02 | 000<br>000 | r | × | x<br>o | o<br>o | H-H | )x00 C | 0x00<br>1 o | 1<br>0 | * | 0 | 0<br>0 | | 0 | 0 | 0 | 1 | | * | | | 0 | 0 | $\vdash$ | 0 2 | 2 0 | 0 | 1 | x | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | e Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | * | 0 | 0 | 0.01 | 000 | | | х | 0 | - | 0 0 | 0x00 | 0 | * | 0 | 0 | | 0 | 0 | o<br>x | 1<br>0 | 0x01 | * 000 | r | × | 0 | o<br>o | | 0x01 1 | | 1<br>0 | 1 * | x<br>o | 0<br>0 | | | 1 | | | 1 | (m. ) = 11 = 1 | | | | | | | | | | | | | Solved Loads 0 | State 1 | Selected<br>0 | Valid Instructions<br>0 | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>× | Dependence Detection<br>o | 10 O: | 0x00 C | Store Queue Entries 0x00 | Solved Loads<br>1 | State 2 | Selected<br>o | Valid Instructions 0 | | 0 | 1 | x | 0 | 0x02 | 000<br>* | r | × | 0 | 0 | H-1 | 0 1 | - 1 | 0 | * | 0 | 0<br>0 | | 0 | 1 | 0 | 1 | <u> </u> | | <u> </u> | <u> </u> | 0 | 0 | 2 | 0 2 | 0 | 0 | 1 | Х | 0 | | Solved Loads | Ctata 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | o Entries C | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | X | 0 | New Head Pointer | 000 | Read / Write EBF | HIL III EBF | O | o Dependence Detection | | 0x00 0 | 0x00 | 1 | * | o | 0 | | 0 | * | 0 | 0<br>1 | 0x02 | 001<br>* | w | O | 0 | x<br>o | | 0 1 | 0 0 | 0<br>0 | * 1 | 0<br>V | 0<br>0 | | 0 | | | 1 | | | | <u> </u> | | O . | | 2 | | U | | _ ^ _ | Ū | | Solved Loads<br>0 | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | Load Queue | e Entries S | Store Queue Entries | Solved Loads | State 2 | Selected<br>× | Valid Instructions 0 | | 0 | * | o | 0 | 0x00 | 001 | r | О | 0 | 0 | _ | 0x01 1 | 0 | 0 | * | 0 | ō | | 0 | 1 | х | 0 | | 001 | | | 0 | 0 | 2 | o 2 | 2 o | 0 | * | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | x<br>o | 0<br>0 | 0x02 | 000<br>001 | w | o | 0 | o<br>x | | 0x00 0 | 0x00<br>1 o | 1<br>0 | * | 0 | 0<br>0 | | 0 | 1 | 0 | 1 | | * | | | 0 | 0 | _ | 0 2 | 0 | 0 | 1 | x | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | e Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 0 | 1 0 | x<br>o | 0<br>1 | 0x01 | 000<br>* | w | o | 0 | o<br>o | | o 0<br>0x01 1 | 0x00<br>1 o | 0<br>1 | 1 | o<br>x | 0<br>0 | | 0 | * | О | 0 | | 001 | | | o | x | | 0 2 | 2 0 | 0 | * | О | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue | | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 0 | 0 | 1 | | (Non) Possible Dependencies Vector | , | | 0 | 0 | 0 0: | e Entries S | 0 | 0 | State 2 | х | 0 | | | _ | | Valid Instructions 1 0 0 | New Head Pointer | (Non) Possible Dependencies Vector * 001 001 | Read / Write EBF | Hit in EBF<br>O | | • | 0 0: | e Entries | 0 0 | | State 2 1 * * | - | | | 0<br>0<br>0 | 0<br>1<br>* | o<br>x<br>o | 1<br>0<br>0 | 0x00 | *<br>001<br>001 | r | o | 0<br>0<br>0 | 0<br>0<br>0 | 0 0: | See Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0 | 1<br>*<br>* | x<br>0<br>0 | 0<br>0<br>0 | | 0<br>0 | 0<br>1<br>* | o<br>x | 1<br>0 | | * 001 001 (Non) Possible Dependencies Vector 000 | , | | o<br>0 | 0<br>0 | 0 0:<br>1 0:<br>2 Load Queue | See Entries | 0 0 | 0<br>0 | State 2 1 * * State 2 State 2 * | x<br>o | 0<br>0 | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | Selected X 0 | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 001 001 (Non) Possible Dependencies Vector 000 * | r | o | o<br>o<br>o<br>Forwarded | Dependence Detection | 0 0:<br>1 0:<br>2 Load Queue | See Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>1 | 1<br>*<br>* | Selected O x | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | o<br>x<br>o<br>Selected | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 0:<br>1 0:<br>2 Load Queue | See Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br><b>Solved Loads</b> | State 2 | X<br>O<br>O | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br>Solved Loads<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected X O O | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 | Read / Write EBF | O Hit in EBF | O<br>O<br>O<br>Forwarded<br>O<br>O | Dependence Detection O X | 0 0:<br>1 0:<br>2 | E Entries | 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>1<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O | Valid Instructions 0 0 0 0 0 0 0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | 0 | Selected X O Selected O Selected O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O Forwarded X | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O | 0 0:<br>1 0:<br>2 | E Entries | O | Solved Loads O 1 0 Solved Loads | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O O Selected O X O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected X O O Selected | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF | Forwarded O O O Forwarded | Dependence Detection O X Dependence Detection | Coad Queue O O | E Entries | O | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>1<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O Selected | Valid Instructions 0 0 0 0 0 0 0 | | 0<br>0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads | O | Selected X O O Selected X O O O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O X O O O O O | Load Queue O | | O | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>1<br>0<br><b>Solved Loads</b><br>1<br>0 | State 2 * 1 * State 2 * 1 * State 2 | Selected O X O Selected O X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1<br>*<br>State 1 | Selected X O O Selected X O O O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded X O | Dependence Detection O X Dependence Detection O O O O O O O | Load Queue O | | O | 0<br>0<br>0<br>Solved Loads 0 1 0 Solved Loads 1 0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O Selected O X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | Solved Loads | O | Selected Selected Selected Selected X O Selected X O X O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 1 Valid Instructions 0 0 1 Valid Instructions 0 0 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded X O Forwarded X O O Forwarded X O O O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O | Coad Queue | | O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | State 2 * 1 * State 2 * 1 * State 2 | Selected O Selected O Selected O Selected O O Selected O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | O | State 1 | Selected X O O Selected X O O Selected O X O Selected O X O | Valid Instructions Valid Instructions Valid Instructions Valid Instructions 0 1 Valid Instructions 0 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 000 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded X O Forwarded X | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O Dependence Detection | Coad Queue | | O | 0<br>0<br>0<br>Solved Loads 0<br>1<br>0 Solved Loads 1 0 0 Solved Loads | State 2 * 1 * State 2 * 1 * State 2 | Selected O X O Selected O X O Selected O X O Selected O O X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 0 1 Valid Instructions 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 000 * 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF X | Forwarded X 0 0 Forwarded X 0 0 Forwarded X 0 0 | Dependence Detection O O X Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O | Load Queue Coad | | O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O O Selected O X O Selected O X X O X Selected O X X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected Selected Selected Selected X O Selected X O X O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X Forwarded X O O Forwarded | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O | Load Queue O | | O | O | State 2 * 1 * State 2 * 1 * State 2 | Selected O X O O Selected O X O Selected O X X O X Selected O X X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O Selected O Selected O Selected O Selected | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 001 | Read / Write EBF Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF X | Forwarded X 0 0 Forwarded X 0 0 Forwarded X 0 0 Forwarded X 0 0 Forwarded | Dependence Detection O O X Dependence Detection O O O O Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O O | Load Queue O | | O | O O O O O O O O O O | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected O X Selected O X O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O O Selected O X O Selected O X O Selected O X O | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 001 (Non) Possible Dependencies Vector 000 * 000 * 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 001 | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O Dependence Detection O O O Dependence Detection O O O O Dependence Detection | Load Queue O | | O | O | State 2 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O X O O O O O O O O O O O O O O O O O | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O O Selected O X O Selected O X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 001 | Read / Write EBF r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF X Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 Forwarded X 0 0 Forwarded X 0 0 Forwarded | Dependence Detection O O X Dependence Detection O O O O Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O O | Load Queue O | | O | O O O O O O O O O O | 1 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O X O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected Selected X O Selected X O Selected X O Selected O X O Selected | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 Valid Instructions O 0 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 001 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 000 001 | Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue O | | O | O | State 2 | Selected O X O O Selected O X O O Selected O X Selected O O X Selected O O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O Selected O X O Selected X O Selected X O Selected X O Selected X O Selected X O Selected X | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | * 001 001 001 (Non) Possible Dependencies Vector 000 000 * 000 000 * (Non) Possible Dependencies Vector 000 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 001 001 001 001 | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF O | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O Forwarded O Forwarded O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue O | | O | O | State 2 | Selected O Selected O Selected O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O O Selected O X O Selected O X O O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x02 | * 001 001 (Non) Possible Dependencies Vector 000 * 000 * 0001 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector * 001 001 (Non) Possible Dependencies Vector 000 001 * | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF w | Hit in EBF X Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue O | | O | O O O O O O O O O O | State 2 | Selected O Selected O O X O Selected O O X Selected O O X Selected O O X Selected O O X Selected O O X Selected O O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected Selected X O Selected X O Selected X O Selected O X O Selected | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 Valid Instructions O 0 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | * 001 001 (Non) Possible Dependencies Vector 000 * 001 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector * 001 001 001 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 000 001 | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue O | | O | O | State 2 | Selected O Selected O O X O Selected O O X Selected O O X Selected O O X Selected O O X Selected O O X Selected O O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions Valid Instructions O Valid Instructions O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x02 | Non Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF r Read / Write EBF w | Hit in EBF X Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O Forwarded O O O Forwarded Forwarded Forwarded Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue O | | O | O | State 2 | Selected O Selected O O X Selected O O Selected O O Selected O O Selected O O Selected O O Selected | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | Appendix-B Memory Disambiguation Test: SLL (Store-Load-Load) | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | |------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | | 000 | , | | × | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | х | О | О | 1 | 0x01 | 1 | О | 1 | | | 000 | | | 0 | О | 2 | О | 2 | О | 0 | | | | | | | | | | _ | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | ٠. | ad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0x03 | 000<br>000 | r | x | x<br>o | o<br>o | 0 | 0x00<br>0x01 | 0 | 0x00<br>o | 1<br>1 | | 0.03 | 000 | · ' | ^ | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | | | - | • | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | | | 000 | | | х | О | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | х | 0 | o | 1 | 0x01 | 1 | О | 1 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | | ite w rieda i omitei | 000 | Redd / Wille EDI | THE III EDI | х | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | x | 0 | О | 1 | 0x01 | 1 | О | 1 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | _ | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | _ | ad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0x03 | 000<br>001 | w | o | 0 | o<br>x | 0 | 0x00<br>0x01 | 0 | 0x00<br>o | 1<br>1 | | 0,03 | 001 | VV | | 0 | x<br>x | 2 | 0,01 | 2 | 0 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | | T | 000 | | | х | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000<br>000 | r | х | 0 | 0 | 2 | 0x01 | 2 | 0 | 1<br>0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | U | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | Sto | ore Queue Entries | Solved Loads | | | 000 | | | х | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | х | 0 | О | 1 | 0x01 | 1 | 0 | 1 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | New Head Pointer | (Nan) Passible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Danandanca Dataction | Lo | ad Queue Entries | C+ | ore Queue Entries | Solved Loads | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | HIL III EBF | o | Dependence Detection o | 0 | 0x00 | 0 | 0x00 | Solved Loads | | 0x03 | 001 | w | О | 0 | x | 1 | 0x01 | 1 | 0 | 1 | | | 001 | | | O | х | 2 | О | 2 | o | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | — | ad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0x03 | 000<br>000 | r | | x | | 0 | 0x00 | | 0x00 | 1 | | 0,03 | 000 | | | 1 ^ 1 | 0 | - | 0v01 | 0 | | 1 | | | | | x | 0 | o | 1 | 0x01<br>o | 1 | o<br>o | 1<br>0 | | | 000 | | X | o<br>o | | - | | - | | | | | 000 | | X | | o | 1 | | 1 | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | | o<br>Forwarded | o<br>o<br>Dependence Detection | 1<br>2 | o<br>ad Queue Entries | 1<br>2 | o<br>ore Queue Entries | 0 Solved Loads | | | (Non) Possible Dependencies Vector | , | Hit in EBF | Forwarded x | O O Dependence Detection O | 1<br>2<br>Lo | o ad Queue Entries 0x00 | 1<br>2<br><b>St</b> t | o<br>ore Queue Entries<br>0x00 | 0 Solved Loads | | New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 | Read / Write EBF | | Forwarded X 0 | O O O O O O O O O O O O O O O O O O O | 1<br>2<br>Los | o ad Queue Entries 0x00 0x01 | 1 2 Sto | ore Queue Entries 0x00 0 | 0 Solved Loads 1 1 | | | (Non) Possible Dependencies Vector | , | Hit in EBF | Forwarded x | O O Dependence Detection O | 1<br>2<br>Lo | o ad Queue Entries 0x00 | 1<br>2<br><b>St</b> t | o<br>ore Queue Entries<br>0x00 | 0 Solved Loads | | | (Non) Possible Dependencies Vector 000 000 | , | Hit in EBF | Forwarded X 0 | O O O O O O O O O O O O O O O O O O O | 1 2 Loc 0 1 2 | o ad Queue Entries 0x00 0x01 | 1 2 Sto 0 1 2 | ore Queue Entries 0x00 0 | 0 Solved Loads 1 1 | | 0x03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 | r | Hit in EBF | Forwarded X 0 | Dependence Detection O O O | 1 2 Los | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 | 1 2 Std 0 1 2 Std 0 | ore Queue Entries 0x00 0 | Solved Loads 1 1 0 Solved Loads | | 0x03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 | r | Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 | Dependence Detection O O O O Dependence Detection O O O O O | 1 2 Co. 1 2 Co. 1 1 2 Co. 1 1 | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 | 1 2 Std 0 1 2 Std 0 1 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o | Solved Loads 1 1 0 Solved Loads 1 1 1 | | 0x03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 | r<br>Read / Write EBF | Hit in EBF<br>X<br>Hit in EBF | Forwarded X O O Forwarded X | Dependence Detection O O O O Dependence Detection O | 1 2 Los | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 | 1 2 Std 0 1 2 Std 0 | ore Queue Entries 0x00 o ore Queue Entries 0x00 | Solved Loads 1 1 0 Solved Loads | | 0x03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 | r<br>Read / Write EBF | Hit in EBF<br>X<br>Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 | Dependence Detection O O O O Dependence Detection O O O O O | 1 2 Co. 1 2 Co. 1 1 2 Co. 1 1 | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 | 1 2 Std 0 1 2 Std 0 1 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o | Solved Loads 1 1 0 Solved Loads 1 1 1 | | 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | r<br>Read / Write EBF<br>r | Hit in EBF<br>X<br>Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 | Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | 1 2 Los 0 1 2 Los 2 2 Los 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 | 1 2 Str 0 1 2 Str 2 2 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o | Solved Loads 1 1 0 Solved Loads 1 1 0 | | Ox03 New Head Pointer Ox03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 | r<br>Read / Write EBF | Hit in EBF X Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 | Dependence Detection O O O O Dependence Detection O O O O O | 1 2 Los 0 1 2 Los 2 2 Los 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 Str 0 1 2 Str 2 2 | over Queue Entries 0x00 0 0 over Queue Entries 0x00 0 0 0 0 0 0 | Solved Loads 1 1 0 Solved Loads 1 1 1 | | Ox03 New Head Pointer Ox03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 | r<br>Read / Write EBF<br>r | Hit in EBF X Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 Forwarded | Dependence Detection O O O O Dependence Detection O O O Dependence Detection O O O O Dependence Detection | Los Control | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 Str 0 1 2 | ore Queue Entries 0x00 0 ore Queue Entries 0x00 o ore Queue Entries 0x00 o | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF X Hit in EBF X | Forwarded X 0 0 Forwarded X 0 0 Forwarded O Forwarded O | Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O O Dependence Detection | Los Control | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 Str. 0 1 2 Str. 0 0 1 2 | ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 001 001 | r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X | Forwarded X O O O Forwarded X O O O Forwarded O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O X X | Loc Co Co Co Co Co Co Co | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 Str. 0 1 2 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF X Hit in EBF X | Forwarded X O O O Forwarded X O O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Loop Control | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o ore Queue Entries 0x00 o ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF x Hit in EBF o Hit in EBF | Forwarded X O O O Forwarded X O O O Forwarded X O O O Forwarded X O O O O Forwarded X | Dependence Detection O O O O O O O O O O O O O O O O O O | Loc Control Lo | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 | ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector | r Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X | Forwarded X O O O Forwarded X O O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Loop Control | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o ore Queue Entries 0x00 o ore Queue Entries | Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads 1 1 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 001 | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF x Hit in EBF o Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O Forwarded X O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Loc Coc | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 | ore Queue Entries 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 001 001 000 | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O O Forwarded X O O O Forwarded X O O O O Forwarded X O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Los Control | 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 2 | ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 0 ore Queue Entries 0x00 0 0 | Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF x Hit in EBF o Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O Forwarded X O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Loc Control Lo | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 | ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 ore Queue Entries 0x00 ore Queue Entries | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded X O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Los Control | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | Str O 1 2 | ore Queue Entries 0x00 o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o ore Queue Entries 0x00 o o ore Queue Entries 0x00 | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 001 001 (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF W Read / Write EBF | Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O O Forwarded X O O O Forwarded X O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Loc Control Lo | ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 ad Queue Entries 0x00 0x01 0 | 1 | ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 0 ore Queue Entries 0x00 ore Queue Entries 0x00 ore Queue Entries | Solved Loads | Appendix-B Memory Disambiguation Test: SLS (Store-Load-Store) | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | |-----------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------------------| | | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0 | 0 0x00 | | | 1 2 | LD<br>SD | 0x00 | 1 | 0 | 0 | 1 | 0x01 | * | w | 0 | 0 | 0 | 0 | 0 | | | | SD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 0 | 2 0 | | 。 | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | PATH ( | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | О | 0 0 | 0 0x00 | | ₹ | 1 2 | LD<br>SD | 0x00<br>0x01 | 1 1 | 0 | 0 | 1 | 0x01 | * | w | 0 | 0 | o<br>o | 1 0 | $\begin{bmatrix} 1 \\ 2 \end{bmatrix}$ | | | | 30 | 0,01 | 1 | - 0 | U | <u> </u> | <u> </u> | | <u> </u> | | U | 0 | 121 0 | 2 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | | 0 | SD | 0x00 | 1 | 1 | х | 0 | 0.01 | 000<br>* | | | 0 | 0 | 0 0 | 0 0x00 | | | 1 2 | LD<br>SD | 0x00<br>0x01 | 1 | 0 | 0 | 1<br>1 | 0x01 | * | w | 0 | 0 | o<br>o | 1 o | 1 o | | | • | | | | | | | | | | | | 0 | | _!! | | | | | | | | | | T | | T = | | | | 1 | | | | Position<br>0 | Instructions<br>SD | L / S Queue Allocation<br>0x00 | Valid Instructions | State 0 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>O | Dependence Detection o | 0 0x00 | Store Queue Entries | | | 1 | LD | 0x00 | 1 | 1 | x | 0 | 0x00 | 001 | r | О | o | 0 | 1 0 | 1 0 | | | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | 1 1 | 0 | SD | 0x00 | 1 | 0 | o | 1 | New Head Polliter | * | Read / Wille EBF | HILIIIEBE | o | o Dependence Detection | 0 0x00 | 0 0 | | РАТН | 1 | LD | 0x00 | 1 | 1 | х | 0 | 0x00 | 001 | r | 0 | О | О | 1 o | 1 o | | - | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | <u> </u> | * | | | 0 | 0 | 2 o | 2 o | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | s Store Queue Entries | | | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | nead / trine ED: | | 0 | 0 | 0 0x00 | 0 0 | | | 1 | LD | 0x00 | 1 | 1 | х | 0 | 0x00 | 001<br>* | r | 0 | 0 | О | 1 0 | 1 0 | | | 2 | SD | 0x01 | 1 | 0 | 0 | 1 | | * | ļ | | 0 | 0 | 2 0 | 2 0 | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | 000 | * | | | 0 | 0 | 0 0 | 0 0 | | | 1 2 | LD<br>SD | 0x00<br>0x01 | 1 1 | 0 | o<br>x | 1 | 0x00 | 010 | w | 0 | 0 | o<br>o | | 1 0x01<br>2 o | | | | | | | | | <u>-</u> | • | | • | | | | 1-1 | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entries | Store Queue Entries | | 7 | | CD. | | 1 | | | 1 | | * | | | | | 1.01 | | | ATH 2 | 0 | SD<br>LD | 0x00 | 1<br>1 | 0 | 0 | 1<br>1 | 0x00 | * | w | 0 | 0 | 0 | 0 0 | 0 o<br>1 0x01 | | PATH 2 | 0<br>1<br>2 | SD<br>LD<br>SD | | 1<br>1<br>1 | 0<br>0<br>1 | o<br>o<br>x | _ | 0x00 | *<br>*<br>010 | w | o | 0<br>0<br>0 | o<br>o<br>o | 0 0<br>1 0<br>2 0 | <u> </u> | | PATH 2 | 1<br>2 | LD<br>SD | 0x00<br>0x00<br>0x01 | 1 | 0 1 | o<br>x | 1<br>0 | <u> </u> | | <u> </u> | | 0 | 0 | 1 o o | 1 0x01 o | | РАТН 2 | 1<br>2<br>Position | LD<br>SD<br>Instructions | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation | _ | 0<br>1<br>State 0 | o<br>x<br>Selected | 1 | 0x00 | * 010 (Non) Possible Dependencies Vector * | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>Forwarded | o<br>o<br>Dependence Detection | 1 o o | 1 0x01<br>2 0 | | PATH 2 | 1<br>2 | LD<br>SD | 0x00<br>0x00<br>0x01 | 1 | 0 1 | o<br>x | 1<br>0 | <u> </u> | | <u> </u> | | 0 | 0 | 1 o o | 1 0x01 o | | PATH 2 | 1<br>2<br>Position | LD<br>SD<br>Instructions | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation<br>0x00 | 1 Valid Instructions | 0<br>1<br>State 0 | Selected | 1<br>0<br>Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | o<br>o<br>Forwarded | O O O Dependence Detection O | 1 o o Load Queue Entries 0 o | 1 0x01 0 0 Store Queue Entries 0 0 0 | | РАТН 2 | 1 2 Position 0 1 | LD<br>SD<br>Instructions<br>SD<br>LD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation<br>0x00<br>0x00 | 1 Valid Instructions 1 1 | 0<br>1<br>State 0 | Selected | 1<br>0<br>Valid Instructions<br>1<br>1 | New Head Pointer | (Non) Possible Dependencies Vector * * | Read / Write EBF | Hit in EBF | Forwarded 0 0 | O O O O O O O O O O O O O O O O O O O | 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 0x01 0 0 | | PATH 2 | 1 2 Position 0 1 2 | LD<br>SD<br>Instructions<br>SD<br>LD<br>SD | 0x00<br>0x00<br>0x01<br>L / S Queue Allocation<br>0x00<br>0x00 | Valid Instructions 1 1 1 | 0<br>1<br>State 0<br>0<br>0 | Selected | 1<br>0<br>Valid Instructions<br>1<br>1 | New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * | Read / Write EBF | Hit in EBF | Forwarded O O O | Dependence Detection O O O | 1 0 0 Load Queue Entries 0 0 1 0 2 0 | 1 0x01 0 | | PATH 2 | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD SD SD Instructions SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 | Valid Instructions 1 1 1 Valid Instructions | 0 | Selected O X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 | New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * 010 | Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue Entries 0 0 1 0 2 0 | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD SD LD LD LD LD LD LD LD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 1 State 0 0 0 1 State 0 1 1 | Selected O O X Selected O O X Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 | New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD SD SD Instructions SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 | Valid Instructions 1 1 1 Valid Instructions | 0 | Selected O X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 | New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector | Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Load Queue Entries 0 0 1 0 2 0 | 1 | | РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 1 State 0 0 0 1 State 0 1 1 | Selected O O X Selected O O X Selected O O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector | Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | Load Queue Entries | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD SD LD SD LD SD Instructions SD SD Instructions | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 0x00 0x01 L/S Queue Allocation 0x00 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected O O X Selected O O X Selected X Selected X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 0 0 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector 000 * * | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O O Dependence Detection | 1 | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 1 1 1 1 | State 0 | Selected O O X Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | Load Queue Entries | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD LD LD SD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O | Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | 1 | 1 | | 3 РАТН | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 3 РАТН | 1 2 Position 0 1 2 | Instructions SD LD SD Instructions SD LD LD LD SD LD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * 010 (Non) Possible Dependencies Vector 000 * * (Non) Possible Dependencies Vector 000 * * | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O | Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | 1 | 1 | | РАТН 3 | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O X | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * 010 (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector 000 * * * (Non) Possible Dependencies Vector 000 * * * * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O O Forwarded O O O Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 4 РАТН 3 | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | РАТН 3 | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 0 1 1 1 | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * * * * (Non) Possible Dependencies Vector * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 4 РАТН 3 | Position 0 | Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 0 1 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 4 РАТН 3 | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD LD SD LD SD LD LD SD LD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X O X O X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 4 РАТН 3 | Position | Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected O O X Selected X O O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 0 1 1 Valid Instructions 1 Valid Instructions 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 4 РАТН 3 | Position 0 | Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD Instructions SD LD SD LD SD LD SD LD LD SD LD LD SD | 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x00 0x00 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X O X O X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 5 PATH 4 PATH 3 | Position 0 | Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X O X O X Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF r | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | 5 PATH 4 PATH 3 | Position | Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * (Non) Possible Dependencies Vector * * * * (Non) Possible Dependencies Vector * * * * * (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | | РАТН В РАТН З | Position 0 | Instructions SD LD SD | 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 L/S Queue Allocation 0x00 0x01 | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected X O O X Selected X O O O Selected X O O Selected X O O Selected O X O Selected Selected O X O Selected | Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF W Read / Write EBF W Read / Write EBF r Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entries | 1 | Appendix-B Memory Disambiguation Test: SLS (Store-Load-Store) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Q | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | |-----------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | * | 0 | 0 | 0.03 | 000 | | | х | О | 0 | 0x00 | 0 0x00 | 1 | * | 0 | 0 | | 0 | 0 | x<br>o | 0<br>1 | 0x02 | 000<br>* | r | х | 0 | o<br>o | 2 | 0 | 2 0 | 0 | 1 | o<br>x | 0<br>0 | | | | | | | | | | | | | | | | 1 | | | | Solved Loads | State 1 | Selected<br>0 | Valid Instructions 0 | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded<br>O | Dependence Detection o | 0 | Queue Entries | Store Queue Entries 0 0x00 | Solved Loads | State 2 | Selected<br>o | Valid Instructions 0 | | 0 | 0 | o | 1 | 0x01 | * | w | О | o | О | 1 | o | 1 0x01 | 0 | 1 | x | 0 | | 0 | 1 | х | 0 | | 010 | | | 0 | 0 | 2 | 0 | 2 0 | 0 | * | О | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Q | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | *<br>1 | o<br>x | 0 | 0x02 | 000<br>000 | l r | × | x<br>o | o<br>o | 0 | 0x00<br>o | 0 0x00<br>1 o | 1 0 | * | 0 | 0<br>0 | | 0 | 1 | o | 1 | 0,02 | * | · | ^ | 0 | 0 | 2 | 0 | 2 0 | 0 | 1 | x | 0 | | | - | - | | | | | _ | - | | | | - | | - | - | _ | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Q | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 | 0x00 | 0 0x00 | 1 | * | 0 | 0 | | 0 | * | 0 | 0 | 0x02 | 001<br>* | w | О | 0 | x<br>o | 2 | 0 | 1 o | 0 | 1 1 | o<br>x | 0 | | | | | _ | | | | | | Ü | | 5 | | , , , | | | Ü | | Solved Loads | State 1 | <b>+</b> | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Q | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 0 | 0<br>* | 0 | 0 | 0x00 | 001 | w | o | 0 | 0 | 1 | 0x00<br>o | 0 0<br>1 0x01 | 0 | * | х<br>о | 0 | | 0 | 1 | х | 0 | | 000 | | | О | 0 | 2 | О | 2 o | 0 | * | O | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load O | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | х | 0 | | 000 | , | | 0 | 0 | 0 | 0x00 | 0 0x00 | 1 | * | 0 | 0 | | 0 | * | 0 | 0<br>1 | 0x02 | 001<br>* | w | 0 | 0 | x<br>o | 2 | 0 | 2 0 | 0 | * | o<br>x | 0<br>0 | | | | U | 1 | | | | | U | U | 2 | U | 2 | U | 1 - | ^ | O | | | | | | | | | T | | | 1 | | I a. a | | | | | | Solved Loads | State 1 | Selected<br>x | Valid Instructions 0 | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection<br>o | 0 | ueue Entries | Store Queue Entries 0 0x00 | Solved Loads | State 2 | Selected<br>o | Valid Instructions 0 | | 0 | 0 | 0 | 1 | 0x01 | * | w | О | О | О | 1 | О | 1 0x01 | 0 | 1 | х | 0 | | 0 | * | 0 | 0 | | 010 | | | 0 | О | 2 | 0 | 2 o | 0 | * | 0 | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Q | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 0 | 0 | 1 | | * | Ĺ | | 0 | 0 | Load Q | 0x00 | 0 0 | 0 | State 2 | х | 0 | | | | | Valid Instructions 1 0 0 | New Head Pointer | (Non) Possible Dependencies Vector * 001 010 | Read / Write EBF | Hit in EBF | | • | 0 1 2 | | <u> </u> | | State 2 1 * * | | | | 0<br>0<br>0 | 0<br>1<br>* | o<br>x<br>o | 1<br>0<br>0 | 0x00 | *<br>001<br>010 | r | х | 0<br>0<br>0 | 0<br>0<br>0 | 0 1 2 | 0x00<br>o<br>o | 0 0<br>1 0x01<br>2 0 | 0<br>0<br>0 | 1<br>*<br>* | x<br>o<br>o | 0<br>0<br>0 | | 0<br>0 | 0 | o<br>x<br>o | 1<br>0 | | *<br>001 | Ĺ | | o<br>o | 0<br>0 | 0 1 2 | 0x00<br>o | 0 o<br>1 0x01 | 0 | State 2 1 * * * State 2 * | x<br>o | 0<br>0 | | 0<br>0<br>0<br>Solved Loads<br>0 | 0<br>1<br>* | o<br>x<br>o | 1<br>0<br>0<br>Valid Instructions<br>0<br>1 | 0x00 | * 001 010 (Non) Possible Dependencies Vector 000 * | r | х | O<br>O<br>O<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 1 2 | 0x00<br>o<br>o<br>tueue Entries | 0 0 0 0 1 0 0 1 2 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>Solved Loads<br>0 | 1<br>*<br>* | Selected O x | 0<br>0<br>0<br>Valid Instructions<br>0 | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | o<br>x<br>o<br>Selected | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 001 010 (Non) Possible Dependencies Vector 000 | r<br>Read / Write EBF | X<br>Hit in EBF | 0<br>0<br>0<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0 1 2 | 0x00<br>o<br>o<br>tueue Entries | 0 0 0 0 1 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>Solved Loads | 1<br>*<br>* | X<br>O<br>O | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br>Solved Loads<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | O<br>X<br>O<br>Selected<br>X<br>O | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 | r<br>Read / Write EBF | X Hit in EBF | O<br>O<br>O<br>Forwarded<br>O<br>O<br>O | Dependence Detection O O | 0<br>1<br>2<br>Load Q<br>0<br>1<br>2 | 0x00<br>o<br>o<br>tueue Entries<br>o<br>o | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O | Valid Instructions 0 0 0 0 0 0 0 | | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected X O O Selected | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector | r<br>Read / Write EBF | X Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O O O Dependence Detection | 0<br>1<br>2<br>Load Q<br>0<br>1<br>2 | 0x00<br>0<br>0<br>tueue Entries<br>0<br>0 | 0 0 0 0 1 0 0 1 2 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O | 0<br>0<br>0<br>Valid Instructions | | 0<br>0<br>0<br>Solved Loads<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | O<br>X<br>O<br>Selected<br>X<br>O | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 | r<br>Read / Write EBF | X Hit in EBF | O<br>O<br>O<br>Forwarded<br>O<br>O<br>O | Dependence Detection O O | 0<br>1<br>2<br>Load Q<br>0<br>1<br>2 | 0x00<br>o<br>o<br>tueue Entries<br>o<br>o | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O | Valid Instructions 0 0 0 0 0 0 0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1<br>* | Selected X O O Selected X O O O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 001 010 (Non) Possible Dependencies Vector 000 | r Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded O O Forwarded Forwarded X | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>Load Q<br>0<br>1<br>2 | 0x00 0 0 tueue Entries 0 0 0 | O O O O O O O O O O | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O O Selected O X O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0 | 0 | Selected X O O Selected X O O X O O | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 001 010 (Non) Possible Dependencies Vector 000 | r Read / Write EBF w Read / Write EBF | Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0 0 0 | O | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>1<br>0 | 1<br>*<br>*<br>State 2<br>*<br>1<br>* | Selected O X O O Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | Solved Loads | O | Selected X O O Selected X O O Selected O X O Selected O X O | 1 0 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF X | Forwarded Forwarded Forwarded X O Forwarded X | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 tueue Entries 0x00 | O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O Selected O X O Selected O X O Selected O O X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O | Selected X O O Selected X O O Selected Selected Selected Selected | 1 0 0 Valid Instructions 0 1 0 0 Valid Instructions 0 1 1 0 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 | r Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded X O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 0 | O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads | O | Selected Selected Selected O X O Selected X O X O X O Selected X O X | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 0 1 Valid Instructions 0 0 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF X | Forwarded Solution Forwarded X Solution Forwarded X Solution Forwarded X Solution Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q Q | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 0 tueue Entries 0x00 0 | O O O O O O O O O O | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O O Selected O X O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O Selected O X O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded O O O O Forwarded X O O Forwarded X O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q 0 1 2 Load Q 0 1 2 Load Q 0 1 2 | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 0 tueue Entries 0x00 0 | O O O O O O O O O O | Solved Loads | State 2 * 1 * State 2 * 1 State 2 * 1 State 2 * 1 | Selected O X O Selected O X O Selected O X O X O X O X O X O X O X O O X O X | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected Selected Selected O X O Selected X O X O X O Selected X O X | Valid Instructions O Valid Instructions O O O I O Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions O Valid Instructions O O O O O O O O O O O O O O O O O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 Forwarded X Forwarded X Forwarded X O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q 0 1 2 Load Q 0 1 2 Load Q 0 1 2 | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 0 tueue Entries 0x00 0 0 | O O O O O O O O O O | Solved Loads | State 2 * | Selected O X O O Selected O X O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected X O Selected X O Selected X O O | Valid Instructions O Valid Instructions O O O Valid Instructions O O O 1 Valid Instructions O Valid Instructions O O O O O O O O O O O O O O O O O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 Forwarded X Forwarded X 0 0 Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q 0 1 2 Load Q 0 1 2 Load Q 0 1 2 | Uueue Entries Ox00 O Uueue Entries Ox00 O Uueue Entries Ox00 O O Uueue Entries Ox00 O O Uueue Entries | O O O O O O O O O O | Solved Loads | State 2 | Selected O X O O Selected O X O Selected O X Selected O X Selected O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | | Solved Loads | State 1 | Selected X O O Selected O X O Selected O X O Selected O X O Selected O X O Selected O X O | Valid Instructions O Valid Instructions O O O I O Valid Instructions O O 1 Valid Instructions O Valid Instructions O Valid Instructions O Valid Instructions O O O O O O O O O O O O O O O O O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X 0 0 Forwarded X 0 0 Forwarded X Forwarded X Forwarded X O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q 0 1 2 Load Q 0 1 2 Load Q 0 1 2 | 0x00 0 0 tueue Entries 0 0 0 tueue Entries 0x00 0 0 tueue Entries 0x00 0 0 | O O O O O O O O O O | Solved Loads | State 2 * | Selected O X O O Selected O X O Selected O X Selected O X Selected O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected O X O O Selected O X O Selected O X O Selected O X O Selected Selected Selected Selected Selected Selected | Valid Instructions O Valid Instructions O O O Valid Instructions O O O 1 Valid Instructions O Valid Instructions O O O O O O O O O O O O O O O O O O | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | Uueue Entries Ox00 O Uueue Entries Ox00 O Uueue Entries Ox00 O O Uueue Entries Ox00 O O Uueue Entries Ox00 O Uueue Entries Ox00 O Uueue Entries | O O O O O O O O O O | Solved Loads | State 2 | Selected O Selected O O X O O Selected O O X Selected O O X Selected O X Selected O X Selected O Selected O Selected O Selected O Selected | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected O X O O Selected O X O Selected O X O Selected O X O O Selected O X O O | Valid Instructions O Valid Instructions O O Valid Instructions O O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF Read / Write EBF r Read / Write EBF w | Hit in EBF x Hit in EBF x Hit in EBF | Forwarded Solution Forwarded X O O Forwarded X O O Forwarded X O O O Forwarded X O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | Useue Entries O O O O O O O O O O O O O O O O O O | O O O O O O O O O O | Solved Loads | State 2 | Selected O X O O Selected O X O O X Selected O X Selected O X Selected O X Selected O X Selected O X Selected O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 1 Valid Instructions 0 1 Valid Instructions 1 Valid Instructions 0 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 000 * * (Non) Possible Dependencies Vector 000 010 * (Non) Possible Dependencies Vector 000 010 * * (Non) Possible Dependencies Vector 0010 * * (Non) Possible Dependencies Vector Depen | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | tueue Entries Ox00 O O O Oxounties Oxo | O O O O O O O O O O | Solved Loads | State 2 | Selected O X O O Selected O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected O X O Selected O Selected O Selected O O Selected O O O Selected O O O Selected O O O O Selected O O O O Selected O O O O Selected O O O O Selected | Valid Instructions O Valid Instructions O O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O O 1 Valid Instructions O O O O O O O O O O O O O O O O O O | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector O00 * 010 (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 010 * (Non) Possible Dependencies Vector O01 010 * | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | tueue Entries Oxoo Oxo | O O O O O O O O O O | Solved Loads | State 2 | Selected O X O O Selected O X O O Selected O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected X O O Selected X O O Selected X O O Selected O X O Selected O Selected O Selected O O Selected O O O Selected O O O Selected O O O O Selected O O O O Selected O O O O Selected O O O O Selected | Valid Instructions O Valid Instructions O O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O O 1 Valid Instructions O O O O O O O O O O O O O O O O O O | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector O00 * 010 (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 000 * (Non) Possible Dependencies Vector O00 010 * (Non) Possible Dependencies Vector O01 010 * | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | tueue Entries Oxoo Oxo | O O O O O O O O O O | Solved Loads | State 2 | Selected O X O O Selected O X O O Selected O X | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected O X O O Selected O X O O Selected O X O Selected O X O O Selected O X O O Selected O X O O Selected O Selected O Selected O O Selected O O Selected O O Selected O O O Selected O O O Selected O O O Selected O O O Selected O O O Selected O O O Selected | 1 | New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | * 001 010 (Non) Possible Dependencies Vector 000 * 010 (Non) Possible Dependencies Vector 000 000 * * 000 000 * * 000 000 * * 000 000 000 * * 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 000 00 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF w Read / Write EBF | Hit in EBF A Hit in EBF A Hit in EBF O Hit in EBF | Forwarded X O O O Forwarded X O O O Forwarded X O O O Forwarded X O O O O Forwarded X O O O O Forwarded X | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | Useue Entries Ox00 O | O O O O O O O O O O | Solved Loads | State 2 | Selected O Selected O O X O Selected O O X Selected O X Selected O X Selected O O X Selected O O X Selected O O X Selected O O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions 0 0 0 0 Valid Instructions | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O O T Valid Instructions O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF O Hit in EBF | Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O Forwarded X O O O Forwarded Forwarded Forwarded Forwarded Forwarded Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Q O 1 2 | Useue Entries Ox00 O | O O O O O O O O O O | Solved Loads | State 2 | Selected O Selected O O X Selected O O X Selected O O X Selected O O X Selected O O O X Selected O O O X Selected O O O Selected O O O Selected O O O Selected O O O Selected O O Selected Selected Selected Selected Selected Selected | Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 | Appendix-B Memory Disambiguation Test: SLS (Store-Load-Store) | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | |------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------| | | 000 | · | | 0 | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | w | 0 | 0 | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | Name II and British II | (New) Persille Person descion Verter | D. J. (Maile EDE | ule in ERF | l e | Daniel Datation | l 1- | and Outside Francisco | l c. | ana Ousus Entries I | C-1 | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | 0 | 0x00 | 0 | ore Queue Entries<br>0x00 | Solved Loads 1 | | 0x03 | 000 | r | x | x<br>o | o<br>o | 1 | 0000 | 1 | 0x00<br>0x01 | 0 | | 0.00 | 010 | · · | ^ | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | _ | | _ | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | w | 0 | 0 | О | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lio | ad Queue Entries | l st | ore Queue Entries | Solved Loads | | New Head Folliter | 000 | Read / WIITE LBF | THE III LDF | o o | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | w | О | 0 | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | _ | ad Queue Entries | _ | ore Queue Entries | Solved Loads | | 0.63 | 000 | | | 0 | o | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 001 | w | 0 | 0 | x | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | oad Queue Entries | St | ore Queue Entries | Solved Loads | | Ointer | 000 | / Witte EDF | III LDI | o o | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | w | o | О | o | 1 | o | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | o | 2 | o | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | ad Queue Entries | - | ore Queue Entries | Solved Loads | | 0x03 | 000 | _ | v | X | 0 | 1 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000<br>010 | r | х | 0 | o<br>o | 2 | 0 | 2 | 0x01<br>o | 0 | | | 010 | | | Ü | | | Ů | | Ů | 0 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 001 | w | 0 | o | x | 1 | o | 1 | 0x01 | 0 | | | 010 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | I | | | | | | | | | | | | New Head Pointer | | D 1 / M/ | III E E EDE | F | Danandana Datastian | l 10 | ad Augus Entries | C+ | | C = b = = d = = = d = | | | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Ь. | oad Queue Entries | - | ore Queue Entries | Solved Loads | | 0x03 | 000 | | | × | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | | Read / Write EBF | Hit in EBF<br>× | | | Ь. | | - | | | | 0x03 | 000<br>000 | | | x<br>o | o<br>o | 0 | 0x00<br>o | 0 | 0x00<br>0x01 | 1<br>0 | | | 000<br>000<br>010 | r | х | x<br>o<br>o | 0<br>0<br>0 | 0<br>1<br>2 | 0x00<br>o<br>o | 0 1 2 | 0x00<br>0x01<br>o | 1<br>0<br>0 | | | 000<br>000<br>010<br>(Non) Possible Dependencies Vector | r | х | x<br>o<br>o | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | 0x00<br>o<br>o | 0<br>1<br>2 | 0x00<br>0x01<br>o | 1<br>0<br>0<br>Solved Loads | | New Head Pointer | 000<br>000<br>010<br>(Non) Possible Dependencies Vector | r<br>Read / Write EBF | X<br>Hit in EBF | X<br>O<br>O | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | 0x00<br>0<br>0<br>pad Queue Entries | 0<br>1<br>2<br>St | 0x00<br>0x01<br>o | 1<br>0<br>0<br>Solved Loads | | | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | r | х | X<br>O<br>O | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br><b>Lo</b><br>0<br>1 | 0x00<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o | 0<br>1<br>2<br>St<br>0<br>1 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | New Head Pointer | 000<br>000<br>010<br>(Non) Possible Dependencies Vector | r<br>Read / Write EBF | X<br>Hit in EBF | X<br>O<br>O | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | 0x00<br>0<br>0<br>pad Queue Entries | 0<br>1<br>2<br>St | 0x00<br>0x01<br>o | 1<br>0<br>0<br>Solved Loads | | New Head Pointer | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | r<br>Read / Write EBF | X<br>Hit in EBF | X<br>O<br>O | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br><b>Lo</b><br>0<br>1<br>2 | 0x00<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o<br>o | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0 | | New Head Pointer 0x03 | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000 | r Read / Write EBF | X<br>Hit in EBF | X<br>O<br>O<br>Forwarded<br>O<br>O | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br><b>Lo</b><br>0<br>1<br>2 | 0x00<br>0<br>0<br>oad Queue Entries<br>0x00<br>0 | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01<br>0 | 1<br>0<br>0<br><b>Solved Loads</b><br>1<br>0 | | New Head Pointer 0x03 | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | r Read / Write EBF | X<br>Hit in EBF | X O O Forwarded O O Forwarded | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2<br>Lo<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0 | | New Head Pointer 0x03 New Head Pointer | 000 000 010 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | r Read / Write EBF w Read / Write EBF | X Hit in EBF O | Forwarded O O Forwarded O O O | Dependence Detection O O O Dependence Detection O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0 | | New Head Pointer 0x03 New Head Pointer | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | r Read / Write EBF w Read / Write EBF | X Hit in EBF O | Forwarded O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2<br>Lo<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0<br>Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000 | r Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2<br>Loo<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 0x00 0x01 0 | 1<br>0<br>0<br><b>Solved Loads</b><br>1<br>0<br><b>Solved Loads</b><br>1<br>0 | | New Head Pointer 0x03 New Head Pointer | 000 000 010 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector | r Read / Write EBF w Read / Write EBF | X Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | Lo C C C C C C C C C | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 | 000<br>000<br>010<br>(Non) Possible Dependencies Vector<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000<br>000 | r Read / Write EBF W Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2<br>Loo<br>0<br>1<br>2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 0x00 0x01 0 | 1<br>0<br>0<br>0<br>Solved Loads<br>1<br>0<br>0<br>Solved Loads<br>1<br>0 | | New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 010 (Non) Possible Dependencies Vector 000 000 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 | r Read / Write EBF w Read / Write EBF w Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O Forwarded O O Forwarded O O Forwarded | Dependence Detection O O O O O Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O O | Lo<br> Co<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>1<br>2<br>St<br>0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 | 000 | r Read / Write EBF w Read / Write EBF w Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 St O 1 2 St O 1 2 St O 1 1 St O 1 1 St O 1 St O 1 O O O O O O O O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 | 000 | r Read / Write EBF w Read / Write EBF w Read / Write EBF | X Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 St O 1 2 | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O O 1 2 St O O O O O O O O O | Ox00 Ox01 Ox01 Ox00 Ox00 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 1 St O 1 1 St O 1 St O 1 St O D T St O T T St O T T St O T T St O T T St T T T T T T T T T | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox01 O Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O O 1 2 St O O O O O O O O O | Ox00 Ox01 Ox01 Ox00 Ox00 | 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 1 St O 1 1 St O 1 St O 1 St O D T St O T T St O T T St O T T St O T T St T T T T T T T T T | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox01 O Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 O O O O O O O O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 O O O O O O O O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox01 O Ox00 Ox01 O Ox00 Ox01 O Ox00 Ox01 O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | (Non) Possible Dependencies Vector O00 O00 O00 O00 O00 O00 O00 O00 O00 O | Read / Write EBF W Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 Lo 0 1 1 2 Lo 0 | 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St St St St St St S | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Appendix-B Memory Disambiguation Test: SSL (Store-Store-Load) | | | | | | I | | 14 19 14 14 14 | I | (n. ) n. 11 n. 1 . 1 . 1 . 1 | I n 1/14/1: =n= | | | | I 1 10 F t 1 | | |-----------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------| | | Position<br>0 | Instructions<br>SD | L / S Queue Allocation<br>0x00 | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector<br>000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | Store Queue Entries 0 0x00 | | | 1 | SD<br>SD | 0x00<br>0x01 | 1 | 0 | x<br>o | 1 | 0x01 | * | w | o | 0 | 0 | | 1 0000 | | | 2 | LD | 0x00 | 1 | 0 | 0 | 1 | 0.02 | * | " | Ů | o | 0 | 2 0 | 2 0 | | | | • | | | | | | | | • | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | ΙĔ | 0 | SD | 0x00 | 1 | 1 | х | 0 | | 000 | | | 0 | 0 | 0 0 | 0 0x00 | | РАТН | 1 | SD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | w | 0 | 0 | О | 0 | 1 0 | | | 2 | LD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | es Store Queue Entries | | | 0 | SD | 0x00 | 1 | 1 | X | 0 | New Head Folliter | 000 | Read / Wille EBF | nit iii EBF | o | o Dependence Detection | 0 0 | 0 0x00 | | | 1 | SD | 0x01 | 1 | 0 | 0 | 1 | 0x01 | * | w | 0 | 0 | 0 | 1 0 | 1 0 | | | 2 | LD | 0x00 | 1 | 0 | o | 1 | | * | | | 0 | 0 | 2 o | 2 o | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | _ | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | <u> </u> | | | 0 1 | SD<br>SD | 0x00<br>0x01 | 1 | 0 1 | o<br>x | 1<br>0 | 0x00 | 000 | w | o | 0 | 0 | | 0 0<br>1 0x01 | | | 2 | LD | 0x00 | 1 | 0 | ^ | 1 | 0.00 | * | ** | | 0 | 0 | 2 0 | 2 0 | | | | | | _ | | | | | | | ı | _ | <u> </u> | 1-1 | | | _ | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | s Store Queue Entries | | ≟ | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | | * | | | 0 | 0 | 0 0 | 0 0 | | РАТН | 1 | SD | 0x01 | 1 | 1 | х | 0 | 0x00 | 000<br>* | w | 0 | 0 | 0 | 0 | 1 0x01 | | | 2 | LD | 0x00 | 1 | 0 | 0 | 1 | l | * | <u> </u> | <u> </u> | 0 | 0 | 2 o | 2 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | s Store Queue Entries | | | 0 | SD | 0x00 | 1 | 0 | 0 | 1 | ew nead i omitei | * | , write LBF | III III LDF | o | 0 | 0 0 | 0 0 | | | 1 | SD | 0x01 | 1 | 1 | x | 0 | 0x00 | 000 | w | o | 0 | 0 | 1 0 | 1 0x01 | | | 2 | LD | 0x00 | 1 | 0 | o | 1 | | * | <u> </u> | | o | 0 | 2 o | 2 o | | | | | | | | | | | | | | | | | | | | I | | | | | | | T | | T = | | | | T. 10 | 10. 0 5.1 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Queue Entri | 1.1 | | | 0 1 | SD<br>SD | 0x00<br>0x01 | 1 | 0 0 | 0 | 1<br>1 | 0x00 | * | r | o | 0 | 0 | 0 0x00<br>1 0 | | | | 2 | | | 1 | 1 1 | 1 . l | 0 | 1 | 044 | l ' | ı ĭ | _ | | <del></del> | <del></del> | | | | LD | 0x00 | 1 | <b>1</b> + | , x | U | | 011 | | | 0 | 0 | 2 0 | <b>2</b> 0 | | | | LD | 0x00 | <u> </u> | 1 1 | х | 0 | | 011 | | | 0 | 0 | 2 0 | 121 0 | | | Position | Instructions | L / S Queue Allocation | Valid Instructions | State 0 | X Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | o<br>Forwarded | O Dependence Detection | Load Queue Entri | | | ¥ 5 | | Instructions<br>SD | | _ | State 0 | Selected o | | | | Read / Write EBF | Hit in EBF | | | | | | РАТН 2 | Position 0 1 | Instructions SD SD | L / S Queue Allocation<br>0x00<br>0x01 | Valid Instructions 1 1 | + | | Valid Instructions 1 1 | New Head Pointer | (Non) Possible Dependencies Vector * * | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection o o | Load Queue Entrico | es Store Queue Entries 0 0 1 0 | | | Position 0 | Instructions<br>SD | L / S Queue Allocation<br>0x00 | _ | 0 | 0 | Valid Instructions | | | | | Forwarded<br>0 | Dependence Detection | Load Queue Entri | es Store Queue Entries | | | Position 0 1 2 | Instructions SD SD LD | L / S Queue Allocation<br>0x00<br>0x01<br>0x00 | Valid Instructions 1 1 1 | 0<br>0<br>1 | о<br>о<br>х | Valid Instructions 1 1 0 | 0x00 | (Non) Possible Dependencies Vector * * 011 | r | o | Forwarded<br>0<br>0<br>0 | Dependence Detection o o o | Load Queue Entri 0 | Store Queue Entries | | | Position 0 1 | Instructions SD SD | L / S Queue Allocation | Valid Instructions 1 1 | 0 | о<br>о<br>х | Valid Instructions 1 1 | | (Non) Possible Dependencies Vector * * | | | Forwarded<br>0<br>0 | Dependence Detection o o | Load Queue Entrico | Store Queue Entries | | | Position 0 1 2 Position | Instructions SD SD LD Instructions | L / S Queue Allocation<br>0x00<br>0x01<br>0x00 | Valid Instructions 1 1 1 | 0<br>0<br>1<br>State 0 | o<br>o<br>x | Valid Instructions 1 1 0 Valid Instructions | 0x00 | (Non) Possible Dependencies Vector * * 011 | r | o | Forwarded O O O Forwarded | Dependence Detection o o o Dependence Detection | Load Queue Entri 0 | es Store Queue Entries 0 0 0 1 0 2 0 Store Queue Entries | | | Position 0 1 2 Position 0 | Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | Valid Instructions 1 1 0 Valid Instructions | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded o o o Forwarded | Dependence Detection O O O O Dependence Detection O | Load Queue Entric 0 | Store Queue Entries 0 0 0 1 0 2 0 Store Queue Entries 0 0 0 | | | Position 0 1 2 Position 0 | Instructions SD SD LD Instructions SD SD SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions | 0<br>0<br>1<br><b>State 0</b> | o<br>o<br>x<br>Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O O Forwarded O O O | Dependence Detection O O O O Dependence Detection O O O | Load Queue Entric 0 | Store Queue Entries | | | Position 0 1 2 Position 0 1 2 2 | Instructions SD SD LD Instructions SD SD LD LD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | 0<br>0<br>1<br><b>State 0</b><br>0<br>0 | Selected O X | Valid Instructions 1 1 0 Valid Instructions 1 0 | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector * * 011 | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O O O | Load Queue Entrice | Store Queue Entries | | | Position 0 1 2 Position 0 1 2 Position 1 2 | Instructions SD SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0<br>0<br>1<br>State 0<br>0<br>0<br>1 | Selected O X Selected O X Selected | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions | 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O Dependence Detection | Load Queue Entri 0 | es Store Queue Entries 0 0 0 1 0 2 0 es Store Queue Entries 0 0 0 1 0 2 0 Store Queue Entries 0 0 0 2 0 Store Queue Entries | | | Position 0 1 2 Position 0 1 2 2 | Instructions SD SD LD Instructions SD SD LD LD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 | 0<br>0<br>1<br><b>State 0</b><br>0<br>0 | Selected O X | Valid Instructions 1 1 0 Valid Instructions 1 0 | 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * 011 (Non) Possible Dependencies Vector * * 011 | r<br>Read / Write EBF | O<br>Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O O O | Load Queue Entrice | Store Queue Entries | | 3 РАТН | Position 0 1 2 Position 0 1 2 Position 0 1 2 | Instructions SD SD LD Instructions SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 | 0 0 1 1 State 0 0 0 1 1 State 0 1 | Selected O X Selected X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | Load Queue Entri 0 | Store Queue Entries | | 3 РАТН | Position O 1 2 Position O 1 2 Position O 1 1 2 | Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 | Selected O X Selected O X Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entries | | РАТН | Position 0 | Instructions SD SD SD SD SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 | Selected O O X Selected O O X Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri 0 | Store Queue Entries | | 3 РАТН | Position | Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | 0 | Selected Selected Selected X Selected X Selected X | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 0 1 1 0 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O Dependence Detection | Load Queue Entri 0 | Store Queue Entries | | 3 РАТН | Position 0 | Instructions SD SD SD SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | 0 0 1 | Selected O O X Selected O O X Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 3 РАТН | Position | Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 1 1 1 1 1 1 1 | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection O O O O O Dependence Detection O O O O O O Dependence Detection | Load Queue Entri 0 | Store Queue Entries | | 3 РАТН | Position | Instructions SD SD SD SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 1 1 1 1 1 1 1 | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 3 РАТН | Position | Instructions SD SD SD SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | O | Selected O X Selected X O O Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | r Read / Write EBF r Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 3 РАТН | Position 0 | Instructions SD SD SD LD Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O State 0 O O O O O O O State 0 O O O O O O O O O | Selected O O X Selected X O O Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection | Load Queue Entri- O | Store Queue Entries | | РАТН 3 | Position | Instructions SD SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O O O O O O O O | Selected Selected X Selected X O Selected X O Selected X O Selected X X X X X X X X X X X X X | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x00 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 4 PATH 3 PATH | Position 0 | Instructions SD SD SD LD Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | O O 1 State 0 O O 1 State 0 1 1 O State 0 1 1 O State 0 O O O O O O O State 0 O O O O O O O O O | Selected O O X Selected X O O Selected X O O Selected X O O Selected X O O O | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection O O O O O O Dependence Detection | Load Queue Entri- O | Store Queue Entries | | 4 PATH 3 PATH | Position | Instructions SD SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O O Selected X O O Selected X O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | РАТН 3 | Position | Instructions SD SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O Selected X O Selected X O Selected X X X X X X X X X X X X X | Valid Instructions 1 1 0 Valid Instructions 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 4 PATH 3 PATH | Position 0 | Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected Selected Selected Selected Selected Selected Selected Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x01 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- 0 | Store Queue Entries | | 4 PATH 3 PATH | Position | Instructions SD SD LD Instructions SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | | 4 PATH 3 PATH | Position | Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X Selected X O O Selected X O O Selected X O O Selected X O O Selected X O O X Selected X O O X X O O Selected X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X X O O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X O X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 Valid Instructions 0 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | | 4 PATH 3 PATH | Position | Instructions SD SD LD | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X O O Selected X O O O Selected X O O O Selected X O O O Selected O X O O Selected O X O O O Selected O O O O O O O O O O O O O O O O O O O | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | | 5 PATH 4 PATH 3 | Position | Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X O O Selected X O O O Selected X O O O Selected X O O Selected O X O O Selected Selected O X O O Selected O X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | | 5 PATH 4 PATH 3 | Position | Instructions SD SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD SD LD | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions | State 0 | Selected Selected X Selected X O O Selected X O O Selected X O O Selected X | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 New Head Pointer | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | | РАТН 3 РАТН 3 | Position | Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD SD LD Instructions SD LD Instructions SD LD Instructions | L / S Queue Allocation | Valid Instructions 1 1 1 1 1 Valid Instructions 1 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions 1 1 1 Valid Instructions | State 0 | Selected X O O Selected X O O O Selected X O O O Selected X O O Selected O X O O Selected Selected O X O O Selected O X O O Selected | Valid Instructions 1 1 0 Valid Instructions 1 1 0 Valid Instructions 0 1 1 1 Valid Instructions 0 1 1 1 Valid Instructions 1 1 Valid Instructions 1 0 1 Valid Instructions | 0x00 New Head Pointer 0x01 New Head Pointer 0x01 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector * * * * * * * * * * * * * * * * * * | Read / Write EBF Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Queue Entri- O | Store Queue Entries | Appendix-B Memory Disambiguation Test: SSL (Store-Store-Load) | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Qu | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | |----------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | * | 0<br>v | 0 | 0x02 | 000<br>000 | w | 0 | 0 | o<br>o | 0 | 0 | 0 0x00<br>1 0x01 | 0 | * | 0 | 0 0 | | 0 | 0 | o | 1 | 0,02 | * | " | Ů | 0 | 0 | 2 | 0 | 2 0 | 0 | 1 | x | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Or | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | * | 0 | 0 | New Head Fornter | 000 | Read / Write LBF | THEHLED | X | o | 0 | 0x00 | 0 0x00 | 0 | * | 0 | 0 | | 0 | 0 | 0 | 1 | 0x01 | * | r | х | 0 | 0 | 1 | 0 | 1 0 | 0 | 1 | × | 0 | | 0 | 1 1 | X | 0 | | 010 | <u> </u> | | 0 | 0 | 2 | 0 | 2 o | 0 | * | 0 | U | | Solved Loads | State 1 | <del> </del> | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Qu | ieue Entries | Store Queue Entries | Solved Loads | State 2 | <del> </del> | Valid Instructions | | 0 | 1 | o<br>x | 0 | 0x02 | 000<br>000 | w | 0 | 0 | 0 | 1 | 0 | 0 0x00<br>1 0x01 | 0 | * | 0 | 0 | | 0 | 1 | 0 | 1 | | * | | | 0 | 0 | 2 | 0 | 2 o | 0 | 1 | х | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Qu | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | x | 0 | 0x02 | 000<br>000 | w | 0 | 0 | 0 | 0 | 0 | 0 0x00<br>1 0x01 | 0 | * | 0 | 0 | | 0 | 0 | 0 | 1 | 0.02 | * | l vv | 0 | 0 | o<br>o | 2 | 0 | 2 0 | 0 | 1 | o<br>x | 0 | | Colodia | 5 | 6.1 | W-P-H | I No. 10 of Balance | (No.) Positive Positive Assistance | D 4 /14/21 EDE | LINE SERVE | Francisco de d | David Salada | 1 0 - | Futulas | Sharra Ossassa Francisco | Col collection | | | M.P.H | | Solved Loads 0 | State 1 | Selected<br>0 | Valid Instructions 1 | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection o | 0 | 0x00 | Store Queue Entries 0 0 | Solved Loads 1 | State 2 | Selected<br>x | Valid Instructions 0 | | 0 | * | o | 0 | 0x00 | 000 | r | х | х | 0 | 1 | 0 | 1 0x01 | 0 | * . | 0 | 0 | | 0 | 1 | X | 0 | | 001 | | | 0 | 0 | 2 | 0 | 2 0 | 0 | * | 0 | 0 | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Qu | ueue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 * | x<br>o | 0 | 0x02 | 000<br>000 | l w | 0 | 0 | o<br>o | 0 | 0 | 0 0x00<br>1 0x01 | 0 0 | * | 0 | 0 | | 0 | 1 | 0 | 1 | | * | · | _ | 0 | 0 | 2 | 0 | 2 0 | 0 | 1 | x | 0 | | | | | | | | | | | | | | | | | | | | Solved Loads | State 1 | Selected | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Load Qu | ieue Entries | Store Queue Entries | Solved Loads | State 2 | Selected | Valid Instructions | | 0 | 1 | Х | 0 | 0v01 | 000<br>* | | 0 | 0 | 0 | 0 | 0x00 | 0 0x00 | 0 | * | 0 | 0 | | 0 | * | 0 | 0 | 0x01 | 011 | W | 0 | 0 | o<br>X | 2 | 0 | 1 o o | 0 | * | x<br>o | 0<br>0 | | | | | | | | | | • | | | | • | | | | | | | | | | | for 1 = 111 = 1 + 1 + 1 + 1 | | | | | | | | | | | | | Solved Loads 0 | State 1 | Selected<br>0 | Valid Instructions | New Head Pointer | (Non) Possible Dependencies Vector * | Read / Write EBF | Hit in EBF | Forwarded<br>0 | Dependence Detection | Load Qu | 0x00 | Store Queue Entries | Solved Loads | State 2 | Selected<br>x | Valid Instructions | | 0<br>0 | _ | | 1<br>0 | New Head Pointer 0x00 | * 000 | Read / Write EBF | Hit in EBF | 0<br>0 | · | Load Qu | 0x00<br>o | 0 0<br>1 0x01 | 1<br>0 | State 2 | x<br>o | 0<br>0 | | 0 | 0 | 0 | 1 | | * | | | 0 | 0 | 0<br>1<br>2 | 0x00 | 0 0 | 1 | State 2 1 * * | х | 0 | | 0<br>0 | 0 | 0 | 1<br>0 | | * 000 | | | 0<br>0<br>0 | 0 | 0<br>1<br>2 | 0x00<br>o | 0 0<br>1 0x01 | 1<br>0 | State 2 1 * * State 2 | x<br>o | 0<br>0 | | 0<br>0<br>0<br><b>Solved Loads</b> | 0<br>1<br>* | O<br>X<br>O<br>Selected | 1<br>0<br>0 | 0x00 New Head Pointer | *<br>000<br>011 | W Read / Write EBF | O<br>Hit in EBF | 0<br>0<br>0<br>Forwarded | O O X Dependence Detection | 0<br>1<br>2 | 0x00<br>o<br>o<br>ueue Entries | 0 0 0 0 1 0 0 0 1 2 0 0 0 0 0 0 0 0 0 0 | 1<br>0<br>0 | 1<br>*<br>* | X<br>O<br>O<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b> | | 0<br>0<br>0<br>Solved Loads | 0<br>1<br>* | 0<br>X<br>0 | 1<br>0<br>0<br>Valid Instructions | 0x00 | * 000 011 (Non) Possible Dependencies Vector 000 | w | 0 | o<br>o<br>o<br>Forwarded | O O X | 0<br>1<br>2 | 0x00<br>0<br>0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1<br>0<br>0<br>Solved Loads | 1<br>*<br>* | x<br>o<br>o<br>Selected | 0<br>0<br>0 | | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | 0<br>1<br>* | O<br>X<br>O<br>Selected | 1<br>0<br>0<br>Valid Instructions<br>0<br>1 | 0x00 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * | W Read / Write EBF | O<br>Hit in EBF | O<br>O<br>O<br>Forwarded | O O X Dependence Detection O O | 0<br>1<br>2 | 0x00<br>0<br>0<br>ueue Entries | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1<br>0<br>0<br><b>Solved Loads</b><br>0 | 1<br>*<br>* | X<br>O<br>O<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | 0<br>0<br>0<br><b>Solved Loads</b><br>0 | 0<br>1<br>*<br>State 1<br>1<br>1 | O<br>X<br>O<br>Selected | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * 011 | Read / Write EBF | O Hit in EBF | Forwarded 0 0 0 | Dependence Detection O X | 0<br>1<br>2<br>Load Qu<br>0<br>1<br>2 | 0x00<br>0<br>0<br>0<br>0x00<br>0 | 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 | 1<br>0<br>0<br><b>Solved Loads</b><br>0 | 1 * * * * * * * * * * * * * * * * * * * | X<br>O<br>O<br>Selected | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0 | 0<br>1<br>*<br>State 1<br>1<br>1<br>*<br>State 1 | Selected X O Selected O Selected O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * 011 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | Hit in EBF | Forwarded O O O Forwarded O O O O | Dependence Detection O X Dependence Detection O X Dependence Detection O | 0<br>1<br>2<br>Load Qu<br>0<br>1<br>2 | 0x00<br>0<br>0<br>0x00<br>0<br>0 | 0 | Solved Loads Solved Loads O Solved Loads O | 1 * * * * * * * * * * * * * * * * * * * | Selected O X O O Selected O X O O Selected O O Selected O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 | | Solved Loads 0 0 0 Solved Loads 0 0 0 Solved Loads | 0<br>1<br>*<br>State 1<br>1<br>1 | Selected X O O Selected | 1<br>0<br>0<br>Valid Instructions<br>0<br>1<br>0 | 0x00 New Head Pointer 0x01 | * 000 011 (Non) Possible Dependencies Vector 000 * 011 (Non) Possible Dependencies Vector | Read / Write EBF | O Hit in EBF | Forwarded Forwarded Forwarded | Dependence Detection O X Dependence Detection O X Dependence Detection | 0<br>1<br>2<br>Load Qu<br>0<br>1<br>2 | 0x00<br>0<br>0<br>ueue Entries<br>0x00<br>0 | 0 | 1<br>0<br>0<br><b>Solved Loads</b><br>0<br>0 | 1 * * * * * * * * * * * * * * * * * * * | Selected Selected Selected Selected | 0<br>0<br>0<br><b>Valid Instructions</b><br>0<br>0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads<br>0<br>0 | State 1 | Selected X O Selected X O O Selected X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector O00 * 011 (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O X Dependence Detection O O O O | Load Qu<br>0 1 2 2 Load Qu<br>0 1 2 2 Load Qu<br>0 1 2 2 Load Qu | Ox00 O O O O O O O O O O O O O O O O O O | O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected O X O Selected O X O Selected X O X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 0 | | 0<br>0<br>0<br>Solved Loads<br>0<br>0<br>0<br>Solved Loads | 0 | Selected X O O Selected X O O O | Valid Instructions 0 1 0 Valid Instructions 0 1 0 Valid Instructions 0 0 | 0x00 New Head Pointer 0x01 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * 011 (Non) Possible Dependencies Vector 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O X Dependence Detection O O | Load Qu<br>0 1 2 2 Load Qu<br>0 1 2 2 Load Qu<br>0 1 2 2 Load Qu | 0x00<br>0<br>0<br>0x00<br>0<br>0<br>0x00<br>0 | O | Solved Loads Solved Loads Solved Loads O O O O O O O O O O O O O O O O O O | State 2 * 1 * State 2 * 1 * State 2 * * * * * * * * * * * * * * | Selected O X O Selected O X O Selected X O X O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 0 Valid Instructions 0 0 | | O | State 1 | Selected Selected Selected Selected X O O O Selected X X O O X X O O O Selected X O O O O O O O O O O O O O O O O O O | Valid Instructions 0 1 0 Valid Instructions 0 0 1 Valid Instructions 0 0 1 Valid Instructions 0 0 0 1 | 0x00 New Head Pointer 0x01 New Head Pointer 0x02 | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 O O O O O O O O O O O O O O O O O O | O | Solved Loads | 1 | Selected O X O Selected O X O Selected O O X O Selected O O O O | Valid Instructions O O Valid Instructions O O Valid Instructions O O O Valid Instructions O O O | | O | State 1 | Selected Selected Selected Selected Selected O Selected O | Valid Instructions O 1 0 Valid Instructions O 1 1 0 Valid Instructions O 1 Valid Instructions O 0 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer | * 000 011 (Non) Possible Dependencies Vector 000 * 011 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded Forwarded Forwarded O O Forwarded O O O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu Load Qu Load Qu Load Qu Load Qu Load Qu 0 1 2 | Ox00 O O O O O O O O O O O O O O O O O O | O | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | Selected Selected Selected Selected Selected O X O | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions | | O O O O O O O O O O | State 1 | Selected X O O Selected X O O Selected O X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector O00 * O11 (Non) Possible Dependencies Vector O00 O00 * (Non) Possible Dependencies Vector O00 O00 * (Non) Possible Dependencies Vector O00 * (Non) Possible Dependencies Vector O00 * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 O O O O O O O O O O O O O O O O O O | O | Solved Loads | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X | Valid Instructions O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | O | State 1 | Selected Selected Selected Selected X O O O Selected X X O O X X O O O Selected X O O O O O O O O O O O O O O O O O O | Valid Instructions 0 1 0 Valid Instructions 0 0 1 1 Valid Instructions 0 0 1 Valid Instructions 0 0 0 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer | (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 000 000 000 000 | Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 O O O O O O O O O O O O O O O O O O | O | Solved Loads | 1 | Selected O X O Selected O X O Selected O O X O Selected O O O O | Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 0 Valid Instructions 0 0 | | Solved Loads | State 1 | Selected X O O Selected X O O Selected O X O O Selected O X O Selected O Selected O Selected O Selected | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector O00 * 011 (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * (Non) Possible Dependencies Vector 000 000 * | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O | Forwarded O O O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O X | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 | O | Solved Loads | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected O X O Selected O O X O O O X | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected X O O Selected C X O O Selected O X O Selected O X O Selected O X O O Selected O X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O O O O Forwarded O O O Forwarded O O O O Forwarded | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 | O | Solved Loads | 1 | Selected O X O Selected O X O Selected O X Selected O X Selected O X Selected O X Selected O X Selected | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected X O O Selected C X O O Selected O X O Selected O X O Selected O X O O Selected O X O O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O X | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 Ox00 | O | Solved Loads | 1 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O O X Selected O O O O O O O O O O O O O O O O O O | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected X O Selected X O Selected X Selected X Selected X Selected X | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O Forwarded O O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Jeue Entries Ox00 O Ox00 O | O | Solved Loads | 1 | Selected O X O O Selected O X O O Selected O X Selected O X Selected O X Selected O X Selected O X Selected O X O O X | Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF A Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O X Dependence Detection O O O Dependence Detection O O O Dependence Detection O O O Dependence Detection O O Dependence Detection | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Jeue Entries Ox00 O Jeue Entries Oxo0 Oxo Oxo Oxo Oxo Oxo Oxo Ox | O | Solved Loads | State 2 | Selected O Selected O Selected O X O Selected O X Selected O O X Selected O O X Selected O Selected Selected Selected Selected Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected X O Selected X O Selected X O Selected X O Selected O X O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 Valid Instructions O 0 0 O 0 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O Forwarded O O O O O Forwarded O O O O Forwarded O O O O Forwarded O O O O O Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 1 2 | Jeue Entries Ox00 O Jeue Entries Ox00 Oxouther in the service of the service oxouther in serv | O | Solved Loads | State 2 | Selected O X O O Selected O X O O Selected O X O O Selected O X O O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions O O O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O Valid Instructions O O O O O Valid Instructions | | Solved Loads | State 1 | Selected Selected Selected Selected Selected Selected X O Selected X O Selected X O Selected X O Selected O X O | Valid Instructions O 1 0 Valid Instructions O 1 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 1 Valid Instructions O 0 1 Valid Instructions O 0 0 O 0 Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 2 | Jeue Entries Ox00 O Jeue Entries Ox00 Oxouther in the service of the service oxouther in serv | O | Solved Loads | 1 | Selected O X O O Selected O X O O Selected O X O O Selected O X O O Selected O O X O O O O O O O O O O O O O O O O | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O O O O O O O O O O O O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O O 1 Valid Instructions O Valid Instructions O O Valid Instructions O O O Valid Instructions O O O O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x02 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF T Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O X Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 Load Qu 0 1 2 | Jeue Entries Ox00 O Jeue Entries Oxo0 Oxo Oxo Oxo Oxo Oxo Oxo Ox | Store Queue Entries | Solved Loads | 1 | Selected O Selected O Selected O Selected O Selected O Selected O X Selected O X Selected O Selected O Selected O Selected O Selected O Selected O O Selected O O Selected O O Selected O O Selected O O O Selected | Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O | | Solved Loads | State 1 | Selected | Valid Instructions O O Valid Instructions O O O 1 Valid Instructions O O O 1 Valid Instructions O O 1 Valid Instructions O O O Valid Instructions O O Valid Instructions O O Valid Instructions | New Head Pointer 0x01 New Head Pointer 0x02 New Head Pointer 0x02 New Head Pointer 0x00 New Head Pointer 0x00 | (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF W Read / Write EBF W Read / Write EBF | Hit in EBF O Hit in EBF O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Load Qu 2 | Jeue Entries Ox00 O Jeue Entries Oxo0 Oxo Jeue Entries Oxo0 Oxo Jeue Entries Oxo0 Oxo Oxo Jeue Entries Oxo0 Oxo Oxo Oxo Jeue Entries Oxo Oxo Oxo Oxo Jeue Entries Oxo Oxo Oxo Oxo Jeue Entries Oxo Oxo Oxo Oxo Jeue Entries Oxo Oxo Oxo Oxo Oxo Jeue Entries Oxo Oxo Oxo Oxo Oxo Oxo Oxo Ox | O | Solved Loads | 1 | Selected O Selected O Selected O Selected O Selected O Selected O X Selected X O O Selected X O O Selected Selected X O O Selected | Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O Valid Instructions O O O O Valid Instructions O O O O O O O O O O O O O O O O O O | Appendix-B Memory Disambiguation Test: SSL (Store-Store-Load) | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | Lo | ad Queue Entries | St | ore Queue Entries | Solved Loads | |------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------| | | 000 | , | | 0 | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | x | х | 0 | 1 | o | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | L | ad Queue Entries | C+ | ore Queue Entries | Solved Loads | | New Head Folliter | 000 | Read / WIILE EBF | HIL III EBF | O O | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | w | o | 0 | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 010 | | | 0 | Х | 2 | 0 | 2 | 0 | 0 | | Name to the table of | (New York and Associated Association (New York and Associated Association (New York and Associated | L B. of Autonorphic | Utata EBE | | D | 1 1- | ad Outre Entwice | l ca | Ourus Futuisa | Calculation Is | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | 0 | ad Queue Entries<br>0x00 | 0 | ore Queue Entries<br>0x00 | Solved Loads | | 0x03 | 000 | r | x | x | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | l 10 | ad Queue Entries | l c+ | ore Queue Entries | Solved Loads | | New Head Political | 000 | Reau / Wille EBF | HIL III EDF | o | o Dependence Detection | 0 | 0x00 | 0 | 0x00 | 1 | | 0x03 | 000 | r | x | x | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | 0 | 0 | | | (1) 10 11 0 1 1 1 1 1 | l n 1/14/11 pp. 1 | uni ene | | | 1 1- | - d O | l ca | O Ft | | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | 0 | ad Queue Entries<br>0x00 | 0 | ore Queue Entries<br>0x00 | Solved Loads | | 0x03 | 000 | w | О | 0 | 0 | 1 | 0 | 1 | 0x00 | 0 | | | 000 | | | 0 | 0 | 2 | 0 | 2 | o | 0 | | | (1) \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | | | | -10 5:: | | | | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | ad Queue Entries | - | ore Queue Entries | Solved Loads | | 0x03 | 000 | r | x | o<br>X | o<br>o | 1 | 0x00<br>o | 1 | 0x00<br>0x01 | 1 0 | | | 000 | | | О | 0 | 2 | o | 2 | 0 | 0 | | | | | | | | | | | | | | | (1) 12 11 2 1 1 1 1 1 | | | | | | - I Company Fortige | L c. | Out of Futule | | | New Head Pointer | (Non) Possible Dependencies Vector 000 | Read / Write EBF | Hit in EBF | Forwarded<br>o | Dependence Detection o | 0 | ad Queue Entries<br>0x00 | 0 | ore Queue Entries<br>0x00 | Solved Loads 1 | | 0x03 | 000 | w | o | 0 | 0 | 1 | 0 | 1 | 0x01 | 0 | | | 010 | | | o | х | 2 | o | 2 | o | 0 | | | | | | | | | | _ | | | | | | | | | | | | | | | | New Head Pointer | (Non) Possible Dependencies Vector | Read / Write EBF | Hit in EBF | Forwarded | Dependence Detection | - | ad Queue Entries | - | ore Queue Entries | Solved Loads | | | 000 | | | 0 | 0 | 0 | 0x00 | 0 | 0x00 | 1 | | New Head Pointer 0x03 | | Read / Write EBF | Hit in EBF | | • | - | | - | | | | | 000<br>000<br>000 | | | o<br>o | 0 | 0<br>1<br>2 | 0x00<br>o<br>o | 0<br>1<br>2 | 0x00<br>0x01<br>o | 1<br>0 | | | 000<br>000<br>000<br>(Non) Possible Dependencies Vector | | | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | 0x00<br>o<br>o<br>ad Queue Entries | 0<br>1<br>2 | 0x00<br>0x01<br>o | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br><b>Lo</b> | 0x00<br>o<br>o<br>ad Queue Entries<br>0x00 | 0<br>1<br>2<br><b>St</b> | 0x00 0x01 0 ore Queue Entries 0x00 | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector | w | 0 | o<br>o<br>o<br>Forwarded | o<br>o<br>o<br>Dependence Detection | 0<br>1<br>2 | 0x00<br>o<br>o<br>ad Queue Entries | 0<br>1<br>2 | 0x00<br>0x01<br>o | 1<br>0<br>0<br>Solved Loads | | 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | W Read / Write EBF | O<br>Hit in EBF | o<br>o<br>o<br>Forwarded | O O O O O O O O O O O O O O O O O O O | 0<br>1<br>2<br><b>Lo</b><br>0<br>1 | 0x00 o o ad Queue Entries 0x00 o | 0<br>1<br>2<br>St<br>0<br>1 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01 | 1<br>0<br>0<br>50 <b>Ved Loads</b> | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 0 | Dependence Detection O X | 0<br>1<br>2<br><b>Lo</b><br>0<br>1<br>2 | 0x00<br>o<br>o<br>ad Queue Entries<br>0x00<br>o | 0<br>1<br>2<br><b>St</b><br>0<br>1<br>2 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01<br>0 | 1<br>0<br>0<br><b>Solved Loads</b><br>1<br>0 | | 0x03 | 000 000 (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector | Read / Write EBF | O<br>Hit in EBF | Forwarded O O Forwarded | Dependence Detection O X Dependence Detection | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 o o ad Queue Entries 0x00 o o | 0<br>1<br>2<br>St<br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1<br>0<br>0<br>Solved Loads<br>1<br>0<br>0 | | 0x03 New Head Pointer 0x03 | 000<br>000<br>000<br>(Non) Possible Dependencies Vector<br>000<br>000 | Read / Write EBF | O<br>Hit in EBF | Forwarded 0 0 0 | Dependence Detection O X | 0<br>1<br>2<br><b>Lo</b><br>0<br>1<br>2 | 0x00<br>o<br>o<br>ad Queue Entries<br>0x00<br>o | 0<br>1<br>2<br><b>St</b><br>0<br>1<br>2 | 0x00<br>0x01<br>0<br>ore Queue Entries<br>0x00<br>0x01<br>0 | 1<br>0<br>0<br><b>Solved Loads</b><br>1<br>0 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O | 0<br>1<br>2<br>0<br>1<br>2 | 0x00 0 0 ad Queue Entries 0x00 0 ad Queue Entries | 0<br>1<br>2<br><b>St</b><br>0<br>1<br>2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O | Lo<br> 0<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 | 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer | 000 000 (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O Dependence Detection | Lo<br> 0<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2<br> St<br> St | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O O Dependence Detection | Lo<br> 0<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2<br> Lo<br> 0 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 | 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2 | 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 | 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 000 010 (Non) Possible Dependencies Vector 000 000 000 000 000 (Non) Possible Dependencies Vector | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O O O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O Dependence Detection O O O Dependence Detection | Lo<br> O<br> 1<br> 2<br> Lo<br> O<br> 1<br> 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2<br> St<br> St | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1 0 0 0 0 Solved Loads 1 0 0 0 0 Solved Loads 1 0 0 0 0 0 Solved Loads | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 000 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O Forwarded O X O Forwarded X X | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo<br> 0<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2<br> Lo<br> 0<br> 1<br> 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 | 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2<br> St<br> 0<br> 1<br> 2 | 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF X | Forwarded O O O Forwarded O X O Forwarded O X O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 0 ad Queue Entries 0x00 0 0 | 0 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF W Read / Write EBF | O Hit in EBF O Hit in EBF | Forwarded O O O O Forwarded O X O O Forwarded O X O O Forwarded | Dependence Detection O X Dependence Detection O O O O Dependence Detection O O Dependence Detection O O Dependence Detection O Dependence Detection | Lo C C C C C C C C C | 0x00 0 ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | O | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 000 (Non) Possible Dependencies Vector 000 010 (Non) Possible Dependencies Vector 000 000 000 000 (Non) Possible Dependencies Vector 000 000 000 000 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF A Hit in EBF X | Forwarded O O O Forwarded O X O Forwarded O X O | Dependence Detection O X Dependence Detection O O O O O O O O O O O O O O O O O O | Lo C C C C C C C C C | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 0 ad Queue Entries 0x00 0 0 | 0 | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 | 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O O O Forwarded O X O Forwarded O Forwarded O Forwarded O To O O O O O O O O O O O O O | Dependence Detection O X Dependence Detection O O O O O O O O Dependence Detection O O O O Dependence Detection O O O O O O O O O O O O O O O O O O | Lo Co Co Co Co Co Co Co | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 ad Queue Entries | O 1 2 St O 1 2 St O 1 2 St O 1 2 St O C C C C C C C C C | 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries 0x00 0x01 0 ore Queue Entries | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O O Forwarded O X O | Dependence Detection O X Dependence Detection O O O O O Dependence Detection O O O Dependence Detection O O O O Dependence Detection O O O O Dependence Detection | Lo 0 1 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 | St O 1 2 O 1 2 O O O O O O O O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox01 O Ox01 O Ox01 O Ox01 O | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O X O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St St O St St O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox00 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O X O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O O C C C C C C C C | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox00 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O X O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St St O St St O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox00 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O X X X X X X X X X X X X | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 Lo 0 1 2 Lo 0 1 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries | St O 1 2 1 2 St O 1 1 C C C C C C C C | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox01 O Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 | Solved Loads | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded O O O O Forwarded O X O Forwarded O X O Forwarded O X O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | St O 1 2 O D D D D D D D D | 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O O O Forwarded O X O Forwarded O X O Forwarded O X O Forwarded O O Forwarded O O Forwarded O O Forwarded | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 0 ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 ad Queue Entries 0x00 0 ad Queue Entries | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St St St St St St S | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 O Ox00 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X | Forwarded O O O O Forwarded O X O Forwarded O X O Forwarded O X O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O Forwarded O O O O O O Forwarded O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 | St O 1 2 O D D D D D D D D | 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 Ore Queue Entries 0x00 0x01 0 | 1 | | New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 New Head Pointer 0x03 | 000 | Read / Write EBF Read / Write EBF r Read / Write EBF w Read / Write EBF r Read / Write EBF | Hit in EBF X Hit in EBF X Hit in EBF X Hit in EBF | Forwarded O O O O O O O O O O O O O | Dependence Detection O O O O O O O O O O O O O O O O O O | Lo 0 1 2 | 0x00 | St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O 1 2 St O St O St O O St O O O O O O O O O | Ox00 Ox01 O Ore Queue Entries Ox00 Ox01 O Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox01 Ox00 Ox00 | Solved Loads | ## References - [1] M. A. Ramírez, A. Cristal Kestelman, A. V. Veidenbaum, L. Villa and M. Valero, "A Simple Low-Energy Instruction Wakeup Mechanism," in *Proceedings of the 5th International Symposium,* ISHPC, Japan, 2003. - [2] A. S. Tanenbaum, Structured Computer Organization, 5th ed., Pearson Prentice Hall, 2006. - [3] R. L. Britton, MIPS Assembly Language Programming, Pearson Prentice Hall, 2004. - [4] T. Shanley and D. Anderson, ISA System Architecture, MindShare, Inc., 1995. - [5] I. Corporation, "Intel®64 and IA-32 Architectures Software Developer's Manual," 2011. - [6] I. Corporation, "Intel®64 and IA-32 Architectures Software Developer's Manual," 2011. - [7] W. M. Johnson, "Super-Scalar Processor Design," 1989. - [8] J. L. Hennessy and D. A. Patterson, Computer Architecture: A Quantitative Approach, 4th ed., USA: Morgan Kauffmann, 2007. - [9] A. González, F. Latorre and G. Magklis, Processor Microarchitecture: An Implementation Perspective, Synthesis Lectures on Computer Architecture, 2010. - [10] J. R. G. Ordaz, *Diseño de un ROB-Distribuido para Procesadores Superescalares,* Mexico, 2011. - [11] J. E. Smith and G. S. Sohi, "The Microarchitecture of Superscalar Processors," in *Proceedings* of the IEEE, 1995. - [12] A. J. Smith, "Cache Memories," *ACM Computing Surveys,* vol. 14, no. 3, pp. 473-530, September 1982. - [13] F. Castro, D. Chaver, L. Piñuel, M. Prieto and F. Tirado, "Memory Disambiguation Hardware: a Review," *Journal of Computer Science & Technology*, vol. 8, no. 3, 2008. - [14] H. W. Cain and M. H. Lipasti, "Memory Ordering: A Value Based Definition," in *Proceedings of the 31st International Symposium on Computer Architecture*, 2004. - [15] L. Sethumadhavan, B. E. and M. S., *Scalable Hardware Memory Disambiguation,* Texas, Austin, 2007. - [16] T. Sha, M. M. K. Martin and A. Roth, "Scalable Store-Load Forwarding via Store Queue Index Prediction (MICRO 38)," in *Proceedings of the 38th Annual IEEE/ACM International Symposium on Microarchitecture*, Barcelona, 2005. - [17] S. S. Stone, K. M. Woley and M. I. Frank, "Address-Indexed Memory Disambiguation and Store-to-Load Forwarding," in *Proceedings of the 38th Annual IEEE/ACM International Symposium on Microarchitecture*, Barcelona, 2005. - [18] S. Subramaniam and G. H. Loh, "Store vectors for scalable memory dependence prediction and scheduling," in *The Twelfth International Symposium on High-Performance Computer Architecture*, 2006, Austin, 2006. - [19] A. M. D. Inc., "Software Optimization Guide for AMD Family 15h Processors," 2014. - [20] S. Bieschewski, *Design of a Distributed Memory Unit for Clustered Microarchitectures,* Spain, 2013. - [21] J. A. Fisher, "Very Long Instruction Word Architectures and the ELI-512," in *Proceedings of the 10th Annual International Symposium on Computer Architecture, ISCA*, New York, USA, 1983. - [22] L. J. Boland, G. D. Granito, A. U. Marcotte, B. U. Messina and J. W. Smith, "The IBM System/360 Model 91: Storage System," *IBM Journal of Research and Development*, vol. 11, no. 1, pp. 54-68, January 1967. - [23] Y. N. Patt, S. W. Melvin, W. M. Hwu and M. C. Shebanow, "Critical issues regarding HPS, a high performance microarchitecture," in *MICRO 18 Proceedings of the 18th annual workshop on Microprogramming*, New York, 1985. - [24] M. Franklin and G. S. Sohi, "ARB: A hardware mechanism for dynamic reordering of memory references," *IEEE Transactions on Computers*, vol. 45, no. 5, pp. 552-571, May 1996. - [25] K. Sankaralingam, R. Nagarajan, R. McDonald, R. Desikan, S. Drolia, M. S. Govindan, P. Gratz, D. Gulati, H. Hanson, C. Kim, H. Liu, N. Ranganathan, S. Sethumadhavan, S. Sharif, P. Shivakumar, S. W. Keckler and D. Burger, "Distributed Microarchitectural Protocols in the TRIPS Prototype Processor," in *Proceeding of the 39th Anual IEEE/ACM International Symposium on Microarchitecture*, Washington, 2006. - [26] S. Sethumadhavan, R. Desikan, R. McDonald, D. C. Burger and S. W. Keckler, "Design and Implementation of the TRIPS Primary Memory System," in *ICCD 2006. International Conference on Computer Design*, 2006. - [27] S. Sethumadhavan, F. Roesner, J. S. Emer, D. Burger and S. W. Keckler, "Late-Binding: Enabling Unordered Load-Store Queues," in *Proceedings of the 34th Anual International Symposium on Computer Architecture*, San Diego, 2007. - [28] S. Sethumadhavan, R. Desikan, D. Burger, C. R. Moore and S. W. Keckler, "Scalable Hardware Memory Disambiguation for High ILP Processors," in *Proceedings of the 36th Annual IEEE/ACM International Symposium on Microarchitecture*, Washington, 2003. - [29] B. H. Bloom, "Space/time trade-offs in hash coding with allowable errors," *Communications of the ACM*, vol. 13, no. 7, pp. 422-426, July 1970. - [30] H. Song, S. Dharmapurikar, J. Turner and J. Lockwood, "Fast Hash Table Lookup Using Extended Bloom filter: An Aid to Network Processing," in *Proceedings of the 2005 Conference on Applications, Technologies, Architectures, and Protocols for Computer Communications*, Philadelphia, 2005. - [31] G. Z. Chrysos and J. S. Emer, "Memory Dependence Prediction using Store Sets," in *Proceedings of the 25th Annual International Symposium on Computer Architecture*, Washington, 1998. - [32] G. Dimitrakopoulos, K. Galanopoulos, C. Mavrokefalidis and D. Nikolos, "Low-Power Leading-Zero Counting and Anticipation Logic for High-Speed Floating Point Units," *IEEE Transactions on Very Large Scale Integration (VLSI) Systems*, vol. 16, no. 7, pp. 837-850, July 2008. - [33] P. Mishra, N. Dutt and A. Nicolau, "A Study of Out-of-Order Completion for the MIPS R10K Superscalar Processor," Information and Computer Science, Irvine, California, 2001. - [34] S. Palacharla, N. P. Jouppi and J. E. Smith, "Complexity-Effective Superscalar Processors," in *Proceedings of the 24th annual International Symposium on Computer Architecture, ISCA '97*, Denver, 1997.