05.07.2013 Views

Xilinx Synthesis Technology User Guide

Xilinx Synthesis Technology User Guide

Xilinx Synthesis Technology User Guide

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

XST <strong>User</strong> <strong>Guide</strong><br />

Example 6-23 Function Declaration and Function Call<br />

package PKG is<br />

function ADD (A,B, CIN : BIT )<br />

return BIT_VECTOR;<br />

end PKG;<br />

package body PKG is<br />

function ADD (A,B, CIN : BIT )<br />

return BIT_VECTOR is<br />

variable S, COUT : BIT;<br />

variable RESULT : BIT_VECTOR (1 downto 0);<br />

begin<br />

S := A xor B xor CIN;<br />

COUT := (A and B) or (A and CIN) or (B and CIN);<br />

RESULT := COUT & S;<br />

return RESULT;<br />

end ADD;<br />

end PKG;<br />

use work.PKG.all;<br />

entity EXAMPLE is<br />

port (A,B : in BIT_VECTOR (3 downto 0);<br />

CIN : in BIT;<br />

S : out BIT_VECTOR (3 downto 0);<br />

COUT: out BIT );<br />

end EXAMPLE;<br />

architecture ARCHI of EXAMPLE is<br />

signal S0, S1, S2, S3 : BIT_VECTOR (1 downto 0);<br />

begin<br />

S0

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!