# **Direct Memory Access Controller**

Final Design Review

ECE 551 – SoC Design

#### Members (Team 4):

- Sk Hasibul Alam
- Milad Tanavardi Nasab
- Tanjina Sabrin

# Interrupt Handler



# Interrupt Handler: Post-synthesis Simulation Result



- 1: Access required by peripheral 2, DMAC is not busy
- 2: Access granted to peripheral 2
- 3: ISR has sent the request to the DMAC and waiting for DMAC to start
- 4: DMAC is not busy, peripheral 2 and 3 requiring access
- 5: Access is granted to peripheral 2, due to its higher priority
- 6: ISR has sent the request to the DMA and waiting for DMAC to start
- 7: DMAC is busy, but ISR can grant access to higher priority access requirement

- 8: Access required by peripheral 1
- 9: Access granted to peripheral 1, due to its higher priority

# Interrupt Handler: Layout and DRC Report

|             |                  |                                                                                                                                                                                                                                   | vdd!          |                    |      |           |
|-------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------|------|-----------|
|             |                  |                                                                                                                                                                                                                                   | gnd!          |                    |      |           |
|             |                  |                                                                                                                                                                                                                                   |               | 7-,                | 1    |           |
|             | 1. 3. res[0] ,67 | Ser. 198 82 44                                                                                                                                                                                                                    | ss[0] percusa | 95[0] <u>1.</u> 70 |      |           |
|             |                  | tr.reg (1) 4/5                                                                                                                                                                                                                    |               | -1_53              |      |           |
|             | A Depervid       | rest11                                                                                                                                                                                                                            |               | 511, 1 501 A.1, 54 |      |           |
| 2           | .1.30 .1.3       | 31.39                                                                                                                                                                                                                             | 44            | 4347               | jang |           |
|             |                  | مرور بر مرد المرد ال<br>مرد المرد | 4-1-12-0314   | y1_32,1_33,73      |      |           |
|             | 1_191_29         |                                                                                                                                                                                                                                   | 22 2 ///      | 1,25.1,29          |      |           |
|             | ويدولاله ويدو    | 11                                                                                                                                                                                                                                |               | 91.15, 17 (brit.17 |      |           |
|             |                  | is_reg[i]                                                                                                                                                                                                                         |               |                    |      |           |
|             |                  |                                                                                                                                                                                                                                   | gndl          |                    |      |           |
|             |                  |                                                                                                                                                                                                                                   |               |                    |      | CARGE CAR |
| (BLADERHALL |                  |                                                                                                                                                                                                                                   | vddl          |                    |      |           |

|                                                                                                                                                                                                                        | Terminal _ 🗖                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| File Edit View Search Terminal Help                                                                                                                                                                                    |                                                       |
| routeDesign: cpu time = 00:00:02, el<br>peak = 963.59 (MB)<br>** Message Summary: 0 warning(s), 0                                                                                                                      | apsed time = 00:00:02, memory = 931.88 (M<br>error(s) |
| .nnovus 1> #-check_implant false<br>:tting                                                                                                                                                                             | <pre># bool, default=true, user</pre>                 |
| t-check_ndr_spacing auto<br>user setting                                                                                                                                                                               | <pre># enums={true false auto}, default=au</pre>      |
| -report int_handler.drc.rpt<br>*** Starting Verify DRC (MEM: 1205.6                                                                                                                                                    | 51                                                    |
| VERIFY DRC Starting Verifica<br>VERIFY DRC Initializing<br>VERIFY DRC Deleting Existing<br>VERIFY DRC Creating Sub-Area<br>VERIFY DRC Using new threadi<br>VERIFY DRC Sub-Area: {0.000<br>VERIFY DRC Sub-Area : 1 comp | Violations<br>s<br>ng<br>0.000 71.400 71.400} 1 of 1  |
| Verification Complete : 0 Viols.                                                                                                                                                                                       |                                                       |
| *** End Verify DRC (CPU: 0:00:00.1                                                                                                                                                                                     | ELAPSED TIME: 0.00 MEM: 0.0M) ***                     |
| nnovus 1>                                                                                                                                                                                                              |                                                       |

# Where we left: Overall Hierarchy



# ISR Wrapper



### Includes

- Interrupt Service Routine
- AXI\_master module

IV Geometry Violation: 0 IV Connectivity Violation: 0

### **IV DRC Report:**

#-report axi\_wrap\_proc.drc.rpt # string, default="", user sett
 \*\*\* Starting Verify DRC (MEM: 2295.1) \*\*\*

VERIFY DRC ..... Starting Verification VERIFY DRC ..... Initializing VERIFY DRC ..... Deleting Existing Violations VERIFY DRC ..... Creating Sub-Areas \*\*WARN: (IMPVFG-1198): The number of CPUs requested 8 is larger than th mode, the number of CPUs verify\_drc used is not larger than the number o Use 'setMultiCpuUsage -localCpu' to specify the less cup number if the VERIFY DRC ..... Using new threading VERIFY DRC ..... Sub-Area: {0.000 0.000 103.700 96.560} 1 of 1 VERIFY DRC ..... Sub-Area : 1 complete 0 Viols.

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.1 ELAPSED TIME: 0.00 MEM: 0.0M) \*\*\*

### Calibre DRC Violations: 52

- (6) M3 vertex must not be connected to two short edges with length < 0.1
- (2) M2 vertex must not be connected to two short edges with length < 0.1
- (44) M3 minimum area >= 0.052

Area=  $(103.7 \times 96.56)\mu m^2 = 23037.9 \mu m^2$ Density= 63.36%

# DMAC Wrapper



WA.

### Includes

- DMA\_ctrl module
- AXI\_master module

#### IV Geometry Violation: 0 IV Connectivity Violation: 0

### **IV DRC Report:**

#-report axi\_wrap\_dma.drc.rpt # string, default="", user setting
 \*\*\* Starting Verify DRC (MEM: 2211.0) \*\*\*

VERIFY DRC ..... Starting Verification VERIFY DRC ..... Initializing VERIFY DRC ..... Deleting Existing Violations VERIFY DRC ..... Creating Sub-Areas \*\*WARN: (IMPVFG-1198): The number of CPUs requested 8 is larger than that veri mode, the number of CPUs verify\_drc used is not larger than the number of subar Use 'setMultiCpuUsage -localCpu' to specify the less cup number if the verify VERIFY DRC ..... Using new threading VERIFY DRC ..... Sub-Area: {0.000 0.000 77.760 148.920} 1 of 2 Thread : 0 VERIFY DRC ..... Thread : 1 finished. VERIFY DRC ..... Sub-Area: {77.760 0.000 154.700 148.920} 2 of 2 Thread : 0 VERIFY DRC ..... Thread : 0 finished.

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.1 ELAPSED TIME: 0.00 MEM: 0.0M) \*\*\*



#### Calibre DRC Violations: 58

- (18) M2 vertex must not be connected to two short edges with length < 0.1
- (40) M2 minimum area >= 0.052

Area=  $(154.7 \times 148.92)\mu m^2 = 23037.9 \ \mu m^2$ Density= 74.92%

# DMA Register Wrapper



### Includes

- DMA\_reg module
- AXI\_slave module

#### IV Geometry Violation: 0 IV Connectivity Violation: 0

### **IV DRC Report:**

#-report axi\_wrap\_dmareg.drc.rpt # string, default="", user sett
 \*\*\* Starting Verify DRC (MEM: 2233.0) \*\*\*

VERIFY DRC ..... Starting Verification VERIFY DRC ..... Initializing VERIFY DRC ..... Deleting Existing Violations VERIFY DRC ..... Creating Sub-Areas \*\*WARN: (IMPVFG-1198): The number of CPUs requested 8 is larger than th mode, the number of CPUs verify\_drc used is not larger than the number c Use 'setMultiCpuUsage -localCpu' to specify the less cup number if the VERIFY DRC ..... Using new threading VERIFY DRC ..... Sub-Area: {0.000 0.000 91.120 87.040} 1 of 1 VERIFY DRC ..... Sub-Area : 1 complete 0 Viols.

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.0 ELAPSED TIME: 0.00 MEM: 0.0M) \*\*\*



### Calibre DRC Violations: 29

- (2) M3 vertex must not be connected to two short edges with length < 0.1
- (27) M3 minimum area >= 0.052

Area=  $(91.12 \times 87.04)\mu m^2 = 7931.1 \ \mu m^2$ Density= 59.42%



DMA\_Reg and DMAC gate-level netlist verification

# Crossbar



### Full matrix cross-connection

IV Geometry Violation: 0 IV Connectivity Violation: 0

#### **IV DRC Report:**

#-report crossbar.drc.rpt # string, default="", user sett
 \*\*\* Starting Verify DRC (MEM: 1055.4) \*\*\*

VERIFY DRC ..... Starting Verification
 VERIFY DRC ..... Initializing
 VERIFY DRC ..... Deleting Existing Violations
 VERIFY DRC ..... Creating Sub-Areas
 VERIFY DRC ..... Using new threading
 VERIFY DRC ..... Sub-Area: {0.000 0.000 96.220 91.800} 1 of 1
 VERIFY DRC ..... Sub-Area : 1 complete 0 Viols.

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.1 ELAPSED TIME: 0.00 MEM: 0.0M) \*\*\*



### Calibre DRC Violations: 52

• (52) M1 minimum area >= 0.042

Area=  $(96.22 \times 91.8)\mu m^2 = 8832.99 \ \mu m^2$ Density= 61.29%



crossbar gate-level netlist verification





axi\_master and axi\_slave gate-level netlist verification

# Compiled SRAM Array



Topology:  $16 \times 32 \times 8$ Calibre DRC Violation: 0 Area=  $(70.99 \times 52.98)\mu m^2 = 3761.05 \mu m^2$ 

# Memory Wrapper



### Includes

- 4 banks of SRAM
- Memory controller
- AXI\_slave module

#### **IV DRC Report:**

#-report axi\_wrap\_mem.drc.rpt # string, default="", user setting
 \*\*\* Starting Verify DRC (MEM: 1047.2) \*\*\*

| VERIFY | DRC | <br>Starting Verification                             |
|--------|-----|-------------------------------------------------------|
| VERIFY | DRC | <br>Initializing                                      |
| VERIFY | DRC | <br>Deleting Existing Violations                      |
| VERIFY | DRC | <br>Creating Sub-Areas                                |
| VERIFY | DRC | <br>Using new threading                               |
| VERIFY | DRC | <br>Sub-Area: {0.000 0.000 109.440 86.400} 1 of 4     |
| VERIFY | DRC | <br>Sub-Area : 1 complete 0 Viols.                    |
| VERIFY | DRC | <br>Sub-Area: {109.440 0.000 218.280 86.400} 2 of 4   |
| VERIFY | DRC | <br>Sub-Area : 2 complete 0 Viols.                    |
| VERIFY | DRC | <br>Sub-Area: {0.000 86.400 109.440 172.720} 3 of 4   |
| VERIFY | DRC | <br>Sub-Area : 3 complete 0 Viols.                    |
| VERIFY | DRC | <br>Sub-Area: {109.440 86.400 218.280 172.720} 4 of 4 |
| VERIFY | DRC | <br>Sub-Area : 4 complete 0 Viols.                    |

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.2 ELAPSED TIME: 0.00 MEM: 7.0M) \*\*\*



### Calibre DRC Violations: 169

- (15) BF minimum space and notch > = 0.47
- (40) RX minimum width > = 0.08
- (40) RX minimum space and notch > = 0.11
- (4) M3 vertex must not be connected to two short edges with length < 0.1
- (12) M1 vertex must not be connected to two short edges with length < 0.09
- (6) M1 minimum space and notch > = 0.09
- (2) (V3 Array with width > 1.090 ) minimum space V3 array >= 0.700
- (21) M2 minimum area >= 0.052
- (15) NW minimum space > = 0.47
- (3) M2 minimum space to (M2 WITH WIDTH > 0.200), for run length > 0.380, >= 0.12
- (11) M2 minimum space to (M2 WITH WIDTH > 0.420), for run length > 0.420, >= 0.16

Area=  $(218.28 \times 172.72)\mu m^2 = 37701.32 \ \mu m^2$ Density= 52.13%

# Top Module



#### **Amoeba View:**



#### IV DRC Report:

VERIFY DRC ..... Starting Verification VERIFY DRC ..... Initializing VERIFY DRC ..... Deleting Existing Violations VERIFY DRC ..... Creating Sub-Areas VERIFY DRC ..... Using new threading VERIFY DRC ..... Sub-Area: {0.000 227.520 141.120 339.320} 7 of 9 Thread : 0 VERIFY DRC ..... Sub-Area: {282.240 0.000 422.620 113.760} 3 of 9 Thread : 7 VERIFY DRC ..... Sub-Area: {282.240 227.520 422.620 339.320} 9 of 9 Thread : 4 VERIFY DRC ..... Sub-Area: {0.000 0.000 141.120 113.760} 1 of 9 Thread : 3 VERIFY DRC ..... Sub-Area: {0.000 113.760 141.120 227.520} 4 of 9 Thread : 3 VERIFY DRC ..... Sub-Area: {282.240 113.760 422.620 227.520} 6 of 9 Thread : 4 VERIFY DRC ..... Sub-Area: {141.120 0.000 282.240 113.760} 2 of 9 Thread : 4 VERIFY DRC ..... Sub-Area: {141.120 227.520 282.240 339.320} 8 of 9 Thread : 3 VERIFY DRC ..... Thread : 4 finished. VERIFY DRC ..... Thread : 7 finished. VERIFY DRC ..... Sub-Area: {141.120 113.760 282.240 227.520} 5 of 9 Thread : 3 VERIFY DRC ..... Thread : 3 finished.

Verification Complete : 0 Viols.

\*\*\* End Verify DRC (CPU: 0:00:00.4 ELAPSED TIME: 0.00 MEM: 32.0M) \*\*\*



#### Calibre DRC Violations: 1235

- (362) M1 minimum space and notch > = 0.09
- (141) M3 minimum space and notch > = 0.1
- (131) M2 minimum space and notch > = 0.1
- (111) M2 vertex must not be connected to two short edges with length < 0.1
- (60) M3 vertex must not be connected to two short edges with length < 0.1
- and some more

Area=  $(422.62 \times 339.32)\mu m^2 = 143403.42 \ \mu m^2$ Density= 87.73%



# Questions? Comments? Concerns?