```
8/6/2022 (Undergraduate students, who got an "A" or an "A-" grade in their EE354L, do not have to submit \frac{HW#1}{2})
```

Dear EE457 students of Fall 2022.

Welcome to EE457! Hope you all had a safe and restful summer vacation!

About two-thirds of the students in EE457 are usually graduate students doing their first semester at USC. If you are one of them, then welcome to USC and to the ECE Department too!

First things first! Please check that you do not have any time conflicts with the three exams as there are no make-up exams. EE457 exams are design exams and are 3 hours long.

Extract from the syllabus <u>.pdf</u> .docx:

```
Quiz (~11%): Thursday, Sep. 22, 2022, 05:30 PM - 08:30 PM PST

Midterm (~24.5%): Thursday, Oct. 27, 2022, 05:30 PM - 08:30 PM PST

Final Exam (~33.5%): Saturday, Dec. 10, 2022, 01:15 PM - 04:15 PM PST Please check
```

The ee457 documents are on two servers. 1. A few documents are on the ee server (links starting with ee <a href="https://ee-classes.usc.edu/">https://ee-classes.usc.edu/</a> or ece <a href="https://ee-classes.usc.edu/">https://ee-classes.usc.edu/</a> (no change for these documents. 2. Most other documents are on the scf (student computing facility) server. This semester, we moved the ee457 scf UNIX course directory from an old server (aludra.usc.edu) to a new server (viterbi-web.usc.edu). I am correcting web links in various documents progressively. I need to replace the earlier prefix <a href="https://www-classes.usc.edu/engr/ee-s/">https://www-classes.usc.edu/engr/ee-s/</a> in every web link to the new prefix <a href="https://viterbi-web.usc.edu/www-classes/engr/ee-s/">https://viterbi-web.usc.edu/www-classes/engr/ee-s/</a> If you find a web link which has not been updated, I appreciate it very much if you report to me the old link on an Ed Discussion thread being created for this purpose. While I try to revise the link, you can still access the old link, but you need to use the Microsoft Edge browser to access the same as it starts with <a href="https://with.no">https://with.no</a> "s"). Google Chrome refuses to open such links.

First three weeks are important to all EE457 students who have not taken EE354L (previously called EE254L/EE201L).

EE457 (Computer Systems Organization) course provides you with foundation material needed to proceed to higher courses such as EE557, EE577a, EE533, and EE560.

If you are a continuing undergraduate student who did not get an A in your EE354L, the rest of this document applies to you also.

The prerequisite course, EE354L (previously called EE254L or EE201L), has been waived for the graduate students but our experience over the last 30 years tells us that most graduate students do not come with adequate introduction to logic design necessary for this course. So, I am providing some make up material which helps them to "survive" in the first three weeks of this course. This material is not difficult, but it is not too easy either. It is not quite intuitive, so it takes substantial time and effort (and creativity and imagination). So, I ask the graduate students to put in at least 30 hours in the next 2 weeks (8/6/2022 to 8/21/2022) preparing for EE457. We have assignments due from the 2nd week of classes and it will be overwhelming if you do not put in time to make up for the lack of prerequisite knowledge. Due dates can be seen in this calendar.

Detailed information about what you should do before the start of the semester is given in this document "Study plan for the first three weeks" (provided in two formats):

pdf: https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 Fall2022 exams/EE457 Study Plan for first 3 weeks.pdf docx: https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 Fall2022 exams/EE457 Study Plan for first 3 weeks.docx

Please download the .docx file also, as depending on the browser or pdf reader you use, the links in the pdf file may or may not work. If any of the links do not work, please email me and I will try to rectify the problem quickly.

It will be great if you go through most of the items provided below and actually complete the <u>HW#1</u> and <u>HW#1B</u>. Undergraduate students, who got an "A" or an "A-" grade in their EE354L, do not have to do <u>HW#1</u>. They need to submit a "Waiver Note". Please see HW#1 posting on D2L.

Best wishes.

Gandhi Puvvada

### What do I want the graduate students to do in the first three weeks:

Please seek help whenever you need from the teaching team, but not through email. If it is a very simple/short question, you can use Ed Discussion (D2L=>MyTools=>Ed Discussion), but otherwise, please come and meet us well prepared to ask your question. After every lecture, go through the material covered in the lecture and prepare your list of questions to ask.

1. Please install several tools including Modelsim on your laptop (windows laptop) as per the following note. <a href="https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_tools/EE457\_README\_first.pdf">https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_tools/EE457\_README\_first.pdf</a>
Use the following userID and 10-digit StudentID to access the following installation guide and to download the installation files for Modelsim SE 10.6e

User name: ttrojan 10-digit ID for Password: 1010101010

https://ece-

 $\underline{classes.usc.edu/ee201/0lO100ooll11/f0r\_UsC\_oN1y/MSim\_SE\_10.6e/ModelSim\_SE\_10\_6e\_Installation\_by\_USC\_students.pdf}\\ \underline{https://ece-classes.usc.edu/ee201/0lO100ooll11/f0r\_UsC\_oN1y/MSim\_SE\_10.6e/ModelSim\_SE\_10\_6e\_Installation\_by\_USC\_students.pdf}$ 

If you do not have a Desktop/Laptop running windows 10, please buy one (or consider the alternatives stated at the bottom of EE457\_README\_first.pdf).

**2.** In the first week of classes, we cover the following 6 topics. However, I want you to watch the 6 short videos on the 6 topics at the following web directory before the first day of classes.

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 first lecture/.

- (a) DPU and CU design (b) Mealy machine example -- Divider Design (c) Data registers -- clocking and controlling (d) Loop Counter Incrementation and Terminal Value Checking (e) ME (Mutually Exclusive) and AI (All Inclusive) rules in designing a state diagram (f) State diagram Design examples
- **3.** Notice that, while HW#1 and HW#1B are assigned, the HW#1A is provided with solution to serve as a practice item. It has four problems. I suggest that you do at least the 2nd problem (Make A close to B) and verify your work with the solution. Come to us if you do not understand the solution. Do not be lazy. Design takes time and effort to learn.
- 4. Then start working on HW#1 followed by HW#1B.
- **5.** Watch the 6 Verilog lectures listed later in this document.

Complete the Verilog code for the HW#1A 2nd problem (Make A close to B) and verify. This is for practice only. It is worthwhile to go through the following procedural steps to simulate and submit:

Procedural steps illustration (from EE201L):

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL coding/ee201 RTL exercises Sp2010/EE201L Introducing the procedure associated with HW8A.pdf

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL coding/ee201 RTL exercises Sp2010/EE201L Introducing the procedure associated with HW8A.avi

Note: If you do not see picture when playing the .avi video files, then you need to install the TSCC codec from https://www.techsmith.com/codecs.html

6. Start working on the lab 1 of EE457 (Min/Max Finder -- 6 parts, but only 4 parts will be assigned).

If you put in goo effort, you will feel good that you are able to follow the first week of lectures (which are covered at a fast rate).

First week's lecture notes and webcasts reviewing EE201L material (.pdf files for slides + .avi or .wmv files for video):

You need to install on your PC TechSmith TSCC Codec to view .avi video files.

1. Chapter #1 Intro.

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 first lecture/ee457x1 Chapter1 microarchitecture.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/1\_EE457\_Chapter1\_microarchitecture.avi

2. DPU and CU

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 first lecture/ee457x2 DPU CU.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457 first lecture/2 DPU CU.wmv

3. Mealy machine example -- Divider Design

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/ee457x3\_Moore\_Mealy\_Divider.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/3\_Divider\_Mealy\_example.avi

4. Data registers -- clocking and controlling

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/ee457x4\_Data\_Registers.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/4\_Data\_Registers\_with\_Data\_Enable.avi

\*\*\*\*\*\*\*\*\*\*\*\*

5. Loop Counter Incrementation and Terminal Value Checking

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/EE457x5\_P1\_loop\_counter.pdf
https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/EE457x5\_P2\_loop\_counter\_example\_doubling\_A.pdf
https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 first lecture/EE457x5 P3 loop counter ee102 midterm1 Sp2005 Q4 question and solution.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_first\_lecture/EE457x5\_P3\_loop\_counter\_ee102\_midterm1\_Sp2005\_Q4\_transparencies.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/5\_Loop\_Iteration\_Counter.avi

6. ME (Mutually Exclusive) and AI (All Inclusive) rules in designing a state diagram

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/ee457x6\_P1\_mutually\_exclusive.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/ee457x6\_P2\_ME\_AI\_tables.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/6\_Mutually\_Exclusive\_All\_Inclusive.avi

7. State diagram Design examples

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/ee457x7\_State\_Diagram\_Design\_examples.pdf https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_first\_lecture/7\_State\_Diagram\_Design\_examples.avi EE457 HW#1 (Due: calendar)

Undergraduate students, who got an "A" or an "A-" grade in their EE354L, do not have to submit HW#1 (ee457\_hw1\_r1.pdf).

However, they need to submit a HW#1 Waiver application. Please see HW#1 posting on D2L

Homework #1 (16 pages) Revised in Fall 2020 <a href="https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_Homeworks/HW1/ee457\_hw1\_r1.pdf">https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_Homeworks/HW1/ee457\_hw1\_r1.pdf</a>

On-campus students will be given hard-copies of the assignment in the first week of classes.

State Diagram design: If you are new to this topic, first go through these ( <a href="mailto:.pdf">.pdf</a> <a href="mailto:.avi">.avi</a>).

Additional help on the first 10 pages (first two questions related to datapath design) of this homework: The first 10 pages of this homework are from the EE101/EE354L homework on datapath design for which solution and webcast are provided below. Do not just copy the solution. Understand the solution. If you are new to this topic, please watch the webcast also.

EE101 items on datapath: <u>ee101 hw on datapath.pdf</u> <u>ee101 hw on datapath sol.pdf</u> <u>ee101 hw on datapath.mp4</u>

HW#1A (for practice only, not for submission)

This HW#1A is an additional practice for graduate students who did not take EE354L (previously called EE254L/EE201L) here at USC. You do not need to submit this.

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/EE457\_HW1A/EE457\_HW1A\_EE201L\_RTL\_Exercises.pdf

Additional help on next page.

Solution: Please do not show this to the EE354L students as it is an assignment in their course:

https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/EE457\_HW1A/DO\_NOT\_SHOW\_TO\_EE354L\_students/

## Help on HW#1A (for practice only, **not** for submission)

Watch these webcasts one at a time and then complete the state diagram. Check with the solution.

Right-click on the video file and download it. Do not stream the videos. The server is not meant for video streaming. If the video does not play on your computer, then you need to install TSCC codec from TechSmith. TechSmith links are provided below.

http://www.techsmith.com/ download.html

http://download.techsmith.com/ tscc/tscc.exe

## 1. The last question (Q#4) of EE201L quiz of Spring 2010

O#4 Convert Inches to Feet and further to Yards

https://viterbi-web.usc.edu/www-classes/engr/ee-s/201/EE201L\_Sp2010\_Exams/ee201\_Quiz\_Sp2010\_Pages\_9\_10\_DataPath\_Inches\_Feet\_Yards\_lec\_mht.pdf .mp4 video file

Right-click on the .mp4 file link below and select "Save Target as" to download.

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/EE201L Sp2010 Exams/ee201 Quiz Sp2010 Pages 9 10 DataPath Inches Feet Yards.mp4

# 2. The **first 3** questions of the EE201L RTL coding exercises:

https://viterbi-web.usc.edu/www-classes/engr/ee-s/201/RTL coding/ee201 RTL exercises Sp2010/

The assignment (only the **first 6** pages)

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL\_coding/ee201\_RTL\_exercises\_Sp2010/EE201L\_RTL\_exercises\_Spring2010.pdf

# Q#1 Largest Number Divisible by 7

https://viterbi-web.usc.edu/www-classes/engr/ee-s/201/RTL coding/ee201 RTL exercises Sp2010/EE201L RTL exercises Spring2010 Q1.pdf .wmv file:

Right-click and select "Save Target as" to download EE201L\_RTL\_exercises\_Spring2010\_Q1.wmv

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL\_coding/ee201\_RTL\_exercises\_Sp2010/EE201L\_RTL\_exercises\_Spring2010\_Q1.wmv

#### O#2 Make A close to B

https://viterbi-web.usc.edu/www-classes/engr/ee-s/201/RTL\_coding/ee201\_RTL\_exercises\_Sp2010/EE201L\_RTL\_exercises\_Spring2010\_Q2.pdf .wmv file:

Right-click and select "Save Target as" to download EE201L\_RTL\_exercises\_Spring2010\_Q2.wmv

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL coding/ee201 RTL exercises Sp2010/EE201L RTL exercises Spring2010 Q2.wmv

### O #3 Copying two parts of a sorted array

https://viterbi-web.usc.edu/www-classes/engr/ee-s/201/RTL\_coding/ee201\_RTL\_exercises\_Sp2010/EE201L\_RTL\_exercises\_Spring2010\_Q3.pdf .wmv file:

Right-click and select "Save Target as" to download EE201L\_RTL\_exercises\_Spring2010\_Q3.wmv

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/201/RTL coding/ee201 RTL exercises Sp2010/EE201L RTL exercises Spring2010 Q3.wmv

HW#1B (Due: calendar)

Selected 9 pages (First 6 pages 1/12-6/12 and last 3 pages 10/12-12/12) of the 12-page HW#1B <a href="https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_HW1B/ee457\_HW1B\_r1.pdf">https://viterbi-web.usc.edu/www-classes/engr/ee-s/457/ee457\_HW1B/ee457\_HW1B\_r1.pdf</a>

Hard copies will be provided to you in class in the first week.

## Help on the last question (Q#1 of EE457 Quiz - Fall 2010) in HW#1B

You may want to review Signed number representation in 2's complement notation. I have provided information below.

Please watch the first 20 minutes (from 00:13:00-00:33:00) of the following lecture (EE457Lx\_20123329.wmv):

Chapter 4 Part 1

Signed number representation in 2's complement notation,

Adder/Subtractor design for unsigned numbers and signed number -- overflow detection in each of them

Time: 1 Hour 2 minutes (from 00:13:00-01:15:00)

Open the following directory and download (not stream) the file <a href="EE457Lx\_20123329">EE457Lx\_20123329</a>.wmv and watch starting at <a href="13">13</a>-minute point.

https://ece-classes.usc.edu/ee457/ee457 Ch4 P1 Lab3 ALU/Fall2012 Sept 18 20/

## Verilog Introduction lectures:

Six lectures (together with slides) were posted at the link below to introduce the essential aspects of Verilog to the EE201L students (and to the graduate students in EE457, who are new to Verilog coding), so that they can get started with using Verilog for completing their labs. The lectures add up to 3 Hours 40 minutes.

https://ece-classes.usc.edu/ee254/Verilog/

O\_Verilog\_Main\_Points\_of\_the\_6\_Lectures.pdf (if you already know Verilog, you can view this in lieu of the 6 modules) <a href="https://ece-classes.usc.edu/ee254/Verilog/0\_Verilog\_Main\_Points\_of\_the\_6\_Lectures.pdf">https://ece-classes.usc.edu/ee254/Verilog/0\_Verilog\_Main\_Points\_of\_the\_6\_Lectures.pdf</a>

1\_Verilog\_Introduction\_mht.pdf

https://ece-classes.usc.edu/ee254/Verilog/1 Verilog Introduction mht.pdf

1\_Verilog\_Introduction.avi (1 H 08 Minutes)

https://ece-classes.usc.edu/ee254/Verilog/1 Verilog Introduction.avi

2\_module\_DataTypes\_in\_Verilog.pdf

https://ece-classes.usc.edu/ee254/Verilog/2 module DataTypes in Verilog.pdf

2\_module\_DataTypes\_in\_Verilog.avi (23 minutes)

https://ece-classes.usc.edu/ee254/Verilog/2\_module\_DataTypes\_in\_Verilog.avi

3\_behavioral\_vs\_structural\_Verilog.pdf

https://ece-classes.usc.edu/ee254/Verilog/3 behavioral vs structural Verilog.pdf

3 behavioral\_vs\_structural\_Verilog.avi (17 minutes)

https://ece-classes.usc.edu/ee254/Verilog/3 behavioral vs structural Verilog.avi

4\_Sequential\_Statements\_in\_Verilog.pdf

https://ece-classes.usc.edu/ee254/Verilog/4 Sequential Statements in Verilog.pdf

4\_Sequential\_Statements\_in\_Verilog.avi (1 Hour)

https://ece-classes.usc.edu/ee254/Verilog/4\_Sequential\_Statements\_in\_Verilog.avi

5\_blocking\_non\_blocking.pdf

https://ece-classes.usc.edu/ee254/Verilog/5\_blocking\_non\_blocking.pdf

5\_blocking\_non\_blocking.avi (56 minutes)

https://ece-classes.usc.edu/ee254/Verilog/5 blocking non blocking.avi

6\_RTL\_coding\_style.pdf

https://ece-classes.usc.edu/ee254/Verilog/6 RTL coding style.pdf

6\_RTL\_coding\_style.avi (33 minutes)

https://ece-classes.usc.edu/ee254/Verilog/6 RTL coding style.avi

EE254L\_RTL\_coding\_style\_verilog.pdf

https://ece-classes.usc.edu/ee254/Verilog/EE254L RTL coding style verilog.pdf

ee254 divider simple.zip

https://ece-classes.usc.edu/ee254/Verilog/ee254 divider simple.zip

Lab #1 min/max finder lab (Verilog) (Due: calendar)

Note: The .zip files will be available for download in the second week of classes.

.pdf of the assignment (both in Color and Black\_n\_White):

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/ee457\_min\_max\_finder\_lab.pdf

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/ee457\_min\_max\_finder\_lab\_Black\_n\_White.pdf

Six of the figures in landscape mode for online reading (both in Color and Black\_n\_White):

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 lab manual Fl2010/min max/ee457 min max finder lab figures.pdf

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/ee457\_min\_max\_finder\_lab\_figures\_Black\_n\_White.pdf

Slides (pdf) file used in class lecture

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 lab manual Fl2010/min max/ee457x8 min max finder.pdf

Short video and slides explaining part 3 (the four methods M1, M2, M3, and M4)

Note: The Part 3 Method M2 and M4 are cancelled for submission.

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/min\_max\_Improved\_testbench\_part3.pdf

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/min\_max\_Improved\_testbench\_part3.avi

Verilog files for downloading and completing (will be available after the 1<sup>st</sup> week of classes):

Part 1:

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 lab manual Fl2010/min max/min max finder part1.zip

Part 2:

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 lab manual Fl2010/min max/min max finder part2.zip

Part 3 Method 1:

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/min\_max\_finder\_part3\_M1.zip

Part 3 Method 2: cancelled

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_FI2010/min\_max/min\_max\_finder\_part3\_M2.zip

Part 3 Method 3:

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457 lab manual Fl2010/min max/min max finder part3 M3.zip

Part 3 Method 4: cancelled

https://viterbi-web.usc.edu/www-classes/engr/ee-

s/457/ee457\_lab\_manual\_Fl2010/min\_max/min\_max\_finder\_part3\_M4.zip

It will be great if you can complete state diagrams on paper for the four parts of Lab 1 (min/max finder) (the first 4 pages of the <u>pdf</u>) before the start of the semester!