# **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 | | | | LECTURES | Tuesday/Thursday 7:30 pm - 9:17 pm @Room EH-208 (Elliott Hall) | | | | LABORATORY | 002: Wednesday 7:30 pm — 10:30 pm @ Room EC-562 003: Thursday 12:00 pm — 2:59 pm @ Room EC-562 TA: Jason Gorski <u>jd2gorsk@oakland.edu</u> | | | ## COURSE CATALOG DESCRIPTION: ECE 3710 – Computer Hardware Design (4 credits) Development of components and techniques needed to design digital circuits and systems for controllers, computers, communication and related applications. Design and analysis of combinational and sequential logic circuits using a hardware description language such as VHDL, timing simulations, test benches, embedded cores. Design of special-purpose processors and their implementation in an FPGA. With Laboratory. Offered fall, winter, summer. Prerequisite(s): ECE2700 or ECE 278 and major standing. #### Trerequisite(5). Leez/00 of Lee 2/0 and major s ## 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="www.secs.oakland.edu/~llamocca/Winter2018">www.secs.oakland.edu/~llamocca/Winter2018</a> ece3710.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: - Pong P. Chu, FPGA Prototyping by VHDL examples: Xilinx Spartan-3 version. John Wiley & Sons, 2011. - M. Morris, C. Kime, T. Martin, Logic and Computer Design Fundamentals, Pearson Education, 5<sup>th</sup> edition, 2015 - S. Brown, Z. Vranesic, Fundamentals of Digital Logic with VHDL Design, 3<sup>rd</sup> ed., McGraw Hill, 2009. - 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: http://www.freerangefactory.org/books\_tuts.html - Peter J. Ashenden, The Designer's Guide to VHDL, 3<sup>rd</sup> ed., Elsevier, 2008. ## COURSE OBJECTIVES - 1. Design combinational and sequential components in VHDL. (a, k) - 2. Describe how combinational and sequential components can be used to design a datapath and control unit for implementing digital systems. (a, e, k) - 3. Design custom architectures to interact with external peripherals. - 4. Design dedicated special-purpose processors using VHDL and synthesize them to an FPGA. (a, b, c, e, i, k) - 5. Build a testbench for a digital system. - 6. Perform functional and timing simulation of a digital circuit described in VHDL. (a, b, e, k) - 7. Work in a team environment to design a digital system and communicate the results in a written report and an oral presentation. (a, b, c, e, g, h, i, j, k) #### **Course Outcomes:** a b c d e f g h i j k ## **GRADING SCHEME:** | Homeworks: | 20% | Midterm Exam: | 25% (February 15 <sup>th</sup> , 5:30-7:17 pm) | |-------------|-----|----------------|------------------------------------------------| | Laboratory: | 30% | Final Project: | 25% (April 24 <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>. - Midterm Exam: Closed-books, closed-notes, in-class exams. Students are not allowed to take the exams neither before nor after the exam date. Make-up exams are given only under extreme circumstances (such as a medical emergency). - **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 24<sup>th</sup>. ## **GRADE ASSIGNMENT:** | 90-100 | 3.6 to 4.0 (A) | |--------------|-----------------| | 80-89 | 3.0 to 3.5 (B) | | 60-79 | 2.0 to 2.9 (C) | | 50-59 | 1.0 to 1.9 (D) | | 49 and below | 0.0 (no credit) | ## LABORATORY MATERIALS - Hardware: Nexys<sup>TM</sup>-4 DDR Artix-7 FPGA Board (you can also use the Nexys<sup>TM</sup>-4 Artix-7 FPGA Board) - ✓ To order: <a href="http://store.digilentinc.com/nexys-4-ddr-artix-7-fpga-trainer-board-recommended-for-ece-curriculum/">http://store.digilentinc.com/nexys-4-ddr-artix-7-fpga-trainer-board-recommended-for-ece-curriculum/</a> Go to: Get Academic Pricing - Software: - ✓ Vivado HL Webpack Edition To download: http://www.xilinx.com/products/design-tools/vivado/vivado-webpack.html # OUTLINE OF TOPICS | | <ul> <li>Components: Datap</li> </ul> | ath circuit, Control circuit. | | | | |--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Digital System<br>Design | <ul> <li>Design examples: Simple processor, Debouncer, Banner on 7-seg displays, Binary to BCD algorithm.</li> </ul> | | | | | | | Extra Topics: Counter Posign | | | | | | | <ul><li>✓ Counter Design.</li><li>✓ Linear Feedback Shift Registers (Example: CRC), Memory Decoding.</li></ul> | | | | | | | | :: flip flop timing parameters, reducing output rate. | | | | | Computer Arithmetic | | Addition/subtraction, multiplication, division | | | | | | Unsigned/signed | Arithmetic units for integers. Comparators, Arithmetic Logic Unit | | | | | | integer numbers | (ALU), Barrel Shifter. | | | | | | Fixed-point (FX) arithmetic | <ul> <li>Addition/subtraction, multiplication, division.</li> </ul> | | | | | Compater Artenmetic | | FX arithmetic units. | | | | | | | Truncation/Rounding/Saturation. | | | | | | Floating-point (FP) arithmetic | <ul> <li>Addition/subtraction, multiplication, division.</li> <li>FP Arithmetic units</li> </ul> | | | | | | | | | | | | External Peripherals: | <ul> <li>Serial Comm.: UART, PS/2 (Keyboard/mouse), SPI (accelerometer), I<sup>2</sup>C (Temp. Sensor)</li> <li>PWM: Tri-color LEDs, Audio output.</li> </ul> | | | | | | | PDM: Microphone: ADMP421. | | | | | | Interfacing | Display: VGA, HDMI | | | | | | | <ul> <li>SRAM/DDRRAM, LCI</li> </ul> | D, SD card. | | | | | | <ul> <li>CORDIC: Computati</li> </ul> | on of trigonometric and hyperbolic functions | | | | | Special-Purpose | • Square Root. | | | | | | Circuits and | <ul> <li>Look-Up Table method: Pixel processor for gamma correction, contrast stretching, etc.</li> </ul> | | | | | | Techniques | Multiply-and-accumulate (MAC) circuit, Wallace multipliers, Booth recording, Square root. | | | | | | | ■ FPGA Resources: CLBs, FIFOs, BlockRAMs, DSPs, Clock Managers, XADCs. | | | | | | Pipelining and | | Iterative, array, and pipelined array designs Multi-operand addition: iterative (accumulator) vs. pipelined array (adder tree) | | | | | unfolding | | | | | | | uniolanig | <ul> <li>Multiplier and Divider: iterative vs. pipelined array</li> <li>CORDIC: iterative vs. pipelined array</li> </ul> | | | | | | Microprocessor | Computer Hardware Organization: Single/Multiple-Cycle Hardwired Control, Instruction Set | | | | | | Design | <ul> <li>Memory technology: RAM/ROM, FIFOs. SRAMs, DDRRAM, Flash.</li> </ul> | | | | | # VHDL: These are the aspects of VHDL description and coding techniques that will be covered in this course. | Introduction | <ul> <li>Design Flow: Design Entry, Behavioral/Timing Simulation, Mapping, Implementation</li> <li>Data Types and Description of Logic Gates</li> </ul> | | | |---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | VHDL Testbench Generation | | | | Concurrent | Concurrent statements: 'with-select', 'when-else' | | | | Description | <ul> <li>Combinational circuits description: (priority) encoder, decoder, comparator, mux, de-mux.</li> </ul> | | | | Behavioral<br>Description | Asynchronous processes. Repositional description of Combinational sixuality (priority) anadox description comparator may | | | | | <ul> <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 | | | | Description | Examples: Adder, Multiplier, Arithmetic Logic Unit, Look-up Table | | | | Sequential<br>Circuits | Synchronous processes: flip-flops, counters, registers | | | | | Description of Finite State Machines (FSMs) | | | | | Testbench: generating clock stimulus | | | | Parameterization | <ul> <li>Use of for-generate, if-generate in VHDL.</li> </ul> | | | | | <ul><li>Custom-defined data types, arrays (e.g.: std_logic_2d), records.</li></ul> | | | | | Generic testbenches | | | | I/O Text files | Synthesis: Reading input text files | | | | | Simulation: Reading input text files and writing output text files. | | | | Miscellaneous<br>Topics | Embedding counters and registers inside ASM diagrams. | | | | | <ul> <li>Using Xilinx primitives: BRAMs, FIFOs, etc.</li> </ul> | | | | | Packages in VHDL. | | | 3 Instructor: Daniel Llamocca ## CLASS POLICIES - **No Credit Policy**: A grade of 0.0 will be given to students not receiving 60% in the Laboratory category and to students not participating in the Final Project, regardless of their performance in other parts of the course. - **Laboratory**: Students must be aware of their Laboratory section: 002, 003. 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 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