# The Design of An Asynchronous RISC Processor BY PEE YAO HONG

# A REPORT SUBMITTED TO Universiti Tunku Abdul Rahman in partial fulfillment of the requirements for the degree of BACHELOR OF INFORMATION TECHNOLOGY (HONOURS) COMPUTER ENGINEERING Faculty of Information and Communication Technology (Kampar Campus) JAN 2021

### UNIVERSITI TUNKU ABDUL RAHMAN

| The Design of An Asynchronous RISC Processor      |                                                                                    |                                                                                    |  |
|---------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--|
|                                                   | Academic Session                                                                   | n: <u>2021/01</u>                                                                  |  |
| I                                                 | PEE YAO HONG                                                                       |                                                                                    |  |
| -                                                 | (CAPITAL                                                                           | LETTER)                                                                            |  |
| 1. The                                            | dissertation is a property of the Librar                                           | ct to the regulations as follows:<br>y.<br>his dissertation for academic purposes. |  |
| 1. The                                            | dissertation is a property of the Librar                                           | у.                                                                                 |  |
| 1. The                                            | dissertation is a property of the Librar                                           | у.                                                                                 |  |
| 1. The                                            | dissertation is a property of the Librar                                           | y.<br>his dissertation for academic purposes.                                      |  |
| 1. The<br>2. The                                  | dissertation is a property of the Librar                                           | y.<br>his dissertation for academic purposes.                                      |  |
| 1. The<br>2. The<br>(Author'<br>Address           | dissertation is a property of the Librar<br>Library is allowed to make copies of t | y.<br>his dissertation for academic purposes.<br>Verified by,                      |  |
| 1. The<br>2. The<br>(Author'<br>Address<br>K-90L, | dissertation is a property of the Librar<br>Library is allowed to make copies of t | y.<br>his dissertation for academic purposes.<br>Verified by,                      |  |

# The Design of An Asynchronous RISC Processor BY PEE YAO HONG

A REPORT SUBMITTED TO Universiti Tunku Abdul Rahman in partial fulfillment of the requirements for the degree of BACHELOR OF INFORMATION TECHNOLOGY (HONOURS) COMPUTER ENGINEERING Faculty of Information and Communication Technology (Kampar Campus) JAN 2021

### **DECLARATION OF ORIGINALITY**

I declare that this report entitled "**The Design of An Asynchronous RISC Processor**" is my own work except as cited in the references. The report has not been accepted for any degree and is not being submitted concurrently in candidature for any degree or other award.

lee

Signature

:

| Name | : | PEE YAO HONG |
|------|---|--------------|
| Date | : | 16/04/2021   |

## ACKNOWLEDGEMENTS

I would like to express my sincere thanks and appreciation to my supervisors, Mr Mok Kai Ming who has given me this bright opportunity to engage in a digital system design project. It is my first step to establish a career in digital system design field. A million thanks to you.

A million thanks to my family, especially my parents, for their patience, unconditional support and love, and for always backing me up throughout the course. They have always been there to provide me with financial support.

To my course mates of CT course, I would like to txtend my gratitude for their friendship, company and encouragement during the course of my bachelor degree. We had been putting in a lot of hard work together as a team for the past 3 years.

Finally, I would like to extend my sincere thanks to my seniors who have willingly helped me out with their abilities, providing necessary and useful information about the project. All the advises and suggestions had contributed to the completion of this project.

#### Abstract

This project is an asynchronous processor design project for academic purpose. It will provide students with the methodology, concept and design of asynchronous RISC processor. This will be illustrated by converting a synchronous processor to an asynchronous processor. This can be done by substituting the global clock for a synchronous processor with a set of controllers that all have an equivalent behavior. Since asynchronous processor is better than synchronous processor in aspects of no clock skew, lower power dissipation and etc, it is well suited for digital circuits and therefore implemented in this project. The tools used in this project are Verilog hardware description language in combination with ModelSim synthesis tools and PCSpim. Moreover, there is several types of asynchronous implementation style and the one used here is the 4-phase single-rail pipeline. The verification plan of the project is a testbench with numbers of instruction to make sure the processor is workable. Lastly, the output of the project would be the synthesized hardware of asynchronous RISC processor with shortest delay for every single instruction in order to implement that asynchronous processor is better than synchronous processor.

| TITLE PAGE                                                               | i       |
|--------------------------------------------------------------------------|---------|
| DECLARATION OF ORIGINALITY                                               |         |
| ACKNOWLEDGEMENTS                                                         |         |
|                                                                          |         |
| ABSTRACT                                                                 | iv      |
| TABLE OF CONTENTS                                                        | v - vii |
| LIST OF TABLES                                                           | viii    |
| LIST OF FIGURES                                                          | ix - x  |
| LIST OF ABBREVIATIONS                                                    | xi      |
|                                                                          |         |
| CHAPTER 1 : INTRODUCTION                                                 |         |
| 1.1 Problem Statement and Motivation                                     | 1 - 4   |
| 1.2 Project Scope                                                        | 5       |
| 1.3 Problem Objectives                                                   | 5       |
| 1.4 Impact, Significance and Contribution                                | 6       |
| 1.5 Background Information                                               | 7       |
|                                                                          |         |
| <b>CHAPTER 2 : LITERATURE REVIEW</b>                                     |         |
| 2.1 Literature Review                                                    | 8 - 15  |
| 2.2 Data Collection                                                      | 16      |
| 2.3 Critical Remark of Previous Works                                    | 17      |
| CHAPTER 3 : HARDWARE DEVELOPMENT                                         |         |
| 3.1 System Overview                                                      | 18      |
| 3.1.1 Design Hierarchy                                                   | 18 - 19 |
| 3.1.2 Internal Operation                                                 | 20      |
|                                                                          | 20      |
| 3.1.3 Memory Map                                                         |         |
| 3.2 CPU                                                                  | 22      |
| 3.2.1 Pipeline Micro-architecture         3.3 Design Block Specification | 22 - 23 |
| 3.3.1 Main Control Block                                                 | 24      |
| 5.5.1 Main Control Block                                                 | 24 - 28 |

# **Table of Contents**

| 3.3.2 Arithmetic Logic Control Block             | 28      |
|--------------------------------------------------|---------|
| 3.3.3 Register File Block                        | 29 - 31 |
| 3.3.4 Forwarding Block                           | 32 - 37 |
| 3.3.5 Interlock Block                            | 38 - 39 |
| 3.3.6 ALU Block                                  | 40 - 41 |
| 3.3.7 Multiplier Block                           | 42 - 43 |
| 3.3.8 Boot ROM Unit                              | 43      |
| 3.3.9 Data and Stack RAM Unit                    | 44 - 45 |
|                                                  |         |
| CHAPTER 4 : METHODLOGY AND TOOLS                 |         |
| 4.1 Design Specifications                        | 46      |
| 4.1.1 Methodologies and General Work Procedures  | 46 - 47 |
| 4.1.2 Development Tools                          | 47 - 48 |
| 4.1.3 Verification Plan                          | 48      |
| 4.2 Timeline                                     | 49      |
|                                                  |         |
| <b>CHAPTER 5 : MULLER C-ELEMENT</b>              |         |
| 5.1 Muller Pipeline                              | 50      |
| 5.2 Circuit Implementation Style                 | 52 - 55 |
| 5.3 Implementation of Pipeline                   | 56      |
| 5.4 Micro-architecture of Asynchronous Processor | 57      |
|                                                  |         |
| CHAPTER 6 : VERIFICATION                         |         |
| 6.1 Simulation Result                            | 58 - 60 |
| CHAPTER 7 : SYNTHESIS                            | 61      |
| 7.1 Utilization Report                           |         |
|                                                  |         |
| <b>CHAPTER 8 : CONCLUSION AND FUTURE WORK</b>    |         |
| 8.1 Conclusion                                   | 62      |
| 8.2 Future Work                                  | 62      |

| BIBLIOGRAPHY            | 63      |
|-------------------------|---------|
| POSTER                  | 64 - 65 |
| PLAGIARISM CHECK RESULT | 66 - 67 |
| FYP2 CHECKLIST          | 68      |

| Table Number | Title                                                          | Page    |
|--------------|----------------------------------------------------------------|---------|
| Table 2.1    | Comparison between different type of asynchronous processor    | 16      |
| Table 3.1    | Design hierarchy of the processor                              | 19      |
| Table 3.2    | Main Control Block I/O description                             | 24 - 28 |
| Table 3.3    | Arithmetic Logic Control Block I/O<br>description              | 28      |
| Table 3.4    | Conventional usange of the registers in<br>Register File Block | 29      |
| Table 3.5    | Register File Block I/O description                            | 30      |
| Table 3.6    | General condition of Register File related<br>data hazards     | 33      |
| Table 3.7    | \$ra register relater data hazards                             | 34      |
| Table 3.8    | HILO register related data hazards                             | 35      |
| Table 3.9    | Forwarding Block I/O description                               | 35 - 37 |
| Table 3.10   | Interlock Block I/O description                                | 38 - 39 |
| Table 3.11   | ALU Block I/O description                                      | 40      |
| Table 3.12   | ALU Block operation                                            | 41      |
| Table 3.13   | Multiplier Block I/O description                               | 42 - 43 |
| Table 3.14   | Boot ROM Unit I/O description                                  | 43      |
| Table 3.15   | Data and Stack RAM Unit I/O description                        | 44 - 45 |
| Table 4.1    | Gantt chart for Project I                                      | 49      |
| Table 4.2    | Gantt chart for Project II                                     | 49      |
| Table 7.1    | The utilization report                                         | 61      |

# List of Tables

| Figure Number | Title                                            | Page |
|---------------|--------------------------------------------------|------|
| Figure 2.1    | The Caltech Asynchronous Processor               | 8    |
| Figure 2.2    | The Fully Asynchronous Processor                 | 9    |
| Figure 2.3    | The Non synchronous RISC                         | 10   |
| Figure 2.4    | The Counter Flow Pipeline Processor              | 12   |
| Figure 2.5    | The structure of the STRIP processor             | 13   |
| Figure 2.6    | Amulet1 processor organization                   | 14   |
| Figure 3.1    | The overview of the processor                    | 18   |
| Figure 3.2    | Micro-architecture of the processor              | 18   |
| Figure 3.3    | Instruction execution cycle                      | 20   |
| Figure 3.4    | Memory map                                       | 21   |
| Figure 3.5    | Abstract view of 5-stage asynchronous processor  | 22   |
| Figure 3.6    | Micro-architecture of datapath with memory unit  | 23   |
| Figure 3.7    | Main Control Block chip interface                | 24   |
| Figure 3.8    | Arithmetic Logic Control Block chip<br>interface | 28   |
| Figure 3.9    | Register File Block chip interface               | 30   |
| Figure 3.10   | Internal operation of Register File Block        | 31   |
| Figure 3.11   | Forwarding Block chip interface                  | 35   |
| Figure 3.12   | Interlock Block chip interface                   | 38   |
| Figure 3.13   | ALU Block chip interface                         | 40   |
| Figure 3.14   | Multiplier Block chip interface                  | 42   |
| Figure 3.15   | Boot ROM Unit chip interface                     | 43   |
| Figure 3.16   | Data and Stack RAM Unit chip interface           | 44   |

# **List of Figures**

| Figure 4.1  | Synchronous circuit                                                   | 46 |
|-------------|-----------------------------------------------------------------------|----|
| Figure 4.2  | Asynchronous circuit                                                  | 46 |
| Figure 4.3  | An asynchronous control circuit                                       | 47 |
| Figure 5.1  | The Muller C-element                                                  | 50 |
| Figure 5.2  | Muller pipeline                                                       | 51 |
| Figure 5.3  | The 4 phases single-rail pipeline                                     | 52 |
| Figure 5.4  | The 2 phases single-rail pipeline                                     | 53 |
| Figure 5.5  | Operation and Implementation of a capture-pass event controlled latch | 53 |
| Figure 5.6  | A simple 3-stage 1-bit wide 4-phase<br>dual-rail pipeline             | 54 |
| Figure 5.7  | An N-bit latch with completion detection                              | 54 |
| Figure 5.8  | Illustration of handshaking on a 2-phase<br>dual-rail channel         | 55 |
| Figure 5.9  | Pipeline with Muller C-element                                        | 56 |
| Figure 5.10 | Micro-architecture of asynchronous processor                          | 57 |
| Figure 6.1  | The waveform of muller pipeline                                       | 58 |
| Figure 6.2  | The results of arithmetic instruction                                 | 58 |
| Figure 6.3  | The results of logical instruction                                    | 58 |
| Figure 6.4  | The results of STORE, SET_BR and LWSW                                 | 59 |
| Figure 6.5  | The results of t_sb, t_lb and t_lbu                                   | 59 |
| Figure 6.6  | The results of t_sh, t_lh and t_lhu                                   | 59 |
| Figure 6.7  | The results of swl, swr, lwl and lwr                                  | 59 |
| Figure 6.8  | The results of multiplication and loop                                | 60 |

| RISC | Reduced Instruction Set Computing                     |  |
|------|-------------------------------------------------------|--|
| FPGA | Field Programmable Gate Array                         |  |
| MIPS | Microprocessor without Interlocked Pipeline<br>Stages |  |
| ALU  | Arithmetic Logic Unit                                 |  |
| FIFO | First-In First-Out                                    |  |
| CMOS | Complementary Metal Oxide Semiconductor               |  |
| RTL  | Register-Transfer Level                               |  |
| HDL  | Hardware Description Language                         |  |

# List of Abbreviations

#### **Chapter 1 : Introduction**

#### **1.1 Problem statement and Motivation**

A 32-bit five stage pipeline asynchronous RISC soft-core can be beneficial in creating a core-based environment to support research and development work in the area of developing IP cores. On the other hand, there are restrictions in obtaining such workable core-based design environment as microprocessors are developed by microchip design companies as IP for commercial purpose and most of these IP are trade secret of those companies.

There are some asynchronous processor cores projects available freely online such as www.opencore.org, www.ics.forth.gr/carv/aspida/ and etc. However, the asynchronous processor's micro-architecture included in these projects is not well presented. Other than that, the Verilog codes wrote in these projects are also hard to understand because of the confused naming convention used.

Furthermore, the verification plans for the asynchronous processor which available on the open source are not completed. The lack of complete verification for the processor will affect the process of design. Therefore, there is a necessary to develop a verification plan to verify the functionality of the asynchronous processor.

Last but not least, the senior who took this FYP title previously was not able to finish her work. The outputs of the supported insturctions are incorrect and the synthesis of the asynchronous processor on FPGA has not been done yet. Nowadays, there are a lot of digital system designed as synchronous. In synchronous circuits, the data stored in memory devices named flip-flops. The flip-flop output the data at discrete instants of time which specified by a clock signal connected to it. This synchronous circuits built based on two assumptions which are the signals are in binary and every parts share a same clock signal. (Jens Sparsø & Steve 2001, p3)

By assuming all signals are in binary, the logic inside the circuit can be illustrated by simple Boolean logic. Moreover, by assuming every parts share a same clock signal, something happen inside the circuit can be ignored such as hazards and feedback. However, when the complexity of system and speed of clock increase, synchronous design has a lot of problems because of its way of keeping operations in lock-step execution. The problems are stated below (Hans Jacobson 1996, p13-14):

### • Worst Case Performance

The clock frequency determines the speed of asynchronous circuit. The clock signal should be big enough to run the worst-case delay and this is the reason why synchronous circuit has worst case performance.

#### Clock Skew

Clock skew is defined as difference in arrival times of a clock signal at different block or stage. All modules of the synchronous circuit need to operate with a same clock in order to operate correctly. It is difficult to minimize the clock skew with a large circuit.

#### • Higher Power Consumption

As synchronous circuit is clocked by a global clock which include those which are not use at a certain cycle. It toggles some of the node unnecessarily and this causes higher power consumption. Other than that, switching of the gate and fanout problem at the root of the clock tree also consume a lot of power.

# • Easier Influenced by The Variations

Semiconductors mainly affected by process speed of fabrication, power supply voltage level and temperature. These three properties will cause a transistor to operate faster or slower. Synchronous circuit need to consider these physical properties across its entire range in order to ensure the device is functioning.

# • Worse Modularity and Composability

Synchronous designer always take serious consideration on satify the detailed interfacial timing specifications. Other than that, replacing new parts do not give advantage to synchronous circuit because one of the part changes, the clock frequency of the whole circuit also need to be changed either follows the old clock frequency or adjust other parts to suit the new clock frequency.

Asynchronous circuits also assume all signals are in binary but there is no same clock signal. Other than that, asynchronous circuits is self-timed instead of governed by a block clock signal. The components inside the circuits use handshaking between each other in order to communicate. A particular component only clocked when it is needed.

Unlike synchronous circuits, asynchronous circuits do not suffer from the problems stated above but it has a lot of advantages which stated below (Jens Sparsø & Steve 2001, p3-4):

## • Averange Case Performance

Asynchronous circuit is controlled by local communications which will direct initial the next computation when the other one is completed. When the computation completed early, the new one can start early and this is why asynchronous circuit does not exhibit worse case performance but an averange case performance.

# • No Clock Skew

Asynchronous circuit is built up with small self-timed circuit which means there is no global clock signal connected between each other. So, there is no need to worry about the clock skew.

# • Lower Power Consumption

Asynchronous circuit only toggles the block or stage when it is being used, thus reduring the power consumption.

# Robustness Towards Variations

The self-timed logic and processing logic in asynchronous circuit are located in the same area, both of them are affected by the same environmental changes so that it is more unaffected to transient changes.

# • Better Modularity and Composability

Asynchronous circuist is simply connect a proper module with a matching interfacial specifications which means sequences of events that take place but not include the timing of the event. It saves a lot of time when designing the asynchronous circuit because of no need to worry about the delays occur inside the individual module. Other than that, parts of the asynchronous circuit can be replaced by the new one in order to improve the performance.

## **1.2 Project Scope**

There is an enorous field of research which covers widely diverse techniques to the implementation of asynchronous design. However, this project will only focus on the goals listed below:

- Architecture of the asynchronous processor.
- Methodologies used to implement the asynchronous processor.

# **1.3 Project Objectives**

The main objective of this project is to design and synthesis the asynchronous RISC processor, and it still can be divided into several sub-objectives as stated below:

- Design Level
  - To design and develop an asynchronous RISC processor that can meet all the specifications correctly by using Verilog HDL.
- Verification Level
  - To develop a complete testbench to verify all the functional correctness of the asynchronous RISC processor.
- Synthesis Level
  - To synthesis and integrate the asynchronous RISC processor which is the FPGA technology.

## 1.4 Impact, significance and contribution

As a summary to the problem statement, there is a lack of well-developed and well-founded 32-bit asynchronous RISC processor core-based development environment. The development environment refers to the availability of the following:

- A well-developed design document, which includes the chip specification, architecture specification and micro-architecture specification.
- A fully functional well-developed 32-bit asynchronous RISC architecture core in the form of synthesis-ready RTL written in Verilog HDL.
- A well-developed verification environment for the 32-bit asynchronous RISC core. The verification specification should contain suitable verification methodology, verification techniques, test plans, test bench architectures etc.
- A complete physical design in Field Programmable Gate Array (FPGA) with documented timing and resource usage information.

With the available well-developed basic 32-bit asynchronous RISC RTL model (which has been fully functional verified), the verification environment and the design documents, researchers can develop their own specific RTL model as part of the development environment (whether directly modifying the internals of the processor or interface to the processor) and can quickly verify their model to obtain results, without having to worry about the development of the verification environment and the modeling environment. This can speed up the research work significantly. For example, a researcher may have developed an image-processing algorithm and modified the algorithm to obtain a structure that suits the hardware implementation. The structure can be modeled in Verilog as part of a specialized data-path or as a coprocessor interfacing to the asynchronous RISC processor.

#### **1.5 Background information**

A circuit is considered to be asynchronous if it does not employ a periodic clock signal to synchronize its internal operations, an obvious example is asynchronous processor. Unlike a conventional processor, the asynchronous processor does not require a central clock to coordinate the progress of data through the pipeline. The first asynchronous design came out on 1952 and are widely used in computer during 1960's. However, during 1970's, the interest of asynchronous design dropped and disappeared after the appearance of synchronous design. The main reasons why was this happened are because of the rapidly growing of complexity of digital systems and the simplicity offered by synchronous design.

However, with the progress of time and the advance in technology, synchronous design showed up several problems when higher performance was a need. The problems include clock skew for high frequency systems, power consumption due to increase of portability of digital systems and worst case performance. The asynchronous design does not suffer from the problems. Therefore, attention of the researchers and designers were created. Today, the semiconductor industry is giving serious consideration to the adoption of asynchronous circuit technology. There are some projects from the industry have proven that the design of asynchronous circuit is achieve the significant benefits stated in (C.H. Van Berkel, M.B. Josephs & S.M. Nowick 1999, p224-230).

#### **Chapter 2 : Literature Review**

#### 2.1 Literature Review

There are several different asynchronous processors with their own architecture, type of communication and data transfer protocol discussed by (Tony Werner & Venkatesh Akella 1997, p.69-76) & (T.Samyuktha & K.Balachandra 2015, p.10208-10211).

**1. Caltech Asynchronous Processor (CAP)** (Alan Martin's group 1980s cited in Tony Werner & Venkatesh Akella 1997)

- Concurrent processes, 4-phase, dual-rail.
- The earliest known asynchronous processor.
- Dynamic logic families works efficiently with this design.
- 15 MIPS performance is estimated by the designers.



Figure 2.1 : The Caltech Asynchronous Processor

**2. Fully Asynchronous Processor (FAM)** (Kyoung.R.C, Kazum.O, Kunijiro.A 1990s cited in Tony Werner & Venkatesh Akella 1997)

- 4-stage pipeline (see Figure 2.2), 4-phase, dual-rail.
- The processor contains 32 bits data path and 32 of 32 bits general registers.
- Only 18 instructions are available for this processor. The method to design asynchronous data path and control path is achieved by this effort.
- It uses combined instruction and data cache (ALU and register file are combined). Disadvantage : Conflicts between the two stages need to be solved.
- Both computation block and interconnection block are used in this design. Each pipeline stage or computation block are separated by the interconnection block and provides space to separate the computation blocks.
- FAM uses at most two transistors in series to both set and reset the flip-flops which called 2-AND logic, describing the state of the system.





Figure 2.2 : The Fully Asynchronous Processor

**3. Non synchronous RISC (NSR)** (Erik.B 1993 cited in Tony Werner & Venkatesh Akella 1997)

- 5-stage pipeline (see Figure 2.3), 2-phase, bounded-delay.
- The processor contains sixteen 16-bit registers.
- FIFO queues are added between the concurrent blocks to minimize stalls caused by slower instructions. Each stage accepts data for processing and passes the result to the next stage by way of FIFO. Potentially, FIFO could greatly increases the penalties from memory access, branching and so on. However, the instructions will only pass through the stages which are needed.
- The validity of the data path is ensured by adding delay to the control path which called bounded-delay.



• 1.3MIPS perfromance is reported by the disigners.

Figure 2.3 : The Non synchronous RISC

# 4. Counter Flow Pipeline Processor (CFPP) (Ivan.S 1994 cited in Tony Werner

& Venkatesh Akella 1997)

- 12 stages pipeline (see Figure 2.4).
- For this processor, the data generated by the instructions flow at opposite direction of the instructions through the pipeline.
- It places program counter and register file at both end respectively. Before the packets send to the register file, instruction with opcode, source and destination register binding, and possibly the corresponding program counter are inserted. Before the instruction is send back to the program counter, it reads the source operands and then only inserts the instruction into the pipeline.
- The instruction packet must match with its source operands is the only requirement to execute in every stage of pipeline.
- This architecture provide register renaming. When the instrction reaches the register file, it does not need to wait to receive its source operands. However, the source operands from the result pipeline will be recerived maybe before updating the register file.
- This processor supports interrupts and a wrongly predicted branches can be recoverd by inserting an identifier into the results pipeline. The instructions in front of the identifier keep on move to the register file and their results are still posted. However, it prevent alter of rigister file by marking the instructions which follow the indentifier. It will enters interrupt routine or loads the correct branch destination when the identifier reached the program counter.
- Long computation delay instructions are executed by using auxiliary stages or "siblings".



Figure 2.4 : The Counter Flow Pipeline Processor

**5. Self-Timed RISC Processor (STRIP)** (Mark.D cited in Tony Werner & Venkatesh Akella 1997)

- 5-stage pipeline, dynamic clock, bounded-delay.
- It is a synchronous processor with an adjustable clock, called dynamic clocking.
- The slowest critical path of current clock cycle determines the clock period. Optimization for every stage of pipeline and functional unit are needed.
- C-element and simple pulse generator are used by STRIP. The propagation delay of a particular critical path represented by a tracking cell. An active critical paths determine the clock cycle because the processor will moves those tracking cells which are not needed for to their next state. Each tracking cells is then input to C-element. When all tracking cells are completed, the C-element changes to its next state. The tracking cells are restarted and the pulse generator is activated (see Figure 2.5).
- The external interface operates on four phases and dual rail protocol.
- It supports precise interrupts because an instructions cannot change the processor's state until the write-back stage. The instructions are stopped and the program counter will set to zero to begin the exception handling when an interrupt occurs. The addresses of the register fetch and

instruction decode, ALU and data memory access stages will be saved by the processor. Restarting the instructions that occupied these stages are required to recover from the interrupt.

• The memory access time decides the performance of the processor. It places memory buffers between each instruction and data memory paths in order to minimize the memory access latency.



• 62.5 MIPS performance is reported by the designers.

Figure 2.5 : The structure of the STRIP processor

**6. Superscalar Asynchronous Low Power Processor (SCALP)** (University of Manchester 1996 cited in T.Samyuktha & K.Balachandra 2015)

- Each instruction only specifies the destination of the results but not the source of their operands. However, they use the values provided by instruction before it.
- Each instruction has a functional unit identifier which indicates which functional unit will execute the instruction.

# 7. AMULET1 (Steve.F cited in T.Samyuktha & K.Balachandra 2015)

- 6-stage pipeline, 2-phase, bounded-delay.
- Contains thirty 32-bit general registers for register bank. Only 16 are able to access once, 15<sup>th</sup> register contains the program counter.
- First fully functional asynchronous processor.
- Two levels of interrupts and the exceptions generated by virtual memory system are supported by this processor.
- FIFO structure called pc pipe uses to keep the record of program counter values. If needed, the value which is at the top of the FIFO queue is transferred along with the instruction to the execute unit. Otherwise, the value is removed.
- It uses lock FIFO to eliminate register hazards.
- The physical size and transistor count are reduced by utilizing dynamic logic of the register bank and execute unit.



Figure 2.6 : Amulet1 processor organization

**8. AMULET2e - An Asynchronous Embedded Controller** (Steve.F cited in T.Samyuktha & K.Balachandra 2015)

- It is designed as embedded system chip with an enhanced ARM core a 4Kbyte pipelined cache, a flexible memory interface and assorted programmable control functions.
- It also consists of counter-timer for real time reference.
- AMULET2e silicon demonstrates competitive performance, power efficiency and ease of design.
- Pipeline reorganization was done with respect to AMULET1.

9. AMULET3 (Steve.F cited in T.Samyuktha & K.Balachandra 2015)

- It is a fully asynchronous implementation of ARM architecture which including 16 bit thumb instruction set.
- Suitable for low power processor.
- It is equal to a 32-bit embedded processor in energy efficiency and was developed for microcontroller applications.

# 2.2 Data Collection

The table below shows the comparison between several asynchronous processors with diffrent architecture, protocol, technology and performance discussed by (Tony Werner & Venkatesh Akella 1997, p.69-76) & (T.Samyuktha & K.Balachandra 2015, p.10208-10211).

| Microprocessor                                | Architecture            | Protocol                  | Technology       | Performance   |
|-----------------------------------------------|-------------------------|---------------------------|------------------|---------------|
| Caltech<br>Asynchronous<br>Processor<br>(CAP) | Concurrent<br>processes | 4-phase,<br>dual-rail     | 2 - µm CMOS      | 15 MIPS       |
| Fully<br>Asynchronous<br>Processor<br>(FAM)   | 4-stage<br>pipeline     | 4-phase,<br>dual-rail     | 0.5 - μm<br>CMOS | 300 MIPS      |
| Non<br>synchronous<br>RISC (NSR)              | 5-stage<br>pipeline     | 2-phase,<br>bounded-delay | Actel FPGAs      | 1.3 MIPS      |
| Self-Timed<br>RISC Processor<br>(STRIP)       | 5-stage<br>pipeline     | dynamic clock             | 2 - µm CMOS      | 62.5 MIPS     |
| AMULET1                                       | 6-stage<br>pipeline     | 2-phase,<br>bounded-delay | 1 - µm CMOS      | 9K Dhrystones |

Table 2.1 : Comparison between different type of asynchronous processor

#### 2.3 Critical Remarks of Previous Works

It can been seen that asynchronous circuits have more advantages than synchronous circuits but it also have its own limitations. These limitations are stated below (Hans Jacobson 1996, p15-16):

- **Hazards.** Asynchronous circuits are easily influenced by glitches and hazards because it depend on the events within the wire to communicate. Therefore, it is important to take care of it during state of synthesis in order to remove the chance of function and logic hazards. Other than that, the result of the circuit is also sensitive to glitches.
- Latency with Handshake. The method where asynchronous circuits used to communicate will slow down the performance due to handshake overhead. The communicating elements are put close to each other in order to solve the problem.
- Different Design Methodologies. Inconsistent of specification and implementation styles caused by different methodologies used to design the asynchronous circuit. It is hard to compare the differences of those systems and also difficult to pull off on exiting works.
- Immature Synthesis Methodologies. There is a must for mature synthesis methodologies in order to let asynchronous design to be accepted by those synchronous designers and industry. Unfortunately, there are many methods are still in their early stages of research. Other than that, it also has not yet been modeled with real industrial designs.

### **Chapter 3 : Hardware Development**

### 3.1 System Overview

The asynchronous RISC processor built with 2 major parts which are Central Processing Unit (CPU) and Memory Unit. It is compatible to a 5-stage 32-bit MIPS Instruction Set Architecture (ISA). It supports instructions included arithmetic, logic, data memory access, program control and etc. The memory unit consists of Boot ROM, Stack RAM and Data RAM.



Figure 3.1 : The overview of the processor

## **3.1.1 Design Hierarchy**

Other than that, the processor is divided into two main units which are datapath unit and control unit. Datapath unit is a collection of functional units and control unit is to generate control signals to datapath. Moreover, both datapath unit and control unit can be further split into smaller blocks. (Chip -> Unit -> Block)



Figure 3.2 : Micro-architecture of the processor

|       |                   | Address Decoder Block                    | ]                   |
|-------|-------------------|------------------------------------------|---------------------|
|       |                   | (baddr_decoder)                          |                     |
|       |                   | ALU Block                                | -                   |
|       |                   | (balb)                                   |                     |
|       |                   | Forwarding Block                         | -                   |
|       |                   | (bfwl_ctrl)                              |                     |
|       |                   | Interlock Block                          | -                   |
|       |                   | (bitl_ctrl)                              |                     |
|       |                   |                                          | adder_lvl1          |
|       |                   |                                          | adder_lvl1_firstrow |
|       | Detenath Unit     |                                          | add_lvl1_lastrow    |
|       | Datapath Unit     | Multiplier Dlock                         | adder_lv12          |
|       | (udata_path)      | Multiplier Block<br>(bmult32)            | adder_lvl2_lastrow  |
|       |                   | (0)(0)(0)(0)(0)(0)(0)(0)(0)(0)(0)(0)(0)( | adder_lv13          |
|       |                   |                                          | adder_lvl4          |
| crisc |                   |                                          | adder_lv15          |
| ense  |                   |                                          | sub_lvl1_lastrow    |
|       |                   | Register Block                           |                     |
|       |                   | (brf)                                    |                     |
|       |                   |                                          | Muller C Gate       |
|       |                   | Muller Pipeline Block                    | (mcg)               |
|       |                   | (bmp)                                    | Muller C Element    |
|       |                   |                                          | (mce)               |
|       |                   | Arithmetic Logic Control Block           |                     |
|       | Control Path Unit | (balb_ctrl)                              |                     |
|       | (uctrl_path)      | Main Control Block                       |                     |
|       |                   | (bmain_ctrl)                             |                     |
|       | Data and Stack    |                                          |                     |
|       | RAM Unit          |                                          |                     |
|       | (uram)            |                                          |                     |
|       | Boot ROM Unit     |                                          |                     |
|       | (uboot_rom)       | 1. Design hierorghy of the processo      |                     |

Table 3.1 : Design hierarchy of the processor

# **3.1.2 Internal Operation**

## Stage 1 : Instruction Fetch (IF)

- Intruction fetched from instruction memory
- Pragram counter (PC) incremented

# **Stage 2 : Instruction Decode (ID)**

- Opcode and funct are gathered and decoded
- Read data from register file

# Stage 3 : Execution (EX)

- Execute R-type, calculate memory address
- Computation of most instructions are done except jump

# Stage 4 : Memory (MEM)

- Read/write the data from/to the data memory
- Only load and store instructions are active in this stage

# Stage 5 : Write Back (WB)

• Write the result data into the register file



Figure 3.3 : Instruction execution cycle

# 3.1.3 Memory Map



Figure 3.4 : Memory map

MIPS memory location is divided into 3 parts, namely text segment, data segment and stack segment.

**Text segment** (0x0040 0000 - 0xFFFF FFFC) is used to hold the program's instruction.

Data segment is divided into:

-Static data segment (0x1000 0000 - 0x1000 FFFB)

- Holds object whose lifetime is the program's entire execution
- Cease to exist only after execution completes
- -Dynamic data segment or heap (0x1000 FFFF ?)
- Holds variables declared dynamically as in structures that grow and shrink

• Heap size is not known in advance, so locations are not assigned during compile time.

**Stack segment** (0x7FFF FFFC - ?) is used by procedure during execution to store register values. Stack size is not known in advance, so locations are not assigned during compile time

# **3.2 CPU**



## 3.2.1 Pipeline Micro-architecture



At IF stage, an instruction is fetched from the Boot ROM or I-MEM and registered to the IF/ID pipeline registers. At ID stage, the instruction that registered in the IF/ID pipeline registers will be decoded by the Main Control block and the Arithmetic Logic Control block. Signals output from both hardware components will be registered to the ID/EX pipeline registers and also pass to the remaining hardware components in the ID stage, i.e. Register File. At the same time, IF stage continues to fetch the consecutive instruction from the I-MEM. At EX stage, ALU block covers all the operation except the multiplication operation. Multiplier block starts the multiplication operation at EX stage and requires 2 clock cycles (EX and MEM stages) to perform a multiplication operation on two 32-bit operands. At the MEM stage, only load and store instructions are permitted to perform the operation, in which other instructions are bypassing this stage. Load or store instruction is used to access the memory components at the MEM stage, i.e. D-MEM and Data and Stack RAM. At WB stage, the result of the operation is updated. Data hazards always exist in a pipeline processor.

Data hazards can cause the computational error when multiple instructions are overlapped during execution. The data hazard occurs due to Read-after-Write (RAW) data dependencies, which involve accessing the processor's system registers, i.e. Register File and HILO register. Extra circuitries (forwarding and interlock) are required to resolve the data hazards arise. However, the high computational speed achieved by pipelined processor still outweighs its counterparts and remains a popular choice in processor design.



Figure 3.6 : Micro-architecture of datapath with memory unit

# 3.3 Design Block Specification

# **3.3.1 Main Control Block**

The Main Control block is used to decode a 32-bit instruction machine code and generate control signals to represent the unique identity of each instruction. The control signals identify the source of operands, destination to save the result and the respective operation to operate. The Main Control block consists of only combinational logic, which the decoding can be done within one clock cycle. Figure 3.7 shows the chip interface of the Main Control Block and describes the function of each pin on Main Control Block.



| Pin name: bomc_alb_op[3:0]   Pin direction: output                          |
|-----------------------------------------------------------------------------|
| Source -> Destination: Main Control Block -> Arithmetic Logic Control Block |
| Pin function: Encoded opcode for Arithmetic Logic Control Block to produce  |
| optimized signal to ALU                                                     |
| Pin name: bomc_mult_en     Pin direction: output                            |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function:                                                               |
|                                                                             |
| 1: Indicate mult instruction is executing                                   |
| 0: Indicate mult instruction is not execute                                 |
| Pin name: bomc_sign_mult Pin direction: output                              |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function:                                                               |
| 1: Indicate mult or multu instruction is executing                          |
| 0: Indicate mult and multu instruction is not executing                     |
| Pin name: bomc_rf_wrPin direction: output                                   |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function:                                                               |
| 1: Enable write to Register File                                            |
| 0: Disable write to Register File                                           |
| Pin name: bomc_sw Pin direction: output                                     |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Store word (32-bit data)                                      |
| 1: Indicate sw, swl or swr instruction is executing                         |
| 0: Indicate sw, swl and swr instructions are not executing                  |
| Pin name: bomc_swl Pin direction: output                                    |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Unaligned store word left (32-bit data)                       |
| 1: Indicate swl instruction is executing                                    |
| 0: Indicate swl instruction is not executing                                |
| Pin name: bomc_swr Pin direction: output                                    |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Unaligned store word right (32-bit data)                      |
| 1: Indicate swr instruction is executing                                    |
| 0: Indicate swr instruction is not executing                                |
| Pin name: bomc_lw   Pin direction: output                                   |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Load word (32-bit data)                                       |
| 1: Indicate lw, lwl or lwr instruction is executing                         |
| 0: Indicate lw, lwl and lwr instructions are not executing                  |
| Pin name:     bomc_lwl     Pin direction:     output                        |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Unaligned load word left (32-bit data)                        |
| 1: Indicate lwl instruction is executing                                    |
| 0: Indicate lwl instruction is not executing                                |
| Pin name:     bomc_lwr     Pin direction:     output                        |
| Source -> Destination: Main Control Block -> Data-path Unit                 |
| Pin function: Unaligned load word right (32-bit data)                       |
|                                                                             |
| 1: Indicate lwr instruction is executing                                    |
| 0: Indicate lwr instruction is not executing                                |
| Pin name: bomc_shPin direction: output                                      |

| Source -> Destination: Main Control Block -> Data-path Unit                             |
|-----------------------------------------------------------------------------------------|
| Pin function: Store half-word (16-bit data)                                             |
| 1: Indicate sh instruction is executing                                                 |
| 0: Indicate sh instruction is not executing                                             |
| Pin name: bomc_sh Pin direction: output                                                 |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Store half-word (16-bit data)                                             |
| 1: Indicate sh instruction is executing                                                 |
| 0: Indicate sh instruction is not executing                                             |
| Pin name: bomc_lhu Pin direction: output                                                |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Load half-word unsigned (16-bit data)                                     |
| 1: Indicate lhu instruction is executing                                                |
| 0: Indicate lhu instruction is not executing                                            |
| Pin name: bomc_sb Pin direction: output                                                 |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Store byte (8-bit data)                                                   |
| 1: Indicate sb instruction is executing                                                 |
| 0: Indicate sb instruction is not executing                                             |
| Pin name: bomc_lb Pin direction: output                                                 |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Load byte (8-bit data), sign extend required (refer uipr_load_sign_ext)   |
| 1: Indicate lb instruction is executing                                                 |
| 0: Indicate lb instruction is not executing                                             |
| Pin name: bomc_lbu Pin direction: output                                                |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Load byte unsigned (8-bit data)                                           |
| 1: Indicate lbu instruction is executing                                                |
| 0: Indicate lbu instruction is not executing                                            |
| Pin name: bomc_load_sign_ext Pin direction: output                                      |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function:                                                                           |
| 1: Indicate lh or lb instruction is executing, sign extend 16-bit to lh or 24-bit to lb |
| 0: Indicate lh or lb instructions are not executing                                     |
| Pin name: bomc_sign_ext Pin direction: output                                           |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function:                                                                           |
| 1: Immediate data sign extend                                                           |
| 0: Immediate data zero extend                                                           |
| Pin name: bomc_mem_to_rfPin direction: output                                           |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function:                                                                           |
| 1: Data memory data to Register File                                                    |
| 0: ALU block result to Register File                                                    |
| Pin name: bomc_alb_to_rf Pin direction: output                                          |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function: Reserved for future development                                           |
| Pin name: bomc_hi_to_rf Pin direction: output                                           |
| Source -> Destination: Main Control Block -> Data-path Unit                             |
| Pin function:                                                                           |
|                                                                                         |

| 1. III register data ta Degister Eila                       |
|-------------------------------------------------------------|
| 1: HI register data to Register File                        |
| 0: LO register data to Register File                        |
| Pin name: bomc_hilo_acc Pin direction: output               |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate mflo or mfhi instruction is executing           |
| 0: Indicate mflo and mfhi instructions are not executing    |
| Pin name: bomc_jump Pin direction: output                   |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate j instruction is executing                      |
| 0: Indicate j instruction is not executing                  |
| Pin name: bomc_jrPin direction: output                      |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate jr instruction is executing                     |
| 0: Indicate jr instruction is not executing                 |
| Pin name: bomc_jal Pin direction: output                    |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate jal instruction is executing                    |
| 0: Indicate jal instruction is not executing                |
| Pin name: bomc_jalrPin direction: output                    |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate jalr instruction is executing                   |
| 0: Indicate jalr instruction is not executing               |
| Pin name: bomc_beq Pin direction: output                    |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate beq instruction is executing                    |
| 0: Indicate beq instruction is not executing                |
| Pin name: bomc_bne Pin direction: output                    |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate bne instruction is executing                    |
| 0: Indicate bne instruction is not executing                |
| Pin name: bomc_blez Pin direction: output                   |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate blez instruction is executing                   |
| 0: Indicate blez instruction is not executing               |
| Pin name: bomc_bgtz Pin direction: output                   |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |
| 1: Indicate bgtz instruction is executing                   |
| 0: Indicate bgtz instruction is not executing               |
| Pin name: bomc_lui Pin direction: output                    |
| Source -> Destination: Main Control Block -> Data-path Unit |
| Pin function:                                               |

| 1: Indicate lui instruction is               | executing                              |  |  |  |  |
|----------------------------------------------|----------------------------------------|--|--|--|--|
| 0: Indicate lui instruction is not executing |                                        |  |  |  |  |
| Pin name: bomc_rtype                         | Pin direction: output                  |  |  |  |  |
| Source -> Destination: Mai                   | n Control Block -> Data-path Unit      |  |  |  |  |
| Pin function:                                |                                        |  |  |  |  |
| 1: Indicate R-type instruction               | on is executing                        |  |  |  |  |
| 0: Indicate I-type or J-type                 | instruction is executing               |  |  |  |  |
| Table 3                                      | 2 : Main Control Block I/O description |  |  |  |  |

# **3.3.2 Arithmetic Logic Control Block**

The Arithmetic Logic Control block generates the optimized control signals which will be used by the ALU block to perform the operation. The decoding is completed within one clock cycle. The chip interface of the Arithmetic Logic Control Block is shown in Figure 3.8.



Figure 3.8 : Arithmetic Logic Control Block chip interface

| Pin name: bialc_funct[5:0]Pin direction: input                                     |
|------------------------------------------------------------------------------------|
|                                                                                    |
| Source -> Destination: PR unit -> Arithmetic Logic Control Block                   |
| Pin function: Instruction funct field                                              |
| Pin name: bialc_op[3:0]Pin direction: input                                        |
| Source -> Destination: Main Control Block -> Arithmetic Logic Control Block        |
| Pin function: Decoded ALU operation signal from Main Control Block                 |
| Pin name: boalc_ctrl[5:0]Pin direction: output                                     |
| Source -> Destination: Arithmetic Logic Control Block -> PR unit -> Data-path Unit |
| Pin function:                                                                      |
| boalc_ctrl[5]-1: Disable sign overflow                                             |
| 0: Enable sign overflow to occurs                                                  |
| boalc_ctrl[4]-1: Inverting operand B of the ALU to perform subtraction             |
| 0: No invert required                                                              |
| boalc_ctrl[3:2]- 00: Final output from the shift operation                         |
| 01: Final output from the logical operation                                        |
| 10: Final output from the summation                                                |
| 11: Final output from the set-on-less-than operation                               |
| Table 3.3 : Arithmetic Logic Control Block I/O description                         |

## **3.3.3 Register File Block**

The Register File block consists of thirty-two 32-bit registers. It is designed with dual read ports and single write port to accommodate the register accessing requirement from the MIPS ISA. Source register operand (\$rs) and target register operand (\$rt) specify for the registers read address, while either target register operand (\$rt) or destination register operand (\$rd) specify the register write address. Table 3.4 shows the conventional usage of each register in the Register File set by MIPS ISA.

| Register | Code  | Register | Usage                                                 |  |  |
|----------|-------|----------|-------------------------------------------------------|--|--|
| No.      |       | Name     |                                                       |  |  |
| 0        | 00000 | \$zero   | The constant value 0                                  |  |  |
| 1        | 00001 | \$at     | Assembler temporary                                   |  |  |
| 2        | 00010 | \$v0     | Values for function results and expression evaluation |  |  |
| 3        | 00011 | \$v1     | Values for function results and expression evaluation |  |  |
| 4        | 00100 | \$a0     | Arguments                                             |  |  |
| 5        | 00101 | \$a1     | Arguments                                             |  |  |
| 6        | 00110 | \$a2     | Arguments                                             |  |  |
| 7        | 00111 | \$a3     | Arguments                                             |  |  |
| 8        | 01000 | \$t0     | Temporaries                                           |  |  |
| 9        | 01001 | \$t1     | Temporaries                                           |  |  |
| 10       | 01010 | \$t2     | Temporaries                                           |  |  |
| 11       | 01011 | \$t3     | Temporaries                                           |  |  |
| 12       | 01100 | \$t4     | Temporaries                                           |  |  |
| 13       | 01101 | \$t5     | Temporaries                                           |  |  |
| 14       | 01110 | \$t6     | Temporaries                                           |  |  |
| 15       | 01111 | \$t7     | Temporaries                                           |  |  |
| 16       | 10000 | \$s0     | Saved temporaries                                     |  |  |
| 17       | 10001 | \$s1     | Saved temporaries                                     |  |  |
| 18       | 10010 | \$s2     | Saved temporaries                                     |  |  |
| 19       | 10011 | \$s3     | Saved temporaries                                     |  |  |
| 20       | 10100 | \$s4     | Saved temporaries                                     |  |  |
| 21       | 10101 | \$s5     | Saved temporaries                                     |  |  |
| 22       | 10110 | \$s6     | Saved temporaries                                     |  |  |
| 23       | 10111 | \$s7     | Saved temporaries                                     |  |  |
| 24       | 11000 | \$t8     | Temporaries                                           |  |  |
| 25       | 11001 | \$t9     | Temporaries                                           |  |  |
| 26       | 11010 | \$k0     | Reserved for OS kernel                                |  |  |
| 27       | 11011 | \$k1     | Reserved for OS kernel                                |  |  |
| 28       | 11100 | \$gp     | Global pointer                                        |  |  |
| 29       | 11101 | \$sp     | Stack pointer                                         |  |  |
| 30       | 11110 | \$fp     | Frame pointer                                         |  |  |
| 31       | 11111 | \$ra     | Return address                                        |  |  |

Table 3.4 : Conventional usange of the registers in Register File Block



Table 3.5 : Register File Block I/O description

Figure 3.10 describes the internal operation of the Register File block. There are three 5-bit multiplexers used to select over thirty-two registers. The write access to the register starts when enable is asserted while the combinational read accesses of the registers allow the updated result to be used in the consecutive instruction. This is to avoid the data hazard that might arise when both read and write access to the same register happen at the same time.



Figure 3.10 : Internal operation of Register File Block

#### **3.3.4 Forwarding Block**

Data hazards exist when the processor is designed in the pipeline structure. Data hazard occurs due to Read-after-Write (RAW) data dependency. According to MIPS ISA, Register File block will only be updated at WB stage. Both read (ID stage) and write (WB stage) to Register File block is occurred in two different stages, thus, an instruction may attempt to read Register File block before it is updated with the latest data. Our approach resolves all the data hazards (except load-use hazard) that might arise within the range of basic MIPS ISA core instructions, using the Forwarding block. The data hazards that can be resolved using data forwarding are divided into 4 groups in relation to the system registers: General Condition of Register File, \$ra Register, Load-store and HILO Register.

For General Condition of Register File related data hazards, the data forwarding is performed as earlier as possible, i.e. from EX or MEM stages to ID stage. This can reduce the power consumption and pipeline size due to lesser control unit signals passing through the pipeline structure. Another small advantage is to balance the stage propagation delay of ID and EX stage: the propagation delay of ALU in EX stage is longer than RF in ID stage. Table 3.6 shows the combination of instructions that causes data hazard grouped under general condition of Register File related data hazards.

| 1  | add \$1, \$1, \$1    | 2  | add \$1, \$1, 0x0    | 3  | add \$1, \$1, \$1    | 4  | addi \$1, \$1, 0x0   |
|----|----------------------|----|----------------------|----|----------------------|----|----------------------|
| 1  | add \$1, \$1, \$1    | 2  | add \$1, \$1, \$1    | 5  | addi \$1, \$1, 0x0   | +  | addi \$1, \$1, 0x0   |
| 5  | add \$1, \$1, \$1    | 6  | addi \$1, \$1, 0x0   | 7  | add \$1, \$1, \$1    | 8  | addi \$1, \$1, 0x0   |
| 5  | lw \$1, 100(\$1)     | 0  | lw \$1, 100(\$1)     | /  | sw \$1, 100(\$1)     | 0  | sw \$1, 100(\$1)     |
| 9  | add \$1, \$1, \$1    | 10 | addi \$1, \$1, 0x0   | 11 | add \$ra, \$ra, \$ra | 10 | addi \$ra, \$ra, 0x0 |
| 7  | beq \$1, \$1, 100    | 10 | beq \$1, \$1, 100    | 11 | jr \$ra              | 10 | jr \$ra              |
| 13 | add \$1, \$1, \$1    | 14 | addi \$1, \$1, 0x0   | 15 | add \$1, \$1, \$1    | 16 | addi \$1, \$1, 0x0   |
| 15 | mult \$1, \$1        | 14 | mult \$1, \$1        | 15 | mtc0 \$1, \$epc      | 10 | mtc0 \$1, \$epc      |
|    | add \$ra, \$ra, \$ra |    | addi \$ra, \$ra, 0x0 |    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |
| 17 | jalr \$ra            | 18 | jalr \$ra            | 19 | nop                  | 20 | nop                  |
|    | jan qia              |    | jan sia              |    | add \$1, \$1, \$1    |    | add \$1, \$1, \$1    |
|    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |
| 21 | nop                  | 22 | nop                  | 23 | nop                  | 24 | nop                  |
|    | addi \$1, \$1, 0x0   |    | addi \$1, \$1, 0x0   |    | lw \$1, 100(\$1)     |    | lw \$1, 100(\$1)     |
|    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |
| 25 | nop                  | 26 | nop                  | 27 | nop                  | 28 | nop                  |
|    | sw \$1, 100(\$1)     |    | sw \$1, 100(\$1)     |    | beq \$1, \$1, 100    |    | beq \$1, \$1, 100    |
|    | add \$ra, \$ra, \$ra |    | addi \$ra, \$ra, 0x0 |    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |
| 29 | nop                  | 30 | nop                  | 31 | nop                  | 32 | nop                  |
|    | jr \$ra              |    | jr \$ra              |    | mult \$1, \$1        |    | mult \$1, \$1        |
|    | add \$1, \$1, \$1    |    | addi \$1, \$1, 0x0   |    | add \$ra, \$ra, \$ra |    | addi \$ra, \$ra, 0x0 |
| 33 | nop                  | 34 | nop                  | 35 | nop                  | 36 | nop                  |
|    | mtc0 \$1, \$epc      |    | mtc0 \$1, \$epc      |    | jalr \$ra            |    | jalr \$ra            |
|    | lw \$1, 100(\$1)     |
| 37 | nop                  | 38 | nop                  | 39 | nop                  | 40 | nop                  |
|    | lw \$1, 100(\$1)     |    | sw \$1, 100(\$1)     |    | mult \$1, \$1        |    | mult \$1, \$1        |
|    | lw \$1, 100(\$1)     |    | lw \$1, 100(\$1)     |    | lw \$1, 100(\$1)     |    |                      |
| 41 | nop                  | 42 | nop                  | 43 | nop                  |    |                      |
|    | jr \$ra              |    | jalr \$ra            |    | mtc0 \$1, \$epc      |    |                      |
|    |                      |    |                      |    |                      |    |                      |

Table 3.6 : General condition of Register File related data hazards

The \$ra register related data hazards arises when the processor issued an unconditional branch instruction such as jump and link, (jal) and jump and link register, (jalr) which updates the \$ra register with the address of the next instruction (PC+4). However, the consecutive instruction right after jal or jalr will read the old value of \$ra register at ID stage. jal will update the \$ra register at WB stage, but the corresponding address value (PC+4) in \$ra register is needed earlier by the consecutive instructions at ID stage. Thus, data forwarding should take place to resolve this problem. Table 3.7 shows the combination of instructions that causes data hazard grouped under \$ra register related data hazards.

|                                 |                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -                                                      |                                                        |                                                         |                                                        |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------|
| jal 10000<br>add \$ra_\$ra_\$ra | 2                                                                                                                                                                                                                                                                                                         | jalr \$ra<br>add \$ra_\$ra_\$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3                                                      | jal 10000<br>lw \$ra_100(\$ra)                         | 4                                                       | jalr \$ra<br>lw \$ra, 100(\$ra)                        |
|                                 |                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                        |                                                        |                                                         |                                                        |
|                                 | 6                                                                                                                                                                                                                                                                                                         | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7                                                      |                                                        | 8                                                       | jalr \$ra                                              |
|                                 |                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _                                                      |                                                        | _                                                       | beq \$ra, \$ra, 100                                    |
| jal 10000                       | 10                                                                                                                                                                                                                                                                                                        | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 11                                                     | jal 10000                                              | 12                                                      | jalr \$ra                                              |
| jr \$ra                         | 10                                                                                                                                                                                                                                                                                                        | jr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 11                                                     | jalr \$ra                                              | 12                                                      | jalr \$ra                                              |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              | 1.6                                                     | jalr \$ra                                              |
| mult \$ra                       | 14                                                                                                                                                                                                                                                                                                        | mult \$ra, \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 15                                                     | jalr \$ra                                              | 16                                                      | mtc0 \$ra, \$epc                                       |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              |                                                         | jalr \$ra                                              |
| nop                             | 18                                                                                                                                                                                                                                                                                                        | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 19                                                     | nop                                                    | 20                                                      | nop                                                    |
| addi \$ra, \$ra, 0x0            |                                                                                                                                                                                                                                                                                                           | addi \$ra, \$ra, 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                        | add \$ra, \$ra, \$ra                                   |                                                         | add \$ra, \$ra, \$ra                                   |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              |                                                         | jalr \$ra                                              |
| nop                             | 22                                                                                                                                                                                                                                                                                                        | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 23                                                     | nop                                                    | 24                                                      | nop                                                    |
| addi \$ra, \$ra, 0x0            |                                                                                                                                                                                                                                                                                                           | addi \$ra, \$ra, 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                        | lw \$ra, 100(\$ra)                                     |                                                         | lw \$ra, 100(\$ra)                                     |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | kalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              |                                                         | jalr \$ra                                              |
| nop                             | 26                                                                                                                                                                                                                                                                                                        | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 27                                                     | nop                                                    | 28                                                      | nop                                                    |
| sw \$ra, 100(\$ra)              |                                                                                                                                                                                                                                                                                                           | sw \$ra, 100(\$ra)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                        | beq \$ra, \$ra, 100                                    |                                                         | beq \$ra, \$ra, 100                                    |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              |                                                         | jalr \$ra                                              |
| nop                             | 30                                                                                                                                                                                                                                                                                                        | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 31                                                     | nop                                                    | 32                                                      | nop                                                    |
| jr \$ra                         |                                                                                                                                                                                                                                                                                                           | jr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                        | jalr \$ra                                              |                                                         | jalr \$ra                                              |
| jal 10000                       |                                                                                                                                                                                                                                                                                                           | jalr \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                        | jal 10000                                              |                                                         | jalr \$ra                                              |
| nop                             | 34                                                                                                                                                                                                                                                                                                        | nop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 35                                                     | nop                                                    | 36                                                      | nop                                                    |
| mult \$ra, \$ra                 |                                                                                                                                                                                                                                                                                                           | mult \$ra, \$ra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                        | mtc0 \$ra, \$epc                                       |                                                         | mtc0 \$ra, \$epc                                       |
|                                 | add \$ra, \$ra, \$ra<br>jal 10000<br>sw \$ra, 100(\$ra)<br>jal 10000<br>jr \$ra<br>jal 10000<br>mult \$ra<br>jal 10000<br>nop<br>addi \$ra, \$ra, 0x0<br>jal 10000<br>nop<br>addi \$ra, \$ra, 0x0<br>jal 10000<br>nop<br>sw \$ra, 100(\$ra)<br>jal 10000<br>nop<br>sw \$ra, 100(\$ra)<br>jal 10000<br>nop | add \$ra, \$ra, \$ra       2         jal 10000       6         sw \$ra, 100(\$ra)       10         jal 10000       10         jal 10000       14         jal 10000       14         jal 10000       14         jal 10000       18         addi \$ra, \$ra, 0x0       18         addi \$ra, \$ra, 0x0       22         addi \$ra, \$ra, 0x0       22         addi \$ra, \$ra, 0x0       26         sw \$ra, 100(\$ra)       30         jr \$ra       30 | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ |

Table 3.7 : \$ra register relater data hazards

A load-store hazard has the similar characteristics as load use hazard, which the RAW dependency exists between the combinations of instructions started with a load instruction. However, it can be resolved by using data forwarding. By referring to the MIPS ISA convention, the registers used for load and store instruction can be classified into two usages, one for holding address (\$rs) and another for holding data (\$rt). Address calculation of the store instruction is performed at the EX stage: \$rs should be ready before going into the ALU unit for address calculation. Since the data of the load instruction is only available at the MEM stage onwards, it requires pipeline stages stalling when the consecutive instruction relies on the respective data to perform calculation in the EX stage. In contrast, for the case where the store instruction not using the data of the load instruction in the EX stage of the data at MEM stage, the data can be forwarded from the MEM stage to EX stage of the consecutive instruction.

The HILO register related data hazards may arise in two scenarios:

1. when after multiplication, the result is to be read by either mflo or mfhi, but it is not ready for reading until at the WB stage. The multiplication result should be forwarded from MEM stage to EX stage.

2. when the processor copies the HILO register's data to the Register File, reading the same register in the Register File before it is updated. The HILO register's data should be forwarded from the EX or MEM stage to ID stage.

The combination of instructions shown in Table 3.8 cover both situations grouped under HILO register related data hazards.

| 1  | mult \$1, \$1<br>mflo \$1 | 2  | mult \$1, \$1<br>mfhi \$1 | 3  | mflo \$1 / mfhi \$1<br>add \$1, \$1, \$1 | 4  | mflo \$1 / mfhi \$1<br>addi \$1, \$1, 0x0 |
|----|---------------------------|----|---------------------------|----|------------------------------------------|----|-------------------------------------------|
|    | 11110-\$1                 |    | 111111 <b>\$</b> 1        |    | add \$1, \$1, \$1                        |    | addi $\$1$ , $\$1$ , $0x0$                |
| 5  | mflo \$1 / mfhi \$1       | 6  | mflo \$1 / mfhi \$1       | 7  | mflo \$1 / mfhi \$1                      | 8  | mflo \$1 / mfhi \$1                       |
| 5  | lw \$1, 100(\$1)          | 0  | sw \$1, 100(\$1)          | /  | mult \$1, \$1                            | 0  | beq \$1, \$1, 100                         |
|    | mflo \$1 / mfhi \$1       |    | mflo \$1 / mfhi \$1       |    | mflo \$1 / mfhi \$1                      |    | mflo \$1 / mfhi \$1                       |
| 9  | nop                       | 10 | nop                       | 11 | nop                                      | 12 | nop                                       |
|    | add \$1, \$1, \$1         |    | addi \$1, \$1, 0x0        |    | lw \$1, 100(\$1)                         |    | sw \$1, 100(\$1)                          |
|    | mflo \$1 / mfhi \$1       |    | mflo \$1 / mfhi \$1       |    |                                          |    |                                           |
| 13 | nop                       | 14 | nop                       |    |                                          |    |                                           |
|    | mult \$1, \$1             |    | beq \$1, \$1, 100         |    |                                          |    |                                           |

Table 3.8 HILO register related data hazards

Figure 3.11 shows the chip interface of the Forwarding block and Table 3.9 describes the function of each pin.



Figure 3.11 : Forwarding Block chip interface

| Pin name: bifw_ex_jal              | Pin direction: input                                     |
|------------------------------------|----------------------------------------------------------|
| Source -> Destination: Data-path   | Unit (Pipeline microarchiecture) -> Forwarding           |
| Block                              |                                                          |
| Pin function: Only use in pipeline | e microarchitecture, indicate a jal instruction is in EX |
| stage                              |                                                          |
| Pin name: bifw_ex_jalr             | Pin direction: input                                     |
| Source -> Destination: Data-path   | Unit (Pipeline microarchiecture) -> Forwarding           |

| Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>EX stage Pin name: bifw_ex_rf_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate enable write to Register File operation is in EX stage Pin name: bifw_ex_hilo_acc Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi instruction is in EX stage Pin name: bifw_ex_h_to_rf Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin name: bifw_ex_h_to_rf Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mfli instruction is in EX stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage Pin name: bifw_mem_f_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a lw, lw, lwr, lh, lhu, lb or lbu instruction is in pipeline microarchitecture, indicate a mult or multu instruction in MEM stage Pin name: bifw_mem_f_wr Pin direction: input Source -> Destination: Data-path Unit                                                                                                                                 | Block                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| EX stage Pin name: bifw_ex_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation is in EX stage Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hil_o_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_f_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_f_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_f_mr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_f_mr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw |                                                                                         |
| Pin name: bifw_ex_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation is in EX stage<br>Pin name: bifw_ex_hilo_acc Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_ff_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_ff_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lw, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline mic                                                |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation is in EX stage<br>Pin name: bifw_ex_hilo_acc Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_ex_hi_to_rf<br>Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_f_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_four Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lw, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitect |                                                                                         |
| Block Pin function: Only use in pipeline microarchitecture, indicate enable write to Register File operation is in EX stage Pin name: bifw_ex_hilo_acc Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi instruction is in EX stage Pin name: bifw_ex_hil_0_rf Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in EX stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in EX stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jalr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin name: bifw_mem_fr_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage Pin name: bifw_mem_fr_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a law, lwl, lwr, lh, lhu, lb or lbu instruction is in MEM stage Pin name: bifw_mem_mult Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mult or multu instruction is in MEM stage Pin name: bifw_mem_mult Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block P                                                                                                                                  |                                                                                         |
| Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation is in EX stage<br>Pin name: bifw_ex_hilo_acc Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_f_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction                                                 |                                                                                         |
| File operation is in EX stage         Pin name: bifw_ex_hilo_acc       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_ex_hi_to_rf       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_ex_hi_to_rf       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in         EX stage       Pin name: bifw_mem_jal         Pin name: bifw_mem_jal       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in         MEM stage       Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in         MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a lalr instruction is in         MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding <t< td=""><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                         |
| Pin name: bifw_ex_hilo_acc Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hi_to_f Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_ff_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_ff_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_foad Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a law, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>nstruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, in                                              |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_noad Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a nult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source |                                                                                         |
| Block Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi instruction is in EX stage Pin name: bifw_ex_hi_to_rf Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jalr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin name: bifw_mem_ff_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage Pin name: bifw_mem_ff_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate enable write to Register File operation in MEM stage Pin name: bifw_mem_ff_wr Pin function: Only use in pipeline microarchitecture, indicate a law, lwk, lwk, lwk, lwk, lwk, lwk, lwk, lw                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                         |
| Pin function: Only use in pipeline microarchitecture, indicate a mflo or mfhi<br>instruction is in EX stage<br>Pin name: bifw_mex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_ff_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate anable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_ff_wr<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Un                                              |                                                                                         |
| instruction is in EX stage<br>Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_ind_rts5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_ind_rts5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_ind_rts5[4:0] Pin direction: in                                              | Block                                                                                   |
| Pin name: bifw_ex_hi_to_rf Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rts5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts5[4:0] Pin direc                                              |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rts[4:0] Pin direction: input                                                                                                               |                                                                                         |
| Block Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in EX stage Pin name: bifw_mem_jal Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in MEM stage Pin name: bifw_mem_jalr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage Pin name: bifw_mem_rf_wr Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate enable write to Register File operation in MEM stage Pin name: bifw_mem_load Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb or lbu instruction is in MEM stage Pin name: bifw_mem_mult Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb or lbu instruction is in MEM stage Pin name: bifw_mem_mult Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mult or multu instruction is in MEM stage Pin name: bifw_mem_mult Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin function: Only use in pipeline microarchitecture, indicate a mult or multu instruction is in MEM stage Pin name: bifw_id_rs5[4:0] Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding Block Pin name: bifw_id_rs5[4:0] Pin direction: input Source -> Destination: Data-path Unit (Pipeline microarchit                                                                                                                                  | Pin name: bifw_ex_hi_to_rfPin direction: input                                          |
| Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in<br>EX stage<br>Pin name: bifw_mem_jal Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lw, lw, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lw, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                          | Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         |
| EX stage         Pin name: bifw_mem_jal       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in         MEM stage       Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding       Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in       MEM stage         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in       MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Block       Pin direction: input         Pour -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin direction: input <tr< td=""><td>Block</td></tr<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Block                                                                                   |
| EX stage         Pin name: bifw_mem_jal       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in         MEM stage       Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding       Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in       MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in         MEM stage       Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Or Ibu instruction is in MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin direction: input         Pin function: Only use in pipeline microarchitecture, indicate a mult                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Pin function: Only use in pipeline microarchitecture, indicate a mfhi instruction is in |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in<br>MEM stage<br>Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                     | EX stage                                                                                |
| Block         Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in         MEM stage         Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in         MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin name: bifw_mem_mult         Pin direction: input       Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a mult or multu instruction is in MEM stage         Pin name:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Pin name: bifw_mem_jalPin direction: input                                              |
| Block         Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in         MEM stage         Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in         MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin name: bifw_mem_mult         Pin direction: input       Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, indicate a mult or multu instruction is in MEM stage         Pin name:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         |
| MEM stage       Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block       Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Block                                                                                   |
| MEM stage       Pin name: bifw_mem_jalr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb or lbu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding Block         Pin name:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Pin function: Only use in pipeline microarchitecture, indicate a jal instruction is in  |
| Pin name: bifw_mem_jalr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                         |
| Block         Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in         MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         or Ibu instruction is in MEM stage         Pin name: bifw_mem_mult         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Bl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                         |
| Pin function: Only use in pipeline microarchitecture, indicate a jalr instruction is in<br>MEM stage<br>Pin name: bifw_mem_rf_wr Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>for lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Block                                                                                   |
| MEM stage         Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rts5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline micr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                         |
| Pin name: bifw_mem_rf_wr       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rts5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | · · · · · · · · · · · · · · · · · · ·                                                   |
| Block         Pin function: Only use in pipeline microarchitecture, indicate enable write to Register         File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         por lbu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding         Block         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rts5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding         Block       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding         Block       Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage       Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                         |
| Pin function: Only use in pipeline microarchitecture, indicate enable write to Register<br>File operation in MEM stage<br>Pin name: bifw_mem_load Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>Instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                         |
| File operation in MEM stage         Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         or lbu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]       Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                         |
| Pin name: bifw_mem_load       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         or Ibu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]       Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>Instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                         |
| Block         Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb         or lbu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ÷                                                                                       |
| Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb<br>or lbu instruction is in MEM stage<br>Pin name: bifw_mem_mult Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>Instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                         |
| or Ibu instruction is in MEM stage         Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                         |
| Pin name: bifw_mem_mult       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin name: bifw_id_rs5[4:0]         Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, indicate a mult or multu<br>Instruction is in MEM stage<br>Pin name: bifw_id_rs5[4:0] Pin direction: input<br>Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                         |
| Block         Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         Instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                                                                       |
| Pin function: Only use in pipeline microarchitecture, indicate a mult or multu         instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                         |
| instruction is in MEM stage         Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                         |
| Pin name: bifw_id_rs5[4:0]       Pin direction: input         Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding         Block         Pin function: Only use in pipeline microarchitecture, address of source register in ID         stage         Pin name: bifw_id_rt5[4:0]         Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding<br>Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | · · · · · · · · · · · · · · · · · · ·                                                   |
| Block<br>Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                       |
| Pin function: Only use in pipeline microarchitecture, address of source register in ID<br>stage<br>Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                         |
| stage       Pin direction: input         Pin direction: input       Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Block                                                                                   |
| Pin name: bifw_id_rt5[4:0] Pin direction: input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | stage                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                         |
| Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Source -> Destination: Data-path Unit (Pipeline microarchitecture) -> Forwarding        |

| Block                                                                                    |
|------------------------------------------------------------------------------------------|
| Pin function: Only use in pipeline microarchitecture, address of target register in ID   |
| stage                                                                                    |
| Pin name: bifw_ex_rt5_rd5[4:0]Pin direction: input                                       |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding          |
| Block                                                                                    |
| Pin function: Only use in pipeline microarchitecture, address of destination register in |
| EX stage                                                                                 |
| Pin name: bifw_mem_rt5_rd5[4:0]Pin direction: input                                      |
| Source -> Destination: Data-path Unit (Pipeline microarchiecture) -> Forwarding          |
| Block                                                                                    |
| Pin function: Only use in pipeline microarchitecture, address of destination register in |
| MEM stage                                                                                |
| Pin name: bofw_rs32_ctrl[2:0]Pin direction: output                                       |
| Source -> Destination: Forwarding Block -> Data-path Unit (Pipeline                      |
| microarchiecture)                                                                        |
| Pin function: Only use in pipeline microarchitecture, used as the forward control        |
| signal for the rs path                                                                   |
| Pin name: bofw_rt32_ctrl[2:0]Pin direction: output                                       |
| Source -> Destination: Forwarding Block -> Data-path Unit (Pipeline                      |
| microarchiecture)                                                                        |
| Pin function: Only use in pipeline microarchitecture, used as the forward control        |
| signal for the rt path                                                                   |
| Pin name: bofw_rt32_ctrl[2:0]Pin direction: output                                       |
| Source -> Destination: Forwarding Block -> Data-path Unit (Pipeline                      |
| microarchiecture)                                                                        |
| Pin function: Only use in pipeline microarchitecture, used as the forward control        |
| signal for the rt path                                                                   |
| Pin name: bofw_rt32_ctrl[2:0]Pin direction: output                                       |
| Source -> Destination: Forwarding Block -> Data-path Unit (Pipeline                      |
| microarchiecture)                                                                        |
| Pin function: Only use in pipeline microarchitecture, used as the forward control        |
| signal for the rt path                                                                   |
| Table 3.9 : Forwarding Block I/O description                                             |
|                                                                                          |

# **3.3.5 Interlock Block**

Our previous work (Kiat, W. P. et al., 2017) also covers resolving the load-use hazard in pipeline processor using Interlock block. Load-use hazard occurs when the consecutive instruction performs a read access to the same register that used by a load instruction to store new memory data. The Interlock block is responsible to detect such condition, stall IF and ID stage and insert a nop at the EX stage. Figure 3.12 shows the chip interface of the Interlock block and Table 3.10 describes the function of each pin.



Figure 3.12 : Interlock Block chip interface

| Din nomer hittlid load Din direction input                                                 |
|--------------------------------------------------------------------------------------------|
| Pin name: bitl_id_load Pin direction: input                                                |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb |
| or lbu instruction is in ID stage                                                          |
| Pin name: biitl_id_store Pin direction: input                                              |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture, indicate a sw, swl, swr, sh or sb    |
| instruction is in ID stage                                                                 |
| Pin name: biitl_id_rtype     Pin direction: input                                          |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture                                       |
| 1: Indicate a R-type instruction is in ID stage                                            |
| 0: Indicate a J-type or I-type instruction is in ID stage                                  |
| Pin name: biitl_ex_load Pin direction: input                                               |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture, indicate a lw, lwl, lwr, lh, lhu, lb |
| or lbu instruction is in EX stage                                                          |
| Pin name: biitl_id_rs5[4:0] Pin direction: input                                           |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture, address of source register in ID     |
| stage                                                                                      |
| Pin name: biitl_id_rt5[4:0] Pin direction: input                                           |
| Source -> Destination: Data-path Unit -> Interlock Block                                   |
| Pin function: Only use in pipeline microarchitecture, address of target register in ID     |
| stage                                                                                      |
|                                                                                            |

| Pin name: biitl_ex_rt5[4:0] Pin direction: input                                       |
|----------------------------------------------------------------------------------------|
| Source -> Destination: Data-path Unit -> Interlock Block                               |
| Pin function: Only use in pipeline microarchitecture, address of target register in EX |
| stage                                                                                  |
| Pin name: boitl_ld_use_pc_enPin direction: output                                      |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Only use in pipeline microarchitecture                                   |
| 1: No stall on PC register                                                             |
| 0: Stall PC register                                                                   |
| Pin name: boitl_ld_use_ifid_en   Pin direction: output                                 |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Only use in pipeline microarchitecture                                   |
| 1: No stall on IF/ID pipeline register                                                 |
| 0: Stall IF/ID pipeline register                                                       |
| Pin name: boitl_idex_en Pin direction: output                                          |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Reserved for future development, temporary always enable                 |
| Pin name: boitl_exmem_en Pin direction: output                                         |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Reserved for future development, temporary always enable                 |
| Pin name: boitl_memwb_enPin direction: output                                          |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Reserved for future development, temporary always enable                 |
| Pin name: boitl_ld_use_flush_exPin direction: output                                   |
| Source -> Destination: Interlock Block -> Data-path Unit                               |
| Pin function: Only use in pipeline microarchitecture                                   |
| 1: Flush ID/EX stage pipeline register                                                 |
| 0: No pipeline register flush is requires                                              |
| Table 3.10 : Interlock Block I/O description                                           |

Table 3.10 : Interlock Block I/O description

# 3.3.6 ALU Block

The Arithmetic Logic Unit (ALU) block is used to perform the operation of an instruction. Figure 3.13 shows the chip interface of the ALU block, describes the function of each pin and Table 3.12 shows the input control signals with respect to the operation of each instruction.



| Pin name: bialb_op_a[31:0]Pin direction: input     |
|----------------------------------------------------|
| Source -> Destination: Data-path Unit -> ALU Block |
| Pin function: ALU operand                          |
| Pin name: bialb_op_b[31:0]Pin direction: input     |
| Source -> Destination: Data-path Unit -> ALU Block |
| Pin function: ALU operand                          |
| Pin name: bialb_ctrl[5:0]Pin direction: input      |
| Source -> Destination: Data-path Unit -> ALU Block |
| Pin function: ALU operation to perform             |
| Pin name: bialb_shamt[4:0]Pin direction: input     |
| Source -> Destination: Data-path Unit -> ALU Block |
| Pin function: Shift amount                         |
| Pin name: boalb_out[31:0]Pin direction: output     |
| Source -> Destination: ALU Block ->Data-path Unit  |
| Pin function: ALU output result                    |
| Pin name: boalb_ovfs Pin direction: output         |
| Source -> Destination: ALU Block ->Data-path Unit  |
| Pin function:                                      |
| 1: Sign overflow has occur                         |
| 0: No sign overflow occur                          |
| Pin name: boalb_zeroPin direction: output          |
| Source -> Destination: ALU Block ->Data-path Unit  |
| Pin function:                                      |
| 1: ALU output result is zero                       |
| 0: ALU output result is not zero                   |

Table 3.11 : ALU Block I/O description

| No.   | Instruction | bialb_ctrl[5:0] |
|-------|-------------|-----------------|
| 1     | add         | 001000          |
| 2     | addu        | 101001          |
| 3     | sub         | 011010          |
| 4     | subu        | 111011          |
| 5     | mult        | 100100          |
| 6     | multu       | 100100          |
| 7     | mfhi        | 100100          |
| 8     | mflo        | 100100          |
| 9     | and         | 100100          |
| 10    | or          | 100101          |
| 11    | xor         | 100110          |
| 12    | nor         | 100111          |
| 13    | sll         | 100000          |
| 14    | srl         | 100010          |
| 15    | sra         | 100011          |
| 16    | slt         | 111110          |
| 17    | sltu        | 111110          |
| 18    | jr          | 100100          |
| 10    | jalr        | 100100          |
| 20    | addi        | 001000          |
| 20    | addiu       | 101000          |
| 21    | andi        | 101000          |
| 23    | ori         | 100100          |
| 23    | xori        | 100101          |
| 25    | lui         | 100110          |
| 25    | lw          | 101000          |
| 20    | lwl         | 101000          |
| 28    | lwr         | 101000          |
| 29    | lh          | 101000          |
| 30    | lhu         | 101000          |
| 30    | lb          | 101000          |
| 32    | lbu         | 101000          |
| 33    | SW          | 101000          |
| 33    | swl         | 101000          |
| 35    |             | 101000          |
| 36    | swr<br>sh   | 101000          |
| 30    | sb          | 101000          |
| 38    | slti        | 111110          |
| 38    | sltiu       | 111110          |
| 40    |             | 100100          |
| 40    | beq         | 100100          |
| 41 42 | bne<br>blez |                 |
| 42    |             | 100100          |
| 43    | bgtz        | 100100          |
|       |             | 100100          |
| 45    | jal         | 100100          |

Table 3.12 : ALU Block operation

# **3.3.7 Multiplier Block**

The Multiplier block is developed based on the Booth algorithm. It is used to perform multiplication operation on two 32-bit values from the Register File block and stored the 64-bits result in the HILO register. Figure 3.14 shows the chip interface of the Multiplier block and Table 3.13 describes the function of each pin.



Figure 3.14 : Multiplier Block chip interface

| Pin name: bimult32_mulcn[31:0]       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin function: Multiplier operand         Pin name: bimult32_mulpl[31:0]       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin function: Multiplier operand         Pin name: bimult32_reg_wr       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin function: Enable multiplication and also writing intermediate results into multiplier pipeline         Pin name: bimult32_reg_wr       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin name: bimult32_sign_mult         Pin name: bimult32_sign_mult       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin function: input         Source -> Destination: Global reset-> Multiplier Block       Pin function:         Pin function:       I: Reset       O: No reset require         Pin name: bimult32_en       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block       Pin function: 1: Enable signal 0: no enable signal         Pin name: bomult32_result[63:0]       Pin direction: output         Source -> Destination: Multiplier Block ->HILO register       Pin function: 0.1L_valid         Pin name: bomult32_mult_valid       Pin direction: outpu |                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| Pin function: Multiplier operand         Pin name: bimult32_mulpl[31:0]       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin name: bimult32_reg_wr       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: Enable multiplication and also writing intermediate results into         multiplier pipeline         Pin name: bimult32_sign_mult       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin name: bimult32_sign_mult       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: Indicate sign multiplication, mult instruction is executing         Pin name: bimult32_rst       Pin direction: input         Source -> Destination: Global reset-> Multiplier Block         Pin function:       I: Reset         0: No reset require       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin name: bimult32_en       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin name: bomult32_result[63:0]       Pin direction: output         Source -> Destination: Multiplier Block ->HILO register         Pin function: Multiplier output result       Pin direction: output <t< td=""><td>Pin name: bimult32_mulcn[31:0]Pin direction: input</td></t<>      | Pin name: bimult32_mulcn[31:0]Pin direction: input                             |
| Pin name: bimult32_mulpl[31:0]Pin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin name: bimult32_reg_wrPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: Enable multiplication and also writing intermediate results intomultiplier pipelinePin name: bimult32_sign_multPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin name: bimult32_sign_multPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: Indicate sign multiplication, mult instruction is executingPin name: bimult32_rstPin direction: inputSource -> Destination: Global reset-> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin name: bomult32_result[63:0]Pin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function:Pin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                             | Source -> Destination: Data-path Unit -> Multiplier Block                      |
| Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Multiplier operand<br>Pin name: bimult32_reg_wr Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Enable multiplication and also writing intermediate results into<br>multiplier pipeline<br>Pin name: bimult32_sign_mult Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Indicate sign multiplication, mult instruction is executing<br>Pin name: bimult32_rst Pin direction: input<br>Source -> Destination: Global reset-> Multiplier Block<br>Pin function:<br>1: Reset<br>0: No reset require<br>Pin name: bimult32_en Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function:<br>1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier Block ->Data-path Unit<br>Pin function: Multiplier Block ->Data-path Unit<br>Pin function: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                | Pin function: Multiplier operand                                               |
| Pin function: Multiplier operandPin name: bimult32_reg_wrPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: Enable multiplication and also writing intermediate results intomultiplier pipelinePin name: bimult32_sign_multPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: Indicate sign multiplication, mult instruction is executingPin name: bimult32_rstPin direction: inputSource -> Destination: Global reset-> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_result[63:0]Pin name: bomult32_result[63:0]Pin name: output resultPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                             |                                                                                |
| Pin name: bimult32_reg_wr       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: Enable multiplication and also writing intermediate results into         multiplier pipeline         Pin name: bimult32_sign_mult       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: Indicate sign multiplication, mult instruction is executing         Pin name: bimult32_rst       Pin direction: input         Source -> Destination: Global reset-> Multiplier Block         Pin function:       1: Reset         0: No reset require       Pin direction: input         Pin name: bimult32_en       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function:       1: Reset         0: No reset require       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: 1: Enable signal 0: no enable signal         Pin name: bomult32_result[63:0]       Pin direction: output         Source -> Destination: Multiplier Block ->HILO register         Pin function: Multiplier output result       Pin direction: output         Source -> Destination: Multiplier Block ->Data-path Unit         Pin name: bomult32_mult_valid       Pin direction: output <td< td=""><td>Source -&gt; Destination: Data-path Unit -&gt; Multiplier Block</td></td<>            | Source -> Destination: Data-path Unit -> Multiplier Block                      |
| Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Enable multiplication and also writing intermediate results into<br>multiplier pipeline<br>Pin name: bimult32_sign_mult Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Indicate sign multiplication, mult instruction is executing<br>Pin name: bimult32_rst Pin direction: input<br>Source -> Destination: Global reset-> Multiplier Block<br>Pin function:<br>1: Reset<br>0: No reset require<br>Pin name: bimult32_en Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: 1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier Block ->Data-path Unit<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function: 1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                            | Pin function: Multiplier operand                                               |
| Pin function: Enable multiplication and also writing intermediate results into         multiplier pipeline         Pin name: bimult32_sign_mult       Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: Indicate sign multiplication, mult instruction is executing         Pin name: bimult32_rst       Pin direction: input         Source -> Destination: Global reset-> Multiplier Block         Pin function:         1: Reset         0: No reset require         Pin name: bimult32_en         Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function:         1: Reset         0: No reset require         Pin name: bimult32_en         Pin direction: input         Source -> Destination: Data-path Unit -> Multiplier Block         Pin function: 1: Enable signal 0: no enable signal         Pin name: bomult32_result[63:0]       Pin direction: output         Source -> Destination: Multiplier Block ->HILO register         Pin function: Multiplier output result         Pin name: bomult32_mult_valid       Pin direction: output         Source -> Destination: Multiplier Block ->Data-path Unit         Pin function:       1: Indicate multiplier result is valid         0: Indicate multiplier res                                                                                                                                                | Pin name: bimult32_reg_wr Pin direction: input                                 |
| multiplier pipelinePin name: bimult32_sign_multPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: Indicate sign multiplication, mult instruction is executingPin name: bimult32_rstPin direction: inputSource -> Destination: Global reset-> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function:1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Source -> Destination: Data-path Unit -> Multiplier Block                      |
| Pin name:bimult32_sign_multPin direction:inputSource ->Destination:Data-path Unit ->Multiplier BlockPin function:Indicate sign multiplication, mult instruction is executingPin name:bimult32_rstPin direction:Source ->Destination:Global reset->Source ->Destination:Global reset->1:ResetResetReset0:No reset requirePin direction:inputSource ->Destination:Data-path Unit ->Source ->Destination:Data-path Unit ->Multiplier BlockPin function:1:Enable signal 0: no enable signalPin name:bomult32_result[63:0]Pin direction:outputSource ->Destination:Multiplier Block ->HILO registerPin function:Multiplier output resultPin direction:outputSource ->Destination:Multiplier Block ->Data-path UnitPin name:bomult32_mult_validPin direction:outputSource ->Destination:Multiplier Block ->Data-path UnitPin function:1:Indicate multiplier result is validO:O:Indicate multiplier result is not ready to useSec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Pin function: Enable multiplication and also writing intermediate results into |
| Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: Indicate sign multiplication, mult instruction is executing<br>Pin name: bimult32_rst Pin direction: input<br>Source -> Destination: Global reset-> Multiplier Block<br>Pin function:<br>1: Reset<br>0: No reset require<br>Pin name: bimult32_en Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: 1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                            | multiplier pipeline                                                            |
| Pin function: Indicate sign multiplication, mult instruction is executingPin name: bimult32_rstPin direction: inputSource -> Destination: Global reset-> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Pin name: bimult32_sign_multPin direction: input                               |
| Pin name: bimult32_rstPin direction: inputSource -> Destination: Global reset-> Multiplier BlockPin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                |
| Source -> Destination: Global reset-> Multiplier Block<br>Pin function:<br>1: Reset<br>0: No reset require<br>Pin name: bimult32_en Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: 1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Pin function: Indicate sign multiplication, mult instruction is executing      |
| Pin function:1: Reset0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Pin name: bimult32_rst Pin direction: input                                    |
| 1: Reset<br>0: No reset require<br>Pin name: bimult32_en Pin direction: input<br>Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: 1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Source -> Destination: Global reset-> Multiplier Block                         |
| 0: No reset requirePin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Pin function:                                                                  |
| Pin name: bimult32_enPin direction: inputSource -> Destination: Data-path Unit -> Multiplier BlockPin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1: Reset                                                                       |
| Source -> Destination: Data-path Unit -> Multiplier Block<br>Pin function: 1: Enable signal 0: no enable signal<br>Pin name: bomult32_result[63:0] Pin direction: output<br>Source -> Destination: Multiplier Block ->HILO register<br>Pin function: Multiplier output result<br>Pin name: bomult32_mult_valid Pin direction: output<br>Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0: No reset require                                                            |
| Pin function: 1: Enable signal 0: no enable signalPin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Pin name: bimult32_en Pin direction: input                                     |
| Pin name: bomult32_result[63:0]Pin direction: outputSource -> Destination: Multiplier Block ->HILO registerPin function: Multiplier output resultPin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1 1                                                                            |
| Source -> Destination: Multiplier Block ->HILO register         Pin function: Multiplier output result         Pin name: bomult32_mult_valid       Pin direction: output         Source -> Destination: Multiplier Block ->Data-path Unit         Pin function:         1: Indicate multiplier result is valid         0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Pin function: 1: Enable signal 0: no enable signal                             |
| Pin function: Multiplier output result         Pin name: bomult32_mult_valid       Pin direction: output         Source -> Destination: Multiplier Block ->Data-path Unit         Pin function:         1: Indicate multiplier result is valid         0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Pin name: bomult32_result[63:0]Pin direction: output                           |
| Pin name: bomult32_mult_validPin direction: outputSource -> Destination: Multiplier Block ->Data-path UnitPin function:1: Indicate multiplier result is valid0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Source -> Destination: Multiplier Block ->HILO register                        |
| Source -> Destination: Multiplier Block ->Data-path Unit<br>Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Pin function: Multiplier output result                                         |
| Pin function:<br>1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                |
| 1: Indicate multiplier result is valid<br>0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Source -> Destination: Multiplier Block ->Data-path Unit                       |
| 0: Indicate multiplier result is not ready to use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Pin function:                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1: Indicate multiplier result is valid                                         |
| Pin name: bomult32_mult_busyPin direction: output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0: Indicate multiplier result is not ready to use                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Pin name: bomult32_mult_busyPin direction: output                              |

| Source -> Destination: Multiplier Block -> Data-path Unit |   |
|-----------------------------------------------------------|---|
| Pin function: Reserved for future development             |   |
|                                                           | _ |

Table 3.13 : Multiplier Block I/O description

# 3.3.8 Boot ROM Unit

The Boot ROM unit is used to store the bootloader program. The Boot ROM unit to be read-only, i.e. no write data bus, and the bootloader program is pass to the Boot ROM unit using "\$readmemh (`ROM\_FILE\_PATH, rom\_data)" in the Verilog HDL). A block wrapper module is designed, as shown in Figure 3.15, for the ease of using the FPGA Block RAM and Table 3.14 describes the function of each pin.



Figure 3.15 : Boot ROM Unit chip interface

| Pin name: birom_wb_addr[SIZE:0]Pin direction: input                           |
|-------------------------------------------------------------------------------|
| Source -> Destination: Data-path Unit -> Boot ROM unit                        |
| Pin function: Address location of the data in the Boot ROM unit               |
| Pin name: birom_wb_stbPin direction: input                                    |
| Source -> Destination: Data-path Unit ->Boot ROM unit                         |
| Pin function: Strobe control                                                  |
| 1: Boot ROM unit is activated to perform read access for new address location |
| 0: Boot ROM unit is de-activated to perform read access                       |
| Pin name: birom_wb_enPin direction: input                                     |
| Source -> Destination: Data-path ->Boot ROM unit                              |
| Pin function:                                                                 |
| 1: Enable signal                                                              |
| 0: No enable signal                                                           |
| Pin name: birom_wb_rstPin direction: input                                    |
| Source -> Destination: Global reset ->Boot ROM unit                           |
| Pin function:                                                                 |
| 1: Reset                                                                      |
| 0: No reset require                                                           |
| Pin name: borom_wb_dout[31:0]Pin direction: output                            |
| Source -> Destination: Boot ROM unit -> Data-path Unit                        |
| Pin function: 32-bits data output                                             |
| Pin name: borom_wb_ackPin direction: output                                   |
| Source -> Destination: Boot ROM unit -> Data-path Unit                        |
| Pin function: Indicate data is ready to be fetched                            |
| Table 3.14 : Boot ROM Unit I/O description                                    |

 Table 3.14 : Boot ROM Unit I/O description

# 3.3.9 Data and Stack RAM Unit

The Data and Stack RAM Unit is created to store the runtime data. A block wrapper module is designed, as shown in Figure 3.16, for the ease of using the FPGA Block RAM and Table 3.15 describes the function of each pin.



Figure 3.16 : Data and Stack RAM Unit chip interface

| Pin name: uiram_wb_din[31:0]   Pin direction: input                                     |
|-----------------------------------------------------------------------------------------|
| Source -> Destination: Data-path Unit -> Data and Stack RAM Unit                        |
| Pin function: 32-bits data input                                                        |
| Pin name: uiram_wb_addr[SIZE:0]     Pin direction: input                                |
| Source -> Destination: Data-path Unit -> Data and Stack RAM Unit                        |
| Pin function: Address location of the data in the Data and Stack RAM Unit               |
| Pin name: uiram_wb_sel[3:0] Pin direction: input                                        |
| Source -> Destination: Address Decoder Block ->Data-path Unit -> Data and Stack         |
| RAM Unit                                                                                |
| Pin function: 4-bit byte select control, to select any one or more bytes to be accessed |
| Pin name: uiram_wb_we     Pin direction: input                                          |
| Source -> Destination: Address Decoder Block -> Data-path Unit-> Data and Stack         |
| RAM Unit                                                                                |
| Pin function: Write control                                                             |
| 1: Enable to write to the Data and Stack RAM Unit                                       |
| 0: No operation                                                                         |
| Pin name: uiram_wb_stb   Pin direction: input                                           |
| Source -> Destination: Address Decoder Block -> Data-path Unit -> Data and Stack        |
| RAM Unit                                                                                |
| Pin function: Strobe control                                                            |
| 1: Data and Stack RAM Unit is activated to perform read or write access for new         |
| address location                                                                        |
| 0: Data and Stack RAM Unit is de-activated to perform read or write access              |
| Pin name: uiram_wb_en Pin direction: input                                              |
| Source -> Destination: Data-path Unit -> Data and Stack RAM Unit                        |
| Pin function:                                                                           |
| 1: Enable signal                                                                        |
| 0: No enable signal                                                                     |
| Pin name: uiram_wb_rstPin direction: input                                              |
| Source -> Destination: Global reset -> Data and Stack RAM Unit                          |
| Pin function:                                                                           |

| 1: Reset                               |                                  |  |
|----------------------------------------|----------------------------------|--|
| 0: No reset require                    |                                  |  |
| Pin name: uoram_wb_dout[31:0]          | Pin direction: output            |  |
| Source -> Destination: Data and Sta    | ck RAM Unit -> Data-path Unit    |  |
| Pin function: 32-bits data output      | _                                |  |
| Pin name: uoram_wb_ack                 | Pin direction: output            |  |
| Source -> Destination: Data and Sta    | ck RAM Unit -> Data-path Unit    |  |
| Pin function: Indicate data is ready t | to be fetched                    |  |
| Table 2 15 · Data an                   | d Stock PAM Unit I/O description |  |

Table 3.15 : Data and Stack RAM Unit I/O description

## **Chapter 4 : Methodology and Tools**

# 4.1 Design Specifications

# 4.1.1 Methodologies and General Work Procedures

Asynchronous circuits can be done by substituting global clock with a set of controllers that all have an equivalent behavior (see Figure 4.1 & Figure 4.2). There are three steps in order to build an asynchronous circuit which listed below:

- 1. Convert the flip-flop-based synchronous circuit to a latch-based by remove local clocks for master and slave latches and retiming to improve performance.
- 2. Generate a match delays for combinational logic which each delay much be greater than the delay at the critical path of the combinational block.
- 3. Substitute the local clocks with controllers.



Figure 4.1 : Synchronous circuit



Figure 4.2 : Asynchronous circuit

Asynchronous circuit is a combination of gates and with some feedback loops. When one of the output gate changes, it can be noticed by other gates and then all of the gates will also change their output accordingly. The figure below shows one of the possible implementation of the CTL circuit.



Figure 4.3 : An asynchronous control circuit Lt is a local clock meant to control latch

# 4.1.2 Development Tools

There will be two tools used in the development of asynchronous RISC processor (Mok K.M 2008):

- 1. The design of asynchronous RISC processor will be based on Verilog hardware description language, in combination with the ModelSim synthesis tools.
  - ModelSim is a hardware description language simulator from Mentor Graphics.
  - It provides simulation (gate-level and RTL-level) and integrated debug environment.
  - It is an intuitive GUI for post-simulation debug and analysis.
- 2. Functional testing will be done by MIPS assembler programming using the PCSpim.
  - Spim is a simulaator that runs MIPS32 assembly language programs.
  - It provides a simple assembler, debugger and a simple set of operating system services.
  - It implements both a simple, terminal-style interface (spim) and a visual windowing interface (xspim and PCSpim).

- 3. Synthesis of the design will be done by using Xilinx Vivado 2020.1.
  - Vivado is designed for HDL designs analysis and synthesis.
  - Artix 7 board will be used to run synthesis of asynchronous design.

# 4.1.3 Verification Plan

The testbench below is developed to test the instructions supported by the 32-bit RISC processor. The instructions are stored inside the text file (TEST\_CODE\_PATH) with its machine code.

```
`timescale 1ns / 1ps
`default nettype none
`define OLD_TEST 1
`ifdef MODEL TECH
    `ifdef OLD_TEST
         `define TEST_CODE_PATH "oldtest_program_mem.txt"
          `define EXC HANDLER "oldtest program exc handler mem.txt"
     `endif
`endif
module tb_r32_pipeline();
reg
         tb_u_rst;
crisc dut_c_risc
(.uirisc_rst(tb_u_rst)
);
//read memory to get instruction
initial begin
$readmemh(`TEST_CODE_PATH,tb_r32_pipeline.dut_c_risc.imem.bsram_1kw_mem_array);
$readmemh(`EXC HANDLER,tb r32 pipeline.dut c risc.imem.bsram 1kw mem array);
#1 tb u rst = 1'b0;
#1 tb_u_rst = 1'b1;
#1 tb u rst = 1'b0;
repeat(1200)@(tb_r32_pipeline.dut_c_risc.u_datapath.uodp_req_from_pc);
$stop;
end
endmodule
```

# 4.2 Timeline

| Task                                                  | Start Date        |           | Week |   |   |   |   |   |   |   |   |    |    |    |
|-------------------------------------------------------|-------------------|-----------|------|---|---|---|---|---|---|---|---|----|----|----|
| 1 43K                                                 | Start Date Enu Da | End Date  | 1    | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
| Studying the existing work that being developed       | 15/6/2020         | 28/6/2020 |      |   |   |   |   |   |   |   |   |    |    |    |
| Study the concept of Muller C-element                 | 29/6/2020         | 12/7/2020 |      |   |   |   |   |   |   |   |   |    |    |    |
| Analyze the synchronous processor developed by senior | 13/7/2020         | 26/7/2020 |      |   |   |   |   |   |   |   |   |    |    |    |
| Apply the Muller C-element to the existing processor  | 27/7/2020         | 9/8/2020  |      |   |   |   |   |   |   |   |   |    |    |    |
| Fixing bug to get correct outputs                     | 10/8/2020         | 23/8/2020 |      |   |   |   |   |   |   |   |   |    |    |    |
| Report Writing                                        | 24/8/2020         | 4/9/2020  |      |   |   |   |   |   |   |   |   |    |    |    |

# Table 4.1 : Gantt chart for Project I

| Task                                  | Start Date End Date |           |   |   |   |   |   | Week |   |   |   |    |    |    |  |  |  |
|---------------------------------------|---------------------|-----------|---|---|---|---|---|------|---|---|---|----|----|----|--|--|--|
|                                       | Start Date          | Linu Date | 1 | 2 | 3 | 4 | 5 | 6    | 7 | 8 | 9 | 10 | 11 | 12 |  |  |  |
| Analyze and fix the size of the RAM   | 18/1/2021           | 14/2/2021 |   |   |   |   |   |      |   |   |   |    |    |    |  |  |  |
| Synthesize the asynchronous processor | 15/2/2021           | 28/3/2021 |   |   |   |   |   |      |   |   |   |    |    |    |  |  |  |
| Report Writing                        | 29/3/2021           | 9/4/2021  |   |   |   |   |   |      |   |   |   |    |    |    |  |  |  |

Table 4.2 : Gantt chart for Project II

#### **Chapter 5 : Muller C-Element**

Muller C-elemnt is a basic component that is often used in asynchronous circuits. It is a state-holding element similar to an asynchronous set-reset latch. The output is set to 0 when both inputs are 0 and when the output is set to 1 when both inputs are 1. For other input pairs, the output does not make change. So, if the output changes from 0 to 1, it can conclude that both inputs are now at 1; similarly, if output changes from 1 to 0, it can conclude that both inputs are now 0.



Figure 5.1 : The Muller C-element

#### 5.1 Muller pipeline

Most of the asynchronous circuits are form by the Muller pipeline. When all of the C-element are set to 0, the left environment may start communication via handshake. It can be think of the signals inside the pipeline propagate as a sequence of waves with a careful control in order to ensure the integrity of each wave.

The link between each stage of C-element pipeline provides observation on correct handshaking. The Muller pipeline will propagate with the speed which comes from the actual delays of the circuits when the wave has been inserted to it.

The handshake which reaches the right hand environment is came from the first handshake inserted by the left hand environment. The pipeline will stop handshaking with the left hand environment if the right hand environment does not respond to the handshake. It just act like a ripple through FIFO.

Finally, the Muller pipeline is delay-insensitive. It works correctly without affect by the delays in gates and wires. There are four types of handshake protocol which are 4-phase bundled-data, 2-phase bundled-data, 4-phase dual-rail and 2-phase dual-rail. The circuit implementation which includes area, speed, power, robustness, etc will be affect by protocol used.



Figure 5.2 : Muller pipeline

# **5.2 Circuit Implementation Style**

# 4-phase single-rail pipeline

The 4-phase single-rail pipeline is simplest. Basically, local clock pulses are generated by using this pipeline. The pulses generated in the neighbouring stages overlaps the clock pulse generated in one stage. The request signal paths should be inserted with matching delays in order to maintain the correct behaviour of the circuit.



Figure 5.3 : The 4 phases single-rail pipeline

# 2-phase single-rail pipeline

The 2-phase bundled data pipeline uses a Muller pipeline as the backbone control circuit but the control signals are explained as events or transitions. Because of this reason, special capture-pass latches are needed: events on the C and P inputs alternate, causing the latch to change between capture mode and pass mode. This type of special latch design is explained below. (see Figure 5.5)



Figure 5.4 : The 2 phases single-rail pipeline



Figure 5.5 : Operation and Implementation of a capture-pass event controlled latch

#### 4-phase dual-rail pipeline

The 4-phase dual-rail pipeline is the combination of Muller pipeline with encoding of data and request. It can be inferred as two Muller pipelines connected in parallel (see Figure 5.6). The C-elements can be store the empty codeword  $\{d.t, d.f\} = \{0, 0\}$ , causing the acknowledge signal outputs a 0, or it can store valid codeword  $\{0, 1\}$  and  $\{1, 0\}$ , cause the acknowledge signal outputs a 1.However, the codeword  $\{1, 1\}$  does not occur and is illegal. In conclusion, the acknowledge signal generated by the OR gate indicates the state of the pipeline stage as "valid" or "empty".



Figure 5.6 : A simple 3-stage 1-bit wide 4-phase dual-rail pipeline



Figure 5.7 : An N-bit latch with completion detection

# 2-phase dual-rail pipeline

It uses 2 wires which are d.t and d.f. For N-bit channel, when one of the wire of the N wire pairs has made a transition, a new codeword is received. A valid message is acknowledged and followed by another message that is acknowledged. So, it is impossible to get an empty value.



Figure 5.8 : Illustration of handshaking on a 2-phase dual-rail channel

#### **5.3 Implementation of Pipeline**

For the implementation of asynchronous RISC processor, four-phase single-rail pipeline is used becasue it is the simplest between four types of implementation style for asynchronous design. The global clock for synchronous design is replaces by the controllers which is Muller C-element. The originally latches used to seperate the datapath stages are then locally clocked by the controlles. There are two signals produced by the controllers which are request and acknowledge. Request signal is generated when there is data available and acknowledge is generated by the right hand environment when it accepts the data. The transfer of data only occurs when both request and acknowledge are asserted.



Figure 5.9 : Pipeline with Muller C-element



# **Chapter 6 : Verification**

# **6.1 Simulation Result**

The muller pipeline will starts to work when the values of all the Muller C-element are set to 0 which we need to assert a reset signal at the beginning of the simulation. After that, the Muller C-element will start to communicate with each other via handshaking.

| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ifid_en      | 1'h0 |  |
|---------------------------------------------------------|------|--|
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_idex_en      | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_exmem_en     | 1ĥ1  |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_memwb_en     | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_from_id  | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_from_pc  | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_to_id    | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_from_if  | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_from_ex  | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_to_ex    | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_to_if    | 1ĥ1  |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_from_id  | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_from_mem | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_to_mem   | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_to_id    | 1'h1 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_from_ex  | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_from_wb  | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_to_wb    | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_to_ex    | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_req_from_mem | 1'h0 |  |
| /tb_r32_pipeline/dut_c_risc/u_datapath/udp_ack_to_mem   | 1'h0 |  |

Figure 6.1 : The waveform of muller pipeline

# Simulation Result:

| <b>.</b> [8]                | -32'd    | 32'd4194340 |                 | 32   | 2d100 |    |                |                 |    |
|-----------------------------|----------|-------------|-----------------|------|-------|----|----------------|-----------------|----|
| 🖕 - 🔶 [9]                   | 32'd2    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [10]                  | 32'd 109 | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [11]                  | 32'd0    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🧇 [12]                  | 32'd0    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [13]                  | 32'd0    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [14]                  | 32'd0    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [15]                  | 32'd0    | 32'd0       |                 |      |       |    |                |                 |    |
| 🛓 - 🔶 [16]                  | 32'd20   | 32'd0       | <u>(</u> 32'd20 |      |       |    |                |                 |    |
| 🛓 - 🧇 [17]                  | -32'd8   | 32'd0       | (-3             | 2'd8 |       |    |                |                 |    |
| 🛓 - 🧇 [18]                  | -32'd6   | 32'd0       |                 |      | (-32  | d6 |                |                 |    |
| 🛓 - 🧇 [19]                  | -32'd    | 32'd0       |                 |      |       | 32 | d106           |                 |    |
| 🛓 - 🔶 [20]                  | -32'd    | 32'd0       |                 |      |       |    | <u>(</u> -32'd | 106             |    |
| <b>±</b> - <b>&gt;</b> [21] | -32'd    | 32'd0       |                 |      |       |    |                | <u>) -32'd2</u> | 12 |

Figure 6.2 : The results of arithmetic instruction

| <b>.</b>   | -32'd110 | 32'd100 | -32'd110 |       |        |             |            |                       |         |                       |         |
|------------|----------|---------|----------|-------|--------|-------------|------------|-----------------------|---------|-----------------------|---------|
| 🛓 🔶 [9]    | 32'd2    | 32'd0   | ) (      | 32'd2 |        |             |            |                       |         |                       |         |
| 🛓 - 🔶 [10] | 32'd109  | 32'd0   |          | (3    | 2'd109 |             |            |                       |         |                       |         |
| 🛓 - 🔶 [11] | 32'd1    | 32'd0   |          |       | ( 32'  | 111 ( 32'd1 | 27 ( 32'd1 | 0048 <u>(</u> 32'd127 | ( 32'd1 | , <mark>32'd</mark> 0 | ( 32'd1 |
| 🛓 - 🔶 [12] | 32'd0    | 32'd0   |          |       |        |             |            |                       |         |                       |         |
| 🛓 - 🔶 [13] | 32'd0    | 32'd0   |          |       |        |             |            |                       |         |                       |         |

Figure 6.3 : The results of logical instruction

| <b>.</b>   | -32'd8      | -32'd110             |                   |         |   | 32'd1 | (32'd0) | 32'd1     |        | ) -32'd8          |     |
|------------|-------------|----------------------|-------------------|---------|---|-------|---------|-----------|--------|-------------------|-----|
| 🛓 🔶 [9]    | 32'd4       | 32'd2                |                   |         |   |       |         |           | , 32'd | <sup>4</sup> outp | uts |
| 🕂          | 32'd109     | 32'd109              |                   |         |   |       | outouts | s of slt, | eltn   | of l              |     |
| 🕂 🔶 [11]   | 32'd1       | <u>(32'd0)(32'd1</u> |                   |         |   |       |         |           |        | 01 1              |     |
| 🛓 🔶 [12]   | 32'd0       | 32'd0                |                   |         |   |       | SIU     | and slti  | u      |                   |     |
| 🛓 🔶 [13]   | 32'd0       | 32'd0                |                   |         |   |       |         |           |        |                   |     |
| 🛓 🔶 [14]   | 32'd0       | 32'd0                |                   |         |   |       |         |           |        |                   |     |
| 🛓 🔶 [15]   | 32'd0       | 32'd0                |                   |         |   |       |         |           |        |                   |     |
| 🛓 - 🔶 [16] | 32'd20      | 32'd20               |                   |         |   |       |         |           |        |                   |     |
| 🛓 🔶 [17]   | -32'd8      | -32'd8               |                   |         |   |       |         |           |        |                   |     |
| 🛓 - 🔶 [18] | -32'd6      | -32'd6               |                   |         |   |       |         |           |        |                   |     |
| 🛓 🔶 [19]   | -32'd106    | -32'd106             | store             | the     |   |       |         |           |        |                   |     |
| 🛓 🔶 [20]   | -32'd106    | -32'd106 a           | ddress            | of setb | r |       |         |           |        |                   |     |
| 🕂 🔶 [21]   | -32'd212    | -32'd212             |                   |         |   |       |         |           |        |                   |     |
| 🛓 - 🔶 [22] | 32h004000a8 | 32'h00000000         | <u>(32')(32'h</u> | 04000a8 |   |       |         |           |        |                   |     |

Figure 6.4 : The results of STORE, SET\_BR and LWSW

| <b>.</b>  | 32'd0        | 32'd0       |       |       |               |   |       |      |     |        |      |
|-----------|--------------|-------------|-------|-------|---------------|---|-------|------|-----|--------|------|
| 🛓 - 🔶 [7] | 32'd0        | 32'd0       |       |       |               |   |       |      | _,  |        |      |
| <b>.</b>  | 32'h000000ff | 32'hffffff8 |       |       |               |   |       |      | nim |        |      |
| <b>.</b>  | 32'd4        | 32'd4       | outru | ts of | t_sh          | 0 | utpul | s of | - 0 | utputs | s of |
| ÷         | 32'd109      | 32'd109     | Juipe |       | 1 <u>_</u> 30 |   | t l   |      |     | t lbı  |      |
| • [11]    | 32'd1        | 32'd1       |       |       |               |   |       |      |     |        |      |
| • [12]    | 32'd0        | 32'd0       |       |       |               |   |       |      |     |        |      |
| 🙀 🔶 [13]  | 32'd0        | 32'd0       |       |       |               |   |       |      |     |        |      |

Figure 6.5 : The results of t\_sb, t\_lb and t\_lbu

| 🛓 🔶 [6]    | 32'd0        | 32'd0   |     |      |       |     |      |      |    |      |        |
|------------|--------------|---------|-----|------|-------|-----|------|------|----|------|--------|
| 🛓 🔶 [7]    | 32'd0        | 32'd0   |     |      |       |     |      |      |    |      |        |
| 🛓 🔶 [8]    | 32'h0000ffff |         |     |      |       |     |      |      |    |      |        |
| 🕂 🔶 [9]    | 32'd4        | 32'd4   | out | anto | oft   | h   |      | puts | of | outr | uts of |
| 🛓 🔶 [10]   | 32'd109      | 32'd109 | out | puis | of t_ | SII | Jour | -    |    |      | uts of |
| 🛓 - 🔶 [11] | 32'd1        | 32'd1   |     |      |       |     |      | t_lh |    | t_   | lhu    |
| 🛓 - 🔶 [12] | 32'd0        | 32'd0   |     |      |       |     |      |      |    |      |        |
| 🛓 - 🔶 [13] | 32'd0        | 32'd0   |     |      |       |     |      |      |    |      |        |
| 🕂 🕂 🕂      | 32'd0        | 32'd0   |     |      |       |     |      |      |    |      |        |

Figure 6.6 : The results of t\_sh, t\_lh and t\_lhu

| <b>.</b>    | [6]  | 32'd0       | 32'd0   |            |          |        |       |         |         |          |         |        |    |           |                 |  |
|-------------|------|-------------|---------|------------|----------|--------|-------|---------|---------|----------|---------|--------|----|-----------|-----------------|--|
| <b>e</b> -4 | [7]  | 32'd0       | 32'd0   |            |          |        |       |         |         |          |         |        |    |           |                 |  |
|             | [8]  | 32'h0000000 | )32'h   | . ) (32'h. | .) (32'h | 0a0b ( | )((3, | 'h ) ): | 2"h ( ) | 32'h0a0b | ) 32ħ ) | (32ħ ( | 32 | h ( ) (3. | 2 <b>'h (</b> ) |  |
| •           | [9]  | 32'd4       | 32'd4   |            |          |        |       |         |         |          |         |        |    |           |                 |  |
| ÷-          | [10] | 32'd109     | 32'd109 |            |          |        |       |         |         |          |         |        |    |           |                 |  |
|             | [11] | 32'd1       | 32'd1   |            |          |        |       |         |         |          |         |        |    |           |                 |  |
|             | [12] | 32'd0       | 32'd0   |            |          |        |       |         |         |          |         |        |    |           |                 |  |
| <b>e</b> -{ | [13] | 32'd0       | 32'd0   |            |          |        |       |         |         |          |         |        |    |           |                 |  |

Figure 6.7 : The results of swl, swr, lwl and lwr

# The Design of An Asynchronous RISC Processor

| •                   | [8]  | 32'h00002710 |         | <u>(32'h0000000</u> | <u>(</u> 32'h00 | , <u>32'h0</u> | ) ( 3 ( 32  | h00 ( | (32h0    | 0 ) (3     | 32'h00 )       | (32°h00 ) 3              | . <u>,</u> 32'h00 <u>,</u> 3 | (32h00)        | ) 32'h00 ) | (32'h00002) |
|---------------------|------|--------------|---------|---------------------|-----------------|----------------|-------------|-------|----------|------------|----------------|--------------------------|------------------------------|----------------|------------|-------------|
| <b>e</b> - <b>〈</b> | 9]   | 32'd20000    | 32'd4   | <u>32'd20000 (</u>  |                 |                |             |       |          |            |                |                          |                              |                |            |             |
| <b>e</b> - <b></b>  | [10] | 32'd0        | 32'd109 | (32'd10             | (32'd9          | (32            | d8 )        | 32'd7 | (32      | d6         | <u>) 32'd5</u> | ) 32'd4                  | 32'd3                        | ( <u>32'd2</u> | (32'd1     | , 32'd0     |
| <b>.</b>            | [11] | 32'd20000    | 32'd1   |                     | 32'd200000      | 32'd180        | )00 ( 32'd1 | 50000 | 32'd1400 | 000 ( 32'd | 120000 (3      | 2 <sup>1</sup> d100000 ( | 32'd80000 (                  | 32'd60000      | 32'd40000  | , 32'd20000 |
| <b>.</b>            | [12] | 32'd0        | 32'd0   |                     |                 |                |             |       |          |            |                |                          |                              |                |            |             |
| <b>.</b>            | [13] | 32'd0        | 32'd0   |                     |                 |                |             |       |          |            |                |                          |                              |                |            |             |
| <b>.</b>            | [14] | 32'd0        | 32'd0   |                     |                 |                |             |       |          |            |                |                          |                              |                |            |             |

Figure 6.8 : The results of multiplication and loop

#### **Chapter 7 : Synthesis**

After the behavioral simulation of the asynchronous RISC processor is done, then it is ready for synthesis by using Xilinx Vivado. The FPGA board used for synthesis is Artix-7 and the part used is xc7a100tcsg324-1.

# 7.1 Utilization Report

After the process of synthesis is done, the utilization report obtained, as shown in Table 7.1 below. From the table, we can conclude that the asynchronous RISC processor utilized 117.11% of lookup table (LUT), 0.95% of input and output (IO) and 37.50% of global buffers (BUFG) of the FPGA board.

| Resource | Estimation | Available | Utilization % |
|----------|------------|-----------|---------------|
| LUT      | 74245      | 63400     | 117.11        |
| Ю        | 2          | 210       | 0.95          |
| BUFG     | 12         | 32        | 37.50         |

#### **Chapter 8 : Conclusion and Future Work**

#### 8.1 Conclusion

The main objective of this project which is to design and synthesis the asynchronous RISC processor has been achieved. The asynchronous RISC processor is done by removing the global clock signal from synchronous processor and replaces with the Muller C-element which has been discussed in Chapter 5. However, the FPGA board, Artix-7 has been chosen to synthesis the asynchronous RISC processor and the utilization report obtained after the synthesis is shown in Chapter 7. Moreover, the behavioral of the asynchronous RISC processor has been verified correct without errors. The simulation results are shown in Chapter 6.

### 8.2 Future Work

It is possible to do more advanced changes, but a good strategy is necessary to have a performance gain. The programmable delays would be interesting to look into so it will be possible to test what delays should be used on the different stages.

# Bibliography

Mok K.M, 2008, Computer Organization and Architecture, lecture notes distributed in Department of Computer and Communication Technology at Universiti Tunku Abdul Rahman, 2008.

C.H. Van Berkel, M.B. Josephs & S.M. Nowick, 1999, Applications of Asynchronous Circuits, Proceeding of the IEEE, vol. 87, no. 2, pp. 223-233.

Jens Sparsø & Steve, 2001, Principle of Asynchronous Circuit Design - A Systems Perspective, Kluwer Academic Publishers.

Tony Werner & Venkatesh Akella, 1997, Asynchronous Processor Survey, IEEE, vol. 30, no. 11, pp. 67-76.

T.Samyuktha & K.Balachandra, 2015, Design and Performance Analysis of 8-Bit Asynchronous Pipelined Processor. International Journal of Scientific Engineering and Technology Research, vol. 4, no. 47, pp. 10206-10211.

Hans Jacobson, 1996, Asynchronous Circuit Design - A Case Study of A Framework Called Ack, Master Thesis, Lulea University of Technology.

Bjørn Thomas Søreng Vee, 2014, Conversion of a simple Processor to asynchronous Logic, Norwegian University of Science and Technology.





xc7a100tcsg324-1. The utilization report is shown in figure below. From the figure, we can conclude that the asynchronous RISC processor utilized 117.11% of lookup table (LUT), 0.95% of input and output (IO) and 37.50% of global buffers (BUFG) of the FPGA board.

| Resource | Estimation | Available | Utilization %       |
|----------|------------|-----------|---------------------|
| LUT      | 74245      | 63400     | <mark>117.11</mark> |
| Ю        | 2          | 210       | 0.95                |
| BUFG     | 12         | 32        | 37.50               |

# Conclusion

-Main objective of this project has been achieved which is to design and synthesis the asynchronous RISC processor

- The behavioral of the asynchronous RISC processor has been verified correct without errors

# Final Year Project 2 Jan 2021

# Plagiarism Check Result

| feedback studio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PEE YAOHONG finalis                                                                                                                                               | ed_fyp2_report          |                                                                             |                                          |        | 1 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------------------------------------------------------------|------------------------------------------|--------|---|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                   |                         |                                                                             | Match Overview                           | N      |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                   |                         |                                                                             | 16%                                      |        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                   |                         |                                                                             |                                          |        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                   |                         | 1 1                                                                         | user.it.uu.se                            | 29     | 2 |
| A 32-bit five stage pipeline asynchro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | onous RISC soft-core can be beneficial in                                                                                                                         |                         | 16                                                                          | www.coursehero.com                       | 00     |   |
| creating a core-based environment to sup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | port research and development work in the                                                                                                                         |                         | ₹ 2<br>▼                                                                    | Internet Source                          | 29     |   |
| area of developing IP cores. On the other l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | hand, there are restrictions in obtaining such                                                                                                                    |                         | 3                                                                           | webee.technion.ac.il                     | 29     |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | nt as microprocessors are developed by                                                                                                                            |                         | *                                                                           | scholarbank.nus.edu.sg                   | 19     |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | mmercial purpose and most of these IP are                                                                                                                         |                         | <i>i</i> 4                                                                  | Internet Source                          | 13     |   |
| trade secret of those companies.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                   |                         | 5                                                                           | docplayer.net<br>Internet Source         | 19     |   |
| There are some asynchronous process                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | or cores projects available freely online such                                                                                                                    |                         | 6                                                                           | backend.orbit.dtu.dk                     | 19     |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | gr/carv/aspida/ and etc. However, the                                                                                                                             |                         | 0                                                                           | Internet Source                          |        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ture included in these projects is not well                                                                                                                       |                         | 7                                                                           | T. Werner, V. Akella. "As<br>Publication | 19     |   |
| presented. Other than that, the Verilog co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | odes wrote in these projects are also hard to                                                                                                                     |                         | 8                                                                           | Martin Simlastik, Viera                  | 1      |   |
| understand because of the confused namin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ng convention used.                                                                                                                                               |                         |                                                                             | Publication                              |        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                   |                         | 9                                                                           | www.lenharth.org<br>Internet Source      | 19     |   |
| : 1 of 33 Word Count: 4447<br>urnitin - Class Portfolio x Ø Turnitin<br>→ C ● turnitin.com/newreport_classicasp?lang=en_us&vo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>× +</b><br>jid=1560109052&ft=1&bypass_cv=1                                                                                                                     | Text-only Report        | High Resolution                                                             | 0n ) Q<br>-<br>☆ ፱                       | •<br>* |   |
| urnitin - Class Portfolio x 🕖 Turnitin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | oid=1560109052&ft=1&bypass_cv=1                                                                                                                                   | Text-only Report        | High Resolution                                                             | -                                        |        |   |
| urnitin - Class Portfolio x 🕖 Turnitin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                   | Text-only Report        | High Resolution                                                             | -                                        |        |   |
| urnitin - Class Portfolio x 🕖 Turnitin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | oid=1560109052&ft=1&bypass_cv=1                                                                                                                                   | Text-only Report        |                                                                             | -<br>☆ 0                                 |        |   |
| urnitin - Class Portfolio x Ø Turnitin<br>→ C  • turnitin.com/newreport_classic.asp?lang=en_us&vo<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | oid=1560109052&ft=1&bypass_cv=1                                                                                                                                   | Similarity Index        | Similarity by Sour<br>Internet Sources:                                     | -<br>* •                                 |        |   |
| urnitin - Class Portfolio x ♥ Turnitin<br>→ C  ■ turnitin.com/newreport_classic.asp?lang=en_us&o<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08<br>ID: 1590109052<br>Word Court: 4447                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | oid=1560109052&ft=1&bypass_cv=1                                                                                                                                   |                         | Similarity by Sour                                                          | -<br>☆ 2                                 |        |   |
| umitin - Class Portfolio x<br>→ C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Tumitin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Turnitin<br>→ C • turnitin.com/newreport_classic.asp?lang=en_us&co<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08<br>ID: 1560109052<br>Word Count: 4447<br>Submitted: 3<br>finalised_fyp2_report By PEE YAOP<br>include_guoted include bibliography exclu<br>2% match (Internet from 03-Sep-2009)<br>http://user.it.uu.se<br>2% match (Internet from 27-Nov-2009)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Turnitin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Tumitin<br>→ C • turnitin.com/newreport_classic.asp?lang=en_us&co<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08<br>ID: 1560109092<br>Word Count: 4447<br>Submitted: 3<br>finalised_fyp2_report By PEE YAOH<br>include_puoted include bibliography exclu<br>2% match (Internet from 03-Sep-2009)<br>http://webee.technion.ac.il<br>1% match (Internet from 25-Oct-2010)<br>http://www.coursehero.com                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Turnitin<br>→ C  turnitin.com/newreport_classic.asp?lang=en_us&co<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08<br>ID: 1560109052<br>Word Count: 4447<br>Submitted: 3<br>finalised_fyp2_report By PEE YAOP<br>include_guated include bibliography exclu<br>2% match (Internet from 03-Sep-2009)<br>http://webee.technion.ac.il<br>1% match (Internet from 30-Nov-2017)<br>http://scholarbank.nus.edu.sg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | oid=1560109052&ft=1&bypass_cv=1 Document Viewer HONG                                                                                                              | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x ♥ Turnitin  C  turnitin com/newreport_classic.asp?lang=en_us&o  Turnitin Originality Report  Processed on: 16-Apr-2021 03:46 + 08 ID: 1500109052 Word Count: 4447 Submitted: 3  finalised_fyp2_report By PEE YAOP  include guated include bibliography exclu  2% match (Internet from 03-Sep-2009) http://webee.technion.ac.il  1% match (Internet from 25-Oct-2010) http://www.coursehero.com  1% match (Internet from 03-Nov-2017) http://scholarbank.nus.edu.sg  1% match (Internet from 04-Oct-2018)                                                                                                                                                                                                                                                                                                                                                                                                                                                 | oid=1560109052&ft=1&bypass_cv=1  Document Viewer  HONG  uding matches < 8 words mode: [quickview (classic) report ♥ Change m                                      | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                | * (    |   |
| umitin - Class Portfolio x ♥ Turnitin  C  turnitin.com/newreport_classic.asp?lang=en_us&co  Turnitin Originality Report  Processed on: 16-Apr-2021 03:46 +08  ID: 1550109052 Word Count: 4447 Submitted: 3  finalised_fyp2_report By PEE YAOH  include outed include bibliography exclu  2% match (Internet from 03-Sep-2009) http://webee.technion.ac.il  1% match (Internet from 25-Oct-2010) http://cholarbank.nus.edu.sp  1% match (Internet from 04-Oct-2018) http://docplayer.net  1% match (Internet from 04-Oct-2018)                                                                                                                                                                                                                                                                                                                                                                                                                                                       | oid=1560109052&ft=1&bypass_cv=1  Document Viewer  HONG  uding matches < 8 words mode: [quickview (classic) report ▼ Change m  895041/JSPA async book 2020 PDE.pdf | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  Pumitin<br>→ C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | oid=1560109052&ft=1&bypass_cv=1  Document Viewer  HONG  uding matches < 8 words mode: [quickview (classic) report ▼ Change m  895041/JSPA async book 2020 PDE.pdf | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:                    | се<br>14%                                |        |   |
| umitin - Class Portfolio x  P Turnitin<br>→ C • turnitin.com/newreport_classic.asp?lang=en_us&co<br>Turnitin Originality Report<br>Processed on: 16-Apr-2021 03:46 +08<br>ID: 1560109052<br>Word Count: 4447<br>Submitted: 3<br>finalised_fyp2_report By PEE YAOP<br>include_guated include bibliography exclu<br>2% match (Internet from 03-Sep-2009)<br>http://webee.technion.ac.il<br>1% match (Internet from 25-Oct-2010)<br>http://www.coursehero.com<br>1% match (Internet from 03-Nov-2017)<br>http://scholarbahk.nus.edu.sg<br>1% match (Internet from 04-Oct-2018)<br>http://backend.orbit.dtu.dk/ws/files/2155<br>1% match (Internet from 23-Mar-2021)<br>http://backend.orbit.dtu.dk/ws/files/2155<br>1% match (publications)<br>1. Werner, V. Akella. "Asynchronous proces<br>1% match (publications)<br>1% match (publications)<br>1% match (publications)<br>1% match (publications)<br>1% match (publications)<br>1% match (publications)<br>1% match (publications) | oid=1560109052&ft=1&bypass_cv=1  Document Viewer  HONG  uding matches < 8 words mode: [quickview (classic) report ▼ Change m  895041/JSPA async book 2020 PDE.pdf | Similarity Index<br>16% | Similarity by Sour<br>Internet Sources:<br>Publications:<br>Student Papers: | Ee<br>14%<br>13%<br>N/A                  |        |   |

#### Universiti Tunku Abdul Rahman

Form Title : Supervisor's Comments on Originality Report Generated by Turnitinfor Submission of Final Year Project Report (for Undergraduate Programmes)Form Number: FM-IAD-005Rev No.: 0EffectiveDate: 01/10/2013Page No.: 10f 1



#### FACULTY OF INFORMATION AND COMMUNICATION TECHNOLOGY

| Full Name(s) of<br>Candidate(s) | PEE YAO HONG                                 |
|---------------------------------|----------------------------------------------|
| ID Number(s)                    | 1802826                                      |
| Programme / Course              | ст                                           |
| Title of Final Year Project     | The Design of An Asynchronous RISC Processor |

| Similarity                                                                 | Supervisor's Comments<br>(Compulsory if parameters of originality<br>exceeds the limits approved by UTAR) |
|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Overall similarity index: 16% Similarity                                   |                                                                                                           |
| by sourceInternet Sources:14%Publications:13%Student Papers:0%             |                                                                                                           |
| <b>Number of individual sources listed</b> of more than 3% similarity: NIL |                                                                                                           |
| (iii) Matching texts in continuous block                                   | nd below, and<br>ted must be less than 3% each, and                                                       |

<u>Note</u> Supervisor/Candidate(s) is/are required to provide softcopy of full set of the originality report to Faculty/Institute

Based on the above results, I hereby declare that I am satisfied with the originality of the Final Year Project Report submitted by my student(s) as named above.

Signature of Supervisor

Name: MOK KAI MING

Date: <u>16/04/2021</u>

Signature of Co-Supervisor

Name: \_\_\_\_\_

Date: \_\_\_\_\_



# UNIVERSITI TUNKU ABDUL RAHMAN

# FACULTY OF INFORMATION & COMMUNICATION TECHNOLOGY (KAMPAR CAMPUS)

#### **CHECKLIST FOR FYP2 THESIS SUBMISSION**

| Student Id      | 1802826      |
|-----------------|--------------|
| Student Name    | PEE YAO HONG |
| Supervisor Name | MOK KAI MING |

| TICK (√)     | DOCUMENT ITEMS                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------|
|              | Your report must include all the items below. Put a tick on the left column after you have      |
|              | checked your report with respect to the corresponding item.                                     |
|              | Front Cover                                                                                     |
|              | Signed Report Status Declaration Form                                                           |
| $\checkmark$ | Title Page                                                                                      |
| $\checkmark$ | Signed form of the Declaration of Originality                                                   |
| $\checkmark$ | Acknowledgement                                                                                 |
|              | Abstract                                                                                        |
| $\checkmark$ | Table of Contents                                                                               |
| $\checkmark$ | List of Figures (if applicable)                                                                 |
| $\checkmark$ | List of Tables (if applicable)                                                                  |
| -            | List of Symbols (if applicable)                                                                 |
| $\checkmark$ | List of Abbreviations (if applicable)                                                           |
| $\checkmark$ | Chapters / Content                                                                              |
| $\checkmark$ | Bibliography (or References)                                                                    |
| $\checkmark$ | All references in bibliography are cited in the thesis, especially in the chapter of literature |
|              | review                                                                                          |
| -            | Appendices (if applicable)                                                                      |
| $\checkmark$ | Poster                                                                                          |
|              | Signed Turnitin Report (Plagiarism Check Result - Form Number: FM-IAD-005)                      |

\*Include this form (checklist) in the thesis (Bind together as the last page)

Supervisor verification. Report with incorrect I, the author, have checked and confirmed all the items listed in the table are included in my format can get 5 mark (1 grade) reduction. report. (Signature of Supervisor) Date: 16/00/2021 (Signature of Student) Date: 16/04/2021