## Lecture 4 Sequential Logic Pset 3 due Thursday Lab 2 part 1 due Thursday Lab 2 part 2 due Next Tuesday Lab 3 out this Thursday-Now! 9/19/2019 6.111 Fall 2019 ## Something We Can Build What if you were given the following design specification: assign light = button; \*Done...This is all we need in life. No it isn't 9/19/2019 6.111 Fall 2019 2 ## Levels of Complexity in Computation #### Automata theory Sipser's Book https://en.wikipedia.org/wiki/Automata\_theory ## Something We Cannot Build (Yet) What if you were given the following design specification: What makes this circuit so different from those we've discussed before? - 1. "State" i.e. the circuit has memory (become "state-ful") - 2. The output was changed by an input "event" (pushing a button) rather than an input "value" 9/19/2019 6.111 Fall 2019 3 9/19/2019 6.111 Fall 2019 #### Digital State Plan: Build a Sequential Circuit with stored digital STATE - Memory stores CURRENT state - Combinational Logic computes: - NEXT state (from input, current state) - OUTPUT values (from input, current state) - State changes on LOAD control input When Output depends on input and current state, circuit is called a Mealy machine. If Output depends only on the current state, circuit is called a Moore machine. 9/19/2019 6.111 Fall 2019 # How is Digital State Created? ...Or How to Make Electronics Remember Previous Values 9/19/2019 6.111 Fall 2019 6 ## From the Ground Up: - MOSFETs are electrically controlled switches: - Electricity can "gate" other electricity #### NAND Gate • Assemble higher functionality from the transistors 9/19/2019 6.111 Fall 2019 #### Full Adder out of NANDs Made completely of NAND gates and lets you add two one bit numbers plus a carry http://vlsiinnovator.blogspot.com/2015/02/full-adder-using-nand-gate-structural.html (36 transistors) 11 9/19/2019 6.111 Fall 2019 #### 8 bit Adder from Full Adders Link together eight Full Adders to get an 8 bit adder... and so on (now you can add two numbers each up to 255) (288 transistors) 10 https://www.researchgate.net/figure/Eight-bit-Ripple-Carry-adder\_fig2\_283037309 9/19/2019 6.111 Fall 2019 #### And So On... - We can keep wiring up larger and more complex digital systems which: - Given a set of inputs, provide a given set of outputs - Base outputs completely on layers of combinational logic - Will always respond the same way in time for a given input - But there are other ways... #### The D Latch - Made of gates (which are made of transistors, which are made of sand(currently)) - Something different though...what is it? "latch" means it holds whatever value was already present...basically: "Previous Q" | Е | D | Q | $\overline{Q}$ | |---|---|-------|----------------| | 0 | 0 | latch | latch | | 0 | 1 | latch | latch | | 1 | 0 | 0 | 1 | | 1 | 1 | 1 | 0 | E = "Enable" D = "Data" Q = not sure, but it is the output #### The D Latch Provides Memory! - 1. Set E=1 - 2. Set your D value - 3. Set E=0 9/19/2019 9/19/2019 - 4. Whatever D was is stored at Q forever until E is 1 again! - 5. Can we do better/different? | Е | D | Q | $\overline{Q}$ | |---|---|-------|----------------| | 0 | 0 | latch | latch | | 0 | 1 | latch | latch | | 1 | 0 | 0 | 1 | | 1 | 1 | 1 | 0 | E = "Enable" D = "Data" Q = not sure, but it is the output The D Flip-Flop (Reg) Two D-Latches in Series driven with opposite enable signals Data propagates through first D Latch #### **CLK LINE is LOW** 9/19/2019 6.111 Fall 2019 14 ## The D Flip-Flop (Reg) Two D-Latches in Series driven with opposite enable signals 15 6.111 Fall 2019 6.111 Fall 2019 ## A New Building Block: the D Flip-Flop The edge-triggered D register: on the rising edge of CLK, the value of D is saved in the register and then appears shortly afterward on Q. Example: 74LS74 internals When you simplify some common/redundant logic between the two stages, you get to about ~25 transistors 9/19/2019 6.111 Fall 2019 1 #### Registers, Latches, and Flip-Flops - The terminology is a mess for historical reasons and just people in general, including myself. Here's one interpretation: - A "register" is something that holds a value. Flip-flops and Latches are registers - Further confusing the situation, people, including myself, often use "register" or "reg" to just refer to flip-flops ## Usage ...Or what does this let us do now? 9/19/2019 6.111 Fall 2019 18 # D Flip-Flop Registers Give Us A Few Critical Capabilities - We can store values for later use - We can sample values at precise times - A rising edge is as close to a delta-function like event as we can get - We can design in stages: - Allow us to non-destructively limit signal propagation ## Remember about Delays in Logic - Every combinational circuit has delays regarding how slowly (or quickly) its outputs change in response to inputs, and this varies based on design/complexity - t<sub>cd</sub> minimum time input takes to start to change output - t<sub>nd</sub> maximum time input takes to finish changing output 9/19/2019 6.111 Fall 2019 19 9/19/2019 6.111 Fall 2019 20 #### Remember about Delays in Logic Registers let us isolate/limit signal propagation and synchronize stages 6.111 Fall 2019 21 23 #### Remember about Delays in Logic ## Design Complex Logic In Stages! 9/19/2019 - D flip-flops regulate signal propagation! - Design complex logic systems in stages - Worry only about affects of delays (t<sub>pd</sub> and t<sub>cd</sub>) and glitches within a given stage, rather than how they all interplay! **Maximum** time it takes for Q to change after rising edge of CLK t<sub>cp</sub>: minimum contamination delay, @posedge CLK D →Q **Minimum** time it takes for Q to start to change after rising edge of CLK $\mathbf{t_{SFTUP}}$ : setup time How long D must be stable **before** the rising edge of CLK iold: noid time How long D must be stable **after** the rising edge of CLK New timing attributes for registers 9/19/2019 6.111 Fall 2019 9/19/2019 6.111 Fall 2019 24 ## D Register Timing 2 #### D Register Timing 2 We may encounter this in 6.111! If we try to make our combinational logic **tooooo complex** and we won't satisfying timing. How do we fix? Two options: $t_{\text{CD,reg1}} + t_{\text{CD,logic}} \ge t_{\text{HOLD,reg2}}$ If you violate this, you have to change your design. This is more an issue for the device engineers...on our FPGAs the contamination delays (min change times) are usually longer than HOLD times, so it is hard for us to run into this problem in 6.111 (though it is a very real problem for people laying out circuits) ## Design Complex Logic In Stages! - Design complex logic systems in stages - Worry only about affects of delays (t<sub>pd</sub> and t<sub>cd</sub>) within a given stage, rather than how they all interplay! 9/19/2019 6.111 Fall 2019 27 9/19/2019 6.111 Fall 2019 28 ## Single Clock Synchronous Discipline - Single Clock signal shared among all clocked devices (one clock domain) - Only care about the value of combinational circuits just before rising edge of clock - Clock period greater than every combinational delay - Change saved state after noise-inducing logic changes have stopped! 9/19/2019 6.111 Fall 2019 29 ## Writing Sequential Logic ...Or how do we create sequential logic using SystemVerilog, overcome the problems of Verilog, and move forward as a Society #### Sequential Circuit Timing - Constraints on t<sub>cp</sub> for the logic? - Minimum clock period? - · Setup, Hold times for Inputs? This is a simple Finite State Machine ... more in future classes! 9/19/2019 6.111 Fall 2019 30 Has a little bit of everything: #### assign statements Synthesize to combinational logic #### always\_comb blocks Synthesize to combinational logic Allow you to be more expressive than simple assign statements #### always\_ff blocks Synthesize to sequential logic 9/19/2019 6.111 Fall 2019 31 9/19/2019 6.111 Fall 2019 32 #### always - In Verilog the always keyword is a way to specify logic (sequential, combinational) that is caused by an event (clock edge, change of state, etc) - Very similar to an asynchronous callback in Javascript etc: - "When an event happens, do a certain thing:" - Historically there was one always word and you would then specify a <u>sensitivity list</u>: - always @(x) = "when x changes" - always @(\*) = "when anything changes (combinational)" - always @(posedge clk) = "when clk edge rises" - Etc... 9/19/2019 6.111 Fall 2019 33 #### Regs, Wires, Logics, and Life - Original Verilog had two main datatypes - wire: Used for continuous assignment (combinational) - reg: Used to "store" values - Despite its name being short for "register" a reg might not actually mean the design will synthesize to an actual register... It depended on usage in the Verilog. - In particular it mostly depended on your sensitivity list in your always block and if you used block or nonblocking assignments (= or <=):</li> - posedge? Make a flip flop - values? Make it a combinational or possibly a latch 9/19/2019 6.111 Fall 2019 34 ## SystemVerilog - Drop the wire and reg terminology, just have logic and let compiler figure out if it becomes an actual register (flip-flop) or wire from use - Use is specified more clearly now by replacing ambiguousness of generic always with specific use cases: - always\_comb: build using combinational logic - always\_ff: build using D-flip-flops (edge-trig sequential) - What is synthesized is NOT "inferred" and more clearly based on user specification! #### Blocking vs. Nonblocking Assignment - Within any type of always block you can assign things in two different ways: - In both ways, you don't need the keyword assign - Blocking assignment (=): evaluation and assignment are immediate; subsequent statements affected. (ORDER MATTERS) - Nonblocking assignment (<=): all assignments deferred to end of simulation time step after all right-hand sides have been evaluated (even those in other active always blocks) (ORDER DOESN'T MATTER) 9/19/2019 6.111 Fall 2019 35 9/19/2019 6.111 Fall 2019 #### Blocking vs. Non-Blocking Assignments - Verilog supports two types of assignments within always-type blocks, with subtly different behaviors. - Blocking assignment (=): evaluation and assignment are immediate ``` always_comb begin x = a | b; // 1. evaluate a|b, assign result to x y = a ^ b ^ c; // 2. evaluate a^b^c, assign result to y z = b & ~c; // 3. evaluate b&(~c), assign result to z end ``` <u>Nonblocking assignment (<=):</u> all assignments deferred to end of simulation time step after <u>all</u> right-hand sides have been evaluated (even those in other active always blocks) ``` always_comb begin x \leftarrow a \mid b; // 1. evaluate a \mid b, but defer assignment to x \neq a \land b \land c; // 2. evaluate a \land b \land c, but defer assignment to a \lor c \rightarrow b \lor c; // 3. evaluate a \lor b \lor c \rightarrow b \lor c; // 4. end of time step: assign new values to a \lor c \rightarrow b \lor c; end ``` Sometimes, as above, both produce the same result. Sometimes, not! 9/19/2019 6.111 Fall 2019 #### Assignment Styles for Sequential Logic - Suppose we want to build the circuit above: - Will nonblocking and blocking assignments both produce the desired result? ("old" means value before clock edge, "new" means the value after most recent assignment) ``` module nonblocking( input val_in, clk_in, output logic val_out ); logic q1, q2; always_ff @(posedge clk_in) begin q1 <= val_in; q2 <= q1; // uses old q1 val_out <= q2; // uses old q2 end endmodule</pre> ``` ``` module blocking( input val_in, clk_in, output logic val_out ); logic q1, q2; always_ff @(posedge clk_in) begin q1 = val_in; q2 = q1; // uses new q1 val_out = q2; // uses new q2 end end ``` 9/19/2019 6.111 Fall 2019 38 #### Use Nonblocking for Sequential Logic ``` module nonblocking( input val_in, clk_in, output logic val_out ); logic q1, q2; always_ff @(posedge clk_in) begin q1 <= val_in; q2 <= q1; // uses old q1 val_out <= q2; // uses old q2 end endmodule ``` "At each rising clock edge, q1, q2, and out simultaneously receive the old values of via, q1, and q2." ``` module blocking( input val_in, clk_in, output logic val_out ); logic q1, q2; always_ff @(posedge clk_in) begin q1 = val_in; q2 = q1; // uses new q1 val_out = q2; // uses new q2 end endmodule ``` "At each rising clock edge, q1 = vin. After that, q2 = q1. After that, out = q2. Therefore out = vin. ``` val_in D Q ou q1 ``` - Blocking assignments <u>do not</u> reflect the intrinsic behavior of multi-stage sequential logic - Guideline: use <u>nonblocking</u> assignments for always\_ff blocks (Sequential always blocks)!! #### General Strong Guidelines - Blocking assignments (=) more closely align with how combinational works (use in <a href="mailto:always\_comb">always\_comb</a>) - Non-blocking assignments (<=) more closely align with how we want to think about how sequential logic works (use in always\_ff) - Avoid mixing blocking and non-block assignments within one block! - Something will synthesize, but sometimes simulation will differ from what gets synthesized (built) - Really hard to comprehend for our limited human minds...so debugging is a nightmare 9/19/2019 6.111 Fall 2019 39 9/19/2019 6.111 Fall 2019 40 #### Example Uses with Assignments: #### **Combinatorial** # module blob(input a\_in, b\_in, sel\_in, sel\_in, sel\_in, output logic val\_out); always\_comb begin if (sel\_in) val\_out = b\_in; else val\_out = a\_in; end endmodule #### **Sequential** ``` module blob(input a_in, b_in, clk_in, clk_in, clk_in, output logic val_out); always_ff @(posedge clk_in) begin if (sel_in) val_out <= b_in; else val_out <= a_in; end endmodule ``` #### Makes: #### Makes: 9/19/2019 6.111 Fall 2019 41 #### **Coding Guidelines** - The following helpful guidelines are from this paper. If followed, they ensure your simulation results will match what they synthesized hardware will do: http://www.sunburst-design.com/papers/CummingsSNUG2000SJ NBA.pdf - 1. When modeling sequential logic, use and always ff with nonblocking assignments. - 2. When modeling combinational logic with an always block, use always\_comb with blocking assignments. - 3. When modeling both sequential and "combinational" logic within the same always block, use nonblocking assignments. - 4. Do not mix blocking and nonblocking assignments in the same always block. - 5. Do not make assignments to the same variable from more than one always block (this should throw errors, but might not if using blocking assignments) - #1 thing we will be checking in your Verilog submissions! 9/19/2019 6.111 Fall 2019 42 #### The Sensitivity List in always ff - The use of posedge and negedge specifies edge you care about - Can have combinational sensitivity lists, but must all be edge-based #### D-Register with synchronous clear ``` module dff_sync_clear( input d_in, clearb_in, clk_in, output logic q_out ); slways @(posedge clk_in) begin if (!clearb_in) q_out <= 1'b0; else q_out <= d_in; end endmodule</pre> ``` #### **D-Register with asynchronous clear** ``` module dff_sync_clear( input d_in, clearb_in, clk_in, output logic q_out ); always @(negedge clearb_in or posedge clk_in) begin if (!clearb_in) q_out <= 1'b0; else q_out <= d_in; end endmodule</pre> ``` always block entered only at each positive clock edge always block entered immediately when (active-low) clearly in is asserted #### Example: Simple Counter Can still specify combinational logic when making sequential logic in always\_ff blocks! 9/19/2019 6.111 Fall 2019 43 9/19/2019 6.111 Fall 2019 **Quite a bit similarity to Lab 2** #### Example: Simple Counter Can still specify combinational logic when making sequential logic in always\_ff blocks! ``` // 4-bit counter with enable and synchronous clear module counter(input clk_in, enb_in, clr_in, output reg [3:0] count_out); always_ff @(posedge clk_in) begin count_out <= clr_in ? 4'b0 : (enb_in ? count_out+1 : count_out); end Sequential endmodule ``` ## Lab 2 Starter Code ...With this all in mind, let's revisit Lab 2's starter code #### Summary - If a logic is assigned values with an assign statement OR inside a always\_comb block, it will synthesize to the result of combinational logic - If a logic is assigned values within a always\_ff block, it will synthesize to a value on a D-flip-flop - While you can mix = and <=, it is really, really discouraged: - Use = inside always\_comb - Use <= inside always\_ff 9/19/2019 6.111 Fall 2019 46 #### Lab 2 Starter Code Has a little bit of everything: #### assign statements Synthesize to combinational logic #### always\_comb blocks Synthesize to combinational logic Allow you to be more expressive #### always\_ff blocks Synthesize to sequential logic 9/19/2019 6.111 Fall 2019 47 9/19/2019 6.111 Fall 2019 48 #### Implicit wire data types • wire data types can only be given values through an assign statement (can't on left side of = or <= in an always block) Outputs on modules default to wires unless specified ``` otherwise module seven_seg_controller(input rst_in, input [31:0] val in, output logic[7:0] cat_out, output logic[7:0] an_out Could also say just output [7:0] cat_out but then you can only do: assign cat_out = blah blah blah; If it is declared as a logic, then you can do either: assign cat_out = blah blah blah; always_ff @(posedge clk_in)begin cat_out <= blah blah blah; Depending on need... 9/19/2019 6.111 Fall 2019 ``` #### Can write your combinational logic in whatever way you most prefer! - Both types of assignments turn into combinational logic - This one could be done with a nested ternary operator, but it would be gross ``` assign cat_out = ~led_out; assign an_out = ~segment_state; always_comb begin case(segment state) routed vals = val in[3:0]; 8'b0000 0001: 8'b0000 0010: routed_vals = val_in[7:4]; 8'b0000_0100: routed_vals = val_in[11:8]; 8'b0000_1000: routed_vals = val_in[15:12]; 8'b0001_0000: routed_vals = val_in[19:16]; 8'b0010_0000: routed_vals = val_in[23:20]; 8'b0100_0000: routed_vals = val_in[27:24]; 8'b1000 0000: routed vals = val in[31:28]; default: routed_vals = val_in[3:0]; endcase ``` 9/19/2019 6.111 Fall 2019 50 ## Same Thing These do the same thing...create combinational logic ``` always_comb begin 8'b0000_0001: routed_vals = val_in[3:0]; 8'50000 0010: routed_vals = val_in[7:4]; routed_vals = val_in[11:8]; routed_vals = val_in[15:12]; 8'b0001 0000: routed_vals = val_in[19:16]; 8'b0010 0000: routed vals = val in[23:20]: 8'b0100_0000: routed_vals = val_in[27:24]; 8'b1000_0000: routed_vals = val_in[31:28]; default: routed_vals = val_in[3:0]; endcase ``` ``` assign routed_vals = segment_state==8'b0000_0001? val_in[3:0]: segment_state==8'b0000_0010? val_in[7:4]: segment_state==8'b0000_0100? val_in[11:8]: segment_state==8'b0000_1000? val_in[15:12]: segment_state==8'b0001_0000? val_in[19:16]: segment_state==8'b0010_0000? val_in[23:20]: segment_state==8'b0100_0000? val_in[27:24]: segment_state==8'b1000_0000? val_in[31:28]: val_in[3:0]; ``` ## Sequential (Synchronous) Logic "Every rising clk edge, if rst in asserted, reset things to 0. Otherwise if segment counter is 100,000, reset segment counter and rotate segment state. Otherwise, increment segment counter by 1..." ``` always ff @(posedge clk in)begin if (rst_in)begin segment_state <= 8'b0000_0001; segment counter <= 32'b0: end else begin if (segment counter == 32'd100 000)begin segment counter <= 32'd0; segment_state <= {segment_state[6:0],segment_state[7]};</pre> end else begin segment_counter <= segment_counter +1; end end ``` 9/19/2019 6.111 Fall 2019 51 9/19/2019 6.111 Fall 2019 52 #### Resetting to a Known State! Usually one can't rely on registers powering-on to a particular initial state\*. So most designs have a RESET signal that when asserted initializes all the state to known, mutually consistent initial values. reset ``` always_ff @(posedge_cll_in)begin if (rst_in)digin segment_state <= 8'b0000_0001; segment_counter <= 32'b0; end else begin if (segment_counter == 32'd100_000)begin segment_counter <= 32'd0; segment_state <= {segment_state[6:0], segment_state[7]}; end else begin segment_counter <= segment_counter +1; end end end ``` \* Actually, our FPGAs will reset all registers to 0 when the device is programmed, unless otherwise specified. But it's nice to be able to press a reset button to return to a known state rather than starting from scratch by reprogramming the device. 9/19/2019 6.111 Fall 2019 # Interfacing to Sequential Logic ...Or what are the problems with working with Sequential Logic?....Optional for today depending on timing 9/19/2019 6.111 Fall 2019 54 $\mathbf{t_{pD}}$ : maximum propagation delay, @posedge CLK D $\rightarrow$ Q **Maximum** time it takes for Q to change after rising edge of CLK $t_{cp}$ : minimum contamination delay, @posedge CLK D $\rightarrow$ Q Minimum time it takes for Q to start to change after rising edge of CLK t<sub>SETUP</sub>: setup time How long D must be stable **before** the rising edge of CLK tuoin: hold time How long D must be stable after the rising edge of CLK New timing attributes for registers 53 Asynchronous Inputs in Sequential Systems When an asynchronous signal causes a setup/hold violation... Q: Which cases are problematic? 9/19/2019 6.111 Fall 2019 55 9/19/2019 6.111 Fall 2019 56 #### Asynchronous Inputs in Sequential Systems - All of them can be, happens simultaneously within the same circuit. - Guidelines: Ensure that external signals feed exactly one flip-flop 9/19/2019 6.111 Fall 2019 #### Metastability D-registers have metastable regions with all that feedback and stuff going on. Can go metastable Figure 1. Metastability Timing Parameters Altera Application Note 42 (1999) 9/19/2019 6.111 Fall 2019 58 #### Figure 5. Metastability Characteristics of Altera Devices **MTBF** FLEX 8000 & FLEX 6000 MAX 9000 & 10 Years 1 Month MTBF 1 Day MTBF: Mean Time Between Failure 1 Minute-10<sup>1</sup> Set by user (how much extra time do you provide per cycle for metastability to dissipate) Metastability in Altera Devices Altera Application Note 42 (1999) 9/19/2019 6.111 Fall 2019 59 #### Handling Metastability Figure 8. Two-flip-flop synchronization circuit. • FF2 (D-reg2) might go a clock cycle late, but it will almost never go metastable "Metastability and Synchronizers: A Tutorial" Ran Ginosar, Technion Israel Institute of Technology 9/19/2019 6.111 Fall 2019 60 ## Handling Metastability - Preventing metastability turns out to be an impossible problem - High gain of digital devices makes it likely that metastable conditions will resolve themselves quickly - Solution to metastability: allow time for signals to stabilize #### How many registers are necessary? - Depends on many design parameters (clock speed, device speeds, ...) - In 6.111, a pair of synchronization registers is sufficient 9/19/2019 6.111 Fall 2019 61