

# ECE 551

## HW4 *(100 pts)*

- 
- Due Fri Oct 31<sup>st</sup> @ 11:55PM
  - Work Individually
  - Use descriptive signal names
  - Comment & indent your code
  - Code will be judged on coding style

## HW4 Problems 1&2 (**10pts**) + (**5pts**)

---

1. (**10pts**) Complete the Synopsys Design Vision tutorial. Sign below, (preferably in blood).

I, \_\_\_\_\_ completed the Synopsys Design Vision tutorial. If I had any problems with it, I discussed them with the TA or Instructor, either in person, or through email.

2. (**5pts**) Project Team Formation

Form a 3 or 4 person project team, **Come up with a team name**, and fill in the table below:

| Team Name: |  |
|------------|--|
| Person1:   |  |
| Person2:   |  |
| Person3:   |  |
| Person4:   |  |

# HW4 Problem 3 (15pts) Auth\_blk.sv

You are on your own for this one...it is not covered by an exercise.

- An authorized rider will carry a phone with an app that sends the proper authorization code to a BLE module on the "Segway" device. The Segway control board has a BLE121LR module on that will be advertising a "Segway" service. When the users phone scans the service, connects, and sends the appropriate authorization code it will cause the BLE121LR module to send out 0x47 ('G') over its UART TX line. This will in turn cause the **pwr\_up** signal to be asserted
- When the phone app deliberately disconnects, or is disconnected due to range the BLE121LR module sends out 0x53 ('S') over its UART TX line . The "Segway" then shuts down (if the weight on the platform no longer exceeds MIN RIDER WEIGHT (**rider\_off** signal from en\_steer block)).
- The UART will send at 9600 using 8N1 variant.
- Of course once the "Segway" is enabled (**pwr\_up** asserted) it will stay enabled as long as there is a rider on the device. We wouldn't want it to power down and throw the rider just because the phone went dead or the BLE link was interrupted. We have a signal (**rider\_off**) that indicates the weight on the platform does not exceed the minimum allowed rider weight.
- pwr\_up** goes to the **balance\_cntrl** unit to enable it.



## HW4 Problem 3 (15pts) Auth\_blk.sv

- Auth\_blk will be constructed from a UART receiver (*UART\_rx*) and a simple state machine comparing the receptions to ‘G’, ‘S’, and monitoring the **rider\_off** signal.



Draw a bubble diagram. Simulate its operation (in your head) under different scenarios. If it helps...my solution had 3 states.

- pwr\_up** is asserted upon reception of ‘G’ (0x47). It is deasserted after the last reception was ‘S’ and the **rider\_off** signal is high.
- UART\_rx** was developed as part of HW3

# HW4 Problem 3 (15pts) Auth\_blk.sv (Testing It)



You need to develop both **Auth\_blk.sv** and a test bench for it (**Auth\_blk\_tb.sv**). Remember you have a **UART\_tx** block that was part of HW3.

Test more than the simple case of **pwr\_up** and then down. Try to traverse all states and arcs of your SM.

Submit: **Auth\_blk.sv**, **Auth\_blk\_tb.sv**, & proof it ran/passed in your testbench.

## HW4 Problem 4 (15pts) Synthesize your **balance\_cntrl.sv**

---

- Write a synthesis script (**balance\_cntrl.dc**). The script should perform the following:
  - Defines a clock of 125MHz frequency and sources it to clock
  - Performs a set don't touch on the clock network
  - Defines input delays of 0.3 ns on all inputs other than clock
  - Defines a drive strength equivalent to a 2-input nand of size 2 from the Synopsys 32nm library (NAND2X2\_RVT) for all inputs except clk and rst\_n
  - Defines an output delay of 0.75ns on all outputs.
  - Defines a 50fF load on all outputs.
  - Sets a max transition time of 0.15ns on all nodes.
  - Employs the Synopsys 32nm wire load model for a block of size 16000 sq microns
  - Compiles, then flattens the design so it has no hierarchy, and compiles again.
  - Produces a min\_delay report
  - Produces a max\_delay report
  - Produces an area report
  - Flattens the design so it has no hierarchy
  - Writes out the gate level verilog netlist (**balance\_cntrl.vg**)
- Submit:
  - Your synthesis script (**balance\_cntrl.dc**)
  - The output reports for area (**area.txt**)
  - The gate level verilog netlist (**balance\_cntrl.vg**)

For reference my area was 4000 square microns  
Started as Exercise18 on Weds Oct 29<sup>th</sup>

## HW4 Problem 5 (20pts) Balance Control & Testing

---

- See Exercise15 (adding ***fast\_sim*** to PID and creating ***balance\_cntrl.sv***)
- See Exercise17 (random testing of ***balance\_cntrl***)
- Submit:
  - *balance\_cntrl.sv*
  - *PID.sv*
  - *balance\_cntrl\_chk\_tb.sv* (self-checking random vector testbench)
  - Proof *balance\_cntrl.sv* passed the above testbench.

This problem represents a combination of  
Exercise15 & Exercise17

## HW4 Problem 6 (35pts) SPI Tranceiver

---

- See Exercise16 (SPI Tranceiver)
- Did you do a good job on **SPI\_mnrch**? If not polish it up now.
- Submit:
  - SPI\_mnrch.sv
  - SPI\_mnrch\_tb.sv
  - Proof your DUT passed the self-checking testbench

We start this problem as Exercise16 on Mon Oct 20<sup>th</sup>