1. Create new project in DK suite
File -> new -> project
Give the project name as xor_gate
data:image/s3,"s3://crabby-images/746fc/746fcc41cec978d3f567818932ce711f7072b174" alt=""
2. add handelc source file to adder
File -. New -> file -> handelc source file
Give name as xor_gate
data:image/s3,"s3://crabby-images/f17fb/f17fbb83ae8b63c8b7fb9367ab87c1c6d7cea5b3" alt=""
3. Add the following code
set clock = external "p77";
set reset = external with {active_low=0};
void main()
{
unsigned 1 in1,in2;
unsigned 1 result;
while(1)
{
interface port_in(unsigned 1 IN1) InBus();
interface port_in(unsigned 1 IN2) InBus1();
interface port_out() OutBus(unsigned 1 OutPort = result);
in1=InBus.IN1;
in2=InBus1.IN2;
result=in1 ^ in2;
}
}
4. set active configuration to vhdl
data:image/s3,"s3://crabby-images/ce206/ce20673fb9cb8c4ccbcb34a91516473c4052a0b6" alt=""
5. Build the project. To build press f7
data:image/s3,"s3://crabby-images/b73cc/b73cc89b801dca9c35619f95ccb7032ce638422a" alt=""
6. Create an ISE project having name adder
Fine -> new project -> give name as adder
Press next
data:image/s3,"s3://crabby-images/afac9/afac9c28644d02e246d10caf3155498bce69d275" alt=""
Select the device and language as VHDL
data:image/s3,"s3://crabby-images/0d7e1/0d7e1fde82761f9fbcab33e0921ed7fa9039c5a9" alt=""
Press next and finidh
7. Add new source to project
Right click to project and select new source
data:image/s3,"s3://crabby-images/4c850/4c85038caaafcc003f59070450e81688243fd09e" alt=""
Select VHDL package and give name as agility
data:image/s3,"s3://crabby-images/01bfa/01bfab86f5aa196eac94fb163aeae0d702fb02a7" alt=""
Click next finish
8. open the installed folder for DK design suity (C:\Program Files\Agility\DK\vhdl) open agility file copy the content of file and replace the conteng of new created agility package with this content.
.
data:image/s3,"s3://crabby-images/28cd5/28cd5420eb6652aed9d2bc14aa2997a94bf5da40" alt=""
9. Again select new source and select VHDL library and give name to librarty as agility
data:image/s3,"s3://crabby-images/1b50f/1b50ffdc82dd53b2ca435f25fdbf68aa7ba4783c" alt=""
Click next anf finish
Goto library tab select the agility package available in work library. Right click to package and select move to library data:image/s3,"s3://crabby-images/3cbb0/3cbb0920eeb3517fb7d1a6426896d42ffdc223d4" alt=""
data:image/s3,"s3://crabby-images/3cbb0/3cbb0920eeb3517fb7d1a6426896d42ffdc223d4" alt=""
Then select agility as library
data:image/s3,"s3://crabby-images/dbb93/dbb93fc7d8ae080e348ccbd4d4753316d5dadd16" alt=""
10. Add new source as a vhdl module having name as adder to design
data:image/s3,"s3://crabby-images/2ce2b/2ce2b550312b9f432ecc79f9168b84b5dcd5c397" alt=""
Click next-> next -> finish
Replace the code of adder with following code
----------------------------------------------------------------------------------
-- Design Name: Half Adder Using HandelC Cores
-- Company: Shivaji University
-- Engineer: Dr S A Shinde
-- Module Name: top_module - Behavioral
----------------------------------------------------------------------------------
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
---- Uncomment the following library declaration if instantiating
---- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;
entity top_module is
Port ( a : in STD_LOGIC;
b : in STD_LOGIC;
sum : out STD_LOGIC;
carry : out STD_LOGIC;
reset : in STD_LOGIC;
clk: in STD_LOGIC);
end top_module;
architecture Behavioral of top_module is
component xor_gate PORT (
IN1 : IN std_logic;
IN2 : IN std_logic;
OutPort : OUT std_logic;
PADIN_xor_gate_hcc_ResetInPin : IN std_logic;
PIN_p77 : IN std_logic);
END COMPONENT;
component and_gate PORT (
IN1 : IN std_logic;
IN2 : IN std_logic;
OutPort : OUT std_logic;
PADIN_and_gate_hcc_ResetInPin : IN std_logic;
PIN_p77 : IN std_logic);
END COMPONENT;
begin
U1 : xor_gate port map(a,b,sum,reset,clk);
U2 : and_gate port map(a,b,carry,reset,clk);
end Behavioral;
data:image/s3,"s3://crabby-images/70777/70777f6e04db4cc716fb6c7c6466e8bedb666dad" alt=""
Then add the xor_gate component from handelc to vhdl code
11. similary creat a project of name and_gate having handelc source fime as and_gate.hcc
and_gate hcc
set clock = external "p77";
set reset = external with {active_low=0};
void main()
{
unsigned 1 in1,in2;
unsigned 1 result;
while(1)
{
interface port_in(unsigned 1 IN1) InBus();
interface port_in(unsigned 1 IN2) InBus1();
interface port_out() OutBus(unsigned 1 OutPort = result);
in1=InBus.IN1;
in2=InBus1.IN2;
result=in1 & in2;
}
}
12. build for VHDL and add the generated vhdl file to xilinx ISE project
data:image/s3,"s3://crabby-images/092fd/092fd8cf5177013af7db0c08029223cbcc354183" alt=""
Then synthesis the design
data:image/s3,"s3://crabby-images/127db/127db16171f88f2a056e8b01f353b71a54aab2d7" alt=""
Then the two components are xor_gate and and_gate are connected to form adder. The two components are generated using handelc and incorporated as a component in VHDL as top level design.
data:image/s3,"s3://crabby-images/5a196/5a196e4de04bcb66ea51152b1a82cde1368396ae" alt=""