Digital Electronics/Register

Register
WAYS OF DEFINING A REGISTER; Registers are data storage devices that are more sophisticated than latches. A register is a group of binary cells suitable for holding binary information. A group of cascaded flip-flops used to store related bits of information is known as a register.

SR Register
In some situations it may be desirable to dictate when the latch can and cannot latch. The gated SR latch is a simple extension of the SR latch which provides an Enable line which must be driven high before data can be latched. Even though a control line is now required, the SR latch is not synchronous, because the inputs can change the output even in the middle of an enable pulse.

When the Enable input is low, then the outputs from the AND gates must also be low, thus the Q and $\overline{Q}$ outputs remain latched to the previous data. Only when the enable input is high can the state of the latch change, as shown in the truth table. When the enable line is asserted, a gated SR latch is identical in operation to an SR latch.

The Enable line is sometimes a clock signal, but is usually a read or write strobe.


 * {| class=wikitable

|- !width=40|Enable !! width=40| S !!width=40| R |rowspan=9| !width=40| Q !! width=40|$\overline{Q}$ |- | 0 || 0 || 0 || colspan=2|Latch |- | 0 || 0 || 1 || colspan=2|Latch |- | 0 || 1 || 0 || colspan=2|Latch |- | 0 || 1 || 1 || colspan=2|Latch |- | 1 || 0 || 0 || colspan=2|Latch |- | 1 || 0 || 1 || 0 || 1  |-  | 1 || 1 || 0 || 1 || 0  |-  | 1 || 1 || 1 || colspan=2 | Metastable
 * }

D Register
The D latch (D for "data") or transparent latch is a simple extension of the gated SR latch that removes the possibility of invalid input states.

Since the gated SR latch allows us to latch the output without using the S or R inputs, we can remove one of the inputs by driving both the Set and Reset inputs with a complementary driver: we remove one input and automatically make it the inverse of the remaining input.

The D latch outputs the 'D' input whenever the Enable line is high, otherwise the output is whatever the D input was when the Enable input was last high. This is why it is also known as a transparent latch - when Enable is asserted, the latch is said to be "transparent" - its signals propagate directly through it as if it isn't there.


 * {| class=wikitable

|- !width=40|Enable !! width=40| D |rowspan=5| !width=40| Q !! width=40|$\overline{Q}$ |- | 0 || 0 || colspan=2|Latch |- | 0 || 1 || colspan=2|Latch |- | 1 || 0 || 0 || 1  |-  | 1 || 1 || 1 || 0
 * }

D latches are often used in I/O ports of integrated circuits and are available as discrete devices, often multiply packaged. An example is the 74HC75, part of the 7400 series of ICs, containing four separate D latches.

T flip-flops
A T flip-flop is a device which swaps or "toggles" state every time it is triggered if the T input is asserted, otherwise it holds the current output. This behavior is described by the characteristic equation:


 * $$Q_{next} = T \oplus Q = T\overline{Q} + \overline{T}Q$$

and can be described either of the following tables:



When T is held high, the toggle flip-flop divides the clock frequency by two; that is, if clock frequency is 4 MHz, the output frequency obtained from the flip-flop will be 2 MHz. This 'divide-by' feature has application in various types of digital counters. A T flip-flop can also be built using a JK flip-flop (J & K pins are connected together and act as T) or D flip-flop (T input and Qprev are connected to the D input through an XOR gate).

JK flip-flop
The JK flip-flop is a simple enhancement of the SR flip-flop where the state J=K=1 is not forbidden. It works just like a SR FF where J is serving as set input and K serving as reset. The only difference is that for the formerly “forbidden” combination J=K=1 this flip-flop now performs an action: it inverts its state. As the behavior of the JK flip-flop is completely predictable under all conditions, this is the preferred type of flip-flop for most logic circuit designs. But there is still a problem i.e. both the outputs are same when one tests the circuit practically. This is because of the internal toggling on every propagation elapse completion. The main remeady is going for master-slave jk flip-flop, this ff overrides the self(internal) recurring toggling through the pulsed clocking feature incorporated.



Reference

 * Register