# Direct mapped cache FSM



### Direct Mapped Cache Schematic



check cache

Los Addr in (Tag, Index, Offset)

Los Comp=1

Los Read = write=0

Write=1

Us check hit bit out put from cache

Checkeset dirty bit

Los Addr in (Tag, Index, Offset)



| Cache | IO                   |
|-------|----------------------|
| TAG   | To offset 27 Index ] |

|   |        | レ      |    |   |                                                                                                                                                                                                                                                                                                                                     |
|---|--------|--------|----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F | 15M -0 | enable | In | 1 | Enable cache. Active high. If low, "write" and "comp" have no effect, and all outputs are zero.                                                                                                                                                                                                                                     |
|   |        | index  | In | 8 | The address bits used to index into the cache memory.                                                                                                                                                                                                                                                                               |
|   |        | offset | In | 3 | $offset \cite{New 2.1} selects which word to access in the cache line. The least significant bit should be 0 for word alignment. If the least significant bit is 1, it is an error condition.$                                                                                                                                      |
|   | KSM-to | • comp | In | 1 | Compare. When "comp"-1, the cache will compare tag_in to the tag of the selected line and indicate if a bit has occurred, the data portion of the cache is read or written but writes are suppressed if there is a miss. When "Comp"-0, no compare is done and the Tag and Data portions of the cache will both be read or written. |
|   | FSM -D | write  | In | 1 | Write signal. If high at the rising edge of the clock, a write is performed to the data selected by "index" and "offset", and (if "comp"=0) to the tag selected by "index".                                                                                                                                                         |
|   | 1.     |        |    |   |                                                                                                                                                                                                                                                                                                                                     |

#### Memory Module

|         | Signal      | In/Out | Width | Description                                                                                                 |
|---------|-------------|--------|-------|-------------------------------------------------------------------------------------------------------------|
| FSM -   | Addr        | In     | 16    | Provides the address to perform an operation on.                                                            |
| Caene - | DataIn      | In     | 16    | Data to be used on a write.                                                                                 |
| FSM -   | <b>炒</b> wr | ln     | 1     | When wr="1", the data on Dataln will be written to Mem[Addr] four cycles after wr is asserted.              |
| FSM -   | <b>→</b> rd | In     | 1     | When  rd ``1'', the  DataOut  will  show  the  value  of  Mem[Addr]  two   cycles  after  rd  is  asserted. |
|         | clk         | In     | 1     | Clock signal; rising edge active.                                                                           |
|         | rst         | In     | 1     | Reset signal. When "rst"=1, the memory will load the data from the file "loadfile".                         |
|         | createdump  | In     | 1     | Write contents of memory to file. Each bank will be written to a different file, named dumpfile[0-3].       |



## 2-Way Set Associative Cache FSM



| 1 |  |
|---|--|

| , -     |            |     |    | if a hit has occurred; the data portion of the cache is read or written but writes are suppressed if there is a miss. When "comp" 0, no compare is done and the Tag and Data portions of the cache will both be read or written.                                                                     |
|---------|------------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FSM -D  | write      | In  | 1  | Write signal. If high at the rising edge of the clock, a write is performed to the data selected by "index" and "offset", and (if "comp"+0) to the tag selected by "index".                                                                                                                          |
| FS14-10 | tag_in     | In  | 5  | When "comp"-1, this field is compared against stored tags to see if a hit occurred; when "comp"-0 and "write"-1 this field is written into the tag portion of the array:                                                                                                                             |
| MEM-    | data_in    | In  | 16 | On a write, the data that is to be written to the location specified by the "index" and "offset" inputs.                                                                                                                                                                                             |
| FSM -D  | valid_in   | In  | 1  | On a write when "comp"=0, the data that is to be written to valid bit at the location specified by the "index" input.                                                                                                                                                                                |
|         | clk        | ln  | 1  | Clock signal; rising edge active.                                                                                                                                                                                                                                                                    |
|         | rst        | ln  | 1  | Reset signal. When "rst"=1 on the rising edge of the clock, all lines are marked invalid. (The rest of the cache state is not initialized and may contain $X$ 's.)                                                                                                                                   |
|         | createdump | In  | 1  | Write contents of entire cache to memory file. Active on rising edge.                                                                                                                                                                                                                                |
| FSM A   | hit        | Out | 1  | Goes high during a compare if the tag at the location specified by the "index" lines matches the "tagin" lines.                                                                                                                                                                                      |
| FSM O-  | dirty      | Out | 1  | When this bit is read, it indicates whether this cache line has been written to. It is valid on a read cycle, and also on a compare-write cycle when hit is false. On a write with "comp" $^{*}$ 1, the cache sets the dirty bit to 1. On a write with "comp" $^{*}$ 0, the dirty bit is reset to 0. |
| 4444    | tag_out    | Out | 5  | When "write" -0, the tag selected by "index" appears on this output. (This value is needed during a writeback.)                                                                                                                                                                                      |
| MEM A-  | data_out   | Out | 16 | When "write" = 0, the data selected by "index" and "offset" appears on this output.                                                                                                                                                                                                                  |

|   | FSM -D | rd         | In  | 1  | When $rd = 1^{\circ}$ , the DataOut will show the value of Mem[Addr] two cycles after rd is asserted.                             |
|---|--------|------------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------|
|   |        | clk        | In  | 1  | Clock signal; rising edge active.                                                                                                 |
|   | 45M    | rst        | In  | 1  | Reset signal. When "rst"=1, the memory will load the data from the file "loadfile".                                               |
|   |        | createdump | In  | 1  | Write contents of memory to file. Each bank will be written to a different file, named dumpfile. $[0-3]$ . Active on rising edge. |
|   | Coen & | - DataOut  | Out | 16 | Two cycles after rd*"1", the data at Mem[Addr] will be shown here.                                                                |
|   | FSM d- | stall      | Out | 1  | Is set to high when the operation requested at the input cannot be completed because the required bank is busy.                   |
|   |        | Busy       | Out | 4  | Shows the current status of each bank. High means the bank cannot be accessed.                                                    |
| , |        | err        | Out | 1  | The error signal is raised on an unaligned access.                                                                                |
|   |        |            |     |    |                                                                                                                                   |



Way 1
h
h
m

Write Datiot

way 2

N -D Nope, not possible, error

m } normal hit

h > mist, pick a cache to overwrite

m -> mist, pick a cache to overwrite

-D offset 2 - D offset 3

# 2 way set associative cache Schematic



Write offset offset 1

Memory Module

Addr

D Wr

Stall

Busy

Data-out

Data-out

El

Quick Notes Page

-D Offset 2 15 offset 3