**CMPE 315: Principles of VLSI Design**

**Project Cover Page**

**Project Title : Cache Design [ Submission Part 1]**

**Name : Marinna Ricketts-Uy & Ben Thompson**

**Section : 01**

**Date Submitted : April 22, 2018**

**TA / Grader Use Only:**

**Late Submission Deduction (20% per day late):**

**Other Deductions:**

**Final Project Grade:**

**Comments to student:**

**CONTENTS Page#**

**----------------------------------------------------------------------------------------------------------**

**No table of contents entries found.**

**Introduction**

Implemented the two-way associative cache design.

**Design Process**

**Chip Design**

Figure x shows the block diagram for the overall design of the chip.

[Insert Block Diagram]

|  |  |
| --- | --- |
| Inputs | Outputs |
| CPU Address | Busy |
| CPU Data | Memory Enable |
| CPU RD/WR Signal | Memory Address |
| Start |  |
| CLK |  |
| Reset |  |
| Memory Data |  |
| Vdd |  |
| Gnd |  |

**Cache Design**

The cache is designed using the two-way associative cache design. The cache was designed using a hierarchical design. There is a 1-bit cache, 8-bit cache, cache block, and a full cache. There is a left and right cache.

Table x details the input and output signals for each cache.

|  |  |
| --- | --- |
| Inputs | Outputs |
| Reset | Valid Bit Data (vb\_data) |
| Cache Enable Signal (Cache\_en) | Tag Data (tag\_data) |
| Hit/Miss Enable Signal (HM\_en) |  |
| Byte Select (CS) |  |
| Block Select (RS) |  |
| ValidBit/Tag RD/WR Signal (vb\_tag\_rd\_wr) |  |
| RD/WR signal (rd\_wr) |  |
| Valid Bit Data (vb\_data) |  |
| Tag Data (tag\_data) |  |

On a reset, the contents of each cache are zeroed out. The cache enable signal is received from the state machine. The left cache is enabled when this signal is low and the right cache is enabled when the signal goes high. The hit/miss enable signal is used to signify whether the state machine is currently determining whether there is a hit or a miss. When this signal is high, this signifies that both caches must be enabled to check for a hit or miss in both caches. The byte select value is received from the byte offset decoder and is used to select which byte to read or write from. This signal is active low. The block select value is received from the block offset decoder and is used to select which block to read or write from. This signal is active low. The valid and tag rd/wr signal is used to signify whether to read or write to the valid and tag. This signal is being received from the state machine. The rd/wr signal is used to signify whether to read or write to the appropriate byte. The valid bit data and tag data are inputs from the state machine and outputs to the hit/miss entity. The state machine will write this data to the cache when it is performing a read miss operation.

**State Machine Design**

Figure x shows the diagram for the state machine.

[Insert State Machine Diagram]

Table x details the inputs and outputs for the state machine

|  |  |
| --- | --- |
| Inputs | Outputs |
| CLK | Busy |
| Reset | CPU Data Output Enable |
| Start | Memory Address Output Enable |
| Hit/Miss Left | Data Mux Select |
| Hit/Miss Right | Valid Bit / Tag RD/WR |
| RD/WR | Cache RD/WR |
| CPU Address | Hit/Miss Enable Signal |
| LRU | Cache Enable |
|  | LRU RD/WR |
|  | Address |
|  | VB Data Left |
|  | VB Data Right |
|  | Tag Data Left |
|  | Tag Data Right |

When the reset input signal goes high, the state machine starts in the initial state 0. For any of the states, if the reset input signal from the CPU goes high, the state machine will move to state 0. The state machine will remain in this state until the start signal from the CPU goes high. From state 0, if the RD/WR input signal signifies a read operation, the state machine will move to state 1, else the state machine will move to state 7. For a read operation, the state machine will wait to receive the outcome of the hit/miss operation. If the read operation results in a hit, the state machine will move to state 6. If the read operation results in a miss, the state machine will move to state 2. For a write operation, the state machine will wait to receive the outcome of the hit/miss operation. If the write operation results in a hit, the state machine will move to state 8. If the write operation results in a miss, the state machine will move to state 9.

The busy output signal is set during states

**Hit/Miss Design**

Table x details the inputs and outputs for the hit/miss entity.

|  |  |
| --- | --- |
| Inputs | Outputs |
| Valid Data (valid) | Hit\_Miss (h\_m) |
| Tag Data [2:0] (tag) |  |
| CPU Address [7:5] (addr) |  |

Figure x shows the schematic for the hit/miss entity

![](data:image/png;base64,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)

The valid and tag data input for the hit/miss entity is an output from the cache. The CPU address bits and the tag data bits are compared to see whether they match. The output of each xor gate is then an input for an and gate with the valid bit. The hit/miss entity results in a hit when the valid bit is set to 1 and each CPU address bit matches the tag bits.

**Decoder Design**

There is a 2 to 4 decoder for the byte offset and a 3 to 8 decoder for the block offset. The decoders are both active low.

**LRU Design**

For the purpose of block replacement, there is a LRU entity that is used to determine the least recently used block in either of the caches. The LRU value for a block is written to when the state machine is at the end of a read hit/miss operation or a write hit operation. The state machine will read from the LRU entity during a read miss operation to see which cache block to write the new data to.

**Data Mux Design**

The data mux is used to select whether to be using memory data or cpu data. The data mux will be writing out data when

**Entity Architecture Pairs**

|  |  |
| --- | --- |
| **Entity** | **Using the Entity** |
| D\_latch |  |
| reg8 |  |
| oe8 |  |
| mux2to1\_8 |  |
| addr\_sel |  |
|  |  |
|  |  |

**Test Bench & Simulations**

Sample Inputs and Outputs

**Enscripted code**

**Work Break Up Sheet**

|  |  |
| --- | --- |
| **Ben** | **Marinna** |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |