De volgende stap is de beschrijving van een logisch NAND poort. Hiervoor maak je een nieuwe component aan in het Vivado project. Het grootste deel van de code van de invertor kunnen we overnemen als startpunt voor deze beschrijving.
We passen de entity aan zodat we 2 inputs hebben in plaats van 1. De behuizing van de nieuwe component zegt nu dat er 3 pinnen zijn: 2 input pinnen en 1 output pin.
Uiteraard moet het gedrag van deze component ook aangepast worden. In de architecture schrijven we dat we een NAND operatie willen doen. De basis poort NAND is ook beschikbaar als keyword in VHDL.
--------------------------------
-- Revision Date Author Comments
-- v0.2 20240118 VlJo Initial version
--------------------------------
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity nand_gate is
Port (
A : in std_logic;
B : in std_logic;
Z : out std_logic
);
end nand_gate;
architecture Behavioral of nand_gate is
-- (DE-)LOCALISING IN/OUTPUTS
signal A_i : STD_LOGIC;
signal B_i : STD_LOGIC;
signal Z_o : STD_LOGIC;
begin
--------------------------------
-- (DE-)LOCALISING IN/OUTPUTS
--------------------------------
A_i <= A;
B_i <= B;
Z <= Z_o;
--------------------------------
-- COMBINATORIAL
--------------------------------
Z_o <= A_i nand B_i;
end Behavioral;
--
Voor deze simpele voorbeelden lijkt het banaal om de link met de discrete component (en de bijhorende schematic) te leggen. Een goede designer verliest echter het volledige schema NOOIT uit het oog.