| | Building sequences with combinatorial logicAs an example, we will design a circuit to generate the sequence of previous section. The circuit will take signals ET0, ET1 as inputs to generate /OTA_E, /MRD, /LD_A as outputs.
 Note: We use a forward slash (/) to denote logic inversion.
 
 From the time-diagram on previous section we can directly deduct the equations. In order to make things simpler we will mentally invert the control signals OTA_E, MRD, LD_A so they will become active-high as opposite as shown in the diagram. The resulting equations are these:
 
 OTA_E = T1 + T2 + T3
 MRD   = T2 + T3
 LD_A  = T3
 
 Where T1, T2 and T3 are products of E0, E1 as following:
 
 T1 = /ET1 * /ET0
 T2 = /ET1 * ET0
 T3 = ET1 * /ET0
 
 The drawing below shows the resulting circuit.
 
 
 The circuit on the left (Products Factory) obtains the required products T1, T2, T3. Notice that NAND gates have been employed instead of AND; the purpose of this is to be able to sum products using NANDs (applying De Morgan's Law) which is some times convenient in practice.
 
 The circuit on the right (Sequencer) conveniently sum different products to obtain the different signals according to the equations being implemented. Notice that NAND gates have been employed instead of OR since they receive inverted signals as mentioned before. The NAND's outputs are then inverted because the intended signals are active-low as shown in the time-diagram on previous section.
 
 A typical board builds more that one sequence, thus same products are reused among different sequencers. A single Products Factory is then employed to build all products involved whereas several Sequencers separately sum the required products as required.
 
 Signal SEQ_STROBE actvivates the Sequencer in question. Needless to say that only one sequencer can be active at a given time in the entire CPU.
 
 
 | 
 
 Homebuilt CPUs WebRing
JavaScript by Qirien Dhaela 
 Join the ring?
David Brooks, the designer of the Simplex-III homebrew computer, has founded the Homebuilt CPUs Web Ring. To join, drop David a line, mentioning your page's URL. He will then add it to the list. You will need to copy this code fragment into your page.
 |