diff options
Diffstat (limited to '12.md')
-rw-r--r-- | 12.md | 76 |
1 files changed, 76 insertions, 0 deletions
@@ -0,0 +1,76 @@ +[\<- Overflow, comparison, and the design of an ALU](11.md) + +--- + +# Latches + +## A circuit that remembers + +### Sequential Circuits + +- Circuits that have "memory" + - A subset of the inputs control whether the output is "allowed" to change + - Otherwise the output will hold its "state" +- In the circuit below, we want On to assert when Set asserts, and to stay asserted even if Set goes back to 0; Reset will clear + +data:image/s3,"s3://crabby-images/7bdba/7bdba608d023140bed18fcc1d46baa9cc596101b" alt="diagram" + +### Inverters in a feeback loop + +- Wires will hold onto value forever => memory + +data:image/s3,"s3://crabby-images/db8a8/db8a8307f90295e7e5f553e51cff3f308b27e7b2" alt="diagram" + +- But how to get a value onto one of the wires? + +### Controlling the feedback loop + +- The control signal affects the output + - If control = 0, NOR gate acts like an inverter + - If control = 1, output is 0 + +data:image/s3,"s3://crabby-images/a8b37/a8b37a9ed5531669955938a9f219ba8164b32649" alt="diagram" + +--- + +## The SR latch + +- Qa is primary output (Qb is the inverse) + - (S)et Qa to 1, or (R)eset to 0 + +data:image/s3,"s3://crabby-images/1b74b/1b74b1b22064c4f47075872b09ba260fe1843e19" alt="diagram" + +--- + +## Synchronizing with a clock signal + +### Using sequential circuits + +- A latch can hold one bit of info (state) +- Typically we want to hold onto multiple bits of info + - A counter is a typical example +- A 2-bit counter cycles thru 00, 01, 10, 11, then back to 00, 01, etc. +- Generally we want the two bits to change at the same time + - How to do this? + +### Using a Clock for Control + +- Most designs use a clock to "synchronize" when the sequential elements can change state +- In the circuit below, the output can only be changed when Clk "enables" S and R + +data:image/s3,"s3://crabby-images/e65bb/e65bbdf69f2b4078bf898842adce598251a86b9c" alt="diagram" + +### Use a D input instead of SR + +- If S and R happen to assert at the same time, the output becomes a function of which deasserts last + - This may be unknown or unintentional +- Don't really need both S and R + - If we're trying to change the output, we generally know if it should be 0 or 1 +- Define a single input, D, that is passed to the output + +### D Latch + +data:image/s3,"s3://crabby-images/83172/831729e86e0782b8c61eaebdf730d3b4c611547e" alt="Circuit" +data:image/s3,"s3://crabby-images/76e78/76e78c523a96d36a036029abba92118687995ebb" alt="Characteristic table" +data:image/s3,"s3://crabby-images/2334e/2334e6ea6fb77f9fd721b5e558d3fc23e8a6a599" alt="Graphical symbol" +data:image/s3,"s3://crabby-images/ca854/ca85433bf86b4b84a52a1d2aaf2be9badbab91b0" alt="Timing diagram" |