1 / 37

ECM585 Special Topics in Computer Design Lecture 2. Combinational Logic Design 1

ECM585 Special Topics in Computer Design Lecture 2. Combinational Logic Design 1 Prof. Taeweon Suh Computer Science Education Korea University Introduction A logic circuit is composed of: Inputs Outputs Functional specification Timing specification Circuits Nodes Inputs: A , B , C

Renfred
Download Presentation

ECM585 Special Topics in Computer Design Lecture 2. Combinational Logic Design 1

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. ECM585Special Topics in Computer DesignLecture 2. Combinational Logic Design 1 Prof. Taeweon Suh Computer Science Education Korea University

  2. Introduction A logic circuit is composed of: • Inputs • Outputs • Functional specification • Timing specification

  3. Circuits • Nodes • Inputs: A, B, C • Outputs: Y, Z • Internal: n1 • Circuit elements • E1, E2, E3

  4. Types of Logic Circuits • Combinational Logic • Memoryless • Outputs determined by current values of inputs • Sequential Logic • Has memory • Outputs determined by previous and current values of inputs

  5. Rules of Combinational Composition • Every circuit element is itself combinational • Every node of the circuit is either designated as an input to the circuit or connects to exactly one output terminal of a circuit element • The circuit contains no cyclic paths: every path through the circuit visits each circuit node at most once • Example:

  6. Boolean Equations • Functional specification of outputs in terms of inputs • Example: S = F(A, B, Cin) Cout = F(A, B, Cin)

  7. Terminology • The Complementof a variable A is A • A variable or its complement is called literal • The AND of one or more literals is called a product orimplicant • Example: AB, ABC, B • OR of one or more literals is called a sum • Example: A + B • Order of operations • NOT has the highest precedence, followed by AND, then OR • Example: Y = A + BC

  8. Sum-of-Products (SOP) Form • All Boolean equations can be written in SOP form • A mintermis a product (AND) of literals involving all of the inputs to the function • Each row in a truth table has a minterm that is TRUE for that row (and only that row) • The function is formed by ORing the minterms for which the output is TRUE • Thus, a sum (OR) of products (AND terms) Y = F(A, B, C) = AB + AB

  9. Product-of-Sums (POS) Form • All Boolean equations can be written in POS form • A maxterm is a sum (OR) of literals • Each row in a truth table has a maxterm that is FALSE for that row (and only that row) • The function is formed by ANDing the maxterms for which the output is FALSE • Thus, a product (AND) of sums (OR terms) Y = F(A, B, C) = (A + B)(A + B)

  10. Boolean Equations Example • You are going to the cafeteria for lunch • You won’t eat lunch (E: eat) • If it’s not open (O: open) • If they only serve corndogs (C: corndogs) • Write a truth table for determining if you will eat lunch (E)

  11. SOP & POS Form • SOP – sum-of-products • POS – product-of-sums Y = AB Y = (A + B)(A + B)(A + B)

  12. When to Use SOP and POS? • SOP produces the shortest equations when the output is true on only a few rows of a truth table • POS is simpler when the output is false on only a few rows of a truth table

  13. HDL • Hardware description language (HDL): allows designer to specify logic function only. Then a computer-aided design (CAD) tool produces the optimized gates. • Most commercial designs built using HDLs • Two leading HDLs: • Verilog • developed in 1984 by Gateway Design Automation • became an IEEE standard (1364) in 1995 • VHDL • Developed in 1981 by the Department of Defense • Became an IEEE standard (1076) in 1987

  14. HDL to Gates • Simulation • Input values are applied to the circuit • Outputs checked for correctness • Millions of dollars saved by debugging in simulation instead of hardware • We are going to use ModelSim Xilinx Edition-III (MXE-III) for simulation • http://www.xilinx.com/ise/optional_prod/mxe.htm • Synthesis • Transforms HDL code into a netlist describing the hardware (i.e., a list of gates and the wires connecting them) • You can see the synthesized result with ISE Webpack IMPORTANT: When describing circuits using an HDL, it’s critical to think of the hardware the code should produce.

  15. Verilog Modules • Two types of Modules: • Behavioral: describe what a module does • Structural: describe how a module is built from simpler modules

  16. Behavioral Verilog Example Verilog: module example(input a, b, c, output y); assign y = ~a & ~b & ~c | a & ~b & ~c | a & ~b & c; endmodule

  17. Behavioral Verilog Simulation Verilog: module example(input a, b, c, output y); assign y = ~a & ~b & ~c | a & ~b & ~c | a & ~b & c; endmodule

  18. Behavioral Verilog Synthesis Verilog: module example(input a, b, c, output y); assign y = ~a & ~b & ~c | a & ~b & ~c | a & ~b & c; endmodule Synthesis:

  19. Verilog Syntax • Verilog is case sensitive. So, reset and Reset are not the same signal. • Verilog does not allow you to start signal or module names with numbers. So, for example, 2mux is an invalid name. • Verilog ignores whitespace. • Comments come in single-line and multi-line varieties: • // single line comment • /* multiline comment */

  20. Structural Modeling - Hierarchy module and3(input a, b, c, output y); assign y = a & b & c; endmodule module inv(input a, output y); assign y = ~a; endmodule module nand3(input a, b, c output y); wire out; // internal signal and3 andgate(a, b, c, out); // instance of and3 inv inverter(out, y); // instance of inverter endmodule

  21. Bitwise Operators module gates(input [3:0] a, b, output [3:0] y1, y2, y3, y4, y5); /* Five different two-input logic gates acting on 4 bit busses */ assign y1 = a & b; // AND assign y2 = a | b; // OR assign y3 = a ^ b; // XOR assign y4 = ~(a & b); // NAND assign y5 = ~(a | b); // NOR endmodule // single line comment /*…*/ multiline comment

  22. Reduction Operators module and8(input [7:0] a, output y); assign y = &a; // &a is much easier to write than // assign y = a[7] & a[6] & a[5] & a[4] & // a[3] & a[2] & a[1] & a[0]; endmodule

  23. Conditional Assignment module mux2(input [3:0] d0, d1, input s, output [3:0] y); assign y = s ? d1 : d0; endmodule ? : is also called a ternary operator because it operates on 3 inputs: s, d1, and d0.

  24. Internal Variables module fulladder(input a, b, cin, output s, cout); wire p, g; // internal nodes assign p = a ^ b; assign g = a & b; assign s = p ^ cin; assign cout = g | (p & cin); endmodule

  25. Precedence Order of operations Highest Lowest

  26. Numbers Format: N'Bvalue N = number of bits, B = base N'B is optional but recommended (default is decimal)

  27. Bit Manipulations: Example 1 assign y = {a[2:1], {3{b[0]}}, a[0], 6’b100_010}; // if y is a 12-bit signal, the above statement produces: y = a[2] a[1] b[0] b[0] b[0] a[0] 1 0 0 0 1 0 // underscores (_) are used for formatting only to make it easier to read. Verilog ignores them.

  28. Bit Manipulations: Example 2 Verilog: module mux2_8(input [7:0] d0, d1, input s, output [7:0] y); mux2 lsbmux(d0[3:0], d1[3:0], s, y[3:0]); // from slide 12 mux2 msbmux(d0[7:4], d1[7:4], s, y[7:4]); // from slide 12 endmodule Synthesis:

  29. Z: Floating Output Verilog: module tristate(input [3:0] a, input en, output [3:0] y); assign y = en ? a : 4'bz; endmodule Synthesis:

  30. Delays module example(input a, b, c, output y); wire ab, bb, cb, n1, n2, n3; assign #1 {ab, bb, cb} = ~{a, b, c}; assign #2 n1 = ab & bb & cb; assign #2 n2 = a & bb & cb; assign #2 n3 = a & bb & c; assign #4 y = n1 | n2 | n3; endmodule

  31. Delays module example(input a, b, c, output y); wire ab, bb, cb, n1, n2, n3; assign #1 {ab, bb, cb} = ~{a, b, c}; assign #2 n1 = ab & bb & cb; assign #2 n2 = a & bb & cb; assign #2 n3 = a & bb & c; assign #4 y = n1 | n2 | n3; endmodule

  32. Testbenches • HDL code written to test another HDL module, the device under test (dut), also called the unit under test (uut) • Not synthesizeable • Types of testbenches: • Simple testbench • Self-checking testbench • Self-checking testbench with testvectors (will be explained later)

  33. Example Write Verilog code to implement the following function in hardware: y = bc + ab Name the module sillyfunction

  34. Example Write Verilog code to implement the following function in hardware: y = bc + ab Name the module sillyfunction Verilog: module sillyfunction(input a, b, c, output y); assign y = ~b & ~c | a & ~b; endmodule

  35. Simple Testbench module testbench1(); reg a, b, c; wire y; // instantiate device under test sillyfunctiondut(a, b, c, y); // apply inputs one at a time initial begin a = 0; b = 0; c = 0; #10; c = 1; #10; b = 1; c = 0; #10; c = 1; #10; a = 1; b = 0; c = 0; #10; c = 1; #10; b = 1; c = 0; #10; c = 1; #10; end endmodule

  36. Self-checking Testbench module testbench2(); reg a, b, c; wire y; // instantiate device under test sillyfunction dut(a, b, c, y); // apply inputs one at a time // checking results initial begin a = 0; b = 0; c = 0; #10; if (y !== 1) $display("000 failed."); c = 1; #10; if (y !== 0) $display("001 failed."); b = 1; c = 0; #10; if (y !== 0) $display("010 failed."); c = 1; #10; if (y !== 0) $display("011 failed.");

  37. Self-checking Testbench (cont.) a = 1; b = 0; c = 0; #10; if (y !== 1) $display("100 failed."); c = 1; #10; if (y !== 1) $display("101 failed."); b = 1; c = 0; #10; if (y !== 0) $display("110 failed."); c = 1; #10; if (y !== 0) $display("111 failed."); end endmodule

More Related