1 / 43

ECE 331 – Digital System Design

Course Introduction and VHDL Fundamentals (Lecture #1). ECE 331 – Digital System Design. The slides included herein were taken from the materials accompanying Fundamentals of Logic Design, 6 th Edition , by Roth and Kinney, and were used with permission from Cengage Learning. .

cher
Download Presentation

ECE 331 – Digital System Design

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Course Introduction and VHDL Fundamentals (Lecture #1) ECE 331 – Digital System Design The slides included herein were taken from the materials accompanying Fundamentals of Logic Design, 6th Edition, by Roth and Kinney, and were used with permission from Cengage Learning.

  2. ECE 331 - Digital Systems Design Course Introduction

  3. ECE 331 - Digital Systems Design Course Info • Course #: ECE 331 • Course Name: Digital Systems Design • Course Objective: • To analyze and design combinational and sequential logic circuits. • To write VHDL code to describe and synthesize both types of circuits. • Course website: • http://ece.gmu.edu/~clorie/Fall10/ECE-331/

  4. ECE 331 - Digital Systems Design Instructor and TA's • Instructor: Craig Lorie • Email: clorie@gmu.edu • Phone: (703) 993 – 9616 • Office: Nguyen Engineering Bldg., Rm. 3221 • TA: Ahmad Salman • Email: asalman@gmu.edu • TA: Smriti Gurung • Email: sgurung@gmu.edu

  5. ECE 331 - Digital Systems Design Textbook • Title: Fundamentals of Logic Design • Edition: 6th • Authors: Charles H. Roth Larry L. Kinney

  6. ECE 331 - Digital Systems Design Office Hours • Instructor: Craig Lorie • TBA • TBA • TA: Ahmad Salman • TBA • TA: Smriti Gurung • TBA

  7. ECE 331 - Digital Systems Design The Lab (ECE 332) • Labs performed weekly. • A total of eleven labs. • Pre-lab must be completed prior to your lab session. • If you fail to complete the pre-lab you will not be allowed to attend your lab session. • Labs are administered by the TA's. • ECE 332 must be taken in conjunction with ECE 331 or been previously completed with a C or better.

  8. ECE 331 - Digital Systems Design Homework • Homework will be assigned on a weekly basis. • Homework is due at the beginning of class on the date specified (generally Thursday). • No late submissions accepted. • Each assignment will consist of 8 problems. • Two will be worth 35 points each; partial credit. • Eight will be worth 5 points each; no partial credit. • Homework is essential to the learning process!

  9. ECE 331 - Digital Systems Design Exams • Two exams during the semester. • Final exam. • All exams are closed-book. • No cheat-sheets. • No make-up exams. • In the case of an emergency, see me. • Notify me in advance (whenever possible) if a conflict or problem exists.

  10. ECE 331 - Digital Systems Design Grading • The final grade will be calculated as follows: • Homework 15% • Exam #1 25% • Exam #2 25% • Final Exam 35% • The grade for lab (ECE 332) is assigned separately. • The letter grade assignment is indicated in the syllabus.

  11. ECE 331 - Digital Systems Design Attendance • Attending class is in your best interest! • I will provide supplemental information to that which is included in the textbook. • I will go over a multitude of examples. • I will answer questions. • However, attendance in lecture is NOT mandatory. • Attendance in Lab (ECE 332) IS mandatory.

  12. ECE 331 - Digital Systems Design When emailing me, please format the subject line as follows: “ECE331 - <last name> <first initial> - <subject>” Email

  13. ECE 331 - Digital Systems Design Please see the class syllabus for more details. (The syllabus can be found on the course website) Syllabus

  14. ECE 331 - Digital Systems Design Expectations

  15. ECE 331 - Digital Systems Design You are expected to: • Attend class (highly recommended). • Spend a minimum of 9 hours each week outside of class learning the material. • Read the text book. • Do the homework. • Attend the lab and complete all of the lab experiments.

  16. ECE 331 - Digital Systems Design Questions?

  17. ECE 331 - Digital Systems Design Chapter 10: Sections 1 – 9 Materials to be covered ...

  18. ECE 331 - Digital Systems Design Introduction to VHDL

  19. ECE 331 - Digital Systems Design Design conception DESIGN ENTRY Schematic capture VHDL Synthesis Functional simulation No Design correct? Yes Physical design Timing simulation No Timing requirements met? Chip configuration The Design Process

  20. ECE 331 - Digital Systems Design Introduction to VHDL • What is VHDL? • Very High Speed Integrated Circuit (VHSIC) • Hardware • Description • Language • VHDL: a formal language for specifying the behavior and structure of a digital circuit. • Verilog: another, equally popular, hardware description language (HDL).

  21. ECE 331 - Digital Systems Design Basic VHDL Convention • VHDL is case insensitive • Naming and Labeling • All names should start with a letter • Should contain only alphanumeric characters, and the underscore; no other characters allowed • Should not have two consecutive underscores • Should not end with an underscore • All names and labels in a given entity and architecture must be unique

  22. ECE 331 - Digital Systems Design Basic VHDL Convention • Free format language • i.e. allows spacing for readability • Comments start with “--” and end at end of line • Use one file per entity • File names and entity names should match

  23. ECE 331 - Digital Systems Design Logic Circuits in VHDL • VHDL description includes two parts • Entity statement • Architecture statement • Entity • Describes the interface (i.e. inputs and outputs) • Architecture • Describes the circuit implementation

  24. ECE 331 - Digital Systems Design VHDL Program Structure

  25. ECE 331 - Digital Systems Design The Entity Statement • Keyword: Entity • Requires a name • Specifies the input and output ports • Ports have • Name • Mode • Data type

  26. ECE 331 - Digital Systems Design The Entity Statement Each entity declaration includes a list of interface signals that can be used to connect to other modules or to the outside world. entity entity-name is [port(interface-signal-declaration);]end [entity] [entity-name]; The items enclosed in brackets are optional. The interface-signal-declaration normally has the following form: list-of-interface-signals: mode type [: = initial-value] {; list-of-interface-signals: mode type [: = initial-value]};

  27. ECE 331 - Digital Systems Design Ports: Mode • IN • Driver outside entity; can be read • OUT • Driver inside entity; cannot be read • INOUT • Driver inside and outside entity; can be read • BUFFER • Driver inside entity; can be read

  28. ECE 331 - Digital Systems Design std_ulogic std_logic bit_vector string std_ulogic_vector std_logic_vector Ports: Data Types bit boolean integer natural positive character There are other data types, including enumerated types.

  29. ECE 331 - Digital Systems Design The Architecture Statement • Keyword: Architecture • Requires a name • The model is typically chosen as the name • References the name of the associated Entity • Specifies the functionality of the Entity • Using one of several models • Multiple architectures can be associated with a single entity • Only one architecture may be referenced

  30. ECE 331 - Digital Systems Design The Architecture Statement Associated with each entity is one or more architecture declarations of the form architecture architecture-name of entity-name is [declarations]begin architecture bodyend [architecture] [architecture-name]; In the declarations section, we can declare signals and components that are used within the architecture. The architecture body contains statements that describe the operation of the module.

  31. ECE 331 - Digital Systems Design Signals • Can be wires or buses (groups of wires) • Wire • SIGNAL a: STD_LOGIC; • Bus (with 8 wires) • SIGNAL b8: STD_LOGIC_VECTOR(7 DOWNTO 0); • Bus (with 16 wires) • SIGNAL b16: STD_LOGIC_VECTOR(15 DOWNTO 0); • Used to interconnect entities and components

  32. ECE 331 - Digital Systems Design Signal Assignment A signal assignment statement has the form: signal_name <= expression [after delay]; Brackets indicate “after delay” is optional. If omitted, an infinitesimal ∆ (delta) delay is assumed. The symbol “<=“ is the signal assignment operator which indicates that the value computed on the right-hand side is assigned to the signal on the left side.

  33. ECE 331 - Digital Systems Design Conditional Signal Assignment The general form of a conditional signal assignment statement is signal_name <= expression1 when condition1 else expression2 when condition2 [else expressionN]; This concurrent statement is executed whenever a change occurs in one of the expressions or conditions. If condition1 is true, signal_name is set equal to the value of expression2, etc. The line in square brackets is optional.

  34. ECE 331 - Digital Systems Design Selected Signal Assignment The general form of a selected signal assignment statement is with expression_s select signal_s <= expression1 [after delay-time] when choice1, expression2 [after delay-time] when choice2, . . . [expression_n [after delay-time] when others];

  35. ECE 331 - Digital Systems Design VHDL Operators When parentheses are not used, operators in class 7 have the highest precedence and are applied first, followed by class 6, then class 5, etc.

  36. ECE 331 - Digital Systems Design IEEE Standard Logic Use of two-valued logic (bits and bit vectors) is generally not adequate for simulation of digital systems. In addition to ‘0’ and ‘1’, values of ‘Z’ (high-impedance or no connection), ‘X’ (unknown), and ‘U’ (uninitialized) are frequently used in digital system simulation. The IEEE standard 1164 defines a std_logic type that actually has nine values: • ‘U’, ‘X’, ‘0’, ‘1’, ‘Z’, ‘W’, ‘L’, ‘H’, ‘-’

  37. ECE 331 - Digital Systems Design Arithmetic Operations on Standard Logic Vectors The basic IEEE standards do not define arithmetic operations for bit_vectors or std_logic_vectors. The package IEEE.Std_logic_unsigned defines arithmetic operations on std_logic_vectors. The arithmetic operators (+, −, and *) and comparison operators (<, <=, =, /=, >=, >) defined in this package treat std_logic_vectors as unsigned binary numbers. These operators are referred to as overloaded operations. This means that the compiler will automatically use the proper definition of the operator depending on its context.

  38. ECE 331 - Digital Systems Design A B C A B F C A B C VHDL Example Entity Architecture

  39. ECE 331 - Digital Systems Design VHDL Example

  40. ECE 331 - Digital Systems Design VHDL Example

  41. ECE 331 - Digital Systems Design VHDL Example

  42. ECE 331 - Digital Systems Design VHDL Example (continued)

  43. ECE 331 - Digital Systems Design Questions?

More Related