# Digital ASIC Fabrication: Design – Part 2

**Team 12** Mitchell Driscoll, Evan Dunn, Baoshan Liang, Katie Wolf

**Client & Faculty Advisor** 

Dr. Henry Duwe

### **Project Overview**

#### **Problem Statement**

 Undergraduate students rarely get the opportunity to create a custom digital ASIC (Application Specific Integrated Circuit) and gain experience with chip fabrication.

#### **Project Goals**

- Our project aims to give interested students experience in chip design and fabrication.
- We plan to build a chip framework that will hold small ASIC projects created by students in a co-curricular team.
- The chip framework will allow the students to have their designs fully implemented and synthesized.

# Detailed Design

- Our framework goes into the user project wrapper
- Framework interacts with the management area and user projects
- Interfaces directly with Wishbone bus, logic analyzer, GPIOs
- Management area configured through software





CLK - System clock

**GPIO** - General-Purpose Input/Output

**IO** - Input/Output; data transfer to or from the chip

**IRQ** - Interrupt Request Signal

LA - Logic Analyzer

RST - Reset

**WB** - Wishbone Bus

**WBS** - Wishbone Slave

WE - Write enable

### Functionality

- Users will design independent ASIC projects that will be used as macros in our framework
- Multiple projects can be placed in the framework at once
- Each project can be run independently and access the management core



## **Technology Considerations**

- Mainly using open-source tools and project framework
- Pros:
  - Regular updates
  - Cost-effective
- Cons:
  - Limited support
  - Learning curve
  - Limited compatibility

|           |                    |              |          |          | GTK                   | Wave - J                                         | 'home/bybe                        | ell/gtkwav<br>Marker: 10 s | e/code/gtk<br>sec   Cursor: | wave3-gt<br>38 sec | k3/examples        | des.fst               | ß                      | ٠   | ۰  |     |
|-----------|--------------------|--------------|----------|----------|-----------------------|--------------------------------------------------|-----------------------------------|----------------------------|-----------------------------|--------------------|--------------------|-----------------------|------------------------|-----|----|-----|
| ≡         | <b>%</b> '         | 4 📫 6        |          | <b>-</b> | ) I¢ -                | <b>&gt;)                                    </b> | ↔ From                            | 0 sec                      |                             |                    | 704 sec            |                       | C                      |     |    |     |
| ₹SS       |                    |              |          |          | Signal                |                                                  | Waves                             |                            |                             |                    |                    |                       |                        |     |    |     |
| •#<br>L • | top<br>des<br>— Af | p<br>o       |          |          | ct[]<br>key[]<br>pt[] | clk=1<br>.:64]=C<br>.:64]=0<br>.:64]=0           | )<br>F xx+ 000000<br>0 0000000000 | 10<br>00000+ 60+<br>000000 | Sec                         | 20<br>(16+ )A5+    | sec<br>07+ FB+ 47+ | 30 sec<br>68+ D1+ 88+ | 40<br>735982163E4EDC58 | sec | 50 | sec |
|           | )                  | evsched      |          |          | ct[]                  | :64]=C                                           | F xx+ 000000                      | 00000+ 00+                 | CF+ B0+ FB+                 | 16+ A5+            | 07+ FB+ 47+        | 6B+ D1+ 88+           | 735982163E4EDC58       |     |    |     |
|           | - he also          | ound1_ (rour | dfunc) - |          |                       | clk=1                                            |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | Type               | Signals      |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c0x[1:28]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c1x[1:28]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c2v[1·28]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c3v[1.28]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c/v[1.20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c5v[1.20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | c6v[1:20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | cox[1.20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | cov[1,20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | =0+[1:20]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
|           | wire               | Cax[1:58]    |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
| Filter:   |                    |              |          |          |                       |                                                  |                                   |                            |                             |                    |                    |                       |                        |     |    |     |
| A         | opend              | Insert       | Re       | eplace   |                       | _                                                |                                   |                            |                             |                    |                    |                       |                        |     |    |     |

#### **Concerns and Development**

#### Areas of Concern

- Will current level of complexity support all possible projects going forward?
- With current level of complexity, will all expected modules fit in die area?

#### **Areas of Development**

- Power optimization
  - Clock gating
- Preserving inactive project state

#### Conclusion

- Current design composition is our base design going forward
- Will incorporate more functionality as needed
- Plan to integrate OpenRAM components
- Refine design and constraints as we implement submodules