#### **E85:** Digital Electronics & Computer Engineering Spring 2018 Harris

# Syllabus

## **Teaching Staff**

Professor: Lab Assistants: David Money Harris Shiv Seetharaman CJ Xin Gabe Quiroz



David Money Harris

#### Schedule

Lecture: MW 8:10 or 9:35 am Shan 3481 Office Hours: M 1:15-2, Tu 2-2:45, Wed 11-11:30, Fri 11-12 Saturday 12-2, Sunday 12-2 in Parsons B183 Lab Hours: TBΠ Tutor Hours: Monday 7-9 pm, TBD

Feel free to stop by even if I do not have official office hours. One of the main reasons that I teach at Harvey Mudd is that I value working with students 1-on-1 and in small groups.

## Text

Harris & Harris, Digital Design and Computer Architecture, ARM Ed., Morgan Kaufmann 2016.

#### **Electronic Communication**

Class web page: http://pages.hmc.edu/harris/class/e85 Class email list: eng-85-l@g.hmc.edu

You also will need a Harvey Mudd College computer to complete your labs. If you are not a HMC student, email me your full name and school affiliation and I will request an account for you.

Parsons 2374

Shiv Seetharaman

x73623 David Harris@hmc.edu sseetharaman@g.hmc.edu cxin@g.hmc.edu gquiroz@g.hmc.edu



CJ Xin

# **Course Objectives**

Digital systems have revolutionized our world. From television to cell phones to GPS to warfare to medicine to automobiles, computers and digital processing have reshaped the way we live and work. Computers are also a vital part of daily practice in every field of science and engineering.

Previous generations of engineers learned the "nuts and bolts" of the profession by doing things like disassembling and rebuilding engines. As technology has advanced, cars have become too complicated for the layperson to work on. Ironically, the same advances have made computers much easier to build. While most fields of engineering require extensive mathematics and complicated analysis of even rather simple components, digital systems merely require counting from 0 to 1. Their challenge, instead, is in combining many simple building blocks into a complex whole. Field programmable gate arrays (FPGAs), containing the equivalent of thousands or millions of logic gates, make it possible to build these complex systems in the lab without the tedium of manually connecting components. In this class, you will build your own microprocessor and test it on a FPGA. In the process, you will master the art and science of digital design. You will learn to speak to and control processors in their native tongue, assembly language. And you will put all the pieces together to demystify how a computer works.

As you probably know, very few complex systems work the first time you put them together. Engineers must become good at systematically and efficiently debugging their creations. One of the course objectives that can be frustrating but vitally important is to learn to teach oneself professional-strength computer-aided design tools and to use these tools to debug systems.

By the end of this course, a successful student will be able to:

- Build digital systems at all levels of abstraction from transistors through circuits, logic, microarchitecture, architecture, and C culminating with implementing and programming a microprocessor soft core on a field programmable gate array.
- Manage complexity using the digital abstraction, data types, static and dynamic disciplines, and hierarchical design.
- Design and implement combinational and sequential digital circuits using schematics and hardware description languages.
- Program a commercial microcontroller in C and assembly language and use it in a physical system.
- Begin the practice of implementing and debugging digital systems with appropriate lab techniques including breadboarding, interpreting datasheets, and using field-programmable gate arrays and microcontroller boards, simulators, debuggers, and test-and-measurement equipment.

### Grading E85

E85A

| Labs:                | 30% | Labs:                | 30% |
|----------------------|-----|----------------------|-----|
| Problem Sets:        | 20% | Problem Sets:        | 20% |
| In-Class Activities: | 5%  | In-Class Activities: | 5%  |
| Midterm:             | 15% | Midterm:             | 45% |
| Final:               | 30% |                      |     |

Lab 11 is the capstone of the labs, in which you design and simulate a microprocessor, drawing on most of the skills you have acquired over the semester. You must turn in a working Lab 11 to pass E85.

Solutions to the labs and problem sets from previous semesters are undoubtedly floating around campus and on the web. You may **not** refer to solutions while doing the assignments; they must be your own work. Many of the labs build on previous labs. If you are sick or do not turn in a lab, you may refer to the solutions handed out to complete the lab when it is needed for a subsequent lab. However, you may not simply copy another student's files.

Labs and homework are due by the end of class and will not be graded if submitted late. Your lowest lab and problem set score will be dropped before the average is calculated, so if you are sick, traveling, interviewing, or just have a bad week, you can simply drop the assignment. In the event of extended illness or other emergency, please contact me for alternative arrangements.

You are welcome to discuss labs and problem sets with other students or with the instructor or lab assistants or tutors **after** you have made an effort by yourself. However, you must turn in your own work, not work identical to that of another student. For labs, asking classmates or tutors for help when you are stuck on a specific issue is encouraged (especially on difficulties with the tools and equipment), but sitting at adjacent computers and working through the lab together in lock-step is specifically prohibited. Pair/group programming is also prohibited. Be sure to credit at the top of your assignment anyone with whom you discussed ideas. It is an honor code violation to simply copy someone else's work.

On a regular basis, there will be short in-class activities related to a recent lecture. You are strongly encouraged to regularly attend class, review your notes before class, and ask questions during class. If you stay on top of the material, you should have no difficulty doing well with these activities. The two lowest scores will be dropped.

| Lecture        | Date         | Topics                                                                       | Readings                     | Assignment                       |
|----------------|--------------|------------------------------------------------------------------------------|------------------------------|----------------------------------|
| 0              | 1/17         | Introduction: digital abstraction,<br>number systems, logic gates, HDL       | 1.1-1.5, A1-A4,<br>4.1-4.2.2 |                                  |
| 1              | 1/22         | Static discipline, CMOS transistors                                          | 1.6-1.9, A5-A7               |                                  |
| 10             | 1/24         | Combinational logic design                                                   | 2.1-2.8                      | PS 1 due                         |
| 11             | 1/29         | Timing, sequential circuits                                                  | 2.9-2.10, 3.1-3.2            | Lab 1 due Digital Circuits       |
| 100            | 1/31         | Finite state machines                                                        | 3.3-3.4                      | PS 2 due                         |
| 101<br>110     | 2/5<br>2/7   | Dynamic discipline, metastability<br>Hardware description languages: Verilog | 3.5-3.7<br>4.1-4.3           | Lab 2 due Comb Logic<br>PS 3 due |
| 111            | 2/12         | Verilog, Part II                                                             | 4.4-4.10                     | Lab 3 due Structural FSM         |
| 1000           | 2/14         | Arithmetic circuits                                                          | 5.1-5.2                      | PS 4 due                         |
| 1001           | 2/19         | Fixed and floating-point number systems                                      | 5.3                          | Lab 4 due Behavioral FSM         |
| 1010           | 2/21         | Sequential building blocks, arrays                                           | 5.4-5.7                      | PS 5 due                         |
| 1011           | 2/26<br>2/28 | Datasheets<br>Midterm                                                        | A.1                          | Lab 5 due Building blocks        |
| 1100           | 3/5          | C Programming                                                                | C.1-C.7                      |                                  |
| 1100           | 3/7          | C Programming                                                                | C.8-C.11                     |                                  |
|                | 3/12         | SPRING BREAK: No class                                                       |                              |                                  |
|                | 3/14         | SPRING BREAK: No class                                                       |                              |                                  |
| 1101           | 3/19         | Microcontrollers: Memory-mapped I/O                                          | 9.1-9.3.3                    | Lab 6 due C                      |
| 1110           | 3/21         | Parallel & serial interfacing                                                | 9.3-9.4                      | PS6 due                          |
| 1111           | 3/26         | ARM assembly language                                                        | 6.1-6.3.6                    | Lab 7 due C I/O                  |
| 10000          | 3/28         | Function calls, machine language                                             | 6.3.7-6.9                    | PS 7 due                         |
| 10001          | 4/2          | Single-cycle processor datapath                                              | 7.1-7.3.1                    | Lab 8 due C Peripherals          |
| 10010          | 4/4          | Single-cycle processor control, Verilog                                      | 7.3, 7.6                     | PS 8 due                         |
| 10011          | 4/9          | Multicycle processor                                                         | 7.4                          | Lab 9 due Assembly               |
| 10100          | 4/11         | Pipelining                                                                   | 7.5.1-2                      | PS 9 due                         |
| 10101          | 4/16         | Memory-mapped I/O interfaces                                                 | 9.5                          | Lab 10 due Multicycle Control    |
| 10110          | 4/18         | Advanced architecture: a sampler                                             | 7.7                          | PS 10 due                        |
| 10111<br>11000 | 4/23<br>4/25 | Case study: ARM processors<br>Class summary and review                       | 6.7, 8.7, 8.5                | Lab 11 due Multicycle CPU        |

## **Tentative Schedule**