



# AXI4-Compliant Memory-Mapped Slave



Rana ayman hamdy Mahmoud

## Contents

|                                                    |    |
|----------------------------------------------------|----|
| Introduction .....                                 | 1  |
| Test Memory in AXI Slave with small testbench..... | 1  |
| Bugs found .....                                   | 1  |
| AXI4 Wrapper Verification .....                    | 3  |
| Test Plan .....                                    | 3  |
| Bugs found .....                                   | 4  |
| Waveform .....                                     | 8  |
| Write .....                                        | 8  |
| Read .....                                         | 9  |
| Log .....                                          | 10 |
| Coverage.....                                      | 11 |
| Assertion Coverage .....                           | 11 |
| Functional Coverage.....                           | 11 |
| Code Coverage.....                                 | 11 |
| GitHub repository for code details.....            | 14 |

## Introduction

This project implements a simplified AXI4-based system that enables communication between an AXI4 master

and an internal memory module. The goal is to model, simulate, and verify the behavior of AXI4 transactions

such as burst reads and writes, address decoding, and proper data handshaking.

## Test Memory in AXI Slave with small testbench

### Bugs found

1)

```

transcript
VSIM 11> run -all
# ERROR mem[  0] = 00000000 while intended wr_data = 12153524
# ERROR mem[  1] = 00000000 while intended wr_data = c0895e81
# ERROR mem[  2] = 00000000 while intended wr_data = 8484de09
# ERROR mem[  3] = 00000000 while intended wr_data = blf05663
# ERROR mem[  4] = 00000000 while intended wr_data = 06b97b0d
# ERROR mem[  5] = 00000000 while intended wr_data = 46df998d
# ERROR mem[  6] = 00000000 while intended wr_data = b2c29465
# ERROR mem[  7] = 00000000 while intended wr_data = 89375212
# ERROR mem[  8] = 00000000 while intended wr_data = 00f3e301
# ERROR mem[  9] = 00000000 while intended wr_data = 06d7cd0d
# ERROR mem[ 10] = 00000000 while intended wr_data = 3b23f176
# ERROR mem[ 11] = 00000000 while intended wr_data = 1e8dcfd3d
# ERROR mem[ 12] = 00000000 while intended wr_data = 76d457ed
# ERROR mem[ 13] = 00000000 while intended wr_data = 462df78c
# ERROR mem[ 14] = 00000000 while intended wr_data = 7cfde9f9
# ERROR mem[ 15] = 00000000 while intended wr_data = e33724c6
# ERROR mem[ 16] = 00000000 while intended wr_data = e2f784c5
# ERROR mem[ 17] = 00000000 while intended wr_data = d513d2aa
# ERROR mem[ 18] = 00000000 while intended wr_data = 72aff7e5
# ERROR mem[ 19] = 00000000 while intended wr_data = bbd27277
# ERROR mem[ 20] = 00000000 while intended wr_data = 8932d612
# ERROR mem[ 21] = 00000000 while intended wr_data = 47ecdb8f
# ERROR mem[ 22] = 00000000 while intended wr_data = 793069f2
# ERROR mem[ 23] = 00000000 while intended wr_data = e77696ce
# ERROR mem[ 24] = 00000000 while intended wr_data = f4007ae8
# ERROR mem[ 25] = 00000000 while intended wr_data = e2ca4ec5
# ERROR mem[ 26] = 00000000 while intended wr_data = 2e58495c
# ERROR mem[ 27] = 00000000 while intended wr_data = de5e28bd
# ERROR mem[ 28] = 00000000 while intended wr_data = 96ab582d
# ERROR mem[ 29] = 00000000 while intended wr_data = b2a72665
# ERROR mem[ 30] = 00000000 while intended wr_data = blef6263
# ERROR mem[ 31] = 00000000 while intended wr_data = 0573870a
# ERROR mem[ 32] = 00000000 while intended wr_data = c03b2280
# ERROR mem[ 33] = 00000000 while intended wr_data = 10642120
# ERROR mem[ 34] = 00000000 while intended wr_data = 557845aa
# ERROR mem[ 35] = 00000000 while intended wr_data = cecccc9d
# ERROR mem[ 36] = 00000000 while intended wr_data = cb203e96

```

Ln: 78 Col: 0 Project : mem Now: 20,490 ns Delta: 1 Si

This is because that reset in design active high while in spec active low

The bug and its correction

```

// Memory write
always @(posedge clk) begin
    if (rst_n)
        mem_rdata <= 0;
    else if (mem_en) begin
        if (mem_we)
            memory[mem_addr] <= mem_wdata;
        else
            mem_rdata <= memory[mem_addr-1];
    end
end

```

```

// Memory write
always @(posedge clk) begin
    if (!rst_n)
        mem_rdata <= 0;
    else if (mem_en) begin
        if (mem_we)
            memory[mem_addr] <= mem_wdata;
        else
            mem_rdata <= memory[mem_addr-1];
    end
end

```

2)

```

Transcript
[VSIM 17> run -all
# ERROR read data = xxxxxxxx while mem[ 0] = 12153524
# ERROR read data = 12153524 while mem[ 1] = c0895e81
# ERROR read data = c0895e81 while mem[ 2] = 8484d609
# ERROR read data = 8484d609 while mem[ 3] = b1f05663
# ERROR read data = b1f05663 while mem[ 4] = 06b97b0d
# ERROR read data = 06b97b0d while mem[ 5] = 46df998d
# ERROR read data = 46df998d while mem[ 6] = b2c28465
# ERROR read data = b2c28465 while mem[ 7] = 89375212
# ERROR read data = 89375212 while mem[ 8] = 00f3e301
# ERROR read data = 00f3e301 while mem[ 9] = 06d7cd0d
# ERROR read data = 06d7cd0d while mem[ 10] = 3b23f176
# ERROR read data = 3b23f176 while mem[ 11] = 1e8dcdd3d
# ERROR read data = 1e8dcdd3d while mem[ 12] = 76d457ed
# ERROR read data = 76d457ed while mem[ 13] = 462df78c
# ERROR read data = 462df78c while mem[ 14] = 7cfde9f9
# ERROR read data = 7cfde9f9 while mem[ 15] = e33724c6
# ERROR read data = e33724c6 while mem[ 16] = e2f784c5
# ERROR read data = e2f784c5 while mem[ 17] = d513d2aa
# ERROR read data = d513d2aa while mem[ 18] = 72aff7e5
# ERROR read data = 72aff7e5 while mem[ 19] = bbd27277
# ERROR read data = bbd27277 while mem[ 20] = 8932d612
# ERROR read data = 8932d612 while mem[ 21] = 47ecdb8f
# ERROR read data = 47ecdb8f while mem[ 22] = 793069f2
# ERROR read data = 793069f2 while mem[ 23] = e77696ce
# ERROR read data = e77696ce while mem[ 24] = f4007ae8
# ERROR read data = f4007ae8 while mem[ 25] = e2ca4ec5
# ERROR read data = e2ca4ec5 while mem[ 26] = 2e58495c
# ERROR read data = 2e58495c while mem[ 27] = de8e28bd
# ERROR read data = de8e28bd while mem[ 28] = 96ab582d
# ERROR read data = 96ab582d while mem[ 29] = b2a72665
# ERROR read data = b2a72665 while mem[ 30] = blef6263
# ERROR read data = blef6263 while mem[ 31] = 0573870a
# ERROR read data = 0573870a while mem[ 32] = c03b2280
# ERROR read data = c03b2280 while mem[ 33] = 10642120
# ERROR read data = 10642120 while mem[ 34] = 557845aa
# ERROR read data = 557845aa while mem[ 35] = cecccc9d
# ERROR read data = cecccc9d while mem[ 36] = cb203e96

```

Ln: 79 Col: 0 Project: mem N

This because design read from memory in location address -1

Bug and its correction

```

mem_rdata <= 0,
else if (mem_en) begin
    if (mem_we)
        memory[mem_addr] <= mem_wdata;
    else
        mem_rdata <= memory[mem_addr-1];
end

```

```

mem_rdata <= 0;
else if (mem_en) begin
    if (mem_we)
        memory[mem_addr] <= mem_wdata;
    else
        mem_rdata <= memory[mem_addr];
end

```

## AXI4 Wrapper Verification

### Test Plan

| Feature     | Check List                                                                                           | Stimulus                       |
|-------------|------------------------------------------------------------------------------------------------------|--------------------------------|
| Clk checker | - check clk toggle with the wanted period by making clk_temp to save past value through half period  |                                |
| Rst checker | - At -ve edge ARESETn and when ARESETn = 0 >> AWREADY, WREADY ,BRESP ,BVALID ,ARREADY , RDATA ,RRESP | - ARESETn = 0<br>- ARESETn = 1 |

|                                           |                                                                                                                                                                                  |                                                                                                                                                                        |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                           | <ul style="list-style-type: none"> <li>,RVALID and RLAST become zero</li> <li>- At ARESETn = 1 system function as expected</li> </ul>                                            |                                                                                                                                                                        |
| Write address to slave                    | <ul style="list-style-type: none"> <li>- Valid asserted until ready come from slave to accept address (AWREADY = 1)</li> </ul>                                                   | <ul style="list-style-type: none"> <li>- AWVALID = 1</li> </ul>                                                                                                        |
| slave accept write data                   | <ul style="list-style-type: none"> <li>- Valid asserted until ready come from slave to accept data (WREADY = 1)</li> </ul>                                                       | <ul style="list-style-type: none"> <li>- WVALID = 1</li> </ul>                                                                                                         |
| Response check                            | <ul style="list-style-type: none"> <li>- If WLAST asserted then !WREADY ,BVALID and BRESP = OKAY or SLVERR</li> </ul>                                                            | <ul style="list-style-type: none"> <li>- WLAST = 1</li> </ul>                                                                                                          |
| Boundary check                            | <ul style="list-style-type: none"> <li>- AxADDR &gt;&gt; 2 + AxLEN + 1 &lt; MEMORY_DEPTH</li> <li>- Negative check by violate boundary with address &gt; MEMORY_DEPTH</li> </ul> | <ul style="list-style-type: none"> <li>- AxADDR + AxLEN + 1 &lt; MEMORY_DEPTH * 4</li> <li>- AxADDR + AxLEN + 1 &gt; MEMORY_DEPTH * 4</li> <li>- AxSIZE = 2</li> </ul> |
| Read address from slave                   | <ul style="list-style-type: none"> <li>- Valid asserted until ready come from slave to accept address (ARREADY = 1)</li> </ul>                                                   | <ul style="list-style-type: none"> <li>- ARVALID = 1</li> </ul>                                                                                                        |
| Read data from slave<br>(internal memory) | <ul style="list-style-type: none"> <li>- When master is ready slave assert RVALID and put data on RDATA also send RRESP and on reading last beat assert RLAST</li> </ul>         | <ul style="list-style-type: none"> <li>- RREADY = 1</li> </ul>                                                                                                         |

## Bugs found

1)

```

# =====
# burst write of length 15 from byte address fc2 (word address 3f0)
# Write response success
# check that if data written successfully in memory
# time = 143480000 Write success: Expected 106flc60, Got 106flc60 addr 3f0
# time = 143480000 Write success: Expected 7fda78cf, Got 7fda78cf addr 3f1
# time = 143480000 Write error: Expected d532507e, Got d68ab4c8 addr 3f2
# time = 143480000 Write error: Expected d9027db5, Got c61f434d addr 3f3
# time = 143480000 Write error: Expected 7eb6047a, Got fa2fce77 addr 3f4
# time = 143480000 Write error: Expected e52cd5dc, Got 5097119d addr 3f5
# time = 143480000 Write error: Expected a6f2dd0f, Got 67d4b9dc addr 3f6
# time = 143480000 Write error: Expected 2a041810, Got 0 addr 3f7
# time = 143480000 Write error: Expected 9a980b12, Got 0 addr 3f8
# time = 143480000 Write error: Expected a69efafa4b, Got 0 addr 3f9
# time = 143480000 Write error: Expected 49d343bb, Got c27a2295 addr 3fa
# time = 143480000 Write error: Expected afc46bd7, Got f9f1e32c addr 3fb
# time = 143480000 Write error: Expected 977785e9, Got e6d5d362 addr 3fc
# time = 143480000 Write error: Expected ffef1f68, Got 0 addr 3fd
# time = 143480000 Write error: Expected c3230b66, Got 0 addr 3fe
#
# =====

```



```

// Address boundary check (4KB boundary = 12 bits)
assign write_boundary_cross = ((write_addr & 12'hFFF) + (write_burst_len << write_size)) > 12'hFFF;

```

The design asserts `write_boundary_cross` and prevents the write operation to memory, even though no actual boundary crossing occurs.

Based on the calculation ( $4034 \times 4 \times 15 = 4094$ ), the address range remains within the allowed boundary, so the `write_boundary_cross` signal should not be asserted in this scenario.

Its correction

```

// Address boundary check (4KB boundary = 12 bits)
//assign write_boundary_cross = ((write_addr & 12'hFFF) + (write_burst_len << write_size)) > 12'hFFF;
assign write_boundary_cross = ((write_addr & 12'hFFF) + ((write_burst_cnt + 1) << write_size)) > 12'hFFF;

```



```
# =====
# burst write of length 15 from byte address fc2 (word address 3f0)
# Write response success
# check that if data written successfully in memory
# time = 143480000 Write success: Expected 106f1c60, Got 106f1c60 addr 3f1
# time = 143480000 Write success: Expected 7fda78cf, Got 7fda78cf addr 3f1
# time = 143480000 Write success: Expected d532507e, Got d532507e addr 3f2
# time = 143480000 Write success: Expected d9027db5, Got d9027db5 addr 3f3
# time = 143480000 Write success: Expected 7eb6047a, Got 7eb6047a addr 3f4
# time = 143480000 Write success: Expected e52cd5dc, Got e52cd5dc addr 3f5
# time = 143480000 Write success: Expected a6f2dd0f, Got a6f2dd0f addr 3f6
# time = 143480000 Write success: Expected 2a041810, Got 2a041810 addr 3f7
# time = 143480000 Write success: Expected 9a980b12, Got 9a980b12 addr 3f8
# time = 143480000 Write success: Expected a69efa4b, Got a69efa4b addr 3f9
# time = 143480000 Write success: Expected 49d343bb, Got 49d343bb addr 3fa
# time = 143480000 Write success: Expected afc46bd7, Got afc46bd7 addr 3fb
# time = 143480000 Write success: Expected 977785e9, Got 977785e9 addr 3fc
# time = 143480000 Write success: Expected ffelf68, Got ffelf68 addr 3fd
# time = 143480000 Write success: Expected c3230b66, Got c3230b66 addr 3fe
# =====
```

2)

```
# =====
# burst read of rlength 15 from byte address fc2 (word address 3f0)
# time = 339606000 Read success: Expected 106f1c60, Got 106f1c60 raddr 3f0
# time = 339626000 Read success: Expected 7fda78cf, Got 7fda78cf raddr 3f1
# time = 339646000 Read error: Expected d532507e, Got 0 raddr 3f2
# time = 339666000 Read error: Expected d9027db5, Got 0 raddr 3f3
# time = 339686000 Read error: Expected 7eb6047a, Got 0 raddr 3f4
# time = 339706000 Read error: Expected e52cd5dc, Got 0 raddr 3f5
# time = 339726000 Read error: Expected a6f2dd0f, Got 0 raddr 3f6
# time = 339746000 Read error: Expected 2a041810, Got 0 raddr 3f7
# time = 339766000 Read error: Expected 9a980b12, Got 0 raddr 3f8
# time = 339786000 Read error: Expected a69efa4b, Got 0 raddr 3f9
# time = 339806000 Read error: Expected 49d343bb, Got 0 raddr 3fa
# time = 339826000 Read error: Expected afc46bd7, Got 0 raddr 3fb
# time = 339846000 Read error: Expected 977785e9, Got 0 raddr 3fc
# time = 339866000 Read error: Expected ffelf68, Got 0 raddr 3fd
# time = 339886000 Read error: Expected c3230b66, Got 0 raddr 3fe
# =====
```



The design asserts `read_boundary_cross` and prevents the memory read operation, even though no boundary crossing actually occurs.

Based on the calculation ( $4034 \times 4 \times 15 = 4094$ ), the address range does not exceed the boundary limit, so the `read_boundary_cross` signal should not be asserted in this case.

Its correction

```

//assign read_boundary_cross = ((read_addr & 12'hFFF) + (read_burst_len << read_size)) > 12'hFFF;
assign read_boundary_cross = ((read_addr & 12'hFFF) + ((read_burst_cnt + 1) << read_size)) > 12'hFFF;

```

```

# burst read of rlength 15 from byte raddress fc2 (word raddress 3f0)
# time = 339606000 Read success: Expected 106fc1c60, Got 106fc1c60 raddr 3f0
# time = 339626000 Read success: Expected 7fda78cf, Got 7fda78cf raddr 3f1
# time = 339646000 Read success: Expected d532507e, Got d532507e raddr 3f2
# time = 339666000 Read success: Expected d9027db5, Got d9027db5 raddr 3f3
# time = 339686000 Read success: Expected 7eb6047a, Got 7eb6047a raddr 3f4
# time = 339706000 Read success: Expected e52cd5dc, Got e52cd5dc raddr 3f5
# time = 339726000 Read success: Expected a6f2dd0f, Got a6f2dd0f raddr 3f6
# time = 339746000 Read success: Expected 2a041810, Got 2a041810 raddr 3f7
# time = 339766000 Read success: Expected 9a980b12, Got 9a980b12 raddr 3f8
# time = 339786000 Read success: Expected a69efa4b, Got a69efa4b raddr 3f9
# time = 339806000 Read success: Expected 49d343bb, Got 49d343bb raddr 3fa
# time = 339826000 Read success: Expected afc46bd7, Got afc46bd7 raddr 3fb
# time = 339846000 Read success: Expected 977785e9, Got 977785e9 raddr 3fc
# time = 339866000 Read success: Expected ffef1f68, Got ffef1f68 raddr 3fd
# time = 339886000 Read success: Expected c3230b66, Got c3230b66 raddr 3fe

```



3)

```
# =====
# burst read of rlength 12 from byte raddress b57 (word raddress 2d5)
# time = 171545000 Read error: Expected f406ab10, Got 829e5889 raddr 2d5
# time = 171565000 Read error: Expected 342dcba, Got f406ab10 raddr 2d6
# time = 171585000 Read error: Expected 72aae25a, Got 342dcba raddr 2d7
# time = 171605000 Read error: Expected 17b5f753, Got 72aae25a raddr 2d8
# time = 171625000 Read error: Expected 6428b0a7, Got 17b5f753 raddr 2d9
# time = 171645000 Read error: Expected ed3f244d, Got 6428b0a7 raddr 2da
# time = 171665000 Read error: Expected 41827315, Got ed3f244d raddr 2db
# time = 171685000 Read error: Expected c11c9142, Got 41827315 raddr 2dc
# time = 171705000 Read error: Expected 586cfab, Got c11c9142 raddr 2dd
# time = 171725000 Read error: Expected 331f629f, Got 586cfab raddr 2de
# time = 171745000 Read error: Expected 87d874c6, Got 331f629f raddr 2df
# time = 171765000 Read error: Expected 3e930251, Got 87d874c6 raddr 2eo
```



According to the AXI specification, read data must be transferred in the same cycle when RVALID is asserted and RREADY is high. Additionally, RLAST must be asserted during the cycle in which the final data beat of the burst is transferred.

However, in the current implementation, the design outputs the read data one clock cycle later than expected after RVALID is asserted.

Please update the checker temporarily so that it tolerates this one-cycle latency and does not report a failure until the design team corrects the behavior.

```
# =====
# burst read of rlength 12 from byte address b57 (word address 2d5)
# time = 171405000 Read success: Expected f406ab10, Got f406ab10 raddr 2d5
# time = 171425000 Read success: Expected 342dcba, Got 342dcba raddr 2d6
# time = 171445000 Read success: Expected 72aae25a, Got 72aae25a raddr 2d7
# time = 171465000 Read success: Expected 17b5f753, Got 17b5f753 raddr 2d8
# time = 171485000 Read success: Expected e428b0a7, Got e428b0a7 raddr 2d9
# time = 171505000 Read success: Expected ed3f244d, Got ed3f244d raddr 2da
# time = 171525000 Read success: Expected 41827315, Got 41827315 raddr 2db
# time = 171545000 Read success: Expected cl1c9142, Got cl1c9142 raddr 2dc
# time = 171565000 Read success: Expected 586cfab, Got 586cfab raddr 2dd
# time = 171585000 Read success: Expected 331f629f, Got 331f629f raddr 2de
# time = 171605000 Read success: Expected 87b874c6, Got 87b874c6 raddr 2df
# time = 171625000 Read success: Expected 3e930251, Got 3e930251 raddr 2eo
```

## Waveform

## Write



As WVALID & WREADY is high data written in memory and at the end WLAST asserted and response OKAY (0)



Long burst



Write burst out of bound so didn't written in memory and response = 2 (SLVERR)

## Read



When RVALID & RREADY are high we read from memory and at the end of burst RLAST is high



## Long burst



Read burst out of bound so RDATA = 0 and response = 2 (SLVERR)

Log

```

# burst write of wlengt 216 from byte waddress 870 (word waddress 217)
# Write response success:GRAY 0
# check that if data burst writing successfully in memory
# time = 91780000 Write success: Expected 7adcd6, Got 7adcd6 waddr 217
# time = 91780000 Write success: Expected 42af01da, Got 42af01da waddr 218
# time = 91780000 Write success: Expected 42af01da, Got 42af01da waddr 219
# time = 91780000 Write success: Expected b377737e, Got b377737e waddr 220
# time = 91780000 Write success: Expected 420cc8db, Got 420cc8db waddr 221
# time = 91780000 Write success: Expected 370cc8db, Got 370cc8db waddr 222
# time = 91780000 Write success: Expected fbd3f1d6, Got fbd3f1d6 waddr 223
# time = 91780000 Write success: Expected as1d54b, Got as1d54b waddr 224
# time = 91780000 Write success: Expected 5c05bd61, Got 5c05bd61 waddr 225
# time = 91780000 Write success: Expected d3d90748, Got d3d90748 waddr 226
# time = 91780000 Write success: Expected b40bd813, Got b40bd813 waddr 227
# time = 91780000 Write success: Expected 120e4b16, Got 120e4b16 waddr 228
# time = 91780000 Write success: Expected b7962495f, Got b7962495f waddr 229
# time = 91780000 Write success: Expected f3ff9c5d, Got f3ff9c5d waddr 230
# time = 91780000 Write success: Expected 3ec95156, Got 3ec95156 waddr 231
# time = 91780000 Write success: Expected 69777ad3, Got 69777ad3 waddr 232
# time = 91780000 Write success: Expected 33fb9650, Got 33fb9650 waddr 233
# time = 91780000 Write success: Expected 9bb91bf1, Got 9bb91bf1 waddr 234
# time = 91780000 Write success: Expected 1117bd12, Got 1117bd12 waddr 235
# time = 91780000 Write success: Expected 9cf6f6107, Got 9cf6f6107 waddr 236
# time = 91780000 Write success: Expected 8ccfbfe1, Got 8ccfbfe1 waddr 237
# time = 91780000 Write success: Expected 3ds29b16, Got 3ds29b16 waddr 238
# time = 91780000 Write success: Expected 541b1c68, Got 541b1c68 waddr 239
# time = 91780000 Write success: Expected af373bb0, Got af373bb0 waddr 240
# time = 91780000 Write success: Expected 142bc51e, Got 142bc51e waddr 241
# time = 91780000 Write success: Expected 20491la1, Got 20491la1 waddr 242
# time = 91780000 Write success: Expected 25718df5, Got 25718df5 waddr 243
# time = 91780000 Write success: Expected 52849b06, Got 52849b06 waddr 244
# time = 91780000 Write success: Expected Sace2a90, Got Sace2a90 waddr 245

# burst read of rlengt 216 from byte raddress 870 (word raddress 217)
# time = 176355000 Read success: Expected 7afcd6d6, Got 7afcd6d6 raddr 217
# time = 176375000 Read success: Expected 42af01da, Got 42af01da raddr 218
# time = 176395000 Read success: Expected dcceac, Got dcceac raddr 219
# time = 176415000 Read success: Expected b377737e, Got b377737e raddr 220
# time = 176435000 Read success: Expected b7f84c79, Got b7f84c79 raddr 221
# time = 176455000 Read success: Expected 370cc8db, Got 370cc8db raddr 222
# time = 176475000 Read success: Expected fbd3f1d6, Got fbd3f1d6 raddr 223
# time = 176495000 Read success: Expected as1d54b, Got as1d54b raddr 224
# time = 176515000 Read success: Expected 5c05bd61, Got 5c05bd61 raddr 225
# time = 176535000 Read success: Expected 3d3d90748, Got 3d3d90748 raddr 226
# time = 176555000 Read success: Expected b40bd813, Got b40bd813 raddr 227
# time = 176575000 Read success: Expected 120e4b16, Got 120e4b16 raddr 228
# time = 176615000 Read success: Expected b7962495f, Got b7962495f raddr 229
# time = 176635000 Read success: Expected f3ff9c5d, Got f3ff9c5d raddr 230
# time = 176655000 Read success: Expected 3ec95156, Got 3ec95156 raddr 231
# time = 176675000 Read success: Expected 69777ad3, Got 69777ad3 raddr 232
# time = 176695000 Read success: Expected 33fb9650, Got 33fb9650 raddr 233
# time = 176715000 Read success: Expected 9bb91bf1, Got 9bb91bf1 raddr 234
# time = 176735000 Read success: Expected 1117bd12, Got 1117bd12 raddr 235
# time = 176755000 Read success: Expected 9cf6f6107, Got 9cf6f6107 raddr 236
# time = 176775000 Read success: Expected 8ccfbfe1, Got 8ccfbfe1 raddr 237
# time = 176795000 Read success: Expected 3ds29b16, Got 3ds29b16 raddr 238
# time = 176815000 Read success: Expected 541b1c68, Got 541b1c68 raddr 239
# time = 176835000 Read success: Expected af373bb0, Got af373bb0 raddr 240
# time = 176855000 Read success: Expected 142bc51e, Got 142bc51e raddr 241
# time = 176875000 Read success: Expected 20491la1, Got 20491la1 raddr 242
# time = 176895000 Read success: Expected 25718df5, Got 25718df5 raddr 243
# time = 176915000 Read success: Expected 52849b06, Got 52849b06 raddr 244
# time = 176935000 Read success: Expected Sace2a90, Got Sace2a90 raddr 245
# time = 176955000 Read success: Expected 40ce2a5f, Got 40ce2a5f raddr 246

```

## Long burst

```

# burst write of width 7 from byte waddr 4095 (word waddr 1022)
# time = 182570000 out of bound address to write to resp = 2'b10
# burst write of width 2 from byte waddr 4090 (word waddr 1021)
# time = 182430000 out of bound address to write to resp = 2'b10
# burst write of width 15 from byte waddr 4087 (word waddr 1016)
# time = 182330000 out of bound address to write to resp = 2'b10
# burst write of width 14 from byte waddr 4074 (word waddr 1018)
# time = 183060000 out of bound address to write to resp = 2'b10
# burst write of width 5 from byte waddr 4034 (word waddr 1013)
# time = 183140000 Write success! Expected 84f3b7fb, Got f03a74da waddr 1013
# check that if data burst written successfully in memory
# time = 183270000 out of bound address to read from resp = 2'b10
# burst write of width 8 from byte waddr 4087 (word waddr 1021)
# time = 183270000 out of bound address to write to resp = 2'b10
# burst write of width 9 from byte waddr 57673 (word waddr 1418)
# time = 183420000 out of bound address to write to resp = 2'b10
# burst write of width 5 from byte waddr 4072 (word waddr 1018)
# Write response success! OCGAY 0
# check that if data burst written successfully in memory
# time = 183550000 Write success! Expected 25dfca56, Got 25dfca96 waddr 1018
# time = 183550000 Write success! Expected 2536e254, Got 2536e25d waddr 1019
# time = 183550000 Write success! Expected 36ee241e, Got 36ee241e waddr 1020
# time = 183550000 Write success! Expected 41202abd, Got 41202abd waddr 1021
# time = 183550000 Write success! Expected b375f484, Got b375f484 waddr 1022
# at the end of simulation, correct_count = 10673, error_count = 0

```

Read and write operation also out of bound operation

```

# at the end of simulation, correct_count = 10673, error_count = 0

```

## Coverage

### Assertion Coverage

|  |                                                         |            |     |    |   |   |   |    |    |      |       |                                      |   |
|--|---------------------------------------------------------|------------|-----|----|---|---|---|----|----|------|-------|--------------------------------------|---|
|  | /axi4_top/TEST/write_burst_of_data/immed_150            | Immediate  | SVA | on | 0 | 1 | - | -  | -  | -    | off   | assert (randomize(...))              | ✓ |
|  | /axi4_top/TEST/read_burst_of_data/immed_257             | Immediate  | SVA | on | 0 | 1 | - | -  | -  | -    | off   | assert (randomize(...))              | ✓ |
|  | /axi4_top/TEST/read_burst_of_data/#ublk#149726914#27... | Immediate  | SVA | on | 0 | 1 | - | -  | -  | -    | off   | assert (randomize(...))              | ✓ |
|  | /axi4_top/DUT/sva/assert_rst                            | Immediate  | SVA | on | 0 | 1 | - | -  | -  | -    | off   | assert (randomize(...))              | ✓ |
|  | /axi4_top/DUT/sva/cck_check                             | Immediate  | SVA | on | 0 | 1 | - | -  | -  | -    | off   | assert (axi4f_AVREADY === 1'baxi...) | ✓ |
|  | /axi4_top/DUT/sva/ap_address_write                      | Concurrent | SVA | on | 0 | 1 | - | 0B | 0B | 0 ps | 0 off | assert( @posedge axi4f_ACLK d...     | ✓ |
|  | /axi4_top/DUT/sva/ap_address_read                       | Concurrent | SVA | on | 0 | 1 | - | 0B | 0B | 0 ps | 0 off | assert( @posedge axi4f_ACLK d...     | ✓ |
|  | /axi4_top/DUT/sva/ap_writeData                          | Concurrent | SVA | on | 0 | 1 | - | 0B | 0B | 0 ps | 0 off | assert( @posedge axi4f_ACLK d...     | ✓ |
|  | /axi4_top/DUT/sva/ap_writeResponse                      | Concurrent | SVA | on | 0 | 1 | - | 0B | 0B | 0 ps | 0 off | assert( @posedge axi4f_ACLK d...     | ✓ |

| Name                                  | Language | Enabled | Log | Count | AtLeast | Limit  | Weight | Cmpit % | Cmpit graph | Included | Memory | Peak Memory | Peak Memory Time | Cumulative Threads |
|---------------------------------------|----------|---------|-----|-------|---------|--------|--------|---------|-------------|----------|--------|-------------|------------------|--------------------|
| /axi4_top/DUT/sva/cp_address_write    | SVA      | ✓       | Off | 7231  | 1       | Unl... | 1      | 100%    | ✓           | ✓        | 0      | 0           | 0 ps             | 0                  |
| /axi4_top/DUT/sva/cp_address_read     | SVA      | ✓       | Off | 11282 | 1       | Unl... | 1      | 100%    | ✓           | ✓        | 0      | 0           | 0 ps             | 0                  |
| /axi4_top/DUT/sva/cp_writeData        | SVA      | ✓       | Off | 5871  | 1       | Unl... | 1      | 100%    | ✓           | ✓        | 0      | 0           | 0 ps             | 0                  |
| /axi4_top/DUT/sva/cp_writeResponse... | SVA      | ✓       | Off | 136   | 1       | Unl... | 1      | 100%    | ✓           | ✓        | 0      | 0           | 0 ps             | 0                  |

## Functional Coverage



## Code Coverage

### Memory Code Coverage

| Expression Coverage: |          |      |         |         |
|----------------------|----------|------|---------|---------|
| Enabled              | Coverage | Bins | Covered | Misses  |
| Expressions          |          | 5    | 5       | 0       |
|                      |          |      |         | 100.00% |

| Statement Coverage: |      |      |        |          |
|---------------------|------|------|--------|----------|
| Enabled Coverage    | Bins | Hits | Misses | Coverage |
| Statements          | 7    | 7    | 0      | 100.00%  |

| Branch Coverage: |      |      |        |          |
|------------------|------|------|--------|----------|
| Enabled Coverage | Bins | Hits | Misses | Coverage |
| Branches         | 5    | 5    | 0      | 100.00%  |

| ====Toggle Details=====                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-----------------|--------|--------|------------|--|------|--------|--------|------------|--|--|-----|---|---|--------|--|--|---------|---|---|------|--|--|---------------|---|---|--------|--|--|--------|---|---|--------|--|--|-----------------|---|---|--------|--|--|-----------------|---|---|--------|--|--|--------|---|---|--------|--|--|-------|---|---|--------|
| Toggle Coverage for instance /axi4_top#DUT /mem_inst --                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
| <table border="1"> <thead> <tr> <th></th> <th></th> <th>Node</th> <th>1H-&gt;0L</th> <th>0L-&gt;1H</th> <th>"Coverage"</th> </tr> </thead> <tbody> <tr> <td></td> <td></td> <td>clk</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>j[31:0]</td> <td>0</td> <td>0</td> <td>0.00</td> </tr> <tr> <td></td> <td></td> <td>mem_addr[0:9]</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>mem_en</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>mem_rdata[31:0]</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>mem_wdata[0:31]</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>mem_we</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> <tr> <td></td> <td></td> <td>rst_n</td> <td>1</td> <td>1</td> <td>100.00</td> </tr> </tbody> </table> |  |                 |        |        |            |  | Node | 1H->0L | 0L->1H | "Coverage" |  |  | clk | 1 | 1 | 100.00 |  |  | j[31:0] | 0 | 0 | 0.00 |  |  | mem_addr[0:9] | 1 | 1 | 100.00 |  |  | mem_en | 1 | 1 | 100.00 |  |  | mem_rdata[31:0] | 1 | 1 | 100.00 |  |  | mem_wdata[0:31] | 1 | 1 | 100.00 |  |  | mem_we | 1 | 1 | 100.00 |  |  | rst_n | 1 | 1 | 100.00 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | Node            | 1H->0L | 0L->1H | "Coverage" |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | clk             | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | j[31:0]         | 0      | 0      | 0.00       |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | mem_addr[0:9]   | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | mem_en          | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | mem_rdata[31:0] | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | mem_wdata[0:31] | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | mem_we          | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  | rst_n           | 1      | 1      | 100.00     |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
| Total Node Count = 119                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
| Toggled Node Count = 78                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
| Untoggled Node Count = 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |
| Toggle Coverage = 70.90% (156 of 220 bins)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |                 |        |        |            |  |      |        |        |            |  |  |     |   |   |        |  |  |         |   |   |      |  |  |               |   |   |        |  |  |        |   |   |        |  |  |                 |   |   |        |  |  |                 |   |   |        |  |  |        |   |   |        |  |  |       |   |   |        |

J is just a loop iterator execute at zero time

### Slave Code Coverage

#### Branch Coverage

| Branch Coverage: |      |      |        |          |
|------------------|------|------|--------|----------|
| Enabled Coverage | Bins | Hits | Misses | Coverage |
| Branches         | 35   | 33   | 2      | 94.28%   |

| -----CASE Branch-----                        |   |         |                                 |  |
|----------------------------------------------|---|---------|---------------------------------|--|
| 188                                          | 1 | 18729   | Count coming in to CASE         |  |
| 189                                          | 1 | 11788   | W_IDLE: begin                   |  |
| 126                                          | 1 | 136     | W_ADDR: begin                   |  |
| 132                                          | 1 | 6737    | W_DATA: begin                   |  |
| 163                                          | 1 | 148     | W RESP: begin                   |  |
| 171                                          | 1 | ***0*** | default: write_state <= W_IDLE; |  |
| Branch totals: 4 hits of 5 branches = 80.00% |   |         |                                 |  |
| -----CASE Branch-----                        |   |         |                                 |  |
| 178                                          | 1 | 18729   | Count coming in to CASE         |  |
| 179                                          | 1 | 7565    | R_IDLE: begin                   |  |
| 196                                          | 1 | 135     | R_ADDR: begin                   |  |
| 206                                          | 1 | 11029   | R_DATA: begin                   |  |
| 242                                          | 1 | ***0*** | default: read_state <= R_IDLE;  |  |
| Branch totals: 3 hits of 4 branches = 75.00% |   |         |                                 |  |

Normal as we expect not enter default during execution of design

#### Condition Coverage

| Condition Coverage: |      |         |        |          |
|---------------------|------|---------|--------|----------|
| Enabled Coverage    | Bins | Covered | Misses | Coverage |
| Conditions          | 23   | 20      | 3      | 86.95%   |

```

-----Focused Condition View-----
Line    133 Item   1  (axi4if.WVALID && axi4if.WREADY)
Condition totals: 1 of 2 input terms covered = 50.00%

```

| Input Term    | Covered        | Reason for no coverage | Hint     |
|---------------|----------------|------------------------|----------|
| axi4if.WVALID | Y              |                        |          |
| axi4if.WREADY | N '_0' not hit |                        | Hit '_0' |

| Rows:  | Hits    | FEC Target      | Non-masking condition(s) |
|--------|---------|-----------------|--------------------------|
| Row 1: | 1       | axi4if.WVALID_0 | -                        |
| Row 2: | 1       | axi4if.WVALID_1 | axi4if.WREADY            |
| Row 3: | ***0*** | axi4if.WREADY_0 | axi4if.WVALID            |
| Row 4: | 1       | axi4if.WREADY_1 | axi4if.WVALID            |

```

-----Focused Condition View-----
Line    144 Item   1  (axi4if.WLAST || (write_burst_cnt == 0))
Condition totals: 1 of 2 input terms covered = 50.00%

```

| Input Term             | Covered        | Reason for no coverage | Hint     |
|------------------------|----------------|------------------------|----------|
| axi4if.WLAST           | Y              |                        |          |
| (write_burst_cnt == 0) | N '_1' not hit |                        | Hit '_1' |

| Rows:  | Hits    | FEC Target               | Non-masking condition(s) |
|--------|---------|--------------------------|--------------------------|
| Row 1: | 1       | axi4if.WLAST_0           | ~(write_burst_cnt == 0)  |
| Row 2: | 1       | axi4if.WLAST_1           | -                        |
| Row 3: | 1       | (write_burst_cnt == 0)_0 | ~axi4if.WLAST            |
| Row 4: | ***0*** | (write_burst_cnt == 0)_1 | ~axi4if.WLAST            |

```

-----Focused Condition View-----
Line    164 Item   1  (axi4if.BREADY && axi4if.BVALID)
Condition totals: 1 of 2 input terms covered = 50.00%

```

| Input Term    | Covered        | Reason for no coverage | Hint     |
|---------------|----------------|------------------------|----------|
| axi4if.BREADY | Y              |                        |          |
| axi4if.BVALID | N '_0' not hit |                        | Hit '_0' |

| Rows:  | Hits    | FEC Target      | Non-masking condition(s) |
|--------|---------|-----------------|--------------------------|
| Row 1: | 1       | axi4if.BREADY_0 | -                        |
| Row 2: | 1       | axi4if.BREADY_1 | axi4if.BVALID            |
| Row 3: | ***0*** | axi4if.BVALID_0 | axi4if.BREADY            |
| Row 4: | 1       | axi4if.BVALID_1 | axi4if.BREADY            |

## FSM Coverage

| Uncovered Transitions : |          |                  |
|-------------------------|----------|------------------|
| Line                    | Trans_ID | Transition       |
| 81                      | 2        | W_ADDR -> W_IDLE |
| 81                      | 4        | W_DATA -> W_IDLE |

  

| Summary         | Bins | Hits | Misses | Coverage |
|-----------------|------|------|--------|----------|
| FSM States      | 4    | 4    | 0      | 100.00%  |
| FSM Transitions | 6    | 4    | 2      | 66.66%   |

  

| Uncovered Transitions : |          |                  |
|-------------------------|----------|------------------|
| Line                    | Trans_ID | Transition       |
| 82                      | 2        | R_ADDR -> R_IDLE |

  

| Summary         | Bins | Hits | Misses | Coverage |
|-----------------|------|------|--------|----------|
| FSM States      | 3    | 3    | 0      | 100.00%  |
| FSM Transitions | 4    | 3    | 1      | 75.00%   |

This uncovered transition totally accepted as in our FSM its impossible to go from R\_ADDR to R\_IDLE or from W\_ADDR ,W\_DATA to W\_IDLE

## Statement Coverage

| Statement Coverage: |      |      |        |          |
|---------------------|------|------|--------|----------|
| Enabled Coverage    | Bins | Hits | Misses | Coverage |
| Statements          | 85   | 83   | 2      | 97.64%   |

|   |         |                                |   |         |                                 |
|---|---------|--------------------------------|---|---------|---------------------------------|
| 1 | ***0*** | default: read_state <= R_IDLE; | 1 | ***0*** | default: write_state <= W_IDLE; |
|---|---------|--------------------------------|---|---------|---------------------------------|

Default never executed expected

## Toggle Coverage

|                       | Node | 1H->0L | 0L->1H            | "Coverage" |
|-----------------------|------|--------|-------------------|------------|
| mem_addr[9-0]         | 1    | 1      | 100.00            |            |
| mem_en                | 1    | 1      | 100.00            |            |
| mem_rdata[0-31]       | 1    | 1      | 100.00            |            |
| mem_rdata_reg[31-0]   | 0    | 0      | 0.00              |            |
| mem_wdata[31-0]       | 1    | 1      | 100.00            |            |
| mem_we                | 1    | 1      | 100.00            |            |
| read_addr[15-0]       | 1    | 1      | 100.00            |            |
| read_addr_incr[0]     | 1    | 1      | 100.00            |            |
| read_addr_incr[1]     | 0    | 0      | 0.00              |            |
| read_addr_incr[2]     | 1    | 1      | 100.00            |            |
| read_addr_incr[3-15]  | 0    | 0      | 0.00              |            |
| read_addr_valid       | 1    | 1      | 100.00            |            |
| read_boundary_cross   | 1    | 1      | 100.00            |            |
| read_burst_cnt[7-0]   | 1    | 1      | 100.00            |            |
| read_burst_len[7-0]   | 1    | 1      | 100.00            |            |
| read_size[2]          | 0    | 0      | 0.00              |            |
| read_size[1]          | 1    | 1      | 100.00            |            |
| read_size[0]          | 0    | 0      | 0.00              |            |
| read_state[2]         | 0    | 0      | 0.00              |            |
| read_state[1-0]       | 1    | 1      | 100.00            |            |
| write_addr[15-0]      | 1    | 1      | 100.00            |            |
| write_addr_incr[0]    | 1    | 1      | 100.00            |            |
| write_addr_incr[1]    | 0    | 0      | 0.00              |            |
| write_addr_incr[2]    | 1    | 1      | 100.00            |            |
| write_addr_incr[3-15] | 0    | 0      | 0.00              |            |
| write_addr_valid      | 1    | 1      | 100.00            |            |
| write_boundary_cross  | 1    | 1      | 100.00            |            |
| write_burst_cnt[7-0]  | 1    | 1      | 100.00            |            |
| write_burst_len[7-0]  | 1    | 1      | 100.00            |            |
| write_size[2]         | 0    | 0      | 0.00              |            |
| write_size[1]         | 1    | 1      | 100.00            |            |
| write_size[0]         | 0    | 0      | 0.00              |            |
| write_state[2]        | 0    | 0      | 0.00              |            |
| write_state[1-0]      | 1    | 1      | 100.00            |            |
| Total Node Count      | =    | 220    |                   |            |
| Toggled Node Count    | =    | 154    |                   |            |
| Untoggled Node Count  | =    | 66     |                   |            |
| Toggle Coverage       | =    | 70.00% | (308 of 440 bins) |            |

Mem\_rdata\_reg is a register that never used in the design

read\_size and write\_size always take value 2

read\_addr\_incr and write\_addr\_incr always take value 4

read\_state and write\_state as I have specific state to go through them

Total Code Coverage

Total Coverage By Instance (filtered view): 91.16%

## GitHub repository for code details

[RanaAyman54/AXI4-Compliant-Memory-Mapped-Slave](https://github.com/RanaAyman54/AXI4-Compliant-Memory-Mapped-Slave)