# ECE 501 Digital Systems Laboratory Experiment 13 – FPGA Circuit Realization Seth So Lab Partner: Martin Klena Station 2 Date Performed: 4-12-18 to 4-18-18 Date Written: 4-20-18 . . . . . . ### **Introduction:** The Field Programmable Gate Array (FPGA), is an integrated circuit chip that can be programmed to implement entire circuits by itself. The FPGA board is an Altera peripheral that compiled schematics can be downloaded to for implementation after pin assignments. In addition to Quartus schematics, the FPGA can also read VHDL (VHSIC [Very High Speed Integrated Circuit] Hardware Description Language) code. Figure 1: Altera DE2 FPGA Board Figure 1 above shows the board that will be used. It features many different I/O ports for high general compatibility, peripheral compatibility for other circuit boards (e.g. Arduino), an onboard LCD display, eight 7-segment LED displays, 19 red/green LEDs, 17 switches, and four push buttons. In Laboratory 13, the 4-bit ALU made in the previous lab was implemented on the FPGA, rather than the protoboard, using the schematic made before. Various schematic components were sequentially replaced with self-written VHDL-coded components to demonstrate the boards VHDL compatibility. # Part I: Quartus II Circuit Design ### Purpose: The purpose of part 1 was to repurpose the ALU schematic designed in the previous lab for programming onto the FPGA. #### Procedure: 1. The first step to repurpose the schematic was altering the components. The 4-bit latch made from D flip-flops was replaced with a new design, which utilized four individual "latch" components in one symbol file. *Figure 2* below in the results section shows this - schematic. Afterwards, the old 7-segment decoders were removed from the schematic. The file DispBin.vhd was also added for the VHDL coding later. - 2. The setting and parameters of the circuit were altered so that the schematic could be downloaded successfully to the FPGA board. Specifically, the device family was set to Cyclone II, the specific device was set to EP2C35F672C6, the optimization technique was set to AREA, and the global clock was deselected. The schematic was compiled with these new settings. Figure 2: New Latch Design Figure 2 above shows the new 4-bit latch design. Similar to the D flip-flops, the design uses four individual latches in tandem with one another, one for each bit, sending a bus of data and enable input to the latch system. Just as easily, a bus of outputs can be read as a 4-bit output from the design. ### Conclusion: The settings for schematic from lab 12 were prepared for use on the FPGA board. Next, pin assignments would be made to replace the deleted 7-segment displays. # Part II: Pin Assignments for 7 Segment LEDs ### Purpose: The purpose of part 2 was to replace the schematic 7-segment LED displays with the FPGA onboard 7-segment displays via pin assignment. Doing this introduced the idea of pin assignment for input/output-pin assignments later in part III. #### Procedure: 1. Using the Assignment Editor, the outputs of the decoders were assigned to the 7-segment displays Hex0 and Hex1 on the FPGA board. *Figure 3* below in the results section shows the table used for assignment and the corresponding assignment in Quartus II. #### Results: Figure 3: Decoder Pin Inputs | Display Segment | Pin for Hex1 | Pin for Hex0 | |-----------------|--------------|--------------| | A | V20 | AF10 | | В | V21 | AB12 | | С | W21 | AC12 | | D | Y22 | AD11 | | E | AA24 | AE11 | | F | AA23 | V14 | | G | AB24 | V13 | | 8 | DataInA | PIN_V20 | |----|-----------|----------| | 9 | DataInB | PIN_V21 | | 10 | ■ DataInC | PIN_W21 | | 11 | ■ DataInD | PIN_Y22 | | 12 | ■ DataInE | PIN_AA24 | | 13 | DataInF | PIN_AA23 | | 14 | ■ DataInG | PIN_AB24 | | 15 | | PIN_AF10 | | 16 | | PIN_AB12 | | 17 | | PIN_AC12 | | 18 | | PIN_AD11 | | 19 | | PIN_AE11 | | 20 | | PIN_V14 | | 21 | DataOutG | PIN_V13 | Figure 3 above shows the decoder pin assignments. On the left is a list of connections from the Altera DE-2 board manual (provided in the lab instruction) for Hex0 and Hex1. On the right is the assignment of the decoder outputs, DataOut (ALU output) and DataIn (Register Read output). ### Conclusion: The basic procedure and references for pin assignments were taught. All pin locations and corresponding parts on the FPGA board were found in the Altera DE-2 manual. Importantly, no pins were double-assigned, and no reserved pins were used. # Part III: Pin Assignments for Inputs and Outputs ### Purpose: The purpose of part 3 was to decide and assign pin assignments for the rest of the circuit, using the same process as part 2. ### Procedure: - 1. Using the Altera DE-2 manual for a full list of pin locations, all the inputs were assigned to switches on the FPGA board. No push buttons were used, as the button seemed more prone to input error (i.e. sticky presses and jamming). - 2. In addition to the inputs, extra outputs were added to make the circuit more user-friendly. This included an extra display for the latch output, since it was one of the operands, and the read and write addresses as red LEDs. *Figure 4* below shows the all pin assignments, and Figure 5 shows the location of all pin assignments on the actual FPGA board: Figure 4: All FPG Board Pin Assignments | | To A | Location | Enabled | |----|----------------|----------|---------| | 1 | <b>I</b> CN | PIN_V2 | Yes | | 2 | Counter 1Clear | PIN_C13 | Yes | | 3 | Counter2Clear | PIN_N1 | Yes | | 4 | DataIn[0] | PIN_N25 | Yes | | 5 | DataIn[1] | PIN_N26 | Yes | | 6 | DataIn[2] | PIN_P25 | Yes | | 7 | DataIn[3] | PIN_AE14 | Yes | | 8 | | PIN_V20 | Yes | | 9 | | PIN_V21 | Yes | | 10 | | PIN_W21 | Yes | | 11 | | PIN_Y22 | Yes | | 12 | | PIN_AA24 | Yes | | 13 | | PIN_AA23 | Yes | | 14 | | PIN_AB24 | Yes | | 15 | | PIN_AF10 | Yes | | 16 | | PIN_AB12 | Yes | | 17 | | PIN_AC12 | Yes | | 18 | | PIN_AD11 | Yes | | 19 | | PIN_AE11 | Yes | | 20 | | PIN_V14 | Yes | | 21 | | PIN_V13 | Yes | | 22 | ■ Latchclock | PIN_AF14 | Yes | | 23 | ■ LatchOutA | PIN_AB23 | Yes | | 24 | ■ LatchOutB | PIN_V22 | Yes | | 25 | | PIN_AC25 | Yes | | 26 | ■ LatchOutD | PIN_AC26 | Yes | | 27 | ■ LatchOutE | PIN_AB26 | Yes | | 28 | | PIN_AB25 | Yes | | 29 | | PIN_Y24 | Yes | | 30 | ■M | PIN_U4 | Yes | | 31 | ■MuxSel | PIN_V1 | Yes | | 32 | ReadClock | PIN_AD13 | Yes | | 33 | ReadCount[0] | PIN_AD23 | Yes | | 34 | ReadCount[1] | PIN_AD21 | Yes | | 35 | ReadEnable | PIN_AC13 | Yes | | 36 | ■ Sel[0] | PIN_P1 | Yes | | 37 | ■ Sel[1] | PIN_P2 | Yes | | 38 | ■ Sel[2] | PIN_T7 | Yes | | 39 | ■ Sel[3] | PIN_U3 | Yes | | 40 | ■WriteClock | PIN_B13 | Yes | | 41 | | PIN_AA14 | Yes | | 42 | | PIN_Y13 | Yes | | 43 | ■ WriteEnable | PIN_A13 | Yes | Figure 4 above: All the pin assignments above are shown on the board on the next page in Figure 5 (see corresponding row number in chart above for labelling key): Figure 5: FPG Board Pin Locations Figure 5 above shows the inputs (green) and outputs (orange) of the pins on the actual FPGA board. The organization of the inputs is also displayed underneath the inputs bar. Note that all numbers refer to the row in Figure 4 for their pin numbers and uses. #### Conclusion: All pins were successfully assigned and organized in a user-friendly manner. This made operating the FPGA board much easier in the next part, so that functionlity could be tested quickly and accurately. # Part IV: Programming the FPGA ### Purpose: The purpose of part 4 was to download the schematic and pin assignments to the FPGA board and begin testing for functionality. ### Procedure: - 1. After powering the board with a 9-V supply and connecting it to the desktop via a USB-A cable, the schematic was configured for downloading onto the board by adding the schematic (as top level entry) .sof file to the "Programmer" window, setting mode to JTAG, and setting hardware to USB Blaster. - 2. Once the code was downloaded, several operations were tested from the previous lab, now on the board. Slips of paper were added to help demarcate the different switch uses. *Figures 6 and 7* on the following page shows the physical board and outputs. Figure 6: Simple Addition Functionality Test Figure 6 above shows a simple addition operation to test the boards functionality. "8"s are null values, so outputs are only being written to the three right-most 7-segment displays. From left to right, a 5 is latched, a 4 is being read from address 1, and the ALU is adding these two together to output a 9 because of the A plus B settings (switches 11-17). Reference Figure 5 for what each specific switch does. Figure 7: Simple Logic Functionality Test Figure 7 above shows a simple logic operation to test the boards functionality. Again "8"s are null values, so outputs are only being written to the three right-most 7-segment displays. From left to right, a 5 is latched, a 3 is being read from address 0, and the ALU is ANDing these two together to output a 1 because of the A AND B settings (switches 11-17). Reference Figure 5 for what each specific switch does. Both operations were successful, and other multi-step operations were as well. A multi-number addition was also tested utilizing the MUX select function to read in the ALU output and was also successful. #### Conclusion: All results were as expected. Th Quartus II schematic and pin assignments were successfully downloaded to the FPGA board, which was then able operated correctly with all of the operations tested, just as the protoboard circuit. ### Part V: Recoding Components in VHDL ### Purpose: The purpose of part 5 was to learn introductory VHDL coding to implement self-designed VHDL parts to replace the pre-made parts in the lab. Functionality was tested both through waveform simulation and on the FPGA ### Procedure: - 1. The DispBin.vhd file added earlier to the project was then opened to reveal a full VHDL code for the 7-segment LED displays that were removed earlier. A symbol file was created directly from this VHDL code to create a replacement part that was then connected to the segment decoders, keeping in mind to change inputs and outputs to busses. After replacement, the schematic was compiled and simulated using the waveform from the previous lab to test for proper functionality of the VHDL components. *Figure 8* below in the results section shows the output waveform of the schematic using the 4-operations file used in the previous lab. - 2. Once functionality of the single decoder was confirmed, the other two VHDL 7-segment displays were added. Additionally, the VHDL file itself was edited to display A, b, C, d, E, and F in addition to 0-9, for full hexadecimal representation. Below, *Figure 9* shows the waveform simulation with no VHDL for reference, *Figure 10* shows the edited code, and *Figure 11* shows the output waveform with all three VHDL displays implemented in the circuit. - 3. In the same way as the 7-segment displays, the 4x2:1 MUX, 4-bit Latch, and Counters were replaced with self-written VHDL code, checking for functionality on both the FPGA and with the waveform simulator. *Figures 12 and 13* show the 4x2:1 MUX VHDL code and waveform simulation report, *Figures 14 and 15* show the 4-bit latch VHDL code and waveform simulation report, and *Figures 16 and 17* show the Counter VHDL code and waveform simulation report. Finally, *Figure 18* shows the entire circuit with all VHDL components. (Results begin on next page) Figure 8: Waveform Simulation with added Single VHDL LED Display The waveform in *figure 8* above is completely identical to the waveform below in *figure 9*. This is good, because it confirms identical functionality of the VHDL component and old display. Figure 9: Waveform Simulation for No VHDL Components Figure 10: Edited Full Hex Display VHDL Code Figure 10 above shows the edited VHDL code for the 7-segment display. Changes were only made in the "dabcdefg" column of the main, editing the outputted segments for 10-15 to display their respective hex characters A-F rather than non-standard symbols. Figure 11: Waveform Simulation for three VHDL LED Displays Figure 11 above shows the simulation report for all three improved VHDL displays added. All inputs and outputs are identical to those in Figures 8 and 9, except for display values above 9, which now display proper hex values A-F. Functionality was confirmed on the FPGA. Figure 12: VHDL Code for 4x2:1 MUX ``` entity Mux4 is 2 port (A, B: in bit_vector(3 downto 0); 3 S: in bit; 4 F: out bit_vector(3 downto 0)); 5 end Mux4; 6 8 9 architecture Mux4 of Mux4 is 10 component Mux1 port(A,B,S: in bit; F: out bit); 11 12 end component; 13 begin 14 M0: Mux1 port map(A(0), B(0), S, F(0)); M1: Mux1 port map(A(1), B(1), S, F(1)); 15 16 M2: Mux1 port map(A(2), B(2), S, F(2)); 17 M3: Mux1 port map(A(3), B(3), S, F(3)); ``` Figure 12 above shows the VHDL code for the 4x2:1 MUX. It was created by referencing the display VHDL code for structure, and the VHDL code for a single 2:1 MUX, which was imported into the code. The 1x2:1 MUX code was used to extrapolate a 4x2:1 MUX component. Value at 25.7 ns ps 25.7 ns Counter2Clea Α0 A 0 A 0 CN A 1 U 9 A 1 A 1 A 0 <u>⊪</u>10 <u>⊪</u>11 WriteEnable ReadClock MuxSel A 0 A 0 ■ WriteCount ■ ReadCount A [0] A [0] ■ WriteVal A [2] A [0] DataIn ■ DataOut A [0] A 0 X [15] X [6] X [3] XXXXXX A 0 A 1 A 0 DataInB DataInD AO A1 AO AX DataInF DataloG LatchOutA LatchOutB AX \*\*\*\* AX \*\*\*\* LatchOut D AX AX LatchOutE \*\*\*\*\*\*\*\*\*\* 535455 LatchOut F \*\*\*\* LatchOutG DataOutA DataOut B AX \*\*\*\* AX DataOut( DataOut D DataOutE DataOutF \*\*\*\* **Figure 13:** Waveform Simulation with added VHDL 4x2:1 MUX Figure 13 above shows the output waveform with the added VHDL MUX component. Again, the simulation waveform is identical to the waveform before component replacement, indicating that the component is functioning identically to the old one as intended. Functionality was verified on the FPGA. Figure 14: VHDL Code for 4-Bit Latch ``` entity MyLatch IS 1 2 PORT ( LatchIn: IN BIT_VECTOR(3 DOWNTO 0):="0000"; 3 4 LatchEnable: IN BIT:='0'; LatchOut: OUT BIT VECTOR(3 DOWNTO 0) 5 6 7 end MyLatch; 8 9 architecture dataflow OF MyLatch IS signal dig_sig: BIT_VECTOR(3 DOWNTO 0):="0000"; 10 11 ■ begin 12 dig sig <= 13 LatchIn WHEN LatchEnable = '1'; 14 15 LatchOut(3 DOWNTO 0) <= dig sig(3 DOWNTO 0); end dataflow; 16 ``` Figure 14 above shows the VHDL code for the replacement 4-bit latch. It operates by setting a conditional output based on whether LatchEnable is HIGH or LOW, just as the physical component acts. 25.7 n ReadEnable ΑO A 0 A 1 U 9 A 1 A 1 A 0 10 11 12 12 13 14 15 15 18 16 21 16 26 WriteClock ΑO MuxSel A [0] ■ WriteCount A [0] A [2] A [0] U 2 A [0] ■ LatchOut ■ DataIn ■ DataOut 9 41 9 42 9 43 9 44 9 45 9 46 9 47 A 0 A 1 A 0 A 1 A 0 A X A X A X DataInC DataInD DataInE DataInF LatchOutA \*\*\*\* ● 48 ● 49 ● 50 ● 51 ● 52 ● 53 ● 54 ● 55 ● 56 ● 57 ● 58 ● 59 ● 60 LatchOutB \*\*\*\* LatchOut D XXXXXXXXXX LatchOutE LatchOutF AX AX LatchOutG DataOutA AX AX AX DataOut B \*\*\*\* DataOutC DataOutD ш DataOut E AX Figure 15: Waveform Simulation with added Single VHDL 4-Bit Latch Figure 14 above shows the output waveform with the added VHDL Latch component. Again, the simulation waveform is identical to the waveform before component replacement, indicating that the component is functioning as intended. Functionality was verified on the FPGA. Figure 16: VHDL Code for Counter ``` mentity counterVHDL is 1 2 port ( 3 UP: IN bit; 4 QB,QA: OUT bit); end counterVHDL; 5 6 7 architecture behaviour of counterVHDL is 8 ■ begin 9 count up: process (UP) 10 variable count value: natural:=0; 11 begin 12 if (UP='1') then 13 count value := (count value+1) mod 4; 14 QA <= bit'val(count value mod 2); 15 QB <= bit'val(count_value / 2); 16 end if; 17 end process count up; 18 end behaviour; ``` Figure 16 above shows the VHDL code for the replacement Counter. It operates by using modulus 4 to keep the count value from 0-3, and then splits up that modded binary value via a combination of modulus 2 and division by 2, a trick learned in ECE 142 Computer Organization. Doing so allows the count value to be split into two output bits, just as in the schematic. Figure 17: Waveform Simulation with added Single VHDL Counters Figure 13 above shows the output waveform with the added VHDL Counter component. Again, the simulation waveform is identical to the waveform before component replacement, indicating that the component is functioning as intended. Functionality was verified on the FPGA. Figure 18: Final Schematic with VHDL Components. Figure 18 above shows the final schematic, with the different components replaced by VHDL equivalents. A successful demonstration of the board was shown to Vianney Mixtur. ### Conclusion: All results were as expected. The FPGA board was able to perform as it was intended, producing the same outputs as those generated in the Quartus II simulation and on the protoboard ciruit. The major advantage of the FPGA was that nothing had to be built, since everything was on one integrated circuit chip. It was fast, since different versions of the cicuit could rapidly be tested by downloading the code to the board. VHDL coding was also introduced. ### **Summary:** The goal of Laboratory 13 was to adapt the 4-bit ALU circuit from lab 12 to the Altera DE2 FPGA board. After successful upload and testing of the schematic to the FPGA, parts were sequentially replaced with VHDL equivalents to demonstrate the FPGA's ability to read VHDL coding. Rigorous testing was conducted at each stage to prevent build up of error and find problems at their root cause. In the end, the board was able to successfully perform all functions intended. (References on next page) ### **References:** • 74193 datasheet: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464854">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464854</a> 2/courses/2184 UPITT ECE 0501 SEC1010/74193.pdf • 74247 datasheet: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464855">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464855</a> 2/courses/2184 UPITT ECE 0501 SEC1010/74247.pdf 7400 datasheet: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464846">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464846</a> 2/courses/2184 UPITT ECE 0501 SEC1010/7400.pdf 74157 datasheet: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464843">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464843</a> 2/courses/2184 UPITT ECE 0501 SEC1010/74AC157.pdf • <u>7474 datasheet</u>: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464850\_2/courses/2184\_UPITT\_ECE\_0501\_SEC1010/7474.pdf">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464850\_2/courses/2184\_UPITT\_ECE\_0501\_SEC1010/7474.pdf</a> 74181 datasheet: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464853">https://courseweb.pitt.edu/bbcswebdav/pid-24291878-dt-content-rid-23464853</a> 2/courses/2184 UPITT ECE 0501 SEC1010/74181.pdf Altera DE2 Manual: <a href="https://courseweb.pitt.edu/bbcswebdav/pid-24291885-dt-content-rid-23464866\_2/courses/2184\_UPITT\_ECE\_0501\_SEC1010/DE2\_UserManuall.pdf">https://courseweb.pitt.edu/bbcswebdav/pid-24291885-dt-content-rid-23464866\_2/courses/2184\_UPITT\_ECE\_0501\_SEC1010/DE2\_UserManuall.pdf</a> • Intro to VHDL PPT: <a href="https://courseweb.pitt.edu/webapps/blackboard/execute/content/">https://courseweb.pitt.edu/webapps/blackboard/execute/content/</a> file?cmd=view&content\_id=\_24291848\_1&course\_id=\_448088\_1 &framesetWrapped=true • LED outputs to Display Conversion: