

# **Course Information**

| Instructor   | Daniel Llamocca                                                                                                                                                                                        |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| CONTACTINFO  | email: <u>llamocca@oakland.edu</u>                                                                                                                                                                     |  |  |
| Office Hours | Tuesday 2:00 to 4:00 pm @ Room EC-438, or by appointment Wednesday: 1:00 to 3:00 pm @ Room EC-562 (TA's lab hours)                                                                                     |  |  |
| LECTURES     | Tuesday/Thursday 5:30 pm - 7:17 pm @Room DH-127 (Dodge Hall)                                                                                                                                           |  |  |
| LABORATORY   | 002: Monday 7:30 pm — 10:30 pm @ Room EC-562 003: Monday 12:00 pm -2:59 pm @ Room EC-562 004: Tuesday 12:00 pm -2:59 pm @ Room EC-562  TAs: Michael Lohrer mflohrer@oakland.edu jsivakumar@oakland.edu |  |  |

### COURSE CATALOG DESCRIPTION: ECE 2700 – Digital Logic Design (4 credits)

Boolean algebra; number systems and arithmetic, combinational logic circuits; synchronous sequential circuits; asynchronous sequential circuits; introduction to a hardware description language (HDL). With Laboratory. (Formerly ECE 278). Prerequisite(s): EGR 240 or EGR 2400.

### COURSE WEBPAGE

- The course material will be hosted on Moodle (moodle.oakland.edu). Grades will be periodically posted via this system.
- As a backup resource, the material will also be posted at: <a href="https://www.secs.oakland.edu/~llamocca/Winter2019">www.secs.oakland.edu/~llamocca/Winter2019</a> ece2700.html
- VHDL for FPGAs Tutorial: Available at the following permanent link: <a href="www.secs.oakland.edu/~llamocca/VHDLforFPGAs.html">www.secs.oakland.edu/~llamocca/VHDLforFPGAs.html</a>

### Техтвоок:

There is no required textbook. Students are encouraged to use the extra references.

### **EXTRA REFERENCES:**

- Bryan J. Mealy, James T. Mealy, *Digital McLogic Design*, Free Range Factory, 2012.
  - ✓ Free download: <a href="http://www.freerangefactory.org/books">http://www.freerangefactory.org/books</a> tuts.html
- Bryan Mealy, Fabrizio Tappero, Free Range VHDL, Free Range Factory, 2013
  - ✓ Free download: <a href="http://www.freerangefactory.org/books">http://www.freerangefactory.org/books</a> tuts.html
- S. Brown, Z. Vranesic, Fundamentals of Digital Logic with VHDL Design, 3<sup>rd</sup> ed., McGraw Hill, 2009. (suggested)
- Richard Haskell, Darrin M. Hanna, Digital Design using Digilent FPGA Boards VHDL/Active-HDL Edition, LBE Books, 2009.
- Peter J. Ashenden, The Designer's Guide to VHDL, 3<sup>rd</sup> ed., Elsevier, 2008.

### COURSE OBJECTIVES

- 1. Design and analyze combinational and sequential logic circuits. (1)
- 2. Design and analyze finite state machines. (1)
- 3. Perform addition, subtraction, and multiplication in binary arithmetic. (1)
- 4. Describe memory operation and memory addressing. (1)
- 5. Describe digital circuits using VHDL and implement them on an FPGA. (1, 6)
- 6. Perform functional and timing simulation of a digital circuit described in VHDL. (1,6)
- 7. Describe how combinational and sequential components can be used to design a datapath and control unit for implementing digital systems. (1, 2)
- 8. Work in a team environment to design a digital system and communicate the results in a written report and an oral presentation. (1, 2, 3, 6)

### **ABET Course Outcomes:**

| 1 | 2 | 3 | 4 | 5 | 6 | 7 |
|---|---|---|---|---|---|---|
|---|---|---|---|---|---|---|

### **GRADING SCHEME:**

| Homeworks:  | 15% | Final Project: | 15%                                            |
|-------------|-----|----------------|------------------------------------------------|
| Quizzes:    | 10% | Midterm Exam:  | 20% (February 14 <sup>th</sup> , 5:30-7:17 pm) |
| Laboratory: | 20% | Final Exam:    | 20% (April 18 <sup>th</sup> , 7:00-10:00 pm)   |

 Homeworks: Homework assignments are meant to strengthen your conceptual understanding of the topics. Completing homework assignments is a key component of this course as it will help students master the course material and prepare them for the exams.

Homeworks will be posted according to the schedule (green rectangles). Students have one week to turn in the completed assignments in class. <u>Late submissions are NOT accepted</u>.

- Quizzes: They will have a duration of 20 minutes at the beginning of the class.
- Exams: Closed-books, closed-notes, in-class exams. The final exam will be a comprehensive test that will cover the whole syllabus. Students are not allowed to take the exams neither before nor after the exam date. Make-up exams are given *only* under extreme circumstances (e.g.: medical emergency, jury duty).
- Laboratory: This important component of the class will reinforce your understanding of the topics. There will be six (6) labs throughout the semester.

TAs will be present <u>every week</u> during the regularly scheduled laboratory times. Students can work during those times or at any other time and place.

Students have one week to complete the lab assignments and have them checked off by the TA.

• **Final Project:** Students will work in groups (up to 4) in a Final Project. Each group will prepare an oral presentation and submit a final report. Presentations will take place on April 16<sup>th</sup>.

### **GRADE ASSIGNMENT:**

| 96-100       | Α  | 4.0 |
|--------------|----|-----|
| 90-95        | A- | 3.7 |
| 85-89        | B+ | 3.3 |
| 80-84        | В  | 3.0 |
| 72-79        | B- | 2.7 |
| 66-71        | C+ | 2.3 |
| 60-65        | С  | 2.0 |
| 56-59        | C- | 1.7 |
| 53-55        | D+ | 1.3 |
| 50-52        | D  | 1.0 |
| 49 and below | F  | 0.0 |

# Su Mo Tu We Th Fr Sa 1 2 3 4 5 HW 1 6 7 8 9 10 11 12 Lab 1 13 14 15 16 17 18 19 Quiz 1 14 2 23 24 25 26 Lab 2 27 28 29 30 31 1 2 Quiz 2 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 Midterm 17 18 19 20 21 22 23 Lab 4 24 25 26 27 28 1 2 Lab 5 10 11 12 13 14 15 16 Quiz 3 2 10 11 12 13 14 15 16 Quiz 3 2 10 11 12 13 14 15 16 Quiz 4 7 8 9 10 11 12 13 Final Project Presentation 14 15 16 17 18 19 20 14 22 23 24 25 26 27 28 29 30

Schedule

### LABORATORY MATERIALS

- Hardware: Nexys<sup>TM</sup> A7 FPGA Trainer Board Option: A7-50T (you can also use the Nexys<sup>TM</sup>-4 DDR Artix-7 FPGA Board)
  - ✓ To order: <a href="https://store.digilentinc.com/nexys-a7-fpga-trainer-board-recommended-for-ece-curriculum/">https://store.digilentinc.com/nexys-a7-fpga-trainer-board-recommended-for-ece-curriculum/</a> Go to: Get Academic Pricing (\$171.75)

If you do not plan to take ECE3710, you can use the Basys3 Trainer Board:

- ✓ To order: <a href="https://store.digilentinc.com/basys-3-artix-7-fpga-trainer-board-recommended-for-introductory-users/">https://store.digilentinc.com/basys-3-artix-7-fpga-trainer-board-recommended-for-introductory-users/</a> Go to: Get Academic Pricing (\$111.75)
- Software: Vivado HL Webpack Edition
  - ✓ To download: <a href="http://www.xilinx.com/products/design-tools/vivado/vivado-webpack.html">http://www.xilinx.com/products/design-tools/vivado/vivado-webpack.html</a>

### **OUTLINE OF TOPICS**

| Introduction to Logic              | <ul> <li>Boolean Algebr</li> </ul>                            |                                                                                   |  |  |
|------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|
| Circuits                           | <ul> <li>Sum-of-Products and Product-of-Sums forms</li> </ul> |                                                                                   |  |  |
|                                    | Logic Gates. Timing diagrams                                  |                                                                                   |  |  |
| Optimized                          | <ul><li>Basic Techniques</li><li>Karnaugh Maps</li></ul>      |                                                                                   |  |  |
| Implementation of                  |                                                               |                                                                                   |  |  |
| Logic Functions                    | Quine-McCluskey algorithm                                     |                                                                                   |  |  |
|                                    | Logic Levels, CMOS Logic gates                                |                                                                                   |  |  |
| Implementation                     | Tri-state buffers, Transmission Gates                         |                                                                                   |  |  |
| Technology                         | Practical aspects: propagation delay, noise margin, hazards   |                                                                                   |  |  |
|                                    | Programmable Logic Devices, Field Programmable Gate Arrays    |                                                                                   |  |  |
|                                    | Unsigned integer numbers                                      | Binary representation                                                             |  |  |
|                                    |                                                               | Octal and hexadecimal representation                                              |  |  |
|                                    |                                                               | Addition and subtraction                                                          |  |  |
| Number Systems and                 | Signed integer                                                | Binary representation                                                             |  |  |
| Computer Arithmetic                | numbers                                                       | Addition and subtraction                                                          |  |  |
| ,                                  | Multiplication of Array multiplier for unsigned numbers       |                                                                                   |  |  |
|                                    | integer numbers   Multiplication of signed numbers            |                                                                                   |  |  |
|                                    | Binary Codes                                                  |                                                                                   |  |  |
|                                    | Introduction to Fixed-point arithmetic                        |                                                                                   |  |  |
|                                    |                                                               | Multiplexers, De-multiplexers                                                     |  |  |
|                                    | Basic circuits                                                | Decoders, Encoders, Comparators                                                   |  |  |
|                                    | basic circuits                                                | Code Converters: BCD to 7-segment, Gray to BCD, etc.                              |  |  |
| Combinational Circuits             |                                                               | Parity generators and parity checkers                                             |  |  |
|                                    |                                                               | Look-up Tables                                                                    |  |  |
|                                    | Complex circuits                                              | Arithmetic Logic Unit (ALU) Design                                                |  |  |
|                                    |                                                               | Barrel shifter                                                                    |  |  |
|                                    |                                                               | Flip flops and latches                                                            |  |  |
|                                    | Basic circuits                                                | Registers, shift registers                                                        |  |  |
|                                    |                                                               | Parallel access shift registers: parallel-to-serial/serial-to-parallel conversion |  |  |
| Synchronous<br>Sequential Circuits |                                                               | Counters: synchronous, BCD, Ring, Johnson                                         |  |  |
|                                    |                                                               | Random Access Memory                                                              |  |  |
|                                    | Finite State<br>Machines (FSMs)                               | Moore and Mealy state Models                                                      |  |  |
|                                    |                                                               | Design Steps: State Diagram, State Table, State assignments.                      |  |  |
|                                    | 7                                                             | Algorithmic State Machine (ASM) charts                                            |  |  |
| Introduction to Digital            | <ul> <li>Digital system</li> </ul>                            | (or special-purpose processor) components: Datapath circuit, Control Circuit      |  |  |
| System Design                      |                                                               | es: Small processor, shift-and-add multiplier, sequential divider.                |  |  |
|                                    | 5 - 1                                                         | 1 / 1                                                                             |  |  |

## $VHDL\mbox{:}$ For every topic, an aspect of VHDL description will be explored.

| Introduction              | <ul> <li>Design Flow: Design Entry, Functional Simulation, Mapping, Timing Simulation, Implementation</li> <li>Data Types</li> <li>VHDL Description: Logic Gates</li> <li>VHDL Testbench Generation</li> </ul>    |  |  |  |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Concurrent                | <ul> <li>Concurrent statements: 'with-select', 'when-else'</li> </ul>                                                                                                                                             |  |  |  |
| Description               | Combinational circuits description: (priority) encoder, decoder, comparator, mux, de-mux.                                                                                                                         |  |  |  |
| Behavioral<br>Description | <ul> <li>Asynchronous processes</li> <li>Behavioral description of Combinational circuits: (priority) encoder, decoder, comparator, mux.</li> <li>Sequential statements: 'if-else', 'case', 'for-loop'</li> </ul> |  |  |  |
| Structural                | Hierarchical design: Use of port-map, for-generate, if-generate.                                                                                                                                                  |  |  |  |
| Description               | Examples: Adder, multiplier, Arithmetic Logic Unit, Look-up Table                                                                                                                                                 |  |  |  |
| Sequential<br>Circuits    | <ul> <li>Testbench: generating clock stimulus</li> <li>Asynchronous processes: Latches</li> <li>Synchronous processes: flip-flops, counters, registers</li> <li>Description of Finite State Machines</li> </ul>   |  |  |  |
| Parameterization          | <ul><li>Simple techniques</li><li>Use of for-generate, if-generate.</li></ul>                                                                                                                                     |  |  |  |

3 Instructor: Daniel Llamocca

### CLASS POLICIES

- **Laboratory**: Students must be aware of their Laboratory section: 002, 003, 004. This will be used to determine whether a student is late in their laboratory submission. Students are advised to attend on the day of their respective Laboratory Section. However, students can attend any other Laboratory Section if there is space available. Students will be able to complete a TA evaluation form at the end of the semester.
- Academic conduct policy: All members of the academic community at Oakland University are expected to practice and uphold standards of academic integrity and honesty. Academic integrity means representing oneself and one's work honestly. Misrepresentation is cheating since it means students are claiming credit for ideas or work not actually theirs and are thereby seeking a grade that is not actually learned. Academic dishonesty will be dealt with seriously and appropriately. Academic dishonesty includes, but it is not limited to cheating on examinations, plagiarizing the works of others, cheating on lab reports, unauthorized collaboration in assignments, hindering the academic work of other students.
- **Special Considerations**: Students with disabilities who may require special consideration should make an appointment with campus Disability Support Services, 106 North Foundation Hall, phone 248 370-3266. Students should also bring their needs to the attention of the instructor as soon as possible. For academic help, such as study and reading skills, contact the Academic Skills/Tutoring Center, 103 North Foundation Hall, phone 248 370-4215.
- Add/Drops: The university policy will be explicitly followed. It is the student's responsibility to be aware of deadline
  dates for dropping courses.
- Attendance: It is assumed that the students are aware of and understand the university attendance policy. Attendance
  is mandatory and maybe monitored. Students are responsible for all material covered in classes that they miss. There will
  be no excuses for being late to quizzes/exams.
- Athlete Excused Absences: Students shall inform the instructor of dates they will miss class due to an excused absence prior to the date of that anticipated absence. For activities such as athletic competitions whose schedules are known prior to the start of a term, students must provide their instructors during the first week of each term a written schedule showing days they expect to miss classes. For other university excused absences, students must provide the instructor at the earliest possible the dates that they will miss.
- Special Circumstances: The instructor should be notified as early as possible regarding any special conditions or circumstances which may affect a student's performance during the course timeframe (e.g., medical emergencies, family circumstances).
- Cellphones: A ringing cellphone going off during a lecture is disruptive to other students as well as the instructor.
   Students are strongly advised to set their cellphones to vibrate (not ringing) and leave the classroom discretely to answer the phone.

4 Instructor: Daniel Llamocca