Untitled Document
Step-by-Step Instructions for Building a Full Adder in Xilinx
- Open up Xilinx Project Navigator
- Under Windows XP, go to Start->All Programs->Xilinx ISE 6->Project Navigator
- Click on File->New Project
- Type in a Name (ie Full Adder). Click Next
- Enter Spartan2 for Device Family. Click Next through the next menus.
- Add Schematic for Half Adder
- We will be building a Full Adder out of two Half Adders. The logic for a Half Adder is as follows:
Truth Table for Half Adder
A
|
B
|
S
|
Co
|
0
|
0
|
0
|
0
|
0
|
1
|
1
|
0
|
1
|
0
|
1
|
0
|
1
|
1
|
0
|
1
|
The logic turns out to be: S = A xor B; Co = AB
- Create the Schematic for the Half Adder
- Go to Project->New Source
- Select 'Schematic' and give a filename (ie half_adder)
- After clicking OK, the Schematic Editor will start.
- Click on the Add Symbol button (
) and the Symbol Side Bar should appear.
- Select an XOR2 gate by finding it in the side bar and clicking once on it.
- Move your mouse on to the canvas area and see how the item you selected is dragged along with it.
- Click once again to place it on the canvas
- Do the same again for an AND2 gate
- Now select the wiring tool ()
- Draw the appropriate wire connections between the gates and leave excess wire for input and output connections.
- Now select the Add I/O Marker tool ()
- Select the option that says "Input" and then click near the two wires on the left hand side of the drawing.
- Next select the option that says "Output" and click near the two wires on the right hand side of the schematic.
- After you have drawn all the IO Connectors, now double click on each of them and give them appropriate names (ie. A, B, S, Co).
- Now we have to make this a symbol in itself so that we can use it to build the Full Adder.
- Click on Tools->Symbol Wizard
- Select Using Schematic. Make sure that the inputs and outputs are correctly labeled and hit OK
- Create the Full Adder
- Close down the HA schematic
- Create a new schematic by going to Project->New Source and selecting schematic and naming it full_adder.
- When the new schematic editor opens and you click on the Symbol Tool (), you should see your Half_Adder symbol that you just created.
- Click on that and bring two instances of it on to your drawing.
- The truth table for a Full Adder is as follows:
Truth Table for Full Adder
A
|
B
|
Ci
|
S
|
Co
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
1
|
1
|
0
|
0
|
1
|
0
|
1
|
0
|
0
|
1
|
1
|
0
|
1
|
1
|
0
|
0
|
1
|
0
|
1
|
0
|
1
|
0
|
1
|
1
|
1
|
0
|
0
|
1
|
1
|
1
|
1
|
1
|
1
|
- Now to complete the Full Adder, you just have to wire the inputs and outputs correctly, add the appropriate IO Connectors and then simulate to make sure it is right.
- Always save the schematic before you simulate.
- To print out your schematic, go to File->Print Setup and choose the appropriate paper size (8.5x11) and then go to File->Print and it should print out for you.
- Simulation
- The first thing you have to do before you can simulate is to create a Test Bench. Back at the Project Navigator, select Project->New Source and select Test Bench Waveform.
- Give it a name (ie. full_adder_tbw) and hit OK
- Hit OK on the next popup as well... allowing the default values:
- Next, a window will pop up with all of your signals (inputs and outputs).
- By clicking on the lines of your input signals at different times, it will change the value of that particular signal. Making sure that you go through all the possible combinations for inputs, your window should look close to the following:
- Back at the Project Navigator window, make sure you have the Test Bench Waveform file that you just created selected, or click on it to select it.
- In the option pane below that, now select Generate Expected Simulation Results (double click on it)
- This will open another window that looks similar to the previous window you had open, except that the output (hopefully correct) values will be visible.
- Make sure that the values are correct, otherwise go back and make sure your schematics have been properly implemented.
- Close the window after the signals have been verified.
If you have any questions or get stuck in this tutorial, please email Kevin at k2li@cs
No comments:
Post a Comment