FPGA Verilog Design Experiments
FPGA Verilog Design Experiments
S.No.
1
2
3
4
5
6
7
8
9
10
11
12
Name of Experiment
Design and simulation of two input LOGIC GATES using
VERILOG, and synthesis on FPGA.
Design and simulation of D Flip Flop, and synthesis on FPGA.
Design and simulation of FULL ADDER using VERILOG, and
synthesis on FPGA.
Design and simulation of 4 bit Adder Using VERILOG, and
synthesis on FPGA.
Design and simulation of [8:1] MUX using VERILOG, and
synthesis on FPGA.
Design and simulation of [1:8] DEMUX using VERILOG, and
synthesis on FPGA.
Design and simulation of CLOCK DIVIDER of 1 Hz using
VERILOG, and synthesis on FPGA.
Design and simulation of 4 bit UP COUNTER & DOWN
COUNTER using VERILOG, and synthesis on FPGA.
Design and simulation of 8-bit SERIAL IN PARALLEL OUT type
register using VERILOG, and synthesis on FPGA.
Design and simulation of 8-bit PARALLEL IN SERIAL OUT type
register using VERILOG, and synthesis on FPGA.
Design and simulation of SEVEN SEGMENT DISPLAY DECODER
using VERILOG, and synthesis on FPGA.
Design and simulation of 4 bit Multiplier using VERILOG, and
synthesis on FPGA.
Date of
Experiment
Sign. /
Remarks
EXPERIMENT-1
Objective:
Design and simulation of two input LOGIC GATES using VERILOG, and synthesis on
FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design AND, OR, NAND, NOR, XOR, XNOR GATE using
Verilog HDL. The Diagram for which is given below:
Diagram for AND GATE :
IN 2
low
low
high
high
Out AND
low
low
low
high
IN 2
low
low
OUT OR
low
high
low
high
high
high
high
high
IN 1
low
high
low
high
IN 2
low
low
high
high
OUT NAND
high
high
high
low
IN 2
low
low
high
high
OUT NOR
high
low
low
low
IN 2
low
low
high
high
OUT XOR
low
high
high
IN 1
low
high
low
high
Diagram for NXOR GATE :
low
IN 2
low
low
high
high
OUT XNOR
high
low
low
high
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in this figure. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in this figure. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used two slide switches & six LEDs. The Inputs of LOGIC GATES IN1, IN2 are
assigned to Slide Switches SW0, SW1 respectively. The output of LOGIC GATES are
assigned to LEDs:
OUTPUTS
and
or
nand
nor
xor
xnor
LED
LED7
LED6
LED5
LED4
LED3
LED2
Result:
We have successfully demonstrate AND GATE using Verilog HDL on Spartan-3E FPGA
Starter Kit Board.
Date of Experiment:
Signature of Student
EXPERIMENT- 2
Objective:
Design and simulation of D Flip Flop, and synthesis on FPGA Hardware and Software
Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a D Flip Flop using Verilog HDL. The Diagram for which
is given below:
D
0
1
x
Q
0
1
Q
input d,
output reg q,
output reg qn,
input clk,
input rst
);
always @(posedge clk or negedge rst)
begin
if(rst==1'b0)
begin
q <=0;
qn <=1;
end
else
begin
q <= d;
qn <= ~d;
end
end
endmodule
(SW) ====
IOSTANDARD = LVTTL | PULLUP ;
| IOSTANDARD = LVTTL | PULLUP ;
| IOSTANDARD = LVTTL | PULLUP ;
Figure : D FlipFlop
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch
connects the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used three slide switches & two LEDs. The Input of D Flip Flop D, RST, & CLK
are assigned to Slide Switches SW0, SW1 & SW2 respectively. The outputs of D Flip Flop Q
& Qn are assigned to LED0 & LED1 respectively.
Signature of Student
EXPERIMENT- 3
Objective:
Design and simulation of FULL ADDER using VERILOG, and synthesis on FPGA.
(by using HALF ADDER)
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a simple Full Adder using Verilog HDL. The Diagram for
which is given below:
Truth Table:
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
Cin
0
1
0
1
0
1
0
1
Sum
0
0
0
1
0
1
1
1
Cout
0
1
1
0
1
0
0
1
Half Adder
module hadd(a,b,sum,cout);
input a;
input b;
output out;
output cout;
assign sum=a^b;
assign cout=a&b;
endmodule
Test Bench:
module fadder;
// Inputs
reg a;
reg b;
reg cin;
// Outputs
wire sum;
wire cout;
// Instantiate the Unit Under Test (UUT)
fadd uut (
.a(a),
.b(b),
.cin(cin),
.sum(sum),
.cout(cout)
);
initial begin
// Initialize Inputs
a = 0;b = 0;cin = 0;#100;
a = 0;b = 0;cin = 1;#100;
a = 0;b = 1;cin = 0;#100;
a = 0;b = 1;cin = 1;#100;
a = 1;b = 0;cin = 0;#100;
a = 1;b = 0;cin = 1;#100;
a = 1;b = 1;cin = 0;#100;
a = 1;b = 1;cin = 1;#100;
// Wait 100 ns for global reset to finis
endmodule
(SW) ====
IOSTANDARD = LVTTL | PULLUP ;
IOSTANDARD = LVTTL | PULLUP ;
| IOSTANDARD = LVTTL | PULLUP ;
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used three slide switches & two LEDs. The Input of Full Adder A, B, & Cin are
assigned to Slide Switches SW0, SW1 & SW2 respectively. The outputs of Full adder Sum &
Carry are assigned to LED0 & LED1 respectively.
Signature of Student
EXPERIMENT 4
Objective:
Design and simulation of 4 bit Adder Using VERILOG, and synthesis on FPGA.
(By using FULL ADDER)
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a 4-bit Adder using Verilog HDL. The Diagram for which
is given below:
Design Specifications:
Full Adder has three inputs, A, B, and Cin. It has two outputs, Sum and Cout. The inputs A
and B are two, 1-bit numbers that the addition will be performed on. The output is located at
the output labeled Sum. There are also two other I/O pins, Cin and Cout. These are called
Carry In and Carry Out, respectively.
Truth Table:
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
SUM
0
1
1
0
1
0
0
1
COUT
0
0
0
1
0
1
1
1
fadd fadd1(a[1],b[1],cy[0],s[1],cy[1]);
fadd fadd2(a[2],b[2],cy[1],s[2],cy[2]);
fadd fadd3(a[3],b[3],cy[2],s[3],cout);
endmodule
module fadd(a,b,cin,sum,cout);
input a;
input b;
input cin;
output sum;
output cout;
wire wa,wb,wc;
hadd hadd1(a,b,wa,wb);
hadd hadd2(wa,cin,sum,wc);
assign cout=wb|wc;
endmodule
module hadd(a,b,sum,cout);
input a;
input b;
output out;
output cout;
assign sum=a^b;
assign cout=a&b;
endmodule
(SW) ====
IOSTANDARD = LVTTL | PULLUP ;
IOSTANDARD = LVTTL | PULLUP ;
| IOSTANDARD = LVTTL | PULLUP ;
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used three slide switches & two LEDs. The Input of Full Adder A, B, & Cin are
assigned to Slide Switches SW0, SW1 & SW2 respectively. The outputs of Full adder Sum
& Carry are assigned to LED0 & LED1 respectively.
Result:
All the outputs of the 4-bit Full Adder are verified with the help of truth table on Xilinx
Spartan-3E FPGA Starter Kit.
Date of Experiment:
Signature of Student
EXPERIMENT 5
Objective:
Design and simulation of [8:1] MUX using VERILOG, and synthesis on FPGA.
(By using [4:1] & [2:1] MUX)
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a [1:8] MUX by using Verilog HDL. The Diagram for which
is given
below
Design Specifications:
In electronics, a multiplexer (or mux) is a device that selects one of
several analog or digital input signals and forwards the selected input into a single line. A
multiplexer of 2n inputs has n select lines, which are used to select which input line to send to
the output.
Truth Table:
S2
0
0
0
0
1
1
1
1
S1
0
0
1
1
0
0
1
1
S0
0
1
0
1
0
1
0
1
Output
D0
D1
D2
D3
D4
D5
D6
D7
module mux2x1(a,b,s0,out);
input a;
input b;
input s0;
output out;
assign out=s0?b:a;
endmodule
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used three slide switches & two LEDs. The Input of MUX is
A[1],A[2],A[3],A[4],A[5],A[6],A[7] are assigned to Slide Switches respectively. The outputs
of Full of MUX OUT is assigned to LED0 respectively.
Result:
We have successfully demonstrate [8:1] MUX using Verilog HDL on Spartan-3E FPGA
Starter Kit Board.
Date of Experiment:
Signature of Student
EXPERIMENT- 6
Objective:
Design and simulation of 1x8DEMUX using VERILOG, and synthesis on FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a 1x8DEMUXusing Verilog HDL.The data distributor,
known more commonly as a Demultiplexer or Demux for short, is the exact opposite of
the Multiplexer we saw in the previous tutorial. The demultiplexer takes one single input data
line and then switches it to any one of a number of individual output lines one at a time.
The demultiplexer converts a serial data signal at the input to a parallel data at its output lines
as shown below.
1-to-4 Channel De-multiplexer
Output Select
b
a
0
0
1
1
0
1
0
1
Data Output
Selected
A
B
C
D
The Boolean expression for this 1-to-4 Demultiplexer above with outputs A to D and data
select lines a, b is given as:
F = abA + abB + abC + abD
The function of the Demultiplexer is to switch one common data input line to any one of the
4 output data lines A to D in our example above. As with the multiplexer the individual solid
state switches are selected by the binary input address code on the output select pins a and
b as shown.
Demultiplexer Output Line Selection
As with the previous multiplexer circuit, adding more address line inputs it is possible to
switch more outputs giving a 1-to-2n data line outputs.
Truth Table:
Clock Input Control Signal
Output
Cycle
I
S2 S1
S0 Out0 Out1 Out2 Out3 Out4 Out5 Out6 Out7
0
1
0
0
0
1
1
1
1
1
1
1
1
1
1
0
0
1
0
1
1
1
1
1
1
1
2
1
0
1
0
0
0
1
1
1
1
1
1
3
1
0
1
1
0
0
0
1
1
1
1
1
4
1
1
0
0
0
0
0
0
1
1
1
1
5
1
1
0
1
0
0
0
0
0
1
1
1
6
1
1
1
0
0
0
0
0
0
0
1
1
7
1
1
1
1
0
0
0
0
0
0
0
1
Table 1: Truth Table of [1:8] DEMUX
demux1x2 d1(I,s2,w1,w2);
demux1x4 d2(w1,s0,s1,out[0],out[1],out[2],out[3]);
demux1x4 d3(w2,s0,s1,out[4],out[5],out[6],out[7]);
endmodule
module demux1x2( input I,s, output o1,o2 );
assign o1=I&~s;
assign o2=I&s;
endmodule
module demux1x4( input I,s0,s1, output out0,out1,out2,out3 );
assign out0=I&~s1&~s0;
assign out1=I&~s1&s0;
assign out2=I&s1&~s0;
assign out3=I&s1&s0;
endmodule
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used four slide switches & eight LEDs. The Input of I s0,s1& s2 are assigned
to Slide Switches L13, L14, H18, & N17 respectively. The SEVEN outputs of
1x8DEMUXout[7:0] aer assigned to LED7 to LED0 respectively.
Signature of Student
EXPERIMENT-7
Objective:
Design and simulation of CLOCK DIVIDER of 1 Hz using VERILOG, and synthesis on
FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design CLOCK DIVIDER of 1 Hz using Verilog HDL. The
Diagram for which is given below:
);
reg [0:25]count;
initial count=0;
always@(negedge clk)
begin
count= count+1;
if(count==25000000)
begin
clk1hz=~clk1hz;
count=0;
end
else
clk1hz=clk1hz;
end
endmodule
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in this figure. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in this figure. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used one clock signal & one LED. The Inputs of CLOCK DIVIDER of 1hz is OnBoard 50 MHz Oscillator CLK_50MHz: (The clock is assign by FPGA PIN C9). The output
of CLOCK DIVIDER is assigned to LED0 (F12) .
Result:
We have successfully demonstrate CLOCK DIVIDER of 1 Hz using Verilog HDL on
Spartan-3E FPGA Starter Kit Board.
Date of Experiment:
Signature of Student
EXPERIMENT- 8
Objective:
Design and simulation of 4 bit UP COUNTER & DOWN COUNTER using VERILOG, and
synthesis on FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design an Up down counter using Verilog HDL. The Diagram for
which is given below.
Design Specifications:
);
endmodule
(LED) ====Outputs
= "F11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE
= "E11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE
= "E12" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE
= "F12" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in Figure 4. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in Figure 4. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used four slide switches ,four push buttons & seven LEDs. The inputs of 4-bit
up/down counter ld,mode,clr ,clk are assigned to Slide Switches SW0,SW, SW2, SW3,SW4
and d_in[0:3] assigned to push buttons respectively. The outputs of Seven segment display
decoder are assigned to Count[3], Count[2], Count[1], Count[0] are assigned to LED3, LED2,
LED1, LED0.
Date of Experiment:
Signature of Student
EXPERIMENT-9
Objective:
Design and simulation of 8 bit Serial In Parallel Out circuit using VERILOG, and synthesis on
FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
The Shift Register is another type of sequential logic circuit that can be used for the storage or
the transfer of data in the form of binary numbers. This sequential device loads the data present
on its inputs and then moves or shifts it to its output once every clock cycle, hence the name
shift register
In this lab, we are going to design Serial In Parallel Out using Verilog HDL. The Diagram
for which is given below:
#####################################################
# ==== Slide Switches (SW) ====Inputs
NET "sin LOC = "L13" | IOSTANDARD = LVTTL | PULLUP ;
NET "clk LOC = "L14" | IOSTANDARD = LVTTL | PULLUP ;
NET "ctrlin LOC = "L17" | IOSTANDARD = LVTTL | PULLUP ;
NET "rst LOC = "H18" | IOSTANDARD = LVTTL | PULLUP ;
# ==== Discrete LEDs
NET outb[7]" LOC =
;
NET outb[6]" LOC =
;
NET outb[5]" LOC =
8 ;
NET outb[4]" LOC =
8 ;
NET outb[3]" LOC =
8 ;
NET outb[2]" LOC =
8 ;
NET outb[1]" LOC =
8 ;
NET outb[0]" LOC =
;
(LED) ====Outputs
"F9" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE = 8
"E9" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE = 8
"D11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
"C11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
"F11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
"E11" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
"E12" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE =
"F12" | IOSTANDARD = LVTTL | SLEW = SLOW | DRIVE = 8
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in this figure. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in this figure. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used four slide switches & seven LEDs. The inputs of Seven segment display decoder
clkin, rst, sin, ctrlin are assigned to Slide Switches SW0,SW1,SW2 & SW3 respectively. The
outputs of Seven segment display decoder are assigned to outb[7], out [6], outb[5], out [4],
out [3], out [2], outb [1], outb[0] are assigned to LED7, LED6, LED5, LED4, LED3, LED2,
LED1, LED0.
Result:
We have successfully demonstrate 8 bit SIPO using Verilog HDL on Spartan-3E FPGA
Starter Kit Board.
Date of Experiment:
Signature of Student
EXPERIMENT-10
Objective:
Design and simulation of 8 bit Parallel In Serial Out circuit using VERILOG, and synthesis on
FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
The Shift Register is another type of sequential logic circuit that can be used for the storage or
the transfer of data in the form of binary numbers. This sequential device loads the data present
on its inputs and then moves or shifts it to its output once every clock cycle, hence the name
shift register
In this lab, we are going to design Parallel In Serial Out using Verilog HDL. The Diagram
for which is given below:
Figure 2
The above figure shows the working of the 8 bit PISO.
Simulation Waveforms:
Demonstration of Experiment:
We have used Xilinx Spartan-3E FPGA Starter Kit developed by Digilent to demonstrate our
experiment. The Spartan-3E FPGA Starter Kit board has four slide switches. The slide
switches are labeled SW3 through SW0 as shown in this figure. Switch SW3 is the left-most
switch, and SW0 is the right-most switch. When in the UP or ON position, a switch connects
the FPGA pin to 3.3V, a logic High. When DOWN or in the OFF position, the switch connects
the FPGA pin to ground, a logic Low.
The board also has eight individual surface-mount LEDs located above the slide switches as
shown in this figure. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED,
LED0 the right-most LED.
We have used four slide switches & seven LEDs. The inputs of Seven segment display decoder
din, clk,load, rst are assigned to Slide Switches SW0,SW1,SW2 & SW3 respectively. The
outputs of Seven segment display decoder are assigned to dout is assigned to LED0.
Result:
We have successfully demonstrate 8 bit PISO using Verilog HDL on Spartan-3E FPGA
Starter Kit Board.
Date of Experiment:
Signature of Student
EXPERIMENT-11
Objective:
Design and simulation of SEVEN SEGMENT DISPLAY DECODER using VERILOG and
synthesis on FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a Seven segment display using Verilog HDL. The Diagram
for which is given below.
Design Specifications:
=
=
=
=
=
=
=
=
=
=
=
7'b1111110;
7'b0110000;
7'b1101101;
7'b1111001;
7'b0110011;
7'b1011011;
7'b1011111;
7'b1110000;
7'b1111111;
7'b1111011;
7'b0000000;
#####################################################
# ==== Slide Switches (SW) ====Inputs
NET "in[3]" LOC = "L13" | IOSTANDARD = LVTTL | PULLUP
NET "in[2]" LOC = "L14" | IOSTANDARD = LVTTL | PULLUP
NET "in[1]" LOC = "L17" | IOSTANDARD = LVTTL | PULLUP
NET "in[0]" LOC = "H18" | IOSTANDARD = LVTTL | PULLUP
;
;
;
;
Simulation Waveforms:
Date of Experiment:
Signature of Student
EXPERIMENT-12
Objective:
Design and simulation of 4 bit Multiplier using VERILOG, and synthesis on FPGA.
Hardware and Software Requirements:
Xilinx ISE Design Suite 14.7 (Software Tool).
Xilinx Spartan-3E FPGA Starter Kit Digilent Inc.
USB Cable & Power Adapter/Cord.
Overview:
In this lab, we are going to design a 4 bit multiplier using Verilog HDL. The Diagram for
which is given below.
A binary computer does exactly the same, but with binary numbers. In binary encoding each
long number is multiplied by one digit (either 0 or 1), and that is much easier than in decimal,
as the product by 0 or 1 is just 0 or the same number. Therefore, the multiplication of two
binary numbers comes down to calculating partial products (which are 0 or the first number),
shifting them left, and then adding them together
1011 (this is 11 in decimal)
x 1110 (this is 14 in decimal)
======
0000 (this is 1011 x 0)
1011 (this is 1011 x 1, shifted one position to the left)
1011 (this is 1011 x 1, shifted two positions to the left)
+ 1011 (this is 1011 x 1, shifted three positions to the left)
=========
10011010 (this is 154 in decimal)
Simulation Waveforms:
Signature of Student