# DESIGN AND DEVELOPMENT OF MEMORY SYSTEM FOR 32-BIT 5 STAGE PIPELINE RISC: MEMORY SYSTEM INTEGRATION

BY GOH DIH JIANN

A REPORT

# SUBMITTED TO

UniversitiTunku Abdul Rahman

in partial fulfilment of the requirements

for the degree of

BACHELOR OF COMPUTER SCIENCE (HONS)

COMPUTER ENGINEERING

Faculty of Information and Communication Technology (Perak Campus)

OCTOBER 2015

# UNIVERSITI TUNKU ABDUL RAHMAN

| REPO                                                                   | ORT STATU                                                                         | S DECLARATION FORM                                                                                                          |
|------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Title:                                                                 |                                                                                   |                                                                                                                             |
|                                                                        |                                                                                   | ic Session :                                                                                                                |
| I                                                                      |                                                                                   | APITAL LETTER)                                                                                                              |
| Universiti Tuni<br>1. The dissert                                      | tation is a property of the                                                       | ry subject to the regulations as follows:<br>e Library.                                                                     |
| Universiti Tuni<br>1. The dissert                                      | ku Abdul Rahman Librar<br>tation is a property of the                             | ry subject to the regulations as follows:                                                                                   |
| Universiti Tunl<br>1. The dissert<br>2. The Librar                     | ku Abdul Rahman Libra<br>tation is a property of the<br>ry is allowed to make cop | ry subject to the regulations as follows:<br>e Library.<br>pies of this dissertation for academic purposes.<br>Verified by, |
| Universiti Tuni<br>1. The dissert                                      | ku Abdul Rahman Libra<br>tation is a property of the<br>ry is allowed to make cop | ry subject to the regulations as follows:<br>e Library.<br>pies of this dissertation for academic purposes.                 |
| Universiti Tuni<br>1. The dissert<br>2. The Librar<br>(Author's signal | ku Abdul Rahman Libra<br>tation is a property of the<br>ry is allowed to make cop | ry subject to the regulations as follows:<br>e Library.<br>pies of this dissertation for academic purposes.<br>Verified by, |

# DESIGN AND DEVELOPMENT OF MEMORY SYSTEM FOR 32-BIT 5 STAGE PIPELINE RISC: MEMORY SYSTEM INTEGRATION

BY GOH DIH JIANN

# A REPORT

# SUBMITTED TO

UniversitiTunku Abdul Rahman

in partial fulfilment of the requirements

for the degree of

BACHELOR OF COMPUTER SCIENCE (HONS)

#### COMPUTER ENGINEERING

Faculty of Information and Communication Technology (Perak Campus)

OCTOBER 2015

# **DECLARATION OF ORIGINALITY**

I declare that this report entitled "DESIGN AND DEVELOPMENT OF MEMORY SYSTEM FOR 32-BIT 5 STAGE PIPELINE RISC: MEMORY SYSTEM INTEGRATION" 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.

Signature : \_\_\_\_\_

 Name
 : \_\_\_\_\_\_\_\_GOH DIH JIANN\_\_\_\_\_\_

Date : <u>14/12/2015</u>

# ACKNOWLEDGEMENTS

I would like to take this opportunity to express my gratitude to my final year project supervisor, Mr. Mok Kai Ming, who encourage me when I lost confidence, comfort me when I am stressed, and enlighten me when I lost my way. A million appreciation and thank for his guidance and wisdom during the entire course of this project. Lastly, I would like to say thanks to my parents for their unconditional support during my hard time throughout the course.

#### ABSTRACTS

This project is to enhance the current RISC32 architecture that developed in Universiti Tunku Abdul Rahman under Faculty of Information and Communication Technology by redesigning the memory system. After reviewing the previous work, the RISC32 processor memory system cache unit using write-through scheme which is able to improve more of it efficiency.

Hence, this project is initiated to redesign the cache unit into write-back cache and adding a write buffer(FIFO) in the cache unit to handling the data transferring back to SDRAM when read miss and write miss occur. Some modification on memory arbiter was done in order for the new cache unit worked in the memory system. This project is modelled using Verilog HDL and a test program will be developed in order to test the functionality and compatibility of the newly design write-back cache with the rest of memory system (memory arbiter, SDRAM controller, SDRAM).

# **TABLE OF CONTENTS**

| Contents                                                                        |    |
|---------------------------------------------------------------------------------|----|
| Chapter 1 Introduction                                                          | 11 |
| 1.1 Background Information                                                      | 12 |
| 1.2 Motivation and Problem Background                                           | 13 |
| 1.3 Problem Statement                                                           | 14 |
| Chapter 2 Literature Review                                                     | 15 |
| 2.1 Write-through Scheme vs Write-back Scheme                                   | 15 |
| 2.2 Write buffer                                                                | 15 |
| 2.2.1 Write Buffer Saturation                                                   | 15 |
| 2.2.2 Write-back Scheme with Write Buffer                                       | 16 |
| 2.3 Reduce Miss Rate via Larger Block Size: Multiword Block Direct Mapped Cache | 16 |
| 2.4 Cache Unit                                                                  | 17 |
| 2.4.1 Cache Associative                                                         | 17 |
| 2.4.2 Scenarios to Represent Cache Behaviours                                   | 18 |
| 2.4.3 Block Partitioning of Cache Unit                                          | 20 |
| 2.5 SDRAM                                                                       | 22 |
| 2.6 SDRAM Controller                                                            | 25 |
| 2.6.1 Block partitioning of SDRAM Controller                                    | 26 |
| 2.7 Memory Arbiter                                                              | 27 |
| 2.7.1 I/O Description                                                           | 28 |
| 2.7.2 Memory Arbiter State Diagram                                              | 31 |
| 2.7.3 State Definition                                                          | 31 |
| 2.7.4 Output or Behaviors Corresponding to the States                           | 32 |
| Chapter 3 Project Scope and Objectives                                          | 34 |
| 3.1 Project Objectives                                                          | 34 |
| 3.2 Impact and Significance                                                     | 35 |
| Chapter 4 Method and Technologies Involved                                      | 36 |
| 4.1 Design Methodology                                                          | 36 |
|                                                                                 |    |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

| 4.1.1 Micro-architecture Level Design (Unit Level)                 | 37           |
|--------------------------------------------------------------------|--------------|
| 4.1.2 Micro-architecture Level Design (Block Level)                | 37           |
| 4.2 Design Tools                                                   |              |
| 4.2.1 Verilog HDL Simulator - Mentor Graphics ModelSim SE-64 10.1c |              |
| Chapter 5 Memory System Specification                              | 39           |
| 5.1 Partitioning and Design Hierarchy                              | 39           |
| 5.2 Memory System Specifications                                   | 40           |
| 5.3 Memory Map                                                     | 41           |
| 5.4 Architecture of Memory System                                  | 43           |
| Chapter 6 Micro-Architecture Specification                         | 44           |
| 6.1 Cache Unit                                                     | 44           |
| 6.2 Scenarios to Represent Cache Behaviors Error! Bookmark r       | not defined. |
| 6.3 Cache Design Protocol Error! Bookmark r                        | not defined. |
| 6.4 Cache Unit I/O Description                                     | 46           |
| 6.5 Block Partitioning of Cache Unit                               | 49           |
| 6.6 Cache Controller Block                                         | 49           |
| 6.6.1 Cache Controller block I/O description                       | 50           |
| 6.6.2 Cache Controller State Diagram                               | 54           |
| 6.6.3 Cache Controller State Definition Error! Bookmark r          | not defined. |
| 6.6.4 Cache Controller Output behavior Error! Bookmark r           | not defined. |
| 6.7 FIFO Controller Block                                          | 55           |
| 6.7.1 FIFO Controller block I/O description                        | 55           |
| 6.7.2 FIFO Controller State Diagram                                | 57           |
| 6.7.3 FIFO Controller State Definition Error! Bookmark r           | not defined. |
| 6.7.4 Cache Controller Output behavior Error! Bookmark r           | not defined. |
| 6.8 FIFO Block                                                     | 58           |
| 6.8.1 FIFO Controller block I/O description                        | 59           |
| Chapter 7 Verification                                             | 62           |
| 7.1 Test Plan                                                      | 62           |
| 7.2 Testbench Verilog Code                                         | 66           |
| 7.3 Simulation Result                                              | 82           |
| Chapter 8 Conclusion                                               |              |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

| 8.1 Conclusion                      | 100 |
|-------------------------------------|-----|
| 8.2 Discussion and Future Work      |     |
| References                          | 101 |
| Appendices                          |     |
| Appendix A                          |     |
| System Specification                |     |
| A.2 Naming Convention               |     |
| A.3 Basic RISC32 processor          |     |
| A.3.1 Processor Interface           |     |
| A.3.2 I/O Pin Description           | 105 |
| A.4 System Register                 |     |
| A.4.1 General Purpose Register      |     |
| A.4.2 Special Purpose Register      |     |
| A.5 Instruction Format              | 107 |
| A.6 Addressing Mode                 |     |
| A.7 Instruction Set and Description |     |
| A.8 Memory Map                      | 112 |
| A.9 Operating Procedure             | 114 |

# LIST OF FIGURES

Figure 1-1-1 starting with 1980 performance as a baseline, the gap in performance between memory and processors is plotted over time.

Figure 2-2-1 Write-back scheme with write buffer

Figure 2-2-2 Multiword block direct mapped cache (block size = 32 bytes)

Figure 2-4-1 Cache Unit designed by Ching Li-lynn

Figure 2-4-2 Block Partitioning of Cache Unit designed by Ching Li-lynn

Figure 2-5-1 Block diagram of MT48LC4M32B2 (Oon Zhi Kang 2008)

Figure 2-5-2 Mode Register definitions to configure SDRAM (Micron)

Figure 2-6-1: SDRAM Controller Block Diagram designed by Chin Chun Lek

Figure 2-6-2: The Micro-Architecture of the SDRAM Controller designed by Chin Chun Lek

Figure 2-7-1: Memory Arbiter Block Diagram

Figure 2-7-2: Memory Arbiter State Diagram

Figure 4-1-1 General Design Flow without Synthesis and Physical Design

Figure 5-1-1 Memory System Partitioning

Figure 5-4-1 Architecture of Memory System

Figure 6-1-1 Block diagram of cache unit

Figure 6-3-1 Read Protocol of Cache

Figure 6-3-2 Write Protocol of Cache

Figure 6-5-1 Block Partition of Cache Unit

Figure 6-6-1 Block diagram of Cache Controller Block

Figure 6-6-2 State Diagram of Cache Controller

Figure 6-7-1 Block diagram of FIFO Controller Block

Figure 6-7-2 State Diagram of Cache Controller

Figure 6-8-1 Block diagram of FIFO Block

#### LIST OF TABLES

Table 2-5-1 List of SDRAM commands and function. (Micron datasheet)

Table 2-7-1: Memory Arbiter I/O Descriptions

Table 2-7-4: Memory Arbiter Output or Behaviours Corresponding to the States

Table 5-1-1 Design hierarchy for 32-bit Memory System

Table 5-2-1 Specifications of the Memory System

Table 5-3-1 Virtual memory map of 32-bits MIPS

Table 6-4-1: Cache Unit I/O Descriptions

Table 6-6-1: Cache Controller Block I/O Descriptions

Table 6-6-2: Cache Controller State Definition

Table 6-6-3: Cache Controller Output or Behaviors Corresponding to the State

Table 6-7-1: Cache Controller Block I/O Descriptions

Table 6-7-2: Cache Controller State Definition

Table 6-7-3: Cache Controller Output or Behaviors Corresponding to the State

Table 6-8-1: FIFO Block I/O Descriptions

Table 7-1-1: Memory system Full Chip Test Plan

# LIST OF ABBREVIATIONS

- MIPS Microprocessor without Interlocked Pipeline Stages
- RISC Reduced Instruction Set Computing
- CPU Central Processing Unit
- RTL Register Transfer Level
- I/O Input output
- FIFO First In First Out
- SOC System On Chip

#### **Chapter 1 Introduction**

#### **1.1 Background Information**

The growing disparity between microprocessor and memory cause by the division of the semiconductor industry into CPU fields and memory fields which their technology have focus on different achievement, the first one has concentrated on increased in speed, while the latter one has concentrated on increased in capacity. Thus the improvement rate in microprocessor speed by far exceeds the one in memory. The continuous growing gap between CPU and memory speeds is a crucial flaw in the overall computer performance. Throughout the history, CPU speeds have been improving at an average of 55% per year, while memory latency has only been improving at 7% per year (Hennessy and Patterson 2007, p. 289).



Figure 1-1-1 starting with 1980 performance as a baseline, the gap in performance between memory and processors is plotted over time.

The performance gap grows exponentially. This make increasing processormemory performance gap is now the leading direction to improved computer system performance.

Faculty of Information and Communication Technology (Perak Campus), UTAR

Memory Hierarchy was introduced in the late of sixties to provide decreased average latency and reduced bandwidth requirements to speed up memory system. The performance of a memory-hierarchy analyse through the average memory access time, using the following expression:

average memory access time = hit time + miss rate \* miss penalty.

(Araújo 2002, p.146)

Thus the effort to decrease the performance gap between processor and physical memory has been concentrated on efficient implementations of a memory hierarchy to reduce miss rate, miss penalty and hit time.

#### **1.2 Motivation and Problem Background**

A 32-bit RISC processor has been developed in Faculty of Information and Communication Technology, University Tunku Abdul Rahman (UTAR). The project is based on Reduced Instruction Set Computing (RISC) architecture. There are several purposes to initiate this project.

- Microchip design companies develop microprocessor cores as IP (Intellectual Property) for commercial purposes only. This simply means that the microprocessor IP which includes information of the entire design process for front-end and back-end IC design are trade secrets of the company and certainly not available in market at affordable price. Hence, RISC32 project is started at University Tunku Abdul Rahman few years ago and still working to complete the design.
- There are several freely available microprocessor cores from open source such as OpenCores (<u>opencores.org</u>) which is the largest site for development of hardware IP cores as open source. However these processors are not complete and did not implement the entire MIPS Instruction Architecture (ISA). Furthermore, they are lack of comprehensive documentation which makes them not suitable for reuse and further customization.

Faculty of Information and Communication Technology (Perak Campus), UTAR

- Verification is important for proving the functionality of any digital design. The microprocessors mentioned above are handicapped by incomplete and poorly developed verification specifications. This hampers the verification process, slowing down the overall design process.
- The lack of well-developed verification specifications for these microprocessor cores will certainly affect the physical design phase. A design need to be functionally proven before the physical design phase can proceed smoothly. Otherwise, if front-end design requires changing, the entire physical design needs to be redone.

#### **1.3 Problem Statement**

This project is aim to provide a solution to the above problems by creating a 32-bit RISC core-based development environment to assist research work in the area of softcore and also application specific hardware modelling. Currently, a SDRAM Controller and SDRAM provided by MICRON Technology Inc. has been modelled at the Register Transfer Level (RTL) using Verilog HDL and both of them have been combined together and had gone through a series of simulation test. There is also a cache and a TLB modelled at RTL using Verilog HDL, both of them were integrated together with the SDRAM controller as a complete memory system.

Seniors of UTAR FICT computer engineering implemented cache unit, memory arbiter and SDRAM controller. In previous implementation, cache unit is a writethrough 2-way set associative caches which it can be improved. Thus this project aim to redesign the cache unit into a write-back multiword direct mapped cache with write buffer (FIFO). The cache unit's protocol need to redesign because of the inclement of write-back ability in cache unit. After implemented the new cache unit, a little modification needs to be done in memory arbiter unit in order to compatible with the new cache unit. After that the functionality need to verify so that every unit is working as expected.

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

#### 2.1 Write-through Scheme vs Write-back Scheme

Write-through cache: Data are written into the cache and sent to the main memory (in this project is SDRAM) as operation is executed. This ensures that the contents of the cache and main memory are always the same, but it has downside that it experiences latency based on writing to SDRAM. This cache is good for application that writes and then re-read data frequently.

Write-back cache: Write-back cache keep stored data in the cache, and when a block that has been written is evicted from the cache, the contents of the block are then written back (copied) into the main memory (SDRAM). Write-back cache keep stored data in the cache, the main memory become the same after the contents of the block are written back (copied) into main memory. The disadvantage is there is data availability exposure risk because the only copy of the written data is in cache. Write-back cache is the best performing solution for mixed workloads as both read and write have similar response time levels. (Carter 2002)

This mean that if use write-through cache system performance is limited by memory speed whereas if use write-back cache the cache will get the full performance.

#### 2.2 Write buffer

Data is not written to the main memory directly but into the write buffer first. Once the data is written into the write buffer and assuming cache hit, the CPU is done with the write, then the SDRAM controller will move the write buffer's contents to the real memory behind the scene. This work as long as the frequency of store is not too high.

#### 2.2.1 Write Buffer Saturation

When store frequency approaching main memory write frequency it leads to write buffer saturation. In this case no matter how big the write buffer it is it will still overflow because data simply come in faster than it can empty it, thus CPU will running at main memory cycle time, which is very slow. The solution for write buffer saturation is to get rid of this write buffer and replace this write through cache with a write back cache. (Mok KM 2009)

#### 2.2.2 Write-back Scheme with Write Buffer

Write buffer allow cache to proceed as soon as data is placed in buffer rather than wait the full latency to write the data into memory. Write-back scheme write data to cache only. It makes main memory is not updated and allow cache and memory to be inconsistent. Since data in cache and memory is inconsistent, each block of data requires a dirty bit to indicate a block is modified. If block replacement happen in cache, only evicted dirty block is kept in a write buffer so that it can write-back to memory later. The drawback of this is it has complex hardware.



Figure 2-2-1 Write-back scheme with write buffer

# 2.3 Reduce Miss Rate via Larger Block Size: Multiword Block Direct Mapped Cache

Using multiword block direct mapped cache is the simplest way to reduce miss rate. This take advantage of spatial locality which mean if a word is accessed, nearby words are likely to be accessed soon, thus it is better to move more words per block from memory to cache. However when miss happen it takes more cycle to handle the miss (miss penalty increase).



# Figure 2-2-2 Multiword block direct mapped cache (block size = 32 bytes)

#### 2.4 Cache Unit

A 2-way set associative write-through cache of 2MB has been modelled by Ching Lilynn. This cache can be used as both Instruction Cache and Data Cache. Inside of cache unit consists of cache controller block and cache datapath block.



Figure 2-4-1 Cache Unit designed by Ching Li-lynn

#### 2.4.1 Cache Associative

- The current cache is a 2-way set associative cache
- N-Way set associative uses N cache, data RAMs and N cache-tag RAMs (built out of N RAMs and N comparators, a cache controller, and isolation buffers. It is actually separate the memory into different set of caches and ease the replacement and searching policy.

• 1-way set associative cache = direct mapped cache

# 2.4.2 Scenarios to Represent Cache Behaviours

Basically there are just 4 scenarios might be happened on cache, we need to decide what to do when these scenarios happen.

- 1. Read Miss
  - Receive physical address and instructions of read from the main controller of the CPU.
  - Check validity and tag for the index of the physical address points to. A miss signal is produced due to either it is invalid or the tag is different.
  - Cache controller asserts strobe, cycle, and read signals to SDRAM controller to fetch new black of data.
  - Meanwhile, the pipelines of the CPU are stalled.
  - Check LRU to determine which slot is least recently used, store the newly fetched block of data in it.
  - Set valid bit for the index pointed.
  - Update LRU.
  - Deassert the miss, strobe, cycle and read signal, the pipelines are un-stalled.

2. Read Hit

- Receive physical address and instruction of read from the main controller of CPU.
- Check validity and tag for index of the physical address points to. Miss signal is active low.
- Load the selected instruction or data by determining the byte offset to host.
- Update LRU.
- 3. Write Miss (For D-Cache only)
  - Receive physical address, data, and instruction of write from the main controller of CPU.
  - Check validity and tag for the index of the physical address points to. A miss signal is produced due to either it is invalid or the tag is different.
  - Stall the pipelines.
  - Check LRU to determine which is least recently used.
  - Cache controller asserts strobe, cycle, and read to SDRAM controller to access the data in SDRAM.
  - If the block of data was dirty, send the block of 8 words back to SDRAM.
  - Fetch new block of data from SDRAM.
  - After the new block is updated from SDRAM, strobe, cycle, read and miss signals are deasserted.
  - Perform the write.
  - Update LRU.

- 4. Write Hit (For D-Cache only)
  - Receive physical address, data, and instruction of write from main controller of CPU.
  - Check validity of tag for index of the physical address points to. Miss signal is active low.
  - Update the selected instruction or data.
  - Update LRU.

# 2.4.3 Block Partitioning of Cache Unit



Faculty of Information and Communication Technology (Perak Campus), UTAR

Figure 2-4-2 Block Partitioning of Cache Unit designed by Ching Li-lynn

#### 2.5 SDRAM

Synchronous Dynamic Random Access Memory (SDRAM) is a type of DRAM that is synchronised with the system bus. This project uses a SDRAM that is provided by MICRON Technology Inc. It is MT48LC4M32B2, with 16MB of storage. (Micron datasheet, n.d.) SDRAM control by SDRAM controller modelled by Chin Chun Lek thus in this project just need to focus on function of SDRAM and it configuration – load mode definition.



#### Figure 2-5-1 Block diagram of MT48LC4M32B2 (Oon Zhi Kang 2008)

The cs (active low) pin is used to select the SDRAM, while we, cas and ras are used to request operations from the SDRAM.

| Name (Function)                                        | CS# | RAS# | CAS# | WE# | DQM | ADDR     | DQ     | Notes |
|--------------------------------------------------------|-----|------|------|-----|-----|----------|--------|-------|
| COMMAND INHIBIT (NOP)                                  | н   | X    | Х    | Х   | Х   | Х        | Х      |       |
| NO OPERATION (NOP)                                     | L   | н    | н    | н   | X   | х        | х      |       |
| ACTIVE (select bank and activate row)                  | L   | L    | н    | н   | Х   | Bank/row | Х      | 2     |
| READ (select bank and column, and start READ burst)    | L   | н    | L    | н   | L/H | Bank/col | Х      | 3     |
| WRITE (select bank and column, and start WRITE burst)  | L   | н    | L    | L   | L/H | Bank/col | Valid  | 3     |
| BURST TERMINATE                                        | L   | н    | н    | L   | Х   | Х        | Active | 4     |
| PRECHARGE (Deactivate row in bank or banks)            | L   | L    | н    | L   | Х   | Code     | Х      | 5     |
| AUTO REFRESH or SELF REFRESH (enter self refresh mode) | L   | L    | L    | н   | Х   | Х        | Х      | 6, 7  |
| LOAD MODE REGISTER                                     | L   | L    | L    | L   | X   | Op-code  | х      | 8     |
| Write enable/output enable                             | X   | X    | Х    | Х   | L   | Х        | Active | 9     |
| Write inhibit/output High-Z                            | X   | X    | Х    | Х   | н   | Х        | High-Z | 9     |

 Table 2-5-1 List of SDRAM commands and function. (Micron datasheet)

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR



#### Figure 2-5-2 Mode Register definitions to configure SDRAM (Micron)

# • Burst Length

Determine the maximum number of column locations that can be accessed for a given READ or WRITE operation.

• Burst Type

Select either sequential or interleaved burst to be adopted by SDRAM. The ordering of accesses within a burst is determined by burst length, burst type, starting column address.

• CAS Latency

Delay in clock cycles between registration of a READ command and the availability of the first piece of output data. It can only be set to 2 or 3 clock cycles.

• Operating Mode

Select which operating mode should the SDRAM be. Currently there is only normal operating mode is available for use.

• Writing Burst Mode

When it is '0', the burst length is programmed via M0-M2 applies to both READ and WRITE burst.

When it is '1', the programmed burst length applies to READ bursts, but write accesses are single-location (non-burst) accesses.

#### **2.6 SDRAM Controller**

A SDRAM controller had been modelled by Chin Chun Lek. The SDRAM controller acts as an intermediary between the SDRAM and the CPU. It handles SDRAM operations using some protocols. It has no longer been modeled based on Industry standard HOST SoC interface due to the current design needs.

The main features of SDRAM Controller are:

- 1) Burst transfers and burst termination
- 2) SDRAM initialization support
- 3) Performance optimization by leaving active rows open
- 4) Load mode control



Figure 2-6-1: SDRAM Controller Block Diagram designed by Chin Chun Lek



# 2.6.1 Block partitioning of SDRAM Controller

Figure 2-6-2: The Micro-Architecture of the SDRAM Controller designed by Chin Chun Lek

#### **2.7 Memory Arbiter**

Chin Chun Lek had modelled a new memory arbiter. This memory arbiter allows multiple caches to access single SDRAM by given priority. The block diagram below shows a memory arbiter that can support up to 4 caches. Some modification needs to be done after that in order to compatible with this project newly designed cache unit.



Figure 2-7-1: Memory Arbiter Block Diagram

#### 2.7.1 I/O Description

Pin name: ui\_ma\_cac\_read

Pin class: Control

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** read signals from the TLBs and Caches.

Pin name: ui\_ma\_cac\_write

Pin class: Control

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** write signal from the TLBs and Caches.

**Pin name:** ui\_ma\_cac\_host\_ld\_mode

Pin class: Control

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** Host Load Mode signals from the TLBs and Caches.

Pin name: ui\_ma\_cac\_sel

Pin class: Control

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** Byte Select signals from the TLBs and Caches.

Pin name: ui\_ma\_cac\_addr

Pin class: Address

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** Addresses from the TLBs and Caches.

**Pin name:** ui\_ma\_cac\_data

Pin class: Data

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

**Description:** Data from the TLBs and Caches.

**Pin name:** ui\_ma\_cac\_miss

Pin class: Control

**Path:** TLB or Cache  $\rightarrow$  Memory Arbiter

Description: Miss signals from the TLBs and Caches.

Pin name: uo\_ma\_cac\_ack

Pin class: Control

BIT (Hons) Computer Engineering

Faculty of Information and Communication Technology (Perak Campus), UTAR

**Path:** Memory Arbiter  $\rightarrow$  TLB or Cache

**Description:** Acknowledge signal (active HIGH) to indicate read or write to SDRAM is done, and send to Caches or TLB.

**Pin name:** uo\_ma\_cac\_data

Pin class: Data

**Path:** Memory Arbiter  $\rightarrow$  TLB or Cache

**Description:** 32-bits data that goes to Cache or TLB.

**Pin name:** ui\_ma\_sdc\_data

Pin class: Data

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

**Description:** 32-bits data that comes from SDRAM.

**Pin name:** ui\_ma\_sdc\_ack

Pin class: control

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

**Description:** Acknowledge signal (active HIGH) to indicate read or write to SDRAM is done.

Pin name: uo\_ma\_sdc\_host\_ld\_mode

Pin class: control

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

**Description:** Host Load Mode signals that send to SDRAM Controller.

**Pin name:** uo\_ma\_sdc\_read

Pin class: control

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

Description: read signal that goes to SDRAM Controller

**Pin name:** uo\_ma\_sdc\_write

Pin class: control

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

**Description:** Write signal that goes to SDRAM Controller.

Pin name: uo\_ma\_sdc\_sel

Pin class: control

**Path:** Memory Arbiter  $\rightarrow$  SDRAM Controller

BIT (Hons) Computer Engineering

Faculty of Information and Communication Technology (Perak Campus), UTAR

**Description:** 4-bits control signals to mask which byte of the 4 bytes (32-bits) data goes in or comes out from SDRAM.

When it is '1', the corresponding byte will enable.

When it is '0', the corresponding byte will be masked and the output becomes 'z'.

**Pin name:** uo\_ma\_sdc\_addr

Pin class: control

**Path:** SDRAM Controller  $\rightarrow$  Memory Arbiter

**Description:** 32-bits address to indicate which location in the SDRAM to be

accessed.

**Pin name:** uo\_ma\_sdc\_data

Pin class: control

**Path:** SDRAM Controller  $\rightarrow$  Memory Arbiter

**Description:** 32-bits data that goes into the SDRAM.

When wants to configure the operating mode of the SDRAM, the configuration values

goes into SDRAM via this port too.

# Table 2-7-1: Memory Arbiter I/O Descriptions

# 2.7.2 Memory Arbiter State Diagram



Figure 2-7-2: Memory Arbiter State Diagram

#### 2.7.3 State Definition

|         | State Name | Definition                                       |
|---------|------------|--------------------------------------------------|
| Memory  | cache3     | First priority cache given to perform operation  |
| Arbiter | cache2     | Second priority cache given to perform operation |
|         | cache1     | Third priority cache given to perform operation  |
|         | cache0     | Last priority cache given to perform operation   |
|         | idle       | Wait for new operation                           |

 Table 2-7-2: State Definition of Memory Arbiter

| State Name | Correspondence Output Behaviors                  |
|------------|--------------------------------------------------|
| cache3     | When ui_ma_cac_miss3 = 1,                        |
|            |                                                  |
|            | from cache3 to SDRAM controller:                 |
|            | uo_ma_sdc_read = ui_ma_cac_read3,                |
|            | uo_ma_sdc_write = ui_ma_cac_write3,              |
|            | uo_ma_sdc_host_ld_mode = ui_ma_cac_host_ld_mode3 |
|            | uo_ma_sdc_sel = ui_ma_cac_sel3,                  |
|            | uo_ma_sdc_addr = ui_ma_cac_addr3,                |
|            | uo_ma_sdc_data = ui_ma_cac_data3                 |
|            |                                                  |
|            | from SDRAM controller to cache3:                 |
|            | ui_ma_sdc_ack = uo_ma_cac_ack3,                  |
|            | ui_ma_sdc_data = uo_ma_cac_data3                 |
| cache2     | When ui_ma_cac_miss3 = 0 and                     |
|            | ui_ma_cac_miss2 = 1,                             |
|            |                                                  |
|            | from cache2 to SDRAM controller:                 |
|            | uo_ma_sdc_read = ui_ma_cac_read2,                |
|            | uo_ma_sdc_write = ui_ma_cac_write2,              |
|            | uo_ma_sdc_host_ld_mode = ui_ma_cac_host_ld_mode2 |
|            | uo_ma_sdc_sel = ui_ma_cac_sel2,                  |
|            | uo_ma_sdc_addr = ui_ma_cac_addr2,                |
|            | uo_ma_sdc_data = ui_ma_cac_data2                 |
|            |                                                  |
|            | from SDRAM controller to cache2:                 |
|            | ui_ma_sdc_ack = uo_ma_cac_ack2,                  |
|            | ui_ma_sdc_data = uo_ma_cac_data2                 |
| cachel     | When ui_ma_cac_miss3 = 0 and                     |

| 274   | Output | or | Rehaviors | Corresi | nonding to | the States |
|-------|--------|----|-----------|---------|------------|------------|
| 4.1.4 | Output | UI | DEHAVIOIS | COLLES  | ponung to  | the States |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

| [      |                                                  |
|--------|--------------------------------------------------|
|        | $ui_ma_cac_miss2 = 0$ and                        |
|        | ui_ma_cac_miss1 = 1,                             |
|        |                                                  |
|        | from cache1 to SDRAM controller:                 |
|        | uo_ma_sdc_read = ui_ma_cac_read1,                |
|        | uo_ma_sdc_write = ui_ma_cac_write1,              |
|        | uo_ma_sdc_host_ld_mode = ui_ma_cac_host_ld_mode1 |
|        | uo_ma_sdc_sel = ui_ma_cac_sel1,                  |
|        | uo_ma_sdc_addr = ui_ma_cac_addr1,                |
|        | uo_ma_sdc_data = ui_ma_cac_data1                 |
|        |                                                  |
|        | from SDRAM controller to cache1:                 |
|        | ui_ma_sdc_ack = uo_ma_cac_ack1,                  |
|        | ui_ma_sdc_data = uo_ma_cac_data1                 |
| cache0 | When ui_ma_cac_miss3 = 0 and                     |
|        | $ui_ma_cac_miss2 = 0$ and                        |
|        | $ui_ma_cac_miss1 = 0$ and                        |
|        | ui_ma_cac_miss $0 = 1$ ,                         |
|        |                                                  |
|        | from cache0 to SDRAM controller:                 |
|        | uo_ma_sdc_read = ui_ma_cac_read0,                |
|        | uo_ma_sdc_write = ui_ma_cac_write0,              |
|        | uo_ma_sdc_host_ld_mode = ui_ma_cac_host_ld_mode0 |
|        | uo_ma_sdc_sel = ui_ma_cac_sel0,                  |
|        | uo_ma_sdc_addr = ui_ma_cac_addr0,                |
|        | uo_ma_sdc_data = ui_ma_cac_data0                 |
|        |                                                  |
|        | from SDRAM controller to cache0:                 |
|        | ui_ma_sdc_ack = uo_ma_cac_ack0,                  |
|        | ui_ma_sdc_data = uo_ma_cac_data0                 |
| idle   | All outputs are received zero.                   |
|        |                                                  |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

# Table 2-7-4: Memory Arbiter Output or Behaviours Corresponding to the States

#### **Chapter 3 Project Scope and Objectives**

This project aims to redesign existing memory system by changing write-through scheme to write-back scheme by adding a write buffer (FIFO) to improve the efficiency of previous memory system. A fully functionality verified and synthesis-ready model will be modelled in RTL using the Verilog HDL at the end of this project including the development of test specification, test plan, test vector and testbench which are written in Verilog HDL to ensure functional correctness and the performance.

#### **3.1 Project Objectives**

This project's objectives include:

- Design the write-back scheme direct mapped cache unit.
- Design the protocol of cache unit (cache controller block).
- Design the write buffer (FIFO).
- Design the protocol of write buffer (FIFO controller block).
- Modification on memory arbiter to compatible with new cache unit.
- Integration of cache unit, memory arbiter, SDRAM controller and SDRAM.
- Verified the functionality of the integrated unit (cache unit, memory arbiter, SDRAM controller and SDRAM) by construct proper test cases.

# **3.2 Impact and Significance**

As a summary to the problem statement, there is a lack of well-developed and wellfounded 32-bit RISC microprocessor 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 RISC architecture core in the form of synthesis-ready RTL written in Verilog HDL.
- A well-developed verification environment for the 32-bit RISC core. The verification specification should contain suitable verification methodology, verification techniques, test plans, testbench 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 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 datapath or as a coprocessor interfacing to the RISC processor.

## **Chapter 4 Method and Technologies Involved**

#### 4.1 Design Methodology

There are several types of design methodologies for design process:

- Top-down design methodology
- Bottom-up design methodology
- Mixed design methodology

A top down design approach was adopted as the main design methodology in this project as shown in the following figure.



Figure 4-1-1 General Design Flow without Synthesis and Physical Design

This methodology put design partition reduces a complex design into smaller and a manageable piece thus provides step to step guideline that leading to a good design work and development of systems A good design methodology can ensure that functionality correctness in design, satisfaction in term of performance and power goals, can catches bugs at early stage, and provide good documentation for future references (Wolf 2004, p.22). This project only involved in micro-Architecture level design (Unit Level and Block Level) since higher architecture level had been complete and waiting for integration only.

#### **4.1.1 Micro-architecture Level Design (Unit Level)**

The alternate appellation of this level is RTL (Register Transfer Level). This level describes the internal design of architecture unit module with data flow. The unit module is partition into several blocks which each block have its own functionality to carry out the sub-function of the unit module to reduce complexity of design process.

#### **4.1.2 Micro-architecture Level Design (Block Level)**

This level further describes each partition from previous level which is block. Their specification are written in this level, normally carry following information such as:

- Functionality / Feature
- Block interface and I/O pin description
- Internal operation which include function table
- Schematic and block diagram
- Test plan
- Timing requirement

Once done with the micro-architecture specification, with the information in the specification, RTL modelling with High Level Language or Hardware Description Language (HDL) can be start. It is combination of behaviour and data flow synthesizable HDL model. Throughout the RTL modelling, Verilog will be use as the design language in this project. The model can be simulate and synthesis. The model is then need to go through verification process which verify the functionality of the design which need to meet the micro-architecture specification. Verification includes development of testbench, timing verification and functionality verification.

Faculty of Information and Communication Technology (Perak Campus), UTAR

#### **4.2 Design Tools**

#### 4.2.1 Verilog HDL Simulator - Mentor Graphics ModelSim SE-64 10.1c

Develop using Verilog Hardware Description Language (HDL) require a simulator tool that can provide simulation environment to verify the functional behaviours and waveform simulation. With multiple choices of HDL simulator in the market, a research had been to choose the most appropriate design tools for this project which affect by language supported, availability, price and etc. From the consideration above, ModelSim from Mentor Graphic is the best choice as a design tools for this project as they offer a free license for Student Edition, can found in internet and support Microsoft Windows platform. Although with some limitation, which is slower simulation speed than full version and have code limitation, but it is sufficient for this project as the scope of this project would not reach the limit.

## **Chapter 5 Memory System Specification**

**5.1 Partitioning and Design Hierarchy** 





| Chip Partitioning at | Unit Partitioning at Micro- | Block and Functional Block |
|----------------------|-----------------------------|----------------------------|
| Architecture level   | Architecture Level          | Partitioning at RTL level  |
|                      |                             | (Micro-Architecture level) |
| Memory System unit   | u_cache (for data)          | b_cache_ctrl               |
|                      |                             | b_fifo_ctrl                |
|                      |                             | b_fifo                     |
|                      | u_cache (for instruction)   | b_cache_ctrl               |
|                      |                             | b_fifo_ctrl                |
|                      |                             | b_fifo                     |
|                      | u_mem_arbiter               | -                          |
|                      | u_sdram_controller          | b_sdc_fsm                  |
|                      |                             | b_sdc_sdram_if             |
|                      |                             | b_sdc_addr_mux             |
|                      |                             | b_sdc_obrt_top             |
|                      | sdram (mt48lc4m32b2)        | -                          |

Table 5-1-1 Design hierarchy for 32-bit Memory System

# **5.2 Memory System Specifications**

|                   | RISC32 with Integrated Main Memory  |
|-------------------|-------------------------------------|
| SDRAM             | 16MB                                |
| Instruction Cache | Direct mapped write-back cache, 2MB |
| Data Cache        | Direct mapped write-back cache, 2MB |
| Data Bus Width    | 32-bits                             |
| Instruction Width | 32-bits                             |

# Table 5-2-1 Specifications of the Memory System

| 5.3 Memory Map |              |                                       |
|----------------|--------------|---------------------------------------|
| Segment        | Address      | Purpose                               |
| kseg2 – 1GB    | 0xFFFF FFFF  | Kernel module,                        |
|                |              | Page Table allocated here             |
|                | 0xC000 0000  |                                       |
| kseg1 – 512MB  | 0xBFFF FFFF  | Boot Rom                              |
|                |              | I/O Register (if below 512MB)         |
|                | 0xA000 0000  |                                       |
| kseg0 – 512MB  | 0x9FFF FFFF  | Direct view of memory to 512MB        |
|                |              | kernel code and data.                 |
|                |              | Exception and Page Table Base         |
|                |              | Register allocated here.              |
|                | 0x8000 0000  |                                       |
| kuseg – 2GB    | 0x7FFF FFFF  | Stack Segment starts from the ending  |
|                |              | address and expand down.              |
|                |              | Heap Segment starts from the starting |
|                |              | address and expand top.               |
|                | 0x1000 8000  |                                       |
|                | 0x1000 7FFF  | Data segment and Dynamic library      |
|                |              | code.                                 |
|                | 0x1000 0000  |                                       |
|                | 0x09FFF FFFF | Code Segment, where the main          |
|                |              | program stored.                       |
|                | 0x0040 0000  |                                       |
|                | 0x003F FFFF  | Reserved                              |
|                |              |                                       |
|                | 0x0000 0000  |                                       |

Table 5-3-1 Virtual memory map of 32-bits MIPS

# • Stack Segment

• Use for storing automatic variables, which are variables that allocated and de-allocated automatically when program flow.

# • Heap Segment

• Use for dynamic memory allocation such as malloc(), realloc() and free().

# • Data Segment

• Use for storing global or static variables that initialize by programmer.

#### • Code Segment

• Use for storing codes of main program or main program instructions.

## **5.4 Architecture of Memory System**



Figure 5-4-1 Architecture of Memory System

#### **Chapter 6 Micro-Architecture Specification**

#### 6.1 Cache Unit



Figure 6-1-1 Block diagram of cache unit

This is a direct mapped write-back cache with write buffer. The functionalities of Cache Unit are:

- 1. Store a small fraction of data (for D-Cache) or instructions (for I-Cache) of main memory.
- 2. Output desired data or instruction to CPU when it issues a READ.
- 3. Write data into desired location as instructed by CPU (D-Cache only).
- 4. Send signal to stall the CPU when read miss or write miss.

5. Communicate with SDRAM Controller to write back 'dirty' block of data back into SDRAM and fetch new block of data from it.

#### 6.4 Cache Unit I/O Description

#### **Input pins**

Pin name: ui\_cac\_clk

Pin class: Global

**Path:** External  $\rightarrow$  Cache

**Description:** System clock signal.

Pin name: ui\_cac\_rst

Pin class: Global

**Path:** External  $\rightarrow$  Cache

**Description:** System reset signal.

**Pin name:** ui\_cac\_cpu\_data[31:0]

Pin class: Data

**Path:** CPU→ Cache

Description: 32-bits data from CPU that to be written into the cache.

**Pin name:** ui\_cac\_cpu\_addr[31:0]

Pin class: Address

**Path:** CPU→ Cache

Description: 32-bits address from CPU that indicates the location that to be accessed.

**Pin name:** ui\_cac\_cpu\_read

Pin class: Control

**Path:** CPU→ Cache

**Description:** A control signal that enables the read from cache based on ui\_cac\_cpu\_addr[31:0] when it is asserted (HIGH).

Pin name: ui\_cac\_cpu\_write

Pin class: Control

**Path:** CPU→ Cache

**Description:** A control signal that enables the write of data into cache based on ui\_cac\_cpu\_addr[31:0] when asserted (HIGH).

**Pin name:** ui\_cac\_mem\_ack

Pin class: Control

**Path:** Memory Arbiter  $\rightarrow$  Cache

BIT (Hons) Computer Engineering

**Description:** Acknowledge signal (active HIGH) to indicate read data is ready from SDRAM (read from SDRAM) or SDRAM prepare to receive data (write to SDRAM).

**Pin name:** ui\_cac\_mem\_data[31:0]

Pin class: Data

**Path:** Memory Arbiter  $\rightarrow$  Cache

**Description:** 32-bits data that is read from SDRAM.

Pin name: ui\_cac\_mem\_lmc\_same

Pin class: Status

**Path:** Memory Arbiter  $\rightarrow$  Cache

Description: Indicate the configuration of SDRAM is same when asserted (HIGH).

**Output pins** 

Pin name: uo\_cac\_cpu\_data[31:0]

Pin class: Data

**Path:** Cache→ CPU

**Description:** 32-bits data that to be output to CPU.

**Pin name:** uo\_cac\_cpu\_stall

Pin class: Control

Path: Cache → CPU

**Description:** A status signal that used to stall the pipelines.

Pin name: uo\_cac\_miss

Pin class: Status

**Path:** Cache → Memory Arbiter

**Description:** A status signal indicates cache miss.

**Pin name:** uo\_cac\_mem\_read

Pin class: Control

**Path:** Cache → Memory Arbiter

**Description:** Read signal that indicate need read from SDRAM.

**Pin name:** uo\_cac\_mem\_write

Pin class: Control

Path: Cache → Memory Arbiter

Description: Write signal that indicate need write data into SDRAM.

BIT (Hons) Computer Engineering

**Pin name:** uo\_cac\_mem\_sel[3:0]

Pin class: Control

**Path:** Cache → Memory Arbiter

Description: 4-bits control signals to mask which byte of the 4 bytes (32-bits) data

goes in or comes out from SDRAM.

When it is '1', the corresponding byte will enable.

When it is '0', the corresponding byte will be masked and the output becomes 'z'.

**Pin name:** uo\_cac\_mem\_addr[31:0]

Pin class: Address

**Path:** Cache → Memory Arbiter

**Description:** 32-bits address that indicates which location in the SDRAM to be accessed.

**Pin name:** uo\_cac\_mem\_data[31:0]

Pin class: Data

**Path:** Cache → Memory Arbiter

**Description:** 32-bits data that to be written in to the SDRAM.

**Pin name:** uo\_cac\_mem\_lmc\_data[31:0]

Pin class: Data

**Path:** Cache → Memory Arbiter

**Description:** 32-bits data that configure the SDRAM.

Pin name: uo\_cac\_mem\_data\_ready

Pin class: Status

Path: Cache → Memory Arbiter

**Description:** When asserted (HIGH), data is ready write back from FIFO to SDRAM.

Pin name: uo\_cac\_mem\_complete

Pin class: Status

Path: Cache → Memory Arbiter

Description: Indicates one block of data was written into SDRAM when HIGH.

# Table 6-4-1: Cache Unit I/O Descriptions

#### 6.5 Block Partitioning of Cache Unit



Figure 6-5-1 Block Partition of Cache Unit

#### **6.6 Cache Controller Block**

|                       | che controller                |
|-----------------------|-------------------------------|
| 1977 (J. 1978)        | bo cac ctrl fifo update vali  |
| bi cac ctrl clk       | bo cac ctrl buffer cac e      |
| bi_cac_ctr1_rst       | bo cac ctrl cac fifo e        |
| bi_cac_ctrl_fifo_busy | bo_cac_ctrl_fifo_buffer_e     |
| bi_cac_ctrl_fifo_full | bo_cac_ctrl_update_dirt       |
| bi_cac_ctrl_fifo_hit  | bo_cac_ctrl_update_e          |
| bi_cac_ctrl_lmc_same  | bo_cac_ctrl_mem_se            |
| bi_cac_ctr1_mem_ack   | bo_cac_ctrl_mem_rea           |
| bi_cac_ctrl_cpu_write | bo_cac_ctrl_mem_writ          |
| bi_cac_ctrl_cpu_read  | bo_cac_ctrl_cache_data_selec  |
| bi_cac_ctrl_hit       | bo_cac_ctrl_counter           |
| bi_cac_ctrl_dirty     | bo_cac_ctrl_cpu_data_output_e |

Functionalities of Cache Controller:

- 1. Control main activity of cache unit.
- 2. Determine data to read when read hit.
- 3. Determine data to be updated when write hit.
- 4. Determine data to read from SDRAM when miss.
- 5. Output control signal and status signal to write back data from FIFO to cache.
- 6. Output control signal to move dirty data from cache to FIFO.
- 7. Output control signal and status signal out to CPU and SDRAM.

## 6.6.1 Cache Controller block I/O description

| Input pins                                                                                                    |  |  |
|---------------------------------------------------------------------------------------------------------------|--|--|
| Pin name: bi_cac_ctrl_clk                                                                                     |  |  |
| Pin class: Global                                                                                             |  |  |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ Cache Controller                                      |  |  |
| Description: System clock signal.                                                                             |  |  |
| Pin name: bi_cac_ctrl_rst                                                                                     |  |  |
| Pin class: Global                                                                                             |  |  |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ Cache Controller                                      |  |  |
| <b>Description:</b> System reset signal.                                                                      |  |  |
| Pin name: bi_cac_ctrl_lmc_same                                                                                |  |  |
| Pin class: Status                                                                                             |  |  |
| <b>Path:</b> Memory Arbiter $\rightarrow$ Cache $\rightarrow$ Cache Controller                                |  |  |
| <b>Description:</b> Indicates the configuration of SDRAM is same when asserted (HIGH).                        |  |  |
| Pin name: bi_cac_ctrl_mem_ack                                                                                 |  |  |
| Pin class: Control                                                                                            |  |  |
| <b>Path:</b> SDRAM controller $\rightarrow$ Memory Arbiter $\rightarrow$ Cache $\rightarrow$ Cache Controller |  |  |
| Description: Acknowledge signal (active HIGH) to indicate read data is ready from                             |  |  |
| SDRAM(read from SDRAM) or SDRAM prepare to receive data (write to SDRAM).                                     |  |  |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

**Pin name:** bi\_cac\_ctrl\_cpu\_write

Pin class: Control

**Path:** CPU $\rightarrow$  Cache  $\rightarrow$  Cache Controller

**Description:** A control signal that enables the write of data into cache based on ui\_cac\_cpu\_addr[31:0] when asserted (HIGH).

**Pin name:** bi\_cac\_ctrl\_cpu\_read

Pin class: Control

**Path:** CPU $\rightarrow$  Cache  $\rightarrow$  Cache Controller

**Description:** A control signal that enables the read from cache based on ui\_cac\_cpu\_addr[31:0] when it is asserted (HIGH).

**Pin name:** bi\_cac\_ctrl\_hit

Pin class: Status

**Path:** Cache  $\rightarrow$  Cache Controller

**Description:** Asserted when (tag == tag\_ram) && (valid\_ram == 1).

**Pin name:** bi\_cac\_ctrl\_dirty

Pin class: Status

**Path:** Cache  $\rightarrow$  Cache Controller

**Description:** Asserted when dirty\_ram == 1.

Pin name: bi\_cac\_ctrl\_fifo\_busy

Pin class: Status

**Path:** FIFO  $\rightarrow$  Cache Controller

Description: HIGH when FIFO is writing into SDRAM.

**Pin name:** bi\_cac\_ctrl\_fifo\_full

Pin class: Status

**Path:** FIFO  $\rightarrow$  Cache Controller

**Description:** Status signal that indicate FIFO is full.

**Pin name:** bi\_cac\_ctrl\_fifo\_hit

Pin class: Status

**Path:** FIFO  $\rightarrow$  Cache Controller

Description: Status Signal that FIFO contain same tag and index with the physical

address tag and index.

BIT (Hons) Computer Engineering

Output pins

**Pin name:** bo\_cac\_ctrl\_cpu\_data\_output\_en

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

Description: When asserted (HIGH), data is enabled to be output to CPU.

**Pin name:** bo\_cac\_ctrl\_counter[2:0]

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

**Description:** 3-bits counter value. This is used to count the data when transferring a whole block (8 words) of data.

**Pin name:** bo\_cac\_ctrl\_cache\_data\_select

Pin class: Control

**Path:** Cache  $\rightarrow$  Cache Controller $\rightarrow$  Cache

**Description:** Instruct the cache datapath which data (data from cpu or data from SDRAM) to be written into.

When HIGH, choose data from SDRAM.

When LOW, choose data from CPU.

**Pin name:** bo\_cac\_ctrl\_mem\_read

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache  $\rightarrow$  Memory Arbiter  $\rightarrow$  SDRAM Controller  $\rightarrow$  SDRAM

**Description:** Read signal that indicate need read from SDRAM.

Pin name: bo\_cac\_ctrl\_mem\_write

Pin class: Control

**Path:** Cache Controller → FIFO controller

**Description:** Write signal that indicate need write data into SDRAM.

Pin name: bo\_cac\_ctrl\_mem\_sel [3:0]

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache  $\rightarrow$  Memory Arbiter

Description: 4-bits control signals to mask which byte of the 4 bytes (32-bits) data

goes in or comes out from SDRAM.

When it is '1', the corresponding byte will enable.

BIT (Hons) Computer Engineering

When it is '0', the corresponding byte will be masked and the output becomes 'z'.

**Pin name:** bo\_cac\_ctrl\_update\_en

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

**Description:** Enables the update of cache when asserted (HIGH).

**Pin name:** bo\_cac\_ctrl\_update\_dirty

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

**Description:** Enables the update of 'Dirty' when asserted (HIGH).

**Pin name:** bo\_cac\_ctrl\_fifo\_buffer\_en

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

Description: Enable to move write back data from FIFO to temporary buffer.

**Pin name:** bo\_cac\_ctrl\_cac\_fifo\_en

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

**Description:** Enable to move cache data to FIFO.

**Pin name:** bo\_cac\_ctrl\_buffer\_cac\_en

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  Cache

Description: Enable to move write back data from temporary buffer to cache.

**Pin name:** bo\_cac\_ctrl\_fifo\_update\_valid

Pin class: Control

**Path:** Cache Controller → FIFO

**Description:** Control signal that update the valid bit in FIFO.

# Table 6-6-1: Cache Controller Block I/O Descriptions

6.6.2 Cache Controller State Diagram



Figure 6-6-2 State Diagram of Cache Controller

## **6.7 FIFO Controller Block**

| bo_fifo_ctrl_mem_write     | bi_fifo_ctrl_hit      |
|----------------------------|-----------------------|
| bo_fifo_ctrl_data_ready    | bi_fifo_ctrl_mem_ack  |
| bo_fifo_ctrl_mem_output_en | bi_fifo_ctrl_lmc_same |
| bo_fifo_ctrl_complete      | bi_fifo_ctrl_empty    |
| bi_fifo_ctrl_mem_write     |                       |
| bi_fifo_ctrl_cpu_clk       |                       |
| bi_fifo_ctrl_cpu_rst       |                       |
|                            |                       |

Figure 6-7-1 Block diagram of FIFO Controller Block

Functionalities of FIFO Controller:

- 1. Control main activity of FIFO block.
- 2. Send control signal to FIFO to write data back to SDRAM behind the scene.

# 6.7.1 FIFO Controller block I/O description

| Input pins                                                                        |
|-----------------------------------------------------------------------------------|
| Pin name: bi_fifo_ctrl_cpu_clk                                                    |
| Pin class: Global                                                                 |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ FIFO Controller           |
| Description: System clock signal.                                                 |
| Pin name: bi_fifo_ctrl_cpu_rst                                                    |
| Pin class: Global                                                                 |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ FIFO Controller           |
| <b>Description:</b> System reset signal.                                          |
| Pin name: bi_fifo_ctrl_hit                                                        |
| Pin class: Status                                                                 |
| <b>Path:</b> FIFO $\rightarrow$ FIFO Controller                                   |
| Description: Status Signal that FIFO contain same tag and index with the physical |

BIT (Hons) Computer Engineering

Faculty of Information and Communication Technology (Perak Campus), UTAR

address tag and index.

Pin name: bi\_fifo\_ctrl\_mem\_write

Pin class: Control

**Path:** Cache Controller  $\rightarrow$  FIFO controller

**Description:** Write signal that indicate need write data into SDRAM

**Pin name:** bi\_fifo\_ctrl\_mem\_ack

Pin class: Control

**Path:** SDRAM controller  $\rightarrow$  Memory Arbiter  $\rightarrow$  Cache  $\rightarrow$  FIFO Controller

Description: Acknowledge signal (active HIGH) to indicate read data is ready from

SDRAM(read from SDRAM) or SDRAM prepare to receive data (write to SDRAM).

**Pin name:** bi\_fifo\_ctrl\_lmc\_same

Pin class: Status

**Path:** Memory Arbiter  $\rightarrow$  FIFO Controller

**Description:** Indicate the configuration of SDRAM is same when asserted (HIGH).

**Pin name:** bi\_fifo\_ctrl\_empty

Pin class: Status

**Path:** FIFO  $\rightarrow$  FIFO Controller

Description: When asserted, it indicate FIFO is empty.

**Output pins** 

**Pin name:** bo\_fifo\_ctrl\_counter [2:0]

Pin class: Control

Path: FIFO Controller → FIFO

Description: 3-bits counter value. This is used to count the data when transferring a

whole block (8 words) of data.

**Pin name:** bo\_fifo\_ctrl\_mem\_write

Pin class: Control

**Path:** FIFO Controller  $\rightarrow$  Memory Arbiter

Description: Write signal that indicate need write data from FIFO into SDRAM.

Pin name: bo\_fifo\_ctrl\_data\_ready

Pin class: Status

**Path:** FIFO Controller  $\rightarrow$  Memory Arbiter

BIT (Hons) Computer Engineering

**Description:** When asserted (HIGH), data is ready write back from FIFO to SDRAM.

**Pin name:** bo\_fifo\_ctrl\_mem\_output\_en

Pin class: Control

**Path:** FIFO Controller  $\rightarrow$  FIFO

Description: Enable data in FIFO to be written into SDRAM

Pin name: bo\_fifo\_ctrl\_complete

Pin class: Control

**Path:** FIFO Controller  $\rightarrow$  Memory Arbiter

Description: Indicates one block of data was written into SDRAM when HIGH.

# Table 6-7-1: Cache Controller Block I/O Descriptions

# 6.7.2 FIFO Controller State Diagram



Figure 6-7-2 State Diagram of Cache Controller

#### **6.8 FIFO Block**



Figure 6-8-1 Block diagram of FIFO Block

This FIFO block consists of 4 entries to store data block from cache. The functionalities of FIFO block are:

- 1. Store dirty block from cache that need to written back to SDRAM
- 2. Data able to written back to cache or back to SDRAM.
- 3. Communicate with SDRAM to written data back to SDRAM when SDRAM is free.
- 4. Compare tag and index to indicate whether same block of data need to accessed next in cache.
- 5. Output a full signal when 4 entries are used.
- 6. Output an empty signal when FIFO contains no data.

| 6.8.1 FIFO Controller block I/O description                                   |
|-------------------------------------------------------------------------------|
| Input pins                                                                    |
| Pin name: bi_fifo_cpu_clk                                                     |
| Pin class: Global                                                             |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ FIFO                  |
| Description: System clock signal.                                             |
| Pin name: bi_fifo_cpu_rst                                                     |
| Pin class: Global                                                             |
| <b>Path:</b> External $\rightarrow$ Cache $\rightarrow$ FIFO                  |
| <b>Description:</b> System reset signal.                                      |
| Pin name: bi_fifo_update_valid                                                |
| Pin class: Control                                                            |
| <b>Path:</b> Cache Controller $\rightarrow$ FIFO                              |
| Description: Control signal that update the valid bit in FIFO.                |
| Pin name: bi_fifo_write                                                       |
| Pin class: Control                                                            |
| <b>Path:</b> Cache Controller $\rightarrow$ FIFO                              |
| <b>Description:</b> Write signal that indicate data write from cache to FIFO. |
| Pin name: bi_fifo_mem_output_en                                               |
| Pin class: Control                                                            |
| Path: FIFO controller → FIFO                                                  |
| Description: Enable data in FIFO to be written into SDRAM                     |
| Pin name: bi_fifo_complete                                                    |
| Pin class: Status                                                             |
| <b>Path:</b> FIFO controller $\rightarrow$ FIFO                               |
| Description: Indicates one block of data was written into SDRAM when HIGH.    |
| Pin name: bi_fifo_tag_compare[10:0]                                           |
| Pin class: Address                                                            |
| Path: Cache → FIFO                                                            |
| Description: Tag from physical address that used to compare FIFO_hit signal   |
| BIT (Hons) Computer Engineering                                               |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

**Pin name:** bi\_fifo\_counter [2:0]

Pin class: Control

**Path:** FIFO Controller → FIFO

**Description:** 3-bits counter value. This is used to count the data when transferring a whole block (8 words) of data.

**Pin name:** bi\_fifo\_data [284:0]

Pin class: Data

Path: Cache→ FIFO

**Description:** contain index from physical address, tag\_ram, data\_ram and byte\_ram from cache.

**Output pins** 

Pin name: bo\_fifo\_hit

Pin class: Status

**Path:** FIFO Controller  $\rightarrow$  Cache Controller

**Description:** Status Signal that FIFO contain same tag and index with the physical address tag and index.

Pin name: bo\_fifo\_full

Pin class: Status

**Path:** FIFO  $\rightarrow$  Cache Controller and FIFO Controller

**Description:** Status signal that indicate FIFO is full.

Pin name: bo\_fifo\_empty

Pin class: Status

**Path:** FIFO  $\rightarrow$  Cache Controller

**Description:** When asserted, it indicate FIFO is empty.

**Pin name:** bo\_fifo\_mem\_addr[31:0]

Pin class: Address

**Path:** FIFO  $\rightarrow$  Memory Arbiter  $\rightarrow$  SDRAM controller  $\rightarrow$  SDRAM

**Description:** 32-bits address that indicates which location in the SDRAM to be accessed.

Pin name: bo\_fifo\_mem\_data [31:0]

Pin class: Data

BIT (Hons) Computer Engineering

**Path:** FIFO  $\rightarrow$  Memory Arbiter  $\rightarrow$  SDRAM controller  $\rightarrow$  SDRAM

**Description: :** 32-bits data that to be written in to the SDRAM.

Pin name: bo\_fifo\_wb\_data [268:0]

Pin class: Data

**Path:** FIFO  $\rightarrow$  Cache

**Description:** Contain all data that need to write back to cache (data, tag and byte).

Table 6-8-1: FIFO Block I/O Descriptions

# **Chapter 7 Verification**

# 7.1 Test Plan

| Function To be Tested              | Test Case                                                                     |
|------------------------------------|-------------------------------------------------------------------------------|
| Test 1: System Reset               | tb_r_rst is asserted to high at least one clock cycle                         |
| Test 2: Testing Cache priority and | Different load mode configuration with burst                                  |
| reading in different burst length  | length 1, 2, 4 and 8.                                                         |
|                                    | tb_r_BL_sel[3] = 3'd3;//burst length = 8                                      |
|                                    | tb_r_BL_sel[2] = 3'd2; ;//burst length = 4                                    |
|                                    | $tb_r_BL_sel[1] = 3'd1; ;//burst length = 2$                                  |
|                                    | $tb_r_BL_sel[0] = 3'd1; ;//burst length = 2$                                  |
|                                    | $tb_r_cpu_cac_addr3 = 32'h00567000;$                                          |
|                                    | tb_r_cpu_cac_addr2 = 32'h00567000 ;<br>tb_r_cpu_cac_addr1 = 32'h00567000 ;    |
|                                    | $tb_1_cpu_cac_addr1 = 32'h0050'000',$<br>$tb_r_cpu_cac_addr0 = 32'h00567000;$ |
|                                    | 10_1_epu_eae_add10 = 32100307000,                                             |
|                                    | $tb_r_cpu_cac_read3 = 1;$                                                     |
|                                    | $tb_r_cpu_cac_write3 = 0;$                                                    |
|                                    | $tb_r_cpu_cac_read2 = 1;$                                                     |
|                                    | tb_r_cpu_cac_write2 = 0;                                                      |
|                                    | $tb_r_cpu_cac_read1 = 1;$                                                     |
|                                    | tb_r_cpu_cac_write1 = 0;                                                      |
|                                    | $tb_r_cpu_cac_read0 = 1;$                                                     |
|                                    | tb_r_cpu_cac_write0 = 0;                                                      |
| Test 3 : Write Hit in Cache 3 and  | First write instruction,                                                      |
| continuous Write Hit               | tb_r_cpu_cac_data3 = 32'h07070707;                                            |
|                                    | tb_r_cpu_cac_addr3 = 32'h00567004;                                            |
|                                    | tb_r_cpu_cac_read3 = 0;                                                       |
|                                    | tb_r_cpu_cac_write3 = 1;                                                      |
|                                    | Second write instruction,                                                     |
|                                    | tb_r_cpu_cac_data3 = 32'h04404404;                                            |
|                                    | tb_r_cpu_cac_addr3 = 32'h00567000;                                            |
|                                    | tb_r_cpu_cac_read3 = 0;                                                       |
|                                    | tb_r_cpu_cac_write3 = 1;                                                      |
| Test 4: Read Hit in Cache 3 and    | First read instruction,                                                       |
| continuous Read Hit                | tb_r_cpu_cac_data3 = 32'h0;                                                   |
|                                    | $tb_r_cpu_cac_addr3 = 32'h00567004;$                                          |

BIT (Hons) Computer Engineering Faculty of Information and Communication Technology (Perak Campus), UTAR

|                                                               | tb_r_cpu_cac_read3 = 1;<br>tb_r_cpu_cac_write3 = 0;                                                                                                                     |
|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                               | Second read instruction,<br>tb_r_cpu_cac_data3 = 32'h0;<br>tb_r_cpu_cac_addr3 = 32'h00567000;                                                                           |
|                                                               | <pre>tb_r_cpu_cac_read3 = 1;<br/>tb_r_cpu_cac_write3 = 0;</pre>                                                                                                         |
| Test 5: Write Miss with FIFO miss<br>in Cache 3               | First read a data from SDRAM by trying write<br>miss in @89A00 (where valid = 0),<br>tb_r_cpu_cac_data3 = 32'h00B00177;<br>tb_r_cpu_cac_addr3 = 32'h0089A000;           |
|                                                               | tb_r_cpu_cac_read3 = 0;<br>tb_r_cpu_cac_write3 = 1;                                                                                                                     |
|                                                               | Then try to write a data with same index but<br>different tag with @56700, (tag different),<br>tb_r_cpu_cac_data3 = 32'h06070809;<br>tb_r_cpu_cac_addr3 = 32'h00167000; |
|                                                               | tb_r_cpu_cac_read3 = 0;<br>tb_r_cpu_cac_write3 = 1;                                                                                                                     |
|                                                               | with FIFO miss,@56700 data evict to FIFO                                                                                                                                |
| Test 6: Write Miss with FIFO hit in<br>Cache 3                | FIFO hit,@56700 data write back from FIFO<br>tb_r_cpu_cac_data3 = 32'hF1FA0000;<br>tb_r_cpu_cac_addr3 = 32'h00567000;                                                   |
|                                                               | tb_r_cpu_cac_read3 = 0;<br>tb_r_cpu_cac_write3 = 1;                                                                                                                     |
|                                                               | @16700 move to FIFO                                                                                                                                                     |
| Test 7: Auto Write Back to SDRAM<br>in Cache 3 with FIFO busy | Give an instruction that give hit cache for 6 clock cycle                                                                                                               |
| , i i i i i i i i i i i i i i i i i i i                       | $tb_r_cpu_cac_data3 = 32'h0;$                                                                                                                                           |
|                                                               | $tb_r_cpu_cac_addr3 = 32'h00567004;$                                                                                                                                    |
|                                                               | tb_r_cpu_cac_read3 = 1;                                                                                                                                                 |
|                                                               | tb_r_cpu_cac_write3 = 0;                                                                                                                                                |
|                                                               | @16700 move from FIFO to SDRAM                                                                                                                                          |
|                                                               |                                                                                                                                                                         |

|                                     | Then give miss cache instruction, cache          |
|-------------------------------------|--------------------------------------------------|
|                                     | controller wait for FIFO finish writing          |
| Test 8: Read Miss with FIFO miss in | $tb_r_cpu_cac_data3 = 32'h0;$                    |
| Cache 3                             | $tb_r_cpu_cac_addr3 = 32'h00E9A000;$             |
|                                     |                                                  |
|                                     | $tb_r_cpu_cac_read3 = 1;$                        |
|                                     | tb_r_cpu_cac_write3 = 0;                         |
|                                     | _                                                |
|                                     | Data read back from SDRAM,@89A00 move            |
|                                     | to FIFO (same index different tag)               |
| Test 9: Read Miss with FIFO hit in  | $tb_r_cpu_cac_data3 = 32'h0;$                    |
| Cache 3                             | $tb_r_cpu_cac_addr3 = 32'h0089A000;$             |
|                                     |                                                  |
|                                     | $tb_r_cpu_cac_read3 = 1;$                        |
|                                     | $tb_r_cpu_cac_write3 = 0;$                       |
|                                     | to_i_epu_eae_writes = 0,                         |
|                                     | Since previous instruction is read only so dirty |
|                                     | is 0. @E9A00 did not move to FIFO                |
| Test 10: Miss homen and EIEO full   |                                                  |
| Test 10: Miss happen and FIFO full  | //FIFO status: *,*,*,*                           |
|                                     | Try a write miss instruction where valid = $0$ , |
|                                     | $tb_r_cpu_cac_data3 = 32'h26100AAA;$             |
|                                     | $tb_r_cpu_cac_addr3 = 32'h00261000;$             |
|                                     |                                                  |
|                                     | $tb_r_cpu_cac_read3 = 0;$                        |
|                                     | tb_r_cpu_cac_write3 = 1;                         |
|                                     |                                                  |
|                                     | Write miss and @26100 move to FIFO,              |
|                                     | $tb_r_cpu_cac_data3 = 32'h46100BBB;$             |
|                                     | $tb_r_cpu_cac_addr3 = 32'h00461000;$             |
|                                     |                                                  |
|                                     | $tb_r_cpu_cac_read3 = 0;$                        |
|                                     | tb_r_cpu_cac_write3 = 1;                         |
|                                     | //FIFO after this: 26100,*,*,*                   |
|                                     |                                                  |
|                                     | Write miss and @46100 move to FIFO,              |
|                                     | $tb_r_cpu_cac_data3 = 32'h66100CCC;$             |
|                                     | $tb_r_cpu_cac_addr3 = 32'h00661000;$             |
|                                     | -                                                |
|                                     | $tb_r_cpu_cac_read3 = 0;$                        |
|                                     | $tb_r_cpu_cac_write3 = 1;$                       |
|                                     | //FIFO after this: 26100,46100,*,*               |
|                                     | ······································           |
|                                     | Write miss and @66100 move to FIFO,              |
|                                     | $tb_r_cpu_cac_data3 = 32'h86100DDD;$             |
|                                     | $tb_r_cpu_cac_addr3 = 32'h00861000;$             |
|                                     | 10_1_0pu_0u0_uu015 = 52100001000,                |
|                                     |                                                  |

| $tb_r_cpu_cac_read3 = 0;$                  |
|--------------------------------------------|
| tb_r_cpu_cac_write3 = 1;                   |
| //FIFO after this: 26100,46100,66100,*     |
|                                            |
| Write miss and @86100 move to FIFO,        |
| $tb_r_cpu_cac_data3 = 32'hA6100EEE;$       |
| -                                          |
| $tb_r_cpu_cac_addr3 = 32'h00A61000;$       |
|                                            |
| $tb_r_cpu_cac_read3 = 0;$                  |
| tb_r_cpu_cac_write3 = 1;                   |
| //FIFO after this: 26100,46100,66100,86100 |
|                                            |
| Write miss and FIFO is full, @ 26100 write |
| back to SDRAM, after that @A6100 move to   |
| FIFO, and cache resumes write operation    |
| tb_r_cpu_cac_data3 = 32'hC6100FFF;         |
| ▲ · · · · · · · · · · · · · · · · · · ·    |
| $tb_r_cpu_cac_addr3 = 32'h00C61000;$       |
|                                            |
| $tb_r_cpu_cac_read3 = 0;$                  |
| tb_r_cpu_cac_write3 = 1;                   |
| //FIFO after this: A6100,46100,66100,86100 |
| and suct and Early Chin Test Dian          |

Table 7-1-1: Memory system Full Chip Test Plan

#### 7.2 Testbench Verilog Code

```
`include ''././util/sdc_macro.v''
`timescale 1ns / 10ps
module tb_cac_ma_sdc();
//CPU to 4 caches
//cache3
wire
      [31:0] tb_w_cpu_cac_data3;
reg
      [31:0] tb_r_cpu_cac_addr3,
             tb_r_cpu_cac_data3;
             tb_r_cpu_cac_read3,
reg
             tb_r_cpu_cac_write3;
//cache2
wire
      [31:0] tb_w_cpu_cac_data2;
reg
      [31:0] tb_r_cpu_cac_addr2,
             tb_r_cpu_cac_data2;
             tb_r_cpu_cac_read2,
reg
             tb_r_cpu_cac_write2;
//cache1
wire
      [31:0] tb_w_cpu_cac_data1;
      [31:0] tb_r_cpu_cac_addr1,
reg
             tb_r_cpu_cac_data1;
             tb_r_cpu_cac_read1,
reg
             tb_r_cpu_cac_write1;
//cache0
wire
      [31:0] tb_w_cpu_cac_data0;
      [31:0] tb_r_cpu_cac_addr0,
reg
             tb_r_cpu_cac_data0;
             tb_r_cpu_cac_read0,
reg
             tb_r_cpu_cac_write0;
             tb_r_clk;
reg
             tb_r_rst;
reg
//between caches and memory arbiter
//4 caches
//cache3
wire
              w_ma_cac_read3,
              w_ma_cac_write3,
              w_data_ready3,
              w_ma_cac_miss3;
wire
      [3:0]
             w_ma_cac_sel3;
wire
      [31:0] w_ma_cac_addr3,
              w_ma_cac_o_data3;
```

[31:0] r\_ma\_cac\_lmc\_data3;

w ma cac complete3;

reg

wire

BIT (Hons) Computer Engineering

| reg                                           | [31:0] | r_ma_cac_i_data3;                 |
|-----------------------------------------------|--------|-----------------------------------|
| wire                                          |        | w_cac_mem_ack3;                   |
| wire                                          |        | w_cac_mem_lmc_same3;              |
| //cach                                        | e2     |                                   |
| wire                                          |        | w_ma_cac_read2,                   |
|                                               |        | w_ma_cac_write2,                  |
|                                               |        | w_data_ready2,                    |
|                                               |        | w_ma_cac_miss2;                   |
| wire                                          | [3:0]  | w_ma_cac_sel2;<br>w_ma_cac_addr2, |
| wire                                          | [31:0] | w_ma_cac_addr2,                   |
|                                               |        | w_ma_cac_o_data2;                 |
| reg                                           | [31:0] | r_ma_cac_lmc_data2;               |
| wire                                          |        | w_ma_cac_complete2;               |
| reg                                           | [31:0] | r_ma_cac_i_data2;                 |
| wire                                          |        | w_cac_mem_ack2;                   |
| wire                                          |        | w_cac_mem_lmc_same2;              |
| //cache1                                      |        |                                   |
| wire                                          |        | w_ma_cac_read1,                   |
|                                               |        | w_ma_cac_write1,                  |
|                                               |        | w_data_ready1,                    |
|                                               |        | w_ma_cac_miss1;                   |
| wire                                          | [3:0]  | w_ma_cac_sel1;                    |
| wire                                          | [31:0] | w_ma_cac_addr1,                   |
|                                               |        | w_ma_cac_o_data1;                 |
| reg                                           | [31:0] | r_ma_cac_lmc_data1;               |
| wire                                          |        | w_ma_cac_complete1;               |
| reg                                           | [31:0] | r_ma_cac_i_data1;                 |
| wire                                          |        | w_cac_mem_ack1;                   |
| wire                                          |        | w_cac_mem_lmc_same1;              |
| //cache0                                      |        |                                   |
| wire                                          |        | w_ma_cac_read0,                   |
|                                               |        | w_ma_cac_write0,                  |
|                                               |        | w_data_ready0,                    |
|                                               |        | w_ma_cac_miss0;                   |
| wire                                          | [3:0]  | w_ma_cac_sel0;                    |
| wire                                          | [31:0] | w_ma_cac_addr0,                   |
|                                               |        | w_ma_cac_o_data0;                 |
| reg                                           | [31:0] | r_ma_cac_lmc_data0;               |
| wire                                          |        | w_ma_cac_complete0;               |
| reg                                           | [31:0] | r_ma_cac_i_data0;                 |
| wire                                          |        | w_cac_mem_ack0;                   |
| wire                                          |        | w_cac_mem_lmc_same0;              |
| //between memory arbiter and sdram controller |        |                                   |
| wire w me sde hest ld mede                    |        |                                   |

wire w\_ma\_sdc\_host\_ld\_mode, w\_ma\_sdc\_read,

w\_ma\_sdc\_write; wire [3:0] w\_ma\_sdc\_sel; wire [31:0] w\_ma\_sdc\_addr, w\_ma\_sdc\_i\_data, w\_ma\_sdc\_o\_data; wire w\_ma\_sdc\_ack; //between sdram controller and sdram [31:0] w\_sc\_sdc\_dq; wire wire [11:0] w\_sc\_sdc\_addr; wire [1:0] w\_sc\_sdc\_ba; wire w\_sc\_sdc\_cs\_n; wire w\_sc\_sdc\_ras\_n; wire w\_sc\_sdc\_cas\_n; wire w\_sc\_sdc\_we\_n; wire [3:0] w\_sc\_sdc\_dqm; //Change burst length of caches to test different mode configuration [2:0] tb\_r\_BL\_sel[0:3]; reg wire [31:0] w\_i\_data3, w i data2, w\_i\_data1, w\_i\_data0; //indicates current test status in waveform reg [300:0] status; //To generate ASCII value in the waveform to ease debugging bfm\_wave\_monitor bfm\_monitor(); u cache cache 3 (//memory arbiter connection .uo\_cac\_mem\_addr(w\_ma\_cac\_addr3), .uo\_cac\_mem\_data(w\_i\_data3), .uo\_cac\_mem\_lmc\_data(), .uo\_cac\_miss(w\_ma\_cac\_miss3), .uo\_cac\_mem\_read(w\_ma\_cac\_read3), .uo\_cac\_mem\_write(w\_ma\_cac\_write3), .uo\_cac\_mem\_data\_ready(w\_data\_ready3), .uo\_cac\_mem\_sel(w\_ma\_cac\_sel3), .uo\_cac\_mem\_complete(w\_ma\_cac\_complete3), .ui\_cac\_mem\_data(w\_ma\_cac\_o\_data3), .ui\_cac\_mem\_ack(w\_cac\_mem\_ack3), .ui\_cac\_mem\_lmc\_same(w\_cac\_mem\_lmc\_same3), // CPU connection .uo\_cac\_cpu\_stall(),

BIT (Hons) Computer Engineering

.uo\_cac\_cpu\_data(tb\_w\_cpu\_cac\_data3), .ui\_cac\_cpu\_addr(tb\_r\_cpu\_cac\_addr3), .ui\_cac\_cpu\_data(tb\_r\_cpu\_cac\_addr3), .ui\_cac\_cpu\_read(tb\_r\_cpu\_cac\_read3), .ui\_cac\_cpu\_write(tb\_r\_cpu\_cac\_write3), .ui\_cac\_rst(tb\_r\_rst), .ui\_cac\_clk(tb\_r\_clk));

u\_cache cache\_2 (//memory arbiter connection .uo\_cac\_mem\_addr(w\_ma\_cac\_addr2), .uo\_cac\_mem\_data(w\_i\_data2), .uo\_cac\_mem\_lmc\_data(), .uo\_cac\_miss(w\_ma\_cac\_miss2), .uo\_cac\_mem\_read(w\_ma\_cac\_read2), .uo\_cac\_mem\_write(w\_ma\_cac\_write2), .uo\_cac\_mem\_data\_ready(w\_data\_ready2), .uo\_cac\_mem\_sel(w\_ma\_cac\_sel2), .uo\_cac\_mem\_complete(w\_ma\_cac\_complete2), .ui\_cac\_mem\_data(w\_ma\_cac\_o\_data2), .ui cac mem ack(w cac mem ack2), .ui\_cac\_mem\_lmc\_same(w\_cac\_mem\_lmc\_same2), // CPU connection .uo\_cac\_cpu\_stall(), .uo\_cac\_cpu\_data(tb\_w\_cpu\_cac\_data2), .ui\_cac\_cpu\_addr(tb\_r\_cpu\_cac\_addr2), .ui\_cac\_cpu\_data(tb\_r\_cpu\_cac\_data2), .ui\_cac\_cpu\_read(tb\_r\_cpu\_cac\_read2), .ui\_cac\_cpu\_write(tb\_r\_cpu\_cac\_write2), .ui\_cac\_rst(tb\_r\_rst), .ui\_cac\_clk(tb\_r\_clk));

u\_cache cache\_1
(//memory arbiter connection
.uo\_cac\_mem\_addr(w\_ma\_cac\_addr1),
.uo\_cac\_mem\_data(w\_i\_data1),
.uo\_cac\_mem\_lmc\_data(),
.uo\_cac\_mem\_lmc\_data(),
.uo\_cac\_mem\_read(w\_ma\_cac\_read1),
.uo\_cac\_mem\_read(w\_ma\_cac\_write1),
.uo\_cac\_mem\_data\_ready(w\_data\_ready1),
.uo\_cac\_mem\_sel(w\_ma\_cac\_sel1),
.uo\_cac\_mem\_complete(w\_ma\_cac\_complete1),
.ui\_cac\_mem\_data(w\_ma\_cac\_o\_data1),
.ui\_cac\_mem\_ack(w\_cac\_mem\_ack1),
.ui\_cac\_mem\_lmc\_same(w\_cac\_mem\_lmc\_same1),

```
// CPU connection
.uo_cac_cpu_stall(),
.uo_cac_cpu_data(tb_w_cpu_cac_data1),
.ui_cac_cpu_addr(tb_r_cpu_cac_addr1),
.ui_cac_cpu_data(tb_r_cpu_cac_data1),
.ui_cac_cpu_read(tb_r_cpu_cac_read1),
.ui_cac_rst(tb_r_rst),
.ui_cac_rst(tb_r_clk));
```

```
u_cache cache_0
```

(//memory arbiter connection .uo\_cac\_mem\_addr(w\_ma\_cac\_addr0), .uo\_cac\_mem\_data(w\_i\_data0), .uo\_cac\_mem\_lmc\_data(), .uo\_cac\_miss(w\_ma\_cac\_miss0), .uo cac mem read(w ma cac read0), .uo\_cac\_mem\_write(w\_ma\_cac\_write0), .uo\_cac\_mem\_data\_ready(w\_data\_ready0), .uo\_cac\_mem\_sel(w\_ma\_cac\_sel0), .uo cac mem complete(w ma cac complete0), .ui\_cac\_mem\_data(w\_ma\_cac\_o\_data0), .ui\_cac\_mem\_ack(w\_cac\_mem\_ack0), .ui\_cac\_mem\_lmc\_same(w\_cac\_mem\_lmc\_same0), // CPU connection .uo\_cac\_cpu\_stall(), .uo\_cac\_cpu\_data(tb\_w\_cpu\_cac\_data0), .ui\_cac\_cpu\_addr(tb\_r\_cpu\_cac\_addr0), .ui\_cac\_cpu\_data(tb\_r\_cpu\_cac\_data0), .ui\_cac\_cpu\_read(tb\_r\_cpu\_cac\_read0), .ui\_cac\_cpu\_write(tb\_r\_cpu\_cac\_write0), .ui\_cac\_rst(tb\_r\_rst), .ui\_cac\_clk(tb\_r\_clk));

```
u_mem_arbiter mem_arbiter
(//caches connection
//cache3
.ui_ma_cac_miss3(w_ma_cac_miss3),
.ui_ma_cac_data_ready3(w_data_ready3),
.ui_ma_cac_read3(w_ma_cac_read3),
.ui_ma_cac_write3(w_ma_cac_write3),
.ui_ma_cac_sel3(w_ma_cac_sel3),
.ui_ma_cac_addr3(w_ma_cac_addr3),
.ui_ma_cac_data3(w_i_data3),
.ui_ma_cac_lmc_data3(r_ma_cac_lmc_data3),
.ui_ma_cac_complete3(w_ma_cac_complete3),
```

.uo\_ma\_cac\_ack3(w\_cac\_mem\_ack3), .uo\_ma\_cac\_lmc\_same3(w\_cac\_mem\_lmc\_same3), .uo\_ma\_cac\_data3(w\_ma\_cac\_o\_data3), //cache2 .ui\_ma\_cac\_miss2(w\_ma\_cac\_miss2), .ui\_ma\_cac\_data\_ready2(w\_data\_ready2), .ui ma cac read2(w ma cac read2), .ui ma cac write2(w ma cac write2), .ui\_ma\_cac\_sel2(w\_ma\_cac\_sel2), .ui\_ma\_cac\_addr2(w\_ma\_cac\_addr2), .ui\_ma\_cac\_data2(w\_i\_data2), .ui\_ma\_cac\_lmc\_data2(r\_ma\_cac\_lmc\_data2), .ui\_ma\_cac\_complete2(w\_ma\_cac\_complete2), .uo\_ma\_cac\_ack2(w\_cac\_mem\_ack2), .uo\_ma\_cac\_lmc\_same2(w\_cac\_mem\_lmc\_same2), .uo\_ma\_cac\_data2(w\_ma\_cac\_o\_data2), //cache1 .ui\_ma\_cac\_miss1(w\_ma\_cac\_miss1), .ui\_ma\_cac\_data\_ready1(w\_data\_ready1), .ui\_ma\_cac\_read1(w\_ma\_cac\_read1), .ui ma cac write1(w ma cac write1), .ui\_ma\_cac\_sel1(w\_ma\_cac\_sel1), .ui\_ma\_cac\_addr1(w\_ma\_cac\_addr1), .ui\_ma\_cac\_data1(w\_i\_data1), .ui\_ma\_cac\_lmc\_data1(r\_ma\_cac\_lmc\_data1), .ui\_ma\_cac\_complete1(w\_ma\_cac\_complete1), .uo\_ma\_cac\_ack1(w\_cac\_mem\_ack1), .uo\_ma\_cac\_lmc\_same1(w\_cac\_mem\_lmc\_same1), .uo\_ma\_cac\_data1(w\_ma\_cac\_o\_data1), //cache0 .ui ma cac miss0(w ma cac miss0), .ui\_ma\_cac\_data\_ready0(w\_data\_ready0), .ui\_ma\_cac\_read0(w\_ma\_cac\_read0), .ui\_ma\_cac\_write0(w\_ma\_cac\_write0), .ui\_ma\_cac\_sel0(w\_ma\_cac\_sel0), .ui\_ma\_cac\_addr0(w\_ma\_cac\_addr0), .ui\_ma\_cac\_data0(w\_i\_data0), .ui\_ma\_cac\_lmc\_data0(r\_ma\_cac\_lmc\_data0), .ui\_ma\_cac\_complete0(w\_ma\_cac\_complete0), .uo\_ma\_cac\_ack0(w\_cac\_mem\_ack0), .uo\_ma\_cac\_lmc\_same0(w\_cac\_mem\_lmc\_same0), .uo ma cac data0(w ma cac o data0), //sdram controller connection

.ui\_ma\_sdc\_ack(w\_ma\_sdc\_ack), .ui\_ma\_sdc\_data(w\_ma\_sdc\_i\_data),

```
.uo_ma_sdc_read(w_ma_sdc_read),
.uo_ma_sdc_write(w_ma_sdc_write),
.uo_ma_sdc_host_ld_mode(w_ma_sdc_host_ld_mode),
.uo_ma_sdc_sel(w_ma_sdc_sel),
.uo_ma_sdc_addr(w_ma_sdc_addr),
.uo_ma_sdc_data(w_ma_sdc_o_data),
.ui_ma_clk(tb_r_clk),
.ui_ma_rst(tb_r_rst));
```

u\_sdram\_controller u\_sdram\_controller (.ui\_sdc\_clk(tb\_r\_clk), .ui\_sdc\_rst(tb\_r\_rst), //memory arbiter connection .ui\_host\_ld\_mode(w\_ma\_sdc\_host\_ld\_mode), .ui\_sdc\_read(w\_ma\_sdc\_read), .ui\_sdc\_write(w\_ma\_sdc\_write), .ui sdc sel(w ma sdc sel), .ui\_sdc\_addr(w\_ma\_sdc\_addr), .ui\_sdc\_dat(w\_ma\_sdc\_o\_data), .uo\_sdc\_dat(w\_ma\_sdc\_i\_data), .uo\_sdc\_ack(w\_ma\_sdc\_ack), //sdram connection .uio\_sdc\_dq(w\_sc\_sdc\_dq), .uo\_sdc\_ba(w\_sc\_sdc\_ba), .uo\_sdc\_dqm(w\_sc\_sdc\_dqm), .uo\_sdc\_addr(w\_sc\_sdc\_addr), .uo\_sdc\_cs\_n(w\_sc\_sdc\_cs\_n), .uo\_sdc\_ras\_n(w\_sc\_sdc\_ras\_n), .uo\_sdc\_cas\_n(w\_sc\_sdc\_cas\_n), .uo\_sdc\_we\_n(w\_sc\_sdc\_we\_n) );

#### //MICRON SDRAM Instantiation

mt48lc4m32b2 sdram( .Dq(w\_sc\_sdc\_dq), .Addr(w\_sc\_sdc\_addr), .Ba(w\_sc\_sdc\_ba), .Clk(tb\_r\_clk), .Cke(1'b1), //cke always activated .Cs\_n(w\_sc\_sdc\_cs\_n), .Ras\_n(w\_sc\_sdc\_cas\_n), .Cas\_n(w\_sc\_sdc\_cas\_n), .We\_n(w\_sc\_sdc\_we\_n), .Dqm(w\_sc\_sdc\_dqm));

//initialize clock signal
initial tb\_r\_clk = 1;

```
always #10 tb_r_clk = ~tb_r_clk;
```

always@\* begin r\_ma\_cac\_lmc\_data3 = {29'h4,tb\_r\_BL\_sel[3]}; r\_ma\_cac\_lmc\_data2 = {29'h4,tb\_r\_BL\_sel[2]}; r\_ma\_cac\_lmc\_data1 = {29'h4,tb\_r\_BL\_sel[1]}; r\_ma\_cac\_lmc\_data0 = {29'h4,tb\_r\_BL\_sel[0]}; end

```
initial begin
```

```
//~~~~~~~
//Signals initialization
status = "Signals initialization";
 tb_r_cpu_cac_addr3
                    = 32'b0;
 tb_r_cpu_cac_data3
                    = 32'b0;
 tb_r_cpu_cac_write3 = 1'b0;
 tb_r_cpu_cac_read3
                    = 1'b0;
 tb_r_cpu_cac_addr2
                    = 32'b0;
                    = 32'b0;
 tb r cpu cac data2
 tb_r_cpu_cac_write2 = 1'b0;
 tb_r_cpu_cac_read2
                    = 1'b0;
 tb_r_cpu_cac_addr1
                    = 32'b0;
 tb_r_cpu_cac_data1
                    = 32'b0;
 tb_r_cpu_cac_write1 = 1'b0;
 tb_r_cpu_cac_read1
                    = 1'b0;
 tb_r_cpu_cac_addr0
                    = 32'b0;
                    = 32'b0;
 tb_r_cpu_cac_data0
 tb_r_cpu_cac_write0
                    = 1'b0;
 tb_r_cpu_cac_read0
                    = 1'b0;
 tb_r_rst
                       = 0;
 repeat(2) @(posedge tb_r_clk);
//Test 1: System Reset
status = "System Reset";
 tb_r_rst = 1;
 repeat(1) @(posedge tb_r_clk);
 tb_r_rst = 0;
```

repeat(20) @(posedge tb\_r\_clk);

```
$readmemh("rtl/micron SDRAM/sdram_bank0_data.txt", sdram.Bank0);
status = "Read data (Cache3->Cache2->Cache1->Cache0)";
     //select brust length 0,1,2,3 = 1,2,4,8
     tb r BL sel[3] = 3'd3;
     tb r BL sel[2] = 3'd2;
     tb_r_BL_sel[1] = 3'd1;
     tb_r_BL_sel[0] = 3'd1;
// Test 2: Testing Cache priority and reading in different burst length
// All 4 cache read misses in same clock cycle
 tb r cpu cac data3 = 0;
 tb r cpu cac data2 = 0;
 tb_r_cpu_cac_data1 = 0;
 tb_r_cpu_cac_data0 = 0;
 tb_r_cpu_cac_addr3 = 32'h00567000;
 tb_r_cpu_cac_addr2 = 32'h00567000;
 tb_r_cpu_cac_addr1 = 32'h00567000;
 tb_r_cpu_cac_addr0 = 32'h00567000 ;
 tb_r_cpu_cac_read3 = 1;
 tb r cpu cac write3 = 0;
 tb_r_cpu_cac_read2 = 1;
 tb_r_cpu_cac_write2 = 0;
 tb_r_cpu_cac_read1 = 1;
 tb_r_cpu_cac_write1 = 0;
 tb_r_cpu_cac_read0 = 1;
 tb_r_cpu_cac_write0 = 0;
 @(posedge tb r clk);
 // Expecting cache misses
 // Wait until they are done
```

```
while(w_ma_cac_miss3||w_ma_cac_miss2||w_ma_cac_miss1||w_ma_cac_miss0
||w_data_ready3||w_data_ready2||w_data_ready1||w_data_ready0)
@(posedge tb_r_clk);
```

```
status = "Write Hit";
 tb_r_cpu_cac_data3 = 32'h07070707;
 tb r cpu cac addr3 = 32'h00567004;
 tb_r_cpu_cac_read3 = 0;
 tb_r_cpu_cac_write3 = 1;
 @(posedge tb_r_clk);
 status = "Write Hit";
 tb_r_cpu_cac_data3 = 32'h04404404;
 tb_r_cpu_cac_addr3 = 32'h00567000;
 tb r cpu cac read3 = 0;
 tb_r_cpu_cac_write3 = 1;
 /*@56700
  0440 4404
  0707_0707
  24A6_0004
  0004_1080
  00C2 3021
  0020_0900
  0100_0750
  3402_000A*/
```

```
@(posedge tb_r_clk);
```

```
//Test 4: Read Hit in Cache 3
```

```
tb_r_cpu_cac_read3 = 1;
tb_r_cpu_cac_write3 = 0;
```

```
//Test 5: Write Miss with FIFO miss in Cache 3
@(posedge tb r clk);
 status = "Write Miss"; // with dirty = 0; after write dirty = 1;
 tb_r_cpu_cac_data3 = 32'h00B00177;
 tb_r_cpu_cac_addr3 = 32'h0089A000;
 tb_r_cpu_cac_read3 = 0;
 tb_r_cpu_cac_write3 = 1;
 /*@89A00
  00B0 0177
  1234 ABCD
  5678_7654
  3456 789A
  9876_3210
  FAFA_FAFA
  BEEF_BEEF
  DEAD_DEAD*/
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
 status = "Check";
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h0089A000;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb_r_clk);
 status = "Write Miss"; // dirty =1; with FIFO miss,@56700 data erect to FIFO
 tb_r_cpu_cac_data3 = 32'h06070809;
 tb_r_cpu_cac_addr3 = 32'h00167000; //same index different tag (@56700)
 tb_r_cpu_cac_read3 = 0;
 tb_r_cpu_cac_write3 = 1;
 /*@16700
  0607 0809
  5201_314B
```

BIT (Hons) Computer Engineering

Faculty of Information and Communication Technology (Perak Campus), UTAR

```
5201_314C
5201_314D
5201_314E
5201_314F
5201_314F
5201_3140
5201_315A
5201_315B */
```

@(posedge tb\_r\_clk); while(w\_ma\_cac\_miss3)@(posedge tb\_r\_clk);

```
status = "Check";
tb_r_cpu_cac_data3 = 32'h0;
tb_r_cpu_cac_addr3 = 32'h00167000;
```

```
tb_r_cpu_cac_read3 = 1;
tb_r_cpu_cac_write3 = 0;
@(posedge tb_r_clk);
```

```
//Test 6: Write Miss with FIFO hit in Cache 3
status = "Write Miss"; //with FIFO hit,@56700 data write back from FIFO
 tb_r_cpu_cac_data3 = 32'hF1FA0000;
 tb_r_cpu_cac_addr3 = 32'h00567000; // @16700 move to FIFO
 tb_r_cpu_cac_read3 = 0;
 tb_r_cpu_cac_write3 = 1;
 /*@56700
  F1FA_0000
  0707_0707
  24A6_0004
  0004_{1080}
  00C2_3021
  0020_0900
  0100_0750
  3402_000A*/
```

```
@(posedge tb_r_clk);
while(w_ma_cac_miss3)@(posedge tb_r_clk);
```

```
status = "Check";
tb_r_cpu_cac_data3 = 32'h0;
tb_r_cpu_cac_addr3 = 32'h00567000;
```

tb\_r\_cpu\_cac\_read3 = 1; tb\_r\_cpu\_cac\_write3 = 0;

```
//Test 7: Auto Write Back to SDRAM in Cache 3 with FIFO busy
@(posedge tb_r_clk);
 status = "FIFO WB to SDRAM"; //(@16700 move from FIFO to SDRAM)
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h00567004;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb r clk);
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h00567008;
 tb r cpu cac read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb_r_clk);
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h0056700C;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb_r_clk);
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h00567010;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb_r_clk);
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h00567014;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
  @(posedge tb_r_clk);
 tb_r_cpu_cac_data3 = 32'h0;
```

```
tb_r_cpu_cac_addr3 = 32'h00567018;
```

tb\_r\_cpu\_cac\_read3 = 1; tb\_r\_cpu\_cac\_write3 = 0;

@(posedge tb\_r\_clk); tb\_r\_cpu\_cac\_data3 = 32'h0; tb\_r\_cpu\_cac\_addr3 = 32'h0056701C;

tb\_r\_cpu\_cac\_read3 = 1; tb\_r\_cpu\_cac\_write3 = 0;

```
@(posedge tb_r_clk);
```

//Test 8: Read Miss with FIFO miss in Cache 3

```
status = "Read Miss"; //data read back from SDRAM,@89A00 move to FIFO
 tb_r_cpu_cac_data3 = 32'h0;
 tb r cpu cac addr3 = 32'h00E9A000;
 tb_r_cpu_cac_read3 = 1;
 tb_r_cpu_cac_write3 = 0;
 /*@89A00
          @E9A00
  1234_ABCD 5555_5555
  5678_7654 7777_7777
  3456 789A FFFF FFFF
  9876 3210
         1212 3434
  FAFA FAFA 0000 0001
  BEEF BEEF
            BAD0 ADD8
  DEAD_DEAD 2345_5432*/
 @(posedge tb_r_clk);
 while(w_ma_cac_miss3)@(posedge tb_r_clk);
//Test 9: Read Miss with FIFO hit in Cache 3
status = "Read Miss"; //@89A00 move from FIFO to cache
 tb_r_cpu_cac_data3 = 32'h0;
 tb_r_cpu_cac_addr3 = 32'h0089A000;
```

tb\_r\_cpu\_cac\_read3 = 1;

tb\_r\_cpu\_cac\_write3 = 0;

```
@(posedge tb_r_clk);
while(w_ma_cac_miss3)@(posedge tb_r_clk);
```

```
status = "FIFO Full,Write Miss1"; //FIFO status: *,*,*,*
 tb_r_cpu_cac_data3 = 32'h26100AAA;
 tb_r_cpu_cac_addr3 = 32'h00261000;
 tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb r clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
  status = "Write Miss2"; //FIFO after this: 26100,*,*,*
  tb r cpu cac data3 = 32'h46100BBB;
  tb_r_cpu_cac_addr3 = 32'h00461000;
 tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
  status = "Write Miss3"; //FIFO after this: 26100,46100,*,*
  tb_r_cpu_cac_data3 = 32'h66100CCC;
  tb_r_cpu_cac_addr3 = 32'h00661000;
 tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
  status = "Write Miss4"; //FIFO after this: 26100,46100,66100,*
  tb_r_cpu_cac_data3 = 32'h86100DDD;
  tb_r_cpu_cac_addr3 = 32'h00861000;
  tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
 status = "Write Miss5"; //FIFO after this: 26100,46100,66100,86100
```

```
tb_r_cpu_cac_data3 = 32'hA6100EEE;
  tb_r_cpu_cac_addr3 = 32'h00A61000;
  tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk); //@26100 wb to SDRAM
  status = "Write Miss6"; //FIFO after this: A6100,46100,66100,86100
  tb_r_cpu_cac_data3 = 32'hC6100FFF;
  tb_r_cpu_cac_addr3 = 32'h00C61000;
  tb_r_cpu_cac_read3 = 0;
  tb_r_cpu_cac_write3 = 1;
  @(posedge tb_r_clk);
  while(w_ma_cac_miss3)@(posedge tb_r_clk);
  repeat(5) @(posedge tb_r_clk);
 $stop;
end
```

endmodule

### 7.3 Simulation Result

## Test 1 and Test 2 overall Timing Diagram

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1        | mmmm       | փուստու | ຸ່ມພາບບານ | ຸ່ມທານທານທາ  | իստոս      | տփտ      | າທາການ   | իտոտու | ຸ່ມທາກທາກທ  | Խուսուս    | իտոտու | փուտուտ | ຸ່ມທານທານທ        | ໂທນນານນານ | ຸ່ມນານນານປຸ |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------|-----------|--------------|------------|----------|----------|--------|-------------|------------|--------|---------|-------------------|-----------|-------------|
| /tb_cac_ma_sdc/tb_r_rst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0        |            |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Read Hit | System Res | æt 🛛    | data (Cad | e3->Cache2-> | Cache 1->C | ache0)   |          |        |             |            |        |         |                   |           |             |
| A cache_3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          | (cache_3)  |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | READ     | READ WRITE | CACHE   | LOAD      | READ MEM     |            |          | ITE CACH |        |             |            |        |         |                   |           |             |
| 💿 🤙 cache_3/ui_cac_mem_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           | α            |            | 00000000 | 0        |        |             |            |        |         |                   |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | St0      | — <u> </u> |         | r         |              |            |          |          |        |             |            |        |         |                   |           |             |
| 主 🔷 cache_3/uo_cac_cpu_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 07070707 | 00000000   |         |           |              | 8          | fa40000  |          |        |             |            |        |         |                   |           |             |
| tb_r_cpu_cac_addr3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00567004 | 00000000   |         | 00567000  |              |            |          |          |        |             |            |        |         |                   |           |             |
| mem_arbiter/ui_ma_cac_miss3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | St0      |            |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| description of the second s |          | (cache_2)  |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| description: de | READ     | READ WRITE | CACHE   | LOAD M    | DDE          |            |          | READ I   | IEM    | READ W      | RITE CACHE |        |         |                   |           |             |
| 🗉 👍 cache_2/ui_cac_mem_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          | <u> </u> | -0000  | (XX)-000000 | 00         |        |         |                   |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | St0      |            |         |           |              |            |          | Π        |        |             |            |        |         |                   |           |             |
| 💿 🔷 cache_2/uo_cac_cpu_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| 💿 🔷 tb_r_cpu_cac_addr2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00567000 | 00000000   |         | 00567000  |              |            |          |          |        |             |            |        |         |                   |           |             |
| mem_arbiter/ui_ma_cac_miss2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | St0      |            |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| cache_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | (cache_1)  |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| cache_1/b_cache_ctrl/status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | READ     | READ WRITE | CACHE   | LOAD M    | DDE          |            |          |          |        |             | READ ME    | 4      |         | READ WRITE        | CACHE     |             |
| 💿 🧄 cache_1/ui_cac_mem_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          |          |        |             |            | 00-00- |         | 0000000           |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | St0      | <u> </u>   |         |           |              |            |          |          |        |             | Π          | h n    |         | 1                 |           |             |
| 🗉 👆 cache_1/uo_cac_cpu_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| tb_r_cpu_cac_addr1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00567000 | 00000000   |         | 00567000  |              |            |          |          |        |             |            |        |         |                   |           |             |
| mem_arbiter/ui_ma_cac_miss1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | St0      |            |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| 🛛 🔶 cache_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          | (cache 0)  |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
| cache_0/b_cache_ctrl/status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | READ     | READ WRITE | CACHE   | LOAD M    | DDE          |            |          |          |        |             |            |        |         | READ M            | м         | )R          |
| 🛓 🍌 cache_0/ui_cac_mem_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          |          |        |             |            |        |         | $\square -\alpha$ | -00-      | 00-00       |
| cache_0/ui_cac_mem_ack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | St0      | _          |         |           |              |            |          |          |        |             |            |        |         |                   | Lñ        | F. T.       |
| + 👌 cache_0/uo_cac_cpu_data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00000000 | 00000000   |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00567000 | 00000000   |         | 00567000  |              |            |          |          |        |             |            |        |         |                   |           |             |
| mem_arbiter/ui_ma_cac_miss0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SHO      |            |         |           |              |            |          |          |        |             |            |        |         |                   |           |             |

# Test 1: System Reset

Signal Initialization and System Reset

|                                 | 1        | 1              |         |            |    |  | <br> |   |
|---------------------------------|----------|----------------|---------|------------|----|--|------|---|
| ♦ /tb_cac_ma_sdc/tb_r_clk       | 1        |                |         |            |    |  |      |   |
| /tb_cac_ma_sdc/tb_r_rst         | 0        | L              |         |            |    |  |      |   |
| 🖃 🔷 /tb_cac_ma_sdc/status       | Read Hit | Signals initia | ization | System Res | et |  |      |   |
| 🖃 🔶 cache_3                     |          | (cache_3)      |         |            |    |  |      | 1 |
| 🕀 🔷 cache_3/b_cache_ctrl/status | READ     | READ WRI       | E CACHE |            |    |  |      |   |
| 🕁 🧼 cache_3/ui_cac_mem_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| —🌧 cache_3/ui_cac_mem_ack       | St0      |                |         |            |    |  |      |   |
| 🕕 🐟 cache_3/uo_cac_cpu_data     | 07070707 | 00000000       |         |            |    |  |      |   |
| 🕀 🔶 tb_r_cpu_cac_addr3          | 00567004 | 00000000       |         |            |    |  |      |   |
| mem_arbiter/ui_ma_cac_miss3     | St0      | L              |         |            |    |  |      |   |
| 🖃 🔶 cache_2                     |          | (cache_2)      |         |            |    |  |      |   |
| 🗉 🔷 cache_2/b_cache_ctrl/status | READ     | READ WRI       | E CACHE |            |    |  |      |   |
| 🕞 🥠 cache_2/ui_cac_mem_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| cache_2/ui_cac_mem_ack          | St0      |                |         |            |    |  |      |   |
| 🕕 卖 cache_2/uo_cac_cpu_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| 庄 🔷 tb_r_cpu_cac_addr2          | 00567000 | 00000000       |         |            |    |  |      |   |
| mem_arbiter/ui_ma_cac_miss2     | St0      | L              |         |            |    |  |      |   |
| □ 🔶 cache_1                     |          | (cache_1)      |         |            |    |  |      |   |
| 🗉 🔷 cache_1/b_cache_ctrl/status | READ     | READ WRI       | E CACHE |            |    |  |      |   |
| 🕞 🌧 cache_1/ui_cac_mem_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| — cache_1/ui_cac_mem_ack        | St0      |                |         |            |    |  |      |   |
| 且 🔷 cache_1/uo_cac_cpu_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| 🕁 🔶 tb_r_cpu_cac_addr1          | 00567000 | 00000000       |         |            |    |  |      |   |
| mem_arbiter/ui_ma_cac_miss1     | St0      |                |         |            |    |  |      |   |
| —                               |          | (cache_0)      |         |            |    |  |      | 1 |
| 🛓 🔶 cache_0/b_cache_ctrl/status | READ     | READ WRI       | E CACHE |            |    |  |      |   |
| 🕁 🍌 cache_0/ui_cac_mem_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| cache_0/ui_cac_mem_ack          | St0      |                |         |            |    |  |      |   |
| 🕁 💊 cache_0/uo_cac_cpu_data     | 00000000 | 00000000       |         |            |    |  |      |   |
| 🕁 🔷 tb_r_cpu_cac_addr0          | 00567000 | 00000000       |         |            |    |  |      |   |
| 🖕 mem_arbiter/ui_ma_cac_miss0   | St0      |                |         |            |    |  |      |   |
|                                 |          |                |         |            |    |  |      |   |

Test 2: Testing Cache priority and reading in different burst length

Priority is given to cache\_3 to run first according to the priority arrangement in Memory Arbiter. Here SDRAM configuration is burst

length = 8.



/tb\_cac\_ma\_sdc/tb\_r\_clk /tb\_cac\_ma\_sdc/tb\_r\_rst data (Cache3->Cache2->Cache1->Cache0) ache\_3 (cache\_3) + <> cache\_3/b\_cache\_ctrl/status READ WRITE CACHE + 🔶 cache 3/ui cac mem data \_\_\_\_\_\_\_ cache\_3/ui\_cac\_mem\_ack + 👌 cache\_3/uo\_cac\_cpu\_data 8fa40000 0056700 → mem arbiter/ui ma cac miss3 ache\_2 (cache\_2) + cache\_2/b\_cache\_ctrl/status LOAD MODE E... READ MEM RIAD WRITE CACHE 🗄 🍌 cache\_2/ui\_cac\_mem\_data 8f... )27... )24... 00...) 00....)00....)01...)34....) 00000000 cache\_2/ui\_cac\_mem\_ack + 👌 cache\_2/uo\_cac\_cpu\_data 0000000 00567000 👍 mem\_arbiter/ui\_ma\_cac\_miss2 (cache + <> cache\_1/b\_cache\_ctrl/status LOAD MODE RE... READ MEM 主 🤙 cache\_1/ui\_cac\_mem\_data \_\_\_\_\_\_ cache\_1/ui\_cac\_mem\_ack 🕂 👌 cache\_1/uo\_cac\_cpu\_data 0056700 mem\_arbiter/ui\_ma\_cac\_miss1 ache\_0 (cache 0) + 🔶 cache\_0/b\_cache\_ctrl/status LOAD MODE 🗄 🧄 cache\_0/ui\_cac\_mem\_data 0000000 \_\_\_\_\_\_ cache\_0/ui\_cac\_mem\_ack 🛓 🔙 cache\_0/uo\_cac\_cpu\_data 0000000 + tb\_r\_cpu\_cac\_addr0 00567000 mem\_arbiter/ui\_ma\_cac\_miss0 Performing Load Mode Cache\_1 repeat the Performing read burst, length = 4process by performing load mode to SDRAM

Then, priority is given to cache\_2 to run. SDRAM configuration is burst length = 4.

Then, priority is given to cache\_1 to run. SDRAM configuration is burst length = 2.



Then, priority is given to cache\_0 to run. SDRAM configuration is burst length = 2. The configuration same as previous thus SDRAM no need to load mode again.



BIT (Hons) Computer Engineering

Faculty of Information and Communication Technology (Perak Campus), UTAR

Test 3: Write Hit in Cache 3 and continuous Write Hit and

Test 4: Read Hit in Cache 3 and continuous Read Hit



Data had been written into cache in previous test. Thus write hit occur here with same tag and index. Data were written into cache continuously (data become dirty because not updated to SDRAM) and then for next two clock cycle data were read out to uo\_cac\_cpu\_data.



Test 5: Write Miss with FIFO misses in Cache 3







FIFO entries: @16700, \*, \*, \*







Test 8: Read Miss with FIFO misses in Cache 3

FIFO entries: @89A00, \*, \*, \*



Test 9: Read Miss with FIFO hit in Cache 3

FIFO entries: \*, \*, \*, \*



#### Test 10: Miss happen and FIFO full

#### **Chapter 8 Conclusion**

#### **8.1 Conclusion**

Cache unit had successfully redesigned with write-back scheme and write buffer (FIFO) from previous work. With this cache unit, data no longer always need to written back to SDRAM since SDRAM accessing taking 40 to 50 cycles

Now with the new cache unit dirty data able to written back to SDRAM if SDRAM is free while CPU is can do other process. In order to suit in this new ability, a little modification on memory arbiter was made while still keeping the same good feature and functionality of memory arbiter modelled by Chin Chun Lek.

At the end, all the objective of this project is achieved. The cache unit is developed in RTL (Register Transfer Level) form and modeled in synthesizable Verilog. A series of test cases and scenarios has been carried to verified memory system functionality. All the expected results are obtained.

#### **8.2 Discussion and Future Work**

With the newly designed cache unit, data no longer always need to written back to SDRAM. In worst case scenario if a miss happen, cache need to access SDRAM twice by writing the dirty data into SDRAM and read another data from SDRAM. With write-back write buffer (FIFO) it can reduce to only read data from SDRAM since dirty data was written into FIFO. Also, if data found in write buffer (FIFO) data can always write back from write buffer (FIFO) and skip the writing from SDRAM. Now with the new cache unit dirty data in FIFO able to written back to SDRAM if SDRAM is free while CPU is can do other process, thus it increase the efficiency use of clock cycle.

Some modifications need to be done in the future work. One is in SDRAM, the acknowledgement signal had two functions in one signal, it indicates load mode is done and data was ready. It is better in to split in two signals to prevent confusion. Next is implementation of Load Mode Instruction in CPU since now did not have a method to change the configuration mode of SDRAM. This need look into pipeline and cache unit and modified both of them.

## References

- Araújo J.P.(2002) Intelligent RAM's: a Radical Solution? In Proceedings of the 3rd Internal Conference on Computer Architecture, Universidade do Minho http://gec.di.uminho.pt/discip/minf/ac0102/1600IRAM.pdf
- Chin Chun Lek (2015) "32-Bit Memory System Design: Design of Memory Controller for Micron SDR SDRAM" University of Tunku Abdul Rahman, Faculty of Information and Communication Technology
- Ching Yi-lynn (2008) "Memory System Design: Integration of Caches, Translation Lookaside Buffer (TLB) and SDRAM" University of Tunku Abdul Rahman, Faculty of Information and Communication Technology
- Hennessy, J.L. and Patterson, D.A. (2007) *Computer Architecture: A Quantitative Approach*, 4th ed., San Francisco, California: Morgan Kauffmann Publisher
- Micron (n.d) 128Mb x 32 Synchronous DRAM [online] Available at: https://www.micron.com/~/media/documents/products/datasheet/dram/128mb\_x32\_sdram.pdf
- MOK, K. M. (2009) Computer organization and architecture 201210 memory-basic cache design note, University of Tunku Abdul Rahman, Faculty of Information and Communication Technology
- Nick Carter (2002) Schaum's Outline of Theory and Problems of Computer Architecture First Edition, McGraw-Hill Education Publisher
- Oon Zhi Kang (2008) "SDRAM Enhancement: Design of a SDRAM Controller WISHBONE Industrial Standard" University of Tunku Abdul Rahman, Faculty of Information and Communication Technology

Wolf, W.(2004), FPGA-Based System Design, Upper Saddle River, New Jersey: Prentice-Hall

# Appendices

# Appendix A

# System Specification

Chip level design: RISC32 processor

#### A.1 Feature

|                                                         | Basic RISC32              | Full RISC32               |
|---------------------------------------------------------|---------------------------|---------------------------|
| Dummy Instruction Cache (KB)                            | 16                        | 16                        |
| Dummy Data Cache (KB)                                   | 16                        | 16                        |
| Data width (bits)                                       | 32                        | 32                        |
| Instruction width (bits)                                | 32                        | 32                        |
| General Purpose Register                                | 32                        | 32                        |
| Special Purpose Register                                | HILO, PC                  | HILO, PC                  |
| Pipelined Stage                                         | 5                         | 5                         |
| Hazard Handling                                         | No                        | Yes                       |
| Interlock Handling                                      | No                        | Yes                       |
| Data Dependency Forwarding                              | No                        | Yes                       |
| Branch Prediction                                       | Fixed – always<br>invalid | Dynamic – 2bits<br>scheme |
| Multiplication (size of multiplier<br>and multiplicand) | yes – 32bits              | yes – 32 bits             |
| Branch Delay Slot                                       | Not supported             | Not supported             |
| Instruction supported                                   | 38                        | 38                        |

Table A-1 RISC32 features

## A.2 Naming Convention

| Module        | – [lvl]_[mod. name]                                 |
|---------------|-----------------------------------------------------|
| Instantiation | - [lvl]_[abbr. mod. name]                           |
| Pin           | - [lvl] [Type] _[abbr. mod. name] _ [pin name]      |
|               | - [lvl]_[abbr. mod. name]_[Type]_[stage]_[pin name] |

# Abbreviation:

|            | Description | Case      | Available    | Remark                   |
|------------|-------------|-----------|--------------|--------------------------|
| lvl        | level       | lower     | c : Chip     |                          |
|            |             |           | u : Unit     |                          |
|            |             |           | b : Block    |                          |
|            |             |           | tb: Test     |                          |
|            |             |           | Bench        |                          |
| mod. name  | Module      | lower all | any          |                          |
|            | Name        |           |              |                          |
| abbr. mod. | Abbreviated | lower all | any          | maximum 3 characters     |
| name       | module      |           |              |                          |
|            | name        |           |              |                          |
| Туре       | Pin type    | lower     | o : output   |                          |
|            |             |           | i : input    |                          |
|            |             |           | r : register |                          |
|            |             |           | w : wire     |                          |
|            |             |           | f- :function |                          |
| stage      | Stage name  | lower all | if, id, ex,  |                          |
|            |             |           | mem, wb      |                          |
| pin name   | Pin name    | lower all | any          | Several word separate by |

Table A-2 Naming Convention

### A.3 Basic RISC32 processor

#### **A.3.1 Processor Interface**



Figure A.3 Block diagram for RISC32-basic processor

### A.3.2 I/O Pin Description

| Pin Name:                                   | Source $\rightarrow$ Destination:              | Registered:   |  |  |  |
|---------------------------------------------|------------------------------------------------|---------------|--|--|--|
| c_r32_i_reset                               | External Source $\rightarrow$ RISC32 processor | No            |  |  |  |
| Pin Function:                               |                                                |               |  |  |  |
| System reset for the RI                     | SC32 microprocessor. It is synchronous to the  | system clock. |  |  |  |
| Pin Name:                                   | Source $\rightarrow$ Destination:              | Registered:   |  |  |  |
| c_r32_i_clk                                 | External Source $\rightarrow$ RISC32 processor | No            |  |  |  |
| Pin Function:                               |                                                |               |  |  |  |
| System clock for the RISC32 microprocessor. |                                                |               |  |  |  |

Table A-3 Basic RISC32 Input Pins Description

## A.4 System Register

#### A.4.1 General Purpose Register

| Width | : 32-bits  |
|-------|------------|
| Size  | : 32 units |

Retrieving method : 5-bits address as index

| Name        | Address | Use                                                     | Preserved Across A<br>Call? |
|-------------|---------|---------------------------------------------------------|-----------------------------|
| \$zero      | 0       | Constant Value 0                                        | N.A.                        |
| \$at        | 1       | Assembler Temporary                                     | No                          |
| \$v0 - \$v1 | 2 - 3   | Value for Function Results<br>and Expression Evaluation | No                          |
| \$a0 - \$a3 | 4 - 7   | Arguments                                               | No                          |
| \$t0 - \$t7 | 8 - 15  | Temporaries                                             | No                          |
| \$s0 - \$s7 | 16 - 23 | Saved temporaries                                       | Yes                         |
| \$t8 - \$t9 | 24 - 25 | Temporaries                                             | No                          |
| \$k0 - \$k1 | 26 - 27 | Reserved for OS kernel                                  | No                          |
| \$gp        | 28      | Global Pointer                                          | Yes                         |
| \$sp        | 29      | Stack Pointer                                           | Yes                         |
| \$fp        | 30      | Frame Pointer                                           | Yes                         |
| \$ra        | 31      | Return Address                                          | Yes                         |

Table A-4-1 Register file

### A.4.2 Special Purpose Register

| Width | : 32-bits |
|-------|-----------|
| Size  | : 2-units |

Retrieving method : access using MFHI, MTHI, MFLO, MTLO, MULT and

| Name | definition                | location in double<br>[64:0] |
|------|---------------------------|------------------------------|
| HI   | Most Significant<br>Word  | Double [63:32]               |
| LO   | Least Significant<br>Word | Double [31:0]                |

MULTU instructions

Table A-4-2 HILO Register

### A.4.3 Program Counter Register

Width : 32-bits

Size : 1 unit

Retrieving method : Control by instruction address generator control

## **A.5 Instruction Format**

| R-type (Regi | ster)         |            |              |              |             |
|--------------|---------------|------------|--------------|--------------|-------------|
| Op [31:26]   | Rs [25:21]    | Rt [20:16] | Rd [15:11]   | Shamt [10:6] | Funct [5:0] |
| I-type (Imme | diate)        |            |              |              |             |
| Op [31:26]   | Rs [25:21]    | Rt [20:16] | Immediate [1 | 5:0]         |             |
| J-type (Jump | )             |            |              |              |             |
| Op [31:26]   | Target [25:0] |            |              |              |             |

Table A-5 Instruction Type

# Abbreviation:

|           | Definition                                             | width |
|-----------|--------------------------------------------------------|-------|
| op        | Operation code (instruction)                           | 6     |
| rs        | Source register                                        | 5     |
| rt        | Target(source/destination) or branch                   | 5     |
| immediate | Immediate, branch displacement or address displacement | 16    |
| target    | Jump target address                                    | 26    |
| rd        | Destination register                                   | 5     |
| shamt     | Shift amount                                           | 5     |
| funct     | Function field                                         | 6     |

## A.6 Addressing Mode

| 8      |          |         |              |                    |
|--------|----------|---------|--------------|--------------------|
| 1 Imme | ediate / | Addres  | sing         |                    |
| ор     | rs       | rt      | Immediate    |                    |
| 2 Reai | ster Ar  | dressi  | na           |                    |
| op     | rs       | rt      | rc funct     | Decision           |
| οp     | 15       |         |              | Registers          |
|        |          |         |              | Register           |
| 3 Base | e Addr   | essing  |              |                    |
| ор     | rs       | rt      | Address      |                    |
|        |          |         |              |                    |
|        |          |         | (+)          | Byte Halfworc Word |
|        |          | Registe | ar .         |                    |
|        |          | Regist  | 51           |                    |
|        |          |         |              |                    |
| 4 PC-r | elative  | Addre   | ssing        |                    |
| ор     | rs       | rt      | Address      |                    |
|        |          |         |              |                    |
|        |          |         | (+)          | Word               |
|        |          |         |              |                    |
|        |          | PC      |              | L                  |
|        |          |         |              |                    |
| 5 Pseu | dodire   | ct Addi | ressina      |                    |
| ор     |          | Add     |              |                    |
| -1-    |          |         |              |                    |
|        |          |         | (:)          | Word               |
|        |          |         | $\checkmark$ |                    |
|        |          |         |              |                    |
|        |          | PC      |              |                    |

Figure A-6 RISC32 Addressing Mode.

- 1. Immediate Addressing, where operand is constant within the instruction itself
- 2. Register Addressing, where operand is a register

3. *Based Displacement Addressing*, where operand is at the memory location whose address is the sum of a register and a constant in the instruction

4. *PC-relative Addressing*, where branch address s the sum of the PC and a constant in the instruction

5. *Pseudodirect Addressing*, where the jump address is the 26-bits of the instruction concatenated with the upper bits of the PC.

| A.7 | Instruction | Set and                                 | Description |
|-----|-------------|-----------------------------------------|-------------|
|     |             | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |             |

| Instruction   | Format | Addr. Mode | Machine    | Lang | uage |      |       |          | Register Transfer Notation   | Assembly                 | Overflow |
|---------------|--------|------------|------------|------|------|------|-------|----------|------------------------------|--------------------------|----------|
| /<br>Assembly |        |            | OpCod<br>e | Rs   | Rt   | Rd   | Shamt | Func     |                              | Format                   |          |
| nop           | R      | Register   | 0x00       | 0    | 0    | 0    | 0     | 0x00     | NOP                          | sll \$zero, \$zero,<br>0 | no       |
| sll           | R      | Register   | 0x00       | 0    | \$rt | \$rd | n     | 0x01     | R[rd] =R[rs] << n            | sll \$rd, \$rt, n        | no       |
| srl           | R      | Register   | 0x00       | 0    | \$rt | \$rd | n     | 0x03     | R[rd] = R[rs] >> n           | srl \$rd, \$rt, n        | no       |
| sra           | R      | Register   | 0x00       | 0    | \$rt | \$rd | n     | 0x04     | R[rd] = R[rs] >>> n          | sra \$rd, \$rt, n        | no       |
| jr            | R      | Register   | 0x00       | \$rs | 0    | 0    | 0     | 0x0<br>A | PC = R[rs]                   | jr \$rs                  | no       |
| jalr          | R      | Register   | 0x00       | \$rs | 0    | 0    | 0     | 0x0<br>B | PC = R[rs]<br>R[31] = PC + 4 | jalr \$rs                | no       |
| mfhi          | R      | Register   | 0x00       | 0    | 0    | \$rd | 0     | 0x10     | R[rd] = HI                   | mfhi \$rd                | no       |
| mthi          | R      | Register   | 0x00       | \$rs | 0    | 0    | 0     | 0x11     | HI = R[rs]                   | mthi \$rs                | no       |
| mflo          | R      | Register   | 0x00       | 0    | 0    | \$rd | 0     | 0x12     | R[rd] = LO                   | mflo \$rd                | no       |
| mtlo          | R      | Register   | 0x00       | \$rs | 0    | 0    | 0     | 0x13     | LO = R[rs]                   | mtlo \$rs                | no       |
| mult          | R      | Register   | 0x00       | \$rs | \$rt | 0    | 0     | 0x24     | HILO = R[rs] * R[rt]         | mult \$rs, \$rt          | no       |
| multu         | R      | Register   | 0x00       | \$rs | \$rt | 0    | 0     | 0x24     | HILO = U(R[rs]) * U(R[rt])   | multu \$rs, \$rt         | no       |
| add           | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x20     | R[rd] = R[rs] + R[rt]        | add \$rd, \$rs, \$rt     | yes      |
| addu          | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x21     | R[rd] = U(R[rs]) + U(R[rt])  | addu \$rd, \$rs,<br>\$rt | no       |
| sub           | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x22     | R[rd] = R[rs] - R[rt]        | sub \$rd, \$rs, \$rt     | yes      |
| subu          | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x23     | R[rd] = U(R[rs]) - U(R[rt])  | subu \$rd, \$rs,<br>\$rt | no       |
| and           | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x24     | R[rd] = R[rs] & R[rt]        | and \$rd, \$rs, \$rt     | no       |
| or            | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x25     | R[rd] = R[rs]   R[rt]        | or \$rd, \$rs, \$rt      | no       |
| xor           | R      | Register   | 0x00       | \$rs | \$rt | \$rd | 0     | 0x26     | $R[rd] = R[rs] \wedge R[rt]$ | xor \$rd, \$rs, \$rt     | no       |

| nor   | R | Register          | 0x00 | \$rs | \$rt            | \$rd                  | 0 | 0x27                                                            | $R[rd] = \sim (R[rs]   R[rt])$                                             | nor \$rd, \$rs, \$rt      | no  |
|-------|---|-------------------|------|------|-----------------|-----------------------|---|-----------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------|-----|
| slt   | R | Register          | 0x00 | \$rs | \$rt            | \$rd                  | 0 | 0x2<br>A                                                        | R[rd] = (R[rs] < R[rt]) ? 1 : 0                                            | slt \$rd, \$rs, \$rt      | no  |
| sltu  | R | Register          | 0x00 | \$rs | \$rt            | \$rd                  | 0 | 0x2<br>B                                                        | R[rd] = (U(R[rs]) < U(R[rt]))?<br>1:0                                      | sltu \$rd, \$rs, \$rt     | no  |
| j     | J | Pseudo-<br>Direct | 0x02 | Jum  | pAddı           | Addr (Label)          |   |                                                                 | PC = {(PC+4) [31:28],<br>JumpAddr, 2'b00}                                  | j label                   | no  |
| jal   | J | Pseudo-<br>Direct | 0x03 | Jum  | ımpAddr (Label) |                       |   | $PC = \{(PC+4) [31:28], \\ JumpAddr, 2'b00\} \\ R[31] = PC + 4$ | jal label                                                                  | no                        |     |
| beq   | I | PC-Relative       | 0x04 | \$rs | \$rt            | BranchAddr<br>(Label) |   |                                                                 | PC = (R[rs] == R[rt]) ? $(PC + 4 +$ $(SE(BranchAddr) << 2)) :$ $(PC + 4)$  | beq \$rs, \$rt,<br>label  | no  |
| bne   | I | PC-Relative       | 0x05 | \$rs | \$rt            | BranchAddr<br>(Label) |   |                                                                 | PC = (R[rs] != R[rt]) ?<br>(PC + 4 +<br>(SE(BranchAddr)<<2)) :<br>(PC + 4) | bne \$rs, \$rt,<br>label  | no  |
| blez  | I | PC-Relative       | 0x06 | \$rs | 0               | BranchAddr<br>(Label) |   |                                                                 | PC = (R[rs] <=0) ?<br>(PC + 4 +<br>(SE(BranchAddr)<<2)):<br>(PC + 4)       | blez \$rs, \$rt,<br>label | no  |
| bgtz  | I | PC-Relative       | 0x07 | \$rs | 0               | BranchAddr<br>(Label) |   |                                                                 | PC = (R[rs] > 0) ?<br>(PC + 4 +<br>(SE(BranchAddr)<<2)):<br>(PC + 4)       | bgtz \$rs, \$rt,<br>label | no  |
| addi  | Ι | Immediate         | 0x08 | \$rs | \$rt            | Imm                   | 1 |                                                                 | R[rt] = R[rs] + SE(Imm)                                                    | addi \$rt, \$rs,<br>imm   | yes |
| addiu | Ι | Immediate         | 0x09 | \$rs | \$rt            | Imm                   | 1 |                                                                 | R[rt] = U(R[rs]) +                                                         | addiu \$rt, \$rs,         | no  |

|       |   |            |      |      |      |     | U(ZE(Imm))                      | imm                 |    |
|-------|---|------------|------|------|------|-----|---------------------------------|---------------------|----|
| slti  | Ι | Immediate  | 0x0A | \$rs | \$rt | Imm | R[rt] = (R[rs] < SE(Imm)) ? 1 : | slti \$rt, \$rs,    | no |
|       |   |            |      |      |      |     | 0                               | imm                 |    |
| sltiu | Ι | Immediate  | 0x0B | \$rs | \$rt | Imm | R[rt] = (U(R[rs]) <             | sltiu \$rt, \$rs,   | no |
|       |   |            |      |      |      |     | U(SE(Imm))) ? 1 : 0             | imm                 |    |
| andi  | Ι | Immediate  | 0x0C | \$rs | \$rt | Imm | R[rt] = R[rs] & ZE(Imm)         | andi \$rt, \$rs,    | no |
|       |   |            |      |      |      |     |                                 | imm                 |    |
| ori   | Ι | Immediate  | 0x0D | \$rs | \$rt | Imm | R[rt] = R[rs]   ZE(Imm)         | ori \$rt, \$rs, imm | no |
| xori  | Ι | Immediate  | 0x0E | \$rs | \$rt | Imm | $R[rt] = R[rs] \wedge ZE(Imm)$  | xori \$rt, \$rs,    | no |
|       |   |            |      |      |      |     |                                 | imm                 |    |
| lui   | Ι | Immediate  | 0x0F | \$rs | \$rt | Imm | R[rt] = Imm << 16               | lui \$rt, imm       | no |
| lw    | Ι | Based-     | 0x23 | \$rs | \$rt | Imm | R[rt] = MEM[R[rs] +             | lw \$rt,            | no |
|       |   | Displaceme |      |      |      |     | SE(Imm)]                        | imm(\$rs)           |    |
|       |   | nt         |      |      |      |     |                                 |                     |    |
| SW    | Ι | Based-     | 0x2B | \$rs | \$rt | Imm | MEM[R[rs] + SE(Imm)] =          | sw \$rt,            | no |
|       |   | Displaceme |      |      |      |     | R[rt]                           | imm(\$rs)           |    |
|       |   | nt         |      |      |      |     |                                 |                     |    |

Table A-7 RISC32 Instruction set

### A.8 Memory Map

| Purpose                                                   | start address  | Direction | Segment |
|-----------------------------------------------------------|----------------|-----------|---------|
| Kernel module                                             | 0xC000<br>0000 | Up        | Kseg2   |
| Boot Rom                                                  |                | Up        |         |
| i/o register(if below 512MB)                              | 0xA000<br>0000 | Up        | Kseg1   |
| Direct view of memory to 512MB linux kernel code and data |                | Up        | Kaago   |
| Exception Entry point                                     | 0x8000<br>0000 | Up        | Kseg0   |
| Stack                                                     | 0x7fff ffff    | Down      |         |
| Program heap                                              | 0x1000<br>8000 | Up        |         |
| Dynamic library code and data                             | 0x1000<br>0000 | Up        | Kuseg   |
| Main program                                              | 0x0040<br>0000 | Up        |         |
| Reserved                                                  | 0x0000<br>0000 | Up        |         |

Table A-8 Memory Map

Memory map description

Kernel module

- Accessible by kernel\*

### Boot Rom

- Start up ROM which keep the system configuration\*

I/O registers (if below 512MB)

- External IO device register\*

Direct view of memory to 512MB linux kernel code and data

\_ \*

Exception Entry point

- Software exception handling \*

Stack

- Use for argument passing

Program heap

- Dynamic memory allocation such as malloc()

Dynamic library code and data

Faculty of Information and Communication Technology (Perak Campus), UTAR

BIT (Hons) Computer Engineering

- Data segment which is access by

Main program

- Text segment which contain the main program

Reserved

Note \*: required CP0



Figure A.8 Memory map for Kuseg section, accessible without CP0

### **A.9 Operating Procedure**

- Start the system
- Porting sequence of instruction into cache (instruction or data)
- Reset the system for at least 2 clocks
- While release the reset, the system will automatically run the program inside instruction cache
- Observe the waveform from the development tools.