Description in this experiment, you will implement the circuit shown in Figure 1. The circuit consists of two main components: a 3-bit synchronous counter and a 3-bit shift register. Note that the clock input of the counter is obtained from the FPGA oscillator (after being slowed down by dividing the frequency). The clock of the 3-bit register, on the other hand, is obtained from the zero\_count output of the 3-bit counter, which is 0 for all count values and 1 for count 0 only. Figure 1.Counter-controlled Register Block Diagram ## Part 1: 3-bit Counter Design: In this part, you are required to design a (count-down) 3-bit counter that counts 7, 6, 5, 4, 3, 2, 1, 0, 7, 6, 5, 4,...., using D flip flops. 1. Fill the following state table according to the required counter design. (PreLab) | Present State | | Next State | | | | | | | |---------------|----|------------|----|----|----|----|----|----| | Q2 | Q1 | Q0 | Q2 | Q1 | Q0 | D2 | D1 | DO | | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | 0 | 0 | 1 | 0 | 0 | o | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | | 0 | 1 | 1 | 0 | ١ | 0 | 0 | ١ | 0 | | 1 | 0 | 0 | 0 | 1 | 1 | ٥ | 1 | 1 | | 1 | 0 | 1 | 1 | ٥ | 0 | 1 | U | 0 | | 1 | 1 | 0 | ١ | ٥ | 1 | Ì | 0 | 1 | | 1 | 1 | 1 | 1 | 1 | U | 1 | V | U | Write the input equations of the three flip flops. (PreLab) | DO= Q0 | 1 | 0 | O | \ | 1 | |---------------------|---|---|---|-----|-----| | | 1 | 0 | 0 | 1 | ] | | DI= Q.Q. +Q.Q. | 1 | O | 1 | 0 | 1 / | | | 1 | 0 | 1 | 0 | | | D2 = Q2 . Q1 · Q0 + | 1 | 0 | o | 0 - | Y | | Q:Q +Q, Q, | 0 | ١ | 1 | 1 | | - 3. Draw the sequential circuit that implements the 3-bit counter. Then, add to your circuit the gate(s) required in order to generate an output signal called zero\_count which is one only when the count is 0. - In the file'threebitcounter.v', write a Verilog module that implements the 3-bit counter with the zero\_count signal structurally. - Convert the 3-bit counter schematic diagram you built to a block as in Figure 2. This block will be used in the final circuit implementation in part 3. File → Create/Update → Create Symbol Files for Current Files Figure 2. Block symbol for the three-bit counter. ## Part 2: 3-bit Shift-Register: In the file reg3b.v, write a Verilog module that implements the 3-bit register shown in Figure 3 structurally. Note: You will need to use the 4-to-1 MUX module implemented in the file mux1.v and the D-flip flop with reset module, which you implemented in experiment 7, in the file dff1.v. Note that the register has 4 modes of operation according to the following table: | m1 | m0 | Operation | |----|----|---------------| | 0 | 0 | Hold | | 0 | 1 | Parallel Load | | 1 | 0 | Rotate Right | | 1 | 1 | Rotate Left | 3. Clock input of the register: In your schematic diagram connect the clock input of the register to the output zero\_count of the counter. This means that the state of the register will be updated each time the counter reaches count 0 according to the mode setting. - Connect the outputs (C2, C1, C0) of the counter to the inputs of the segdecoder. Note that A is the MSB. - Connect seven output ports to the outputs of the segdecoder (a, b, c, d, e, f, g) with the same names. These will be assigned to a seven segment display when you do pins assignment. - Connect an input pin called restart, which resets the counter to count 7 and the register to - 7. Perform the following pins assignment for your input and outputs: | Input | | | | |---------|----------------|----------|--| | clk | | PIN_E16 | | | restart | iSW[1] | PIN_AB26 | | | m0 | ISW[2] | PIN_AB25 | | | m1 | iSW[3] | PIN_AC27 | | | PO | 1SW[4] | PIN_AC26 | | | P1 | 1SW[5] | PIN_AC24 | | | P2 | ISW[6] | PIN_AC23 | | | Outpu | its of the seg | decader | | | a | HEXO | PIN_AEB | | | b | (HEXO) | PIN_AF9 | | | с | HEX0/ | PIN_AH9 | | | d | HEXO | PIN_AD10 | | | e | HEXO | PIN_AF10 | | | f | HEX0 | PIN_AD11 | | | g | HEX0 | PIN_AD12 | | | Outpu | ts of the reg | ister | | | Out0 | oLEDR[1] | PIN_AK5 | | | Out1 | oLEDR[2] | PIN_AIS | | | Out2 | oLEDR[3] | PIN_AI4 | | 8. Download your circuit on the FPGA and test it. Figure3. 3-bit Register Diagram Convert the 3-bit register/Verilog module you implemented to a block as in Figure 4. This block will be used in the final circuit implementation in part 3. File → Create/Update → Create Symbol Files For Current Files Figure 4. Block symbol for the three-bit register. ## Part 3: Final Circuit Implementation: In the file circuit1.bdf, build the schematic diagram shown in Figure 1. The following steps detail how to add needed blocks to your diagram. Add one segdecoder symbol, clock symbol, 3-bit counter (threebitcounter) symbol and 3-bit register (reg3b) symbol to your bdf file. Note: In order to add these symbols to your design, select the symbol of AND gate on the tool bar (from where you get the ICs usually) then expand the project menu. If you cannot find any of the two symbols under the project menu, you can add them by typing the symbol name in the text box below. ## Clock input of the counter: Note that the block 'clock.bsf' has one input 'os\_clock' and one output 'out\_clock'. This module implements a frequency division circuit which will be used to divide the high frequency clock of the FPGA oscillator (28 MHz) to obtain a slower clock (10 Hz) so that changes in the counter value can be detected on the 7-segment display and provide sufficient time for register setup. Hence, in your schematic diagram you are required to connect the "os\_clock" to an input pin called "clk" (which will be assigned to the oscillator clock when you do pins assignment) and connect "out\_clock" to the counter clock input.