aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite/pyunit/lsp/files/adder.vhdl
blob: 38ff2a60f93acafc505cb89bec7b7986d9f5a501 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
entity adder is
  -- `i0`, `i1`, and the carry-in `ci` are inputs of the adder.
  -- `s` is the sum output, `co` is the carry-out.
  port (i0, i1 : in bit; ci : in bit; s : out bit; co : out bit);
end adder;

architecture rtl of adder is
begin
  --  This full-adder architecture contains two concurrent assignments.
  --  Compute the sum.
  s <= i0 xor i1 xor ci;
  --  Compute the carry.
  co <= (i0 and i1) or (i0 and ci) or (i1 and ci);
end rtl;