## Flip-Flops and Registers

**Exercise 1**: Is a signal named **overload** active-high or active-low? Is there an overload if this signal is high? What if the signal was named

overload? overload: active low H >> folse: no overload. (overload is false).

overload: actively (and is true.)

**Exercise 2**: Come up with an appropriate name for a signal that is at 3 V when a door is open and 0 V when the door is closed.

**Exercise 3**: Fill in the waveform for the Q signal in the diagram above.



**Exercise 4**: What would be another name for a 1-bit register?

**Exercise 5**: Assuming a 3-bit counter, fill in the values of D and Q in the diagram above.



**Exercise 6**: Draw the block diagram for a counter that: (a) counts up by 3? (b) counts down by 1? (c) whose value doubles on each clock edge?



**Exercise 7**: Fill in the diagram above for a 4-bit shift register. Assume the initial value of each flip-flop is zero. Which is the oldest (first) value the D waveform? Which flip-flop holds the oldest value?



**Exercise 8**: Add parallel outputs to the shift register schematic. Draw a circuit whose output is high when the sequence 1, 0, 1, 1 is detected. Add the output of this circuit to the timing diagram above.



**Exercise 9**: What would you change to make an 8-bit register? A 4-bit counter? A 3-bit shift register? Follow the course coding conventions.

```
module test
                                                                         q[0]~reg[7..0]
   ( input logic [7:0] d,
      input logic clk,
                                                             d[7..0]
      output logic [7:0] q);
                                                                clk
                                                                           >CLK
                                                                                      q[7..0]
                                                                        8'h0
    always_ff @(posedge clk) q = d ;
 endmodule
                                                                                             count[3..0]
 module test
                                                             1'h0 CIN Add0
                                                                               count[0]~reg[3..0]
    ( // input logic d,
                                                              A[3..0]
     input logic clk,
                                                           4'h1 B[3..0]
                                                                                  CLK
     output logic [3:0] count );
                                                                               4'h0 SCLR
                                                   clk 
    logic [3:0] count_next ;
    assign count_next = count + 1'b1 ;
    always_ff @(posedge clk) count = count_next ;
  endmodu le
module test
  ( input logic d,
    input logic clk,
    output logic q ) ;
   logic [2:0] yeet, yeet_next ;
   assign yeet_next = { d, yeet[2:1] } ;
   always_ff @(posedge clk) yeet = yeet_next ;
   assign q = yeet[0] ;
endmodule
                                                                                      6
                         yeet[2..0]
      d
     clk
                          >CLK
                                 O
                     3'h0
                          SCLR
```

**Exercise 10**: Label the specifications A through C as requirements or guaranteed responses.



input -> input : requirement

input - output : response

output -> output: response