## Team 1

# **Bug Report**

## **Bug 1**

**Test Case**: Read processor 0, Write processor 1, Read processor 1. (All at the same address)

**Assertion failed**: @posedge(clk) \$fell (cpu\_wr) |=> \$fell (cpu\_wr\_done),

<u>Explanation</u>: When we encountered the above assertion failure, we looked into the waveforms and observed the same. i.e. when cpu\_wr falls, cpu\_wr\_done does not fall. In fact, cpu\_wr\_done was never asserted. Since CPU\_wr\_done was never asserted, from the HAS pdf, we can confirm that cache\_var and cache\_proc\_contr are not updated with the values that were passed by write proc1.

In order to find out why these two variables are not updated, we looked at the waveforms of address\_bus\_cpu\_lv1[processor 1] and data\_bus\_cpu\_lv1[processor 1]. We figured out that address\_bus\_cpu\_lv1 is only 15 bits which ideally should be 32 bits.

Since the address bus is of only 15 bits, passing an address of 32h AABB\_CCDD, the address gets truncated to 4CDD. This truncated address is less than the d\_cache address and thus write operation is not permitted.

**Solution:** In cache\_lv1\_multicore line 140 (.ADDR\_WID(INDEX\_MSB),) should be replaced by .ADDR\_WID(ADDR\_WID).

Please find the waveforms as attached and let us know your inputs.



# Bug 2

**Test Case**: Four writes to same processor i.e. processor 0 with different addresses (having different tags but same index number) followed by two reads (again having different tags but same index number)

**Test Intent**: To check block replacement policy (LRU) working

UVM ERROR ../uvm/cache scoreboard c.sv(414) @

1725: <u>uvm\_test\_top.tb.sb</u> [cache\_scoreboard\_c] Expected activity is not observed on the system bus

```
UVM_ERROR ../uvm/cache_scoreboard_c.sv(433) @ 1675: uvm_test_top.tb.sb [cache_scoreboard_c] System bus activity MISMATCH!!!
UVM_INFO ../uvm/cache_scoreboard_c.sv(434) @ 1675: uvm_test_top.tb.sb [cache_scoreboard_c] Expected SBUS Packet
                                                       Size Value
                                   Type
expected
                                   sbus packet c
                                                              @7826
  bus_req_type
                                                       32
                                   bus req t
                                   bus_req_proc_t
  bus_req_proc_num
                                                               REQ_PROCO
  req_address
                                   integral
                                                               'h70000000
                                                               'h0
  bus_req_snoop
                                   integral
                                                              SERV L2
  rea serviced by
                                   serv by t
                                                               'haaaa5555
  rd data
                                   integral
                                                        32
  wr_data_snoop
                                   integral
  snoop_wr_req_flag
cp_in_cache
                                                               'h0
                                    integral
                                   integral
                                                               'h0
                                                       1
32
  shared
                                                               'h0
                                   integral
                                                               'h0
  service time
                                    integral
  proc_evict_dirty_blk_addr
                                                               'h55550000
                                   integral
  proc_evict_dirty_blk_data
proc_evict_dirty_blk_flag
                                                               'h5011959
                                                               'h1
                                   integral
UVM INFO ../uvm/cache scoreboard c.sv(435) @ 1675: uvm test top.tb.sb [cache scoreboard c] Received SBUS Packet
                                                       Size Value
  packet
                                                              07952
                                   sbus packet c
                                                              BUS_RD
  bus req type
                                   bus req t
  bus_req_proc_num
                                   bus_req_proc_t
                                                               RE0 PR0C0
  req_address
                                   integral
                                                               'h70000000
  bus_req_snoop
                                   integral
                                                               'h0
  req_serviced_by
rd_data
                                   serv_by_t
integral
                                                              SERV L2
                                                               'haaaa5555
  wr data snoop
                                   integral
                                                        32
  snoop_wr_req_flag
cp_in_cache
                                    integral
                                                               'h0
                                    integral
                                                               'h0
  shared
                                   integral
                                                               'h0
  service time
                                                       'h0
                                   integral
  proc_evict_dirty_blk_addr
                                                       32
                                   integral
                                                               'h44440000
  proc_evict_dirty_blk_data
proc_evict_dirty_blk_flag
                                                               'h11111111
                                                               'h1
```

#### **Observation:**

Initially, as the cache was empty, the first four write instructions caused write miss and the data was written in the cache and all of them were in a modified state. When the fifth instruction, which was a read instruction belonging to the same set (as all had the same index) was executed, the first block of the cache was replaced and it matched with the expected result. However, when the sixth instruction which was also read having addresses belonging to the same set was executed, the expected block that must have been replaced was 3<sup>rd</sup> block (i.e. block 2). But as seen from the above image the expected and received did not match. In our test case, the received packet from the monitor showed that the 2<sup>nd</sup> block (i.e. block 3). This clearly indicated that there was some error in the flow of blocks getting replaced.

**Solution**: line 38 and 39 of file <u>lru\_block\_lv1.sv</u> in design/lv1 folder. The values of block to be replaced where exchanged for BLK\_1 and BLK\_2 replacement. The correct value is as follows.

BLK1\_REPLACEMENT: lru\_replacement\_proc = 2'b01;

BLK2\_REPLACEMENT: lru\_replacement\_proc = 2'b10;

## Bug 3

**Test Case**: Write Processor 3, Read Processor 0, Write Processor 3, Read Processor 0

**Test Intent:** To verify MESI state by targeting same address in reads and writes

UVM ERROR:/uvm/cache scoreboard c.sv(297) @

735: uvm\_test\_top.tb.sb [cache\_scoreboard\_c] Data MISMATCH!!! expected = 29292929

received = 28282828

### **Observation**

Data when read from processor0 reads correctly the first time but when the second write is made at the same address, the processor0 reads stale and old value causing the DATA Mismatch. That is because the invalidation to the processor 0 did not happen and it keeps the old data. Hence we see the received data as 28282828 which ideally should be the updated value i.e. 29292929.

Since we saw that the received data in processor 0 is the same as the old data that has been received, we assumed that there has been a read hit in processor 0. To verify it, we checked at the invalidation signal that should have been high since we had a write to processor 3 in the third step. But the Invalidation signal was not set high. Since invalidation was not set high, we looked into the MESI states of processors.

When the processor 3 is writing data in step 3, the previous MESI states of processor 0 and processor 3 are both shared. As we are modifying the data in Processor 3 (shared to modified), the processor 0 should switch from shared to invalid. But as it is evident from the waveform that, processor 0 state is not being changed to Invalid(invalidation signal not high). Hence when we give the read command for the same address to processor 0 in step 4, as the current state of processor 0 is still shared, a read hit occurs and an old value is being displayed.

This confirmed that the mesi state of the processors are not getting updated correctly.

**Solution:** In main func lv1 dl.sv the SHARED value should be set 01 and EXCLUSIVE value should be set 10 so as to align it with the values set in <u>cache block lv1 dl.sv</u> file.

### Waveform:

