

# MESI\_ISC Specification Draft

Author: Yair Amitay yair.amitay@yahoo.com www.linkedin.com/in/yairamitay

> Rev. 0.11 January 2013



This page has been intentionally left blank.



#### **Revision History**

| Rev. | Date     | Author | Description                                                                          |
|------|----------|--------|--------------------------------------------------------------------------------------|
| 0.10 | 1/3/2013 | Yair   | Draft, Under Construction                                                            |
|      |          | Amitay |                                                                                      |
| 0.11 | 8/3/2012 | Yair   | Stabilized the Coherency Systems chapter.                                            |
|      |          | Amitay | Stabilized the MESI_ISC Coherency Concept                                            |
|      |          |        | chapter.                                                                             |
|      |          |        | Add and improve the Examples Diagrams.<br>Start stabilized the Architecture chapter. |
|      |          |        | start stabilized the Arcintecture enapter.                                           |
| L    |          |        | <u> </u>                                                                             |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        | $\mathbf{O}$                                                                         |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        | <b>Y</b> (),                                                                         |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |
|      |          |        |                                                                                      |

## Contents

| Introduction                                                     |
|------------------------------------------------------------------|
| Coherency Systems                                                |
| MESI Coherency Protocol                                          |
| Project Purpose                                                  |
| MESI_ISC Coherency Concept                                       |
| MESI_ISC Coherency Protocol                                      |
| Coherency operation for a write miss                             |
| Coherency operation for a read miss 11                           |
| Coherency operation for a write to a Shared line                 |
| Examples Diagrams for Coherency Scenarios                        |
| A write miss to a an Invalid location 13                         |
| A write miss to a Modified location in other master's cache      |
| Two parallel write misses to the same location which is Invalid  |
| A write miss and a parallel read miss to two different addresses |
| Architecture                                                     |
| Coherency System Architecture                                    |
| Coherency Operations                                             |
| System Performance and Memory Mapping                            |
| Masters Definition and Requirements (Under Construction)19       |
| Integration MESI_ISC to Existing Systems (Under Construction) 19 |
| MESI_ISC Configuration (Under Construction)                      |
| Clock and Reset (Under Construction)                             |
| Micro Architecture                                               |
| Verification                                                     |
| Verification Environment (Under Construction)                    |
| Validation of Data Consistency                                   |
| Validation of MESI Protocol                                      |
| Random Stimulus                                                  |
| Timing, Power and Area                                           |
| Design Environment                                               |



| (Under Construction) |  |
|----------------------|--|
| Tools                |  |
| Synthesis            |  |
| Simulation           |  |
| Lint                 |  |
| IO Ports             |  |
| Waveforms            |  |
| Open Issues          |  |
|                      |  |

~



## 1 Introduction

# The MESI InterSection Controller (ISC) is a coherence system controller. It supports the MESI coherence protocol. It synchronizes the memory requests of the system masters. It enables to keep the consistency of the data in the memory and in the local caches.

This project provides a synthesizable controller core and it defines the requirements of the system masters.



## **Coherency Systems**

A coherency system is a system in which all the different copies of the same memory address are consistency. It means that if a master writes a certain data to a memory address then any other master that access this address read the update data. One of the cases that an inconsistency can occur is when the system masters have memory caches. If a data copy in the cache is not update according to the least written data the master that own this cache may read the wrong data.

A system is coherent if it obeys the all following rules:

#### Rule 1

| Time          | Maste<br>r | Address | Write Data | Read Data |
|---------------|------------|---------|------------|-----------|
| T1            | M1         | A1      | D1         |           |
| T2            | M1         | A1      |            | D1        |
| $T^{1}$ , $T$ | 1          |         |            |           |

T2 > T1

#### Rule 2

| Time   | Master | Address | Write Data | Read Data |
|--------|--------|---------|------------|-----------|
| T1     | M1     | A1      | D1         |           |
| T2     | M2     | A1      |            | D1        |
| T2 > 7 | T1     |         |            |           |
| Rule   | 3      |         |            |           |

#### Rule 3

| Time | Master | Address | Write Data | Read Data | Comment                         |
|------|--------|---------|------------|-----------|---------------------------------|
| T1   | M1     | A1      | D1         |           |                                 |
| T2   | M2     | A1      | D2         |           |                                 |
| T3   | M3     | A1      |            | D2        |                                 |
| T4   | M3     | A1      |            | D2        | It is not allowed to read D1 at |
|      |        |         |            |           | this point                      |

T4 > T3 > T2 > T1



Figure 1 describes an example of a basic system. It contains a main memory and three masters. The masters are connected to the main memory and all of them can access the memory through the arbiter. A write action of a master has three stages. First the master performs a read access to the main memory and the requested memory data is copied to the master's cache. Then the local copy of the data in the cache is updated with the write data. Later, the master may evict the cache line that contains the update data and write it back to the memory. Data inconsistent can occur in several cases. The following scenario describes an example of data inconsistent:

- 1. Master 1 write data D1 to address A1
  - a. Master 1 performs a read access to A1 in the main memory.
  - b. The data of A1 in the main memory, D0, is copied to the local cache of master 1.
  - c. The data of A1 in the local cache is overwritten with the written data, D1.
- 2. Master 2 read from address A1
  - a. Master 2 performs a read access to A1 in the main memory.
  - b. The data of A1 in the main memory, D0, is copied to the local cache of master 2.

The data of A1 in the memory in not update and Master 2 read the wrong data.

In a basic system data inconsistent can be prevented by software synchronization between the masters.



Figure 1: Basic System



Figure 2 describes an example of a hardware coherency system. It is similar to the basic system with some changes. Each master monitors (snoops) the actions of all other master. A master can postpones main memory accesses of the other masters. A master postpones a memory access of other master when it has a data copy of a certain memory address in its cache and the other master tries to access this memory location. It evicts the cache line that contains the certain data and writes it back to the memory. Then it enables the other master to continue and access the memory. The following scenario describes an example which preventing data inconsistent:

- 1. Master 1 write data D1 to address A1
  - a. Master 1 performs a read access to A1 in the main memory.
  - b. The data of A1 in the main memory, D0, is copied to the local cache of master 1.
  - c. The data of A1 in the local cache is overwritten with the written data, D1.
- 2. Master 2 read from address A1
  - a. Master 2 starts to perform a read access to A1 in the main memory.
  - b. Master 1 detects this access and holds it.
  - c. Master 1 evicts the cache line that contains the data copy of A1. This line contains data D1.
  - d. Data D1 is written to the main memory to address A1.
  - e. Master 1 releases the memory access of master 2 and lets it continue.
  - f. Master 2 finishes performing the read access from A1 in the main memory and read the data D1.

In a coherency system data inconsistent is prevented by the hardware.





Figure 2: Schematic Coherence System



#### **MESI Coherency Protocol**

MESI\_ISC supports the MESI protocol. There are several types of system architectures and cache structures. The coherency of any combination of them can be done by some coherency protocols. The MESI protocol is used for system with multi masters and local caches. The cache policy is write-back. In the MESI protocol any cache line has one four states: Modified, Exclusive, Shared, and Invalid. A cache line in Modified state is a line that owned only by the current cache and it is modified (dirty) by a write data of the local master. A cache line in Exclusive state is a line that owned only by the current cache and it is not dirty. A cache line in Shared state is a line that owned by the current and also by other caches and it is not dirty. Invalid state means that the cache line in invalid and does not contains a valid data. The next table describes, for any given pair of caches, the permitted states of a two cache line that contains the same address location:

|         | Cache A |   |   |   |
|---------|---------|---|---|---|
| Cache B | Μ       | Ε | S | Ι |
| М       | Χ       | X | X | V |
| E       | X       | X | X | V |
| S       | X       | X | V | V |
| Ι       | V       | V | V | V |

Figure 3 describes the MESI state machine.



Figure 3: MESI State Machine (Wikipedia)



## **Project Purpose**

A coherence system contains several elements that together enable the data consistency. The major elements of the coherency mechanism are:

- 1. Coherency controller.
- 2. Coherency masters.
- 3. Coherency buses.

This project provides a synthesizable coherency controller block. This block can be combined to exist system with some additional changes. In addition this project defines the masters' behavior and requirements that enable a correct coherency operation.



## MESI\_ISC Coherency Concept

#### **MESI\_ISC Coherency Protocol**

The MESI\_ISC coherency protocol is based on the MESI protocol. This protocol is defined by the order and types of event for each coherency action.

In a basic system any master has a port of a main bus for performing the memory read accesses and writes accesses. In coherency system the masters have to accept information and messages from the coherency controller. The masters of a system that adopts the MESI\_ISC contain additional port of coherency bus. The main bus is used as in a basic system for performs memory accesses. In addition the main bus and the coherency bus are used for the coherence protocol. The transactions of the main bus are initiated and drive by the masters. They respond by the main memory, the system matrix or the coherency controller. The transactions that are done in the main bus are:

- 1. Write access A write access to the memory (legacy bus transaction).
- 2. Read access A read access to the memory (legacy bus transaction).
- 3. Write broadcast A write broadcast request. Asks for all other master to evict and invalidate data of the requested address. This transaction type is unique for coherency systems.
- 4. Read broadcast A read broadcast request. Asks for all other master to evict modified data of the requested address. This transaction type is unique for coherency systems.



The coherency bus is unique for coherency systems. Its transactions are initiated and drive by the coherency controller. They respond by the masters. The transactions that are done in the coherency bus are:

- 1. Write snoop Another master request to write to a requested memory location.
- 2. Read snoop Another master request to read to a requested memory location.
- 3. Enable write A respond to a write broadcast (which was performed in the main bus). It means that the write to the requested memory location can be done.
- 4. Enable read A respond to a read broadcast (which was performed in the main bus). It means that the read to the requested memory location can be done.

In general, a coherency operation starts when a master (initiator) starts generating an access the memory. Prior to any memory access the master sends a broadcast request in the main memory. The coherency controller spreads the request to all the other masters and collects the responds. Then it enables the initiator to perform the memory access. All operations of the coherency controller are done in the coherency bus.

A coherency operation occurs when one of the caches in the system performs a read miss, a write miss, or a write to a Shared cache line. Write hit, read hit, line eviction, and line invalidate do not cause to a coherency operations.

The following tables define in details all the stages for the coherency operations. In the tables the meanings of some expression are:

**Source/destination: Initiator** – A master which requests to perform one of the following memory accesses: (1) A read access to a memory location that is not present in its cache (read miss), or (2) a write access to a memory location that is not present in its cache (write miss) or present and has a Shared state (write to a Shared cache line).

**Source/destination:** Coherency Controller – The element that responsible for the broadcast management. In this project is the MESI\_ISC.

Source/destination: Snooper – A master that receives a write or read snoop request.

**Bus: Internal** – An internal operation in a block.

-76



#### Coherency operation for a write miss

The following table defines the stages that are done for a write miss.

| Stage | Source                  | Destination             | Bus       | Operation                               | Comments                                                       |
|-------|-------------------------|-------------------------|-----------|-----------------------------------------|----------------------------------------------------------------|
| 1     | Initiator               | Coherency<br>Controller | Main      | Send write broadcast                    |                                                                |
| 2     | Coherency<br>Controller | Initiator               | Main      | Acknowledge write<br>broadcast request  | When it receive the request                                    |
| 3     | Coherency<br>Controller | Snooper                 | Coherency | Write snoop                             | Done to all masters<br>except the initiator                    |
| 4     | Snooper                 | 26                      | Internal  | Evicts a dirty line                     | In case the line is M state                                    |
|       |                         | C/A                     |           | Cache state: E/S->I                     | In case the line is E or S states                              |
|       |                         |                         |           | Do nothing                              | In case there is no a valid<br>line                            |
| 5     | Snooper                 | Memory                  | Main      | Write back line to<br>memory            | In case of eviction                                            |
|       |                         |                         |           | Cache state: M->I                       |                                                                |
| 6     | Snooper                 | Coherency<br>Controller | Coherency | Acknowledge write<br>snoop              |                                                                |
| 7     | Coherency<br>Controller | Initiator               | Coherency | Enable write                            | After all masters<br>acknowledged the write<br>snoop broadcast |
| 8     | Initiator               | Memory                  | Main      | Read line                               | Fill line                                                      |
|       | Initiator               |                         | Internal  | Cache state: I->S                       | For the cache line that contains the read data                 |
| 9     | Initiator               |                         | Internal  | Write to the cache<br>Cache state: S->M | For the cache line that contains the read data                 |
|       |                         |                         |           |                                         |                                                                |



#### Coherency operation for a read miss

| Stage | Source                  | Destination             | Bus       | Operation                          | Comments                                             |
|-------|-------------------------|-------------------------|-----------|------------------------------------|------------------------------------------------------|
| 1     | Initiator               | Coherency<br>Controller | Main      | Send read broadcast                |                                                      |
| 2     | Coherency<br>Controller | Initiator               | Main      | Acknowledge read broadcast request | When it receive the request                          |
| 3     | Coherency<br>Controller | Snooper                 | Coherency | Read snoop                         | Done to all masters<br>except the initiator          |
| 4     | Snooper                 |                         | Internal  | Evicts a dirty line                | In case the line is M                                |
|       |                         |                         |           | Cache state: E->S                  | In case the line is E                                |
|       | í Ç                     |                         |           | Do nothing                         | In case the line is S or<br>there is no a valid line |
| 5     | Snooper                 |                         | Main      | Write back line to memory          | In case of eviction                                  |
|       |                         |                         |           | Cache state: M->I                  |                                                      |
| 6     | Snooper                 | Coherency<br>Controller | Coherency | Acknowledge read snoop             |                                                      |
| 7     | Coherency<br>Controller | Initiator               | Coherency | Enable read                        | After all masters<br>acknowledged the read<br>snoop  |
| 8     | Initiator               | Memory                  | Main      | Read line                          | Fill line                                            |
| 9     | Initiator               |                         | Internal  | Cache state: I->S                  | For the cache line that contains the read data       |
|       |                         |                         |           |                                    |                                                      |

The following table defines the stages that are done for a read miss.



#### Coherency operation for a write to a Shared line

The following table defines the stages that are done for a write hit to a line in Shared state.

| 1 Initiator Coherency<br>Controller Main Send write broadcast   2 Coherency<br>Controller Initiator Main Acknowledge write<br>broadcast request   3 Coherency<br>Controller Snooper Coherency<br>Coherency Snooper Coherency<br>Coherency Done to all masters<br>cept the initiator   5 Snooper Internal Invalidates the valid<br>line:<br>Cache state: S->I   6 Snooper Coherency<br>Controller Coherency<br>Controller Coherency<br>Coherency   7 Coherency<br>Controller Coherency<br>Controller Coherency<br>Coherency Coherency<br>Coherency After all masters<br>acknowledged the w<br>snoop                                                                                                                                                                                  |   | Source    | Destination | Bus       | Operation            | Comments                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------|-------------|-----------|----------------------|-----------------------------------------------|
| ControllerSnooperCoherency<br>Coherency<br>ControllerSnooperCoherency<br>Coherency<br>InternalWrite snoopDone to all masters<br>cept the initiator5SnooperInternalInvalidates the valid<br>line:<br>Cache state: S->IInvalidates the valid<br>line:<br>Cache state: S->I6SnooperCoherency<br>ControllerCoherency<br>ControllerAcknowledge write<br>snoop7Coherency<br>ControllerCoherency<br>Coherency<br>ControllerCoherency<br>Rable writeAfter all masters<br>acknowledged the w<br>snoop8SnooperInternalWrite to the cache<br>Cache state: S->MFor the cache line th<br>contains the read da                                                                                                                                                                                    |   | Initiator | Controller  |           | Send write broadcast |                                               |
| Controller I cept the initiator   5 Snooper Internal Invalidates the valid<br>line:<br>Cache state: S->I   6 Snooper Coherency<br>Controller Coherency<br>Controller Coherency<br>Coherency Coherency<br>Snoop Acknowledge write<br>snoop After all masters<br>acknowledged the w<br>snoop   7 Coherency<br>Controller Initiator Coherency Enable write After all masters<br>acknowledged the w<br>snoop   8 Snooper Internal Write to the cache<br>Cache state: S->M For the cache line th<br>contains the read da                                                                                                                                                                                                                                                                 |   |           | Initiator   | Main      |                      |                                               |
| 1 Internal Intern |   |           | Snooper     | Coherency | Write snoop          | Done to all masters ex-<br>cept the initiator |
| Coherency<br>Controller Initiator Coherency<br>Coherency<br>Controller Initiator Coherency<br>Coherency Enable write After all masters<br>acknowledged the w<br>snoop   8 Snooper Internal Write to the cache<br>Cache state: S->M For the cache line th<br>contains the read da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   | Snooper   |             | Internal  | line:                |                                               |
| 7 Coherency<br>Controller Initiator Coherency<br>Coherency Enable write After all masters<br>acknowledged the w<br>snoop   8 Snooper Internal Write to the cache<br>Cache state: S->M For the cache line th<br>contains the read da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ; | Snooper   |             | Coherency |                      |                                               |
| Cache state: S->M contains the read da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |           | Initiator   | Coherency |                      | acknowledged the write                        |
| Cache state: S->M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ; | Snooper   |             | Internal  | Write to the cache   | For the cache line that                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |           |             |           | Cache state: S->M    | contains the read data                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |           |             |           | 20.                  |                                               |



#### Examples Diagrams for Coherency Scenarios

The diagrams in this section describe the development of events in different coherency scenarios. They do not show the detailed timing behavior. The diagrams help to understand the coherency operation and the MESI\_ISC coherency protocol.

#### A write miss to a an Invalid location

The following diagram describes a write miss of M0 (master 0) to an address that is invalid in all masters. M0 sends write-broadcast on the main bus. M1 and M2 receive write-snoop on the coherency busses and return immediately acknowledge. M0 receives write-enable on the coherency bus and performs a writes access (read A1 from memory on the main bus and write to its cache).



Figure 4: Write miss to an Invalid location



#### A write miss to a Modified location in other master's cache

The following diagram describes a write miss of M0 to an address that is modified in the cache of M1. M0 sends write-broadcast in the main bus. M1 and M2 receive write-snoop in coherency busses. M2 returns immediately acknowledge. As a result of the write snoop, M1 evicts A1 and writes it back to the memory through the main bus. Then M1 returns acknowledge. M0 receives write-enable and performs a writes access (read A1 from memory and write to its cache).

| -                   | Time           |                   |
|---------------------|----------------|-------------------|
| M0 event            | wr miss A1     | I->S wir to cache |
| M0 main bus         | wr brod At     | rd A1             |
| M0<br>Coherency bus |                | wr en A1          |
| M1 event            | ev             | ict A1            |
| M1 main bus         |                | WI A1             |
| M1<br>Coherency bus | wr snoop A     | wr ack A1         |
| M2 event            |                |                   |
| M2 main bus         |                |                   |
| M2<br>Coherency bus | wr snoop A1 wr | ack A1            |

Figure 5: Write miss to a Modified location in other master



#### Two parallel write misses to the same location which is Invalid

The following diagram describes a write miss of M0 to address A1 in parallel to a write miss of M1 to address A1. A1 is invalid in all masters. M0 and M1 send, separately, write-broadcasts. MESI\_ISC responds first to M0 (according to a random priority). M1 and M2 receive write-snoop on the coherency busses and return immediately acknowledge. M0 receives write-enable on the coherency bus and performs a writes access (read A1 from memory and write to its cache). Then MESI\_ISC responds the broadcast of M1. M0 and M2 receive write-snoop on the coherency busses. M2 returns immediately acknowledge. As a result of the write snoop, M0 evicts A1 and writes it back to the memory through the main bus. Then M0 returns acknowledge. M1 receives write-enable and performs a writes access (read A1 from memory and write to the cache).



Figure 6: Two parallel write misses to an Invalid location



#### A write miss and a parallel read miss to two different addresses

The following diagram describes a write miss of M0 to address A1. Address A1 is in an **E**xclusive state at M1. In parallel to the write miss M1 performs a read miss to address A2. Address A2 is in a **M**odified state at M1. M0 and M1 send, separately, write-broadcasts and read broadcast, respectively. MESI\_ISC responds first to M1 (according to a random priority). M0 and M2 receive read-snoop for A2 on the coherency busses. M2 returns immediately acknowledge. As a result of the read snoop M0 evicts A2 and writes it back the memory through the main bus. Then M0 returns acknowledge. M1 receives read-enable and performs a read access (read A2 from memory and copy it to its cache). Then MESI\_ISC responds the broadcast of M0. M1 and M2 receive write-snoop on the coherency busses. Both return immediately acknowledge. M1 also change the line state from Exclusive to Invalid. M0 receives write-enable and performs a writes access (read A1 from memory and write to its cache).







## Architecture

#### **Coherency System Architecture**

A coherency system contains, in addition to the legacy elements, the MESI\_ISC, coherency ports of the masters and the coherency bus. MESI\_ISC has two connection types. In one direction it connects to the main bus as a slave and receives the bus' controls and address. In the other direction it connects to the coherency bus as a bus master. MESI\_ISC has two ports for each system master, one main bus port and one coherency bus port. The legacy structure of the system that include the memory matrix, the arbitration, and the memory, remains unchanged.

Figure 8 describes a coherence system with MESI\_ISC



Figure 8: MESI\_ISC Architecture and the Masters system



#### **Coherency Operations**

The MESI\_ISC receives the broadcast request from the system masters through the main bus. It sends the write snoop, read snoop, write-enable, and read-enable to the system masters through the coherency bus. MESI\_ISC separates each broadcast request that a master sends (initiator) to a separated snoop requests for each master, except for the initiator.

#### System Performance and Memory Mapping

The memory mapping of a coherency system can contain two areas, a private area and a shared area. The private area has several nonoverlapping spaces, each space directed to a specific master. There is no consistency of the data in the private area between the different masters of the system. Therefore a space memory in the private area which is directed to a specific master can be accessed only by that master. The shared area can be used by all masters and its data is consistency between the masters. The shared area is used to synchronize the masters and to transfer data between them. Both the areas are cacheable.

The way masters access the memory depends on the memory mapping. A memory access to an address which is located in the private area is done without prior actions. The master performs a read or a write access directly to the memory. The memory data is copied to the local cache and is used by the regular cache operations.

A master that intends to access a location in the shared area is required to notify the other master about the action. The notification enables the other master to invalidate that location in their caches or to write back the dirty data. The notification is done by sending to the MESI\_ISC a broadcast request. Only after the MESI\_ISC enables the access the master can perform the intended memory access.

A synchronization system, by nature, requires additional resources such as timing and area. In a coherence systems with MESI\_ISC the latency of the MESI protocol (sending a broadcast request and receive acknowledges), in the best case, is seven cycles. This latency can cause to degradation of the system performance.

However it is possible to reduce the performance degradation. This list describes the major field for doing it:

- 1. System configuration and S/F management
  - a. The usage of the shared memory is done only for synchronization and for data transfer between the masters. All the other tasks use the private memory.
  - b. Evict or invalidate dirty cache lines when are unused.
- 2. MESI\_ISC configuration
  - a. Defining and tuning the MESI\_ISC FIFO sizes to achieve the best system performance (see <u>MESI\_ISC Configuration (Under Construction)</u>)



- 3. Maters architecture
  - a. Improving the respond time of the masters for the snoop requests (see Masters Definition and Requirements (Under Construction)).
  - b. Change the cache configurations. For example increase the line size to reduce the synchronization events.
- 4. MESI\_ISC architecture
  - a. Changes of the to reduce its latency (remove the snoop FIFOs see Open issues)

#### Masters Definition and Requirements (Under Construction)

#### Integration MESI\_ISC to Existing Systems (Under Construction)

#### MESI\_ISC Configuration (Under Construction)

#### FIFO sizes

Number of masters in the system

# Clock and Reset (Under Construction)



## **Micro Architecture**

#### (Under Construction)

Figure 4 describes the micro-architecture of MESI\_ISC



Figure 9: MESI\_ISC Micro-Architecture



## 7 Verification

#### (Under Construction)

#### Verification Environment (Under Construction)

Figure 5 describes the MESI\_ISC verification environment.



Figure 10: MESU\_ISC Verification Environment



#### Validation of Data Consistency

Validation of MESI Protocol

20

よ

#### **Random Stimulus**

www.opencores.org

00

Sic Cic



## Timing, Power and Area

ic

(Under Construction)

www.opencores.org



## **Design Environment**

Ĩn,

|  | (U | In | der | Con | stru | ction) |  |
|--|----|----|-----|-----|------|--------|--|
|--|----|----|-----|-----|------|--------|--|

Tools

**Synthesis** 

Simulation

Lint



## 10 **IO Ports**

#### (Under Construction)

This section specifies the MESI\_ISC IO ports.

Clock and reset

| Port     | Direction | Description |
|----------|-----------|-------------|
| clk      | Input     |             |
| rst      | Input     |             |
|          |           |             |
| Main bus |           |             |

| Port         | Direction | Description |
|--------------|-----------|-------------|
| mbus_cmd3_i  | Input     |             |
| mbus_cmd2_i  | Input     |             |
| mbus_cmd1_i  | Input     |             |
| mbus_cmd0_i  | Input     |             |
| mbus_addr3_i | Input     |             |
| mbus_addr2_i | Input     |             |
| mbus_addr1_i | Input     |             |
| mbus_addr0_i | Input     |             |
| mbus_ack3_o  | Output    |             |
| mbus_ack2_o  | Output    |             |
| mbus_ack1_o  | Output    |             |
| mbus_ack0_o  | Output    |             |



Coherency Bus

| Port        | Direction | Description |
|-------------|-----------|-------------|
| cbus_ack3_i | Input     |             |
| cbus_ack2_i | Input     |             |
| cbus_ack1_i | Input     |             |
| cbus_ack0_i | Input     |             |
| cbus_addr_o | Output    |             |
| cbus_cmd3_o | Output    |             |
| cbus_cmd2_o | Output    |             |
| cbus_cmd1_o | Output    |             |
| cbus_cmd0_o | Output    |             |
|             |           |             |



## Waveforms

#### (Under Construction)

The next figure shows a read access to the memory which preceded by a read broadcast. A similar operation is describe in figure <u>A write miss and a parallel read miss to two</u> <u>different addresses</u>

| clk=                 |                   |              |     |            |    |     |
|----------------------|-------------------|--------------|-----|------------|----|-----|
| mbus data rd[31:0] = | 0000000           |              |     |            |    |     |
| mbus m3 {            |                   |              |     |            |    |     |
| mbus cmd3[2:0] =     | NOP RD BR         | NOP          |     |            | RD | NOP |
| mbus_addr3_i[31:0] = | xxxxxxxx 00000002 | 9. Control - |     |            |    |     |
| mbus ack[3] =        |                   |              |     |            |    |     |
| } mbus m3            |                   |              |     |            |    |     |
| mbus_cmd2[2:0] =     | NOP               |              |     |            |    |     |
| mbus_cmd1[2:0] =     | NOP               |              |     |            |    |     |
| mbus_cmd0[2:0] =     | NOP               |              |     |            |    |     |
| } mbus               |                   |              |     |            |    |     |
| cbus {               |                   |              |     |            |    |     |
| cbus_addr_o[31:0] =  | 0000000           | 00000002     |     |            |    |     |
| cbus_cmd3_o[2:0] =   | -                 |              |     | en_rd      |    | ).  |
| cbus_ack3_i =        |                   |              |     |            |    |     |
| cbus_cmd2_o[2:0] =   | -                 | rd sr        | n i | χ.         |    |     |
| cbus_ack2_i =        |                   |              |     |            |    |     |
| cbus_cmd1_o[2:0] =   | -                 | (rd_sr       | n   | χ.         |    |     |
| cbus_ack1_i =        |                   |              |     |            |    |     |
| cbus_cmd0_o[2:0] =   | 2                 | (rd_si       | n   | <u>)</u> - |    |     |
| cbus_ack0_i =        |                   |              |     |            |    |     |
| } cbus               |                   |              |     |            |    |     |
|                      |                   |              |     | 67         | 0  | )   |



## **Open Issues**

1. Add an option to remove the snoop request FIFOs in the RTL (by Verilog define or by additional MESI\_ISC version).

www.opencores.org