diff options
Diffstat (limited to 'doc/examples/quick_start/adder')
| -rw-r--r-- | doc/examples/quick_start/adder/README.rst | 36 | ||||
| -rw-r--r-- | doc/examples/quick_start/adder/adder.vhdl | 14 | ||||
| -rw-r--r-- | doc/examples/quick_start/adder/adder_tb.vhdl | 57 | 
3 files changed, 0 insertions, 107 deletions
| diff --git a/doc/examples/quick_start/adder/README.rst b/doc/examples/quick_start/adder/README.rst deleted file mode 100644 index 5ff607801..000000000 --- a/doc/examples/quick_start/adder/README.rst +++ /dev/null @@ -1,36 +0,0 @@ -.. program:: ghdl -.. _QuickStart:adder: - -`Full adder` module and testbench -================================= - -Unlike :ref:`Heartbeat <QuickStart:heartbeat>`, the target hardware design in this example is written using the -synthesisable subset of `VHDL`. It is a `full adder <https://en.wikipedia.org/wiki/Adder_(electronics)#Full_adder>`_ -described in a file named :file:`adder.vhdl`: - -.. literalinclude:: adder.vhdl -   :language: vhdl - -You can :ref:`analyse <Analysis:command>` this design file, ``ghdl -a adder.vhdl``, and try to execute the `adder` -design. But this is useless, since nothing externally visible will happen. In order to check this full adder, a -:dfn:`testbench` has to be run. The :dfn:`testbench` is a description of how to generate inputs and how to check the -outputs of the Unit Under Test (UUT). This one is very simple, since the adder is also simple: it checks exhaustively -all inputs. Note that only the behaviour is tested, timing constraints are not checked. A file named -:file:`adder_tb.vhdl` contains the testbench for the adder: - -.. literalinclude:: adder_tb.vhdl -   :language: vhdl - -As usual, you should analyze the file, ``ghdl -a adder_tb.vhdl``. - -.. HINT:: -   Then, if required, :ref:`elaborate <Elaboration:command>` the testbench: ``ghdl -e adder_tb``. You do not need to -   specify which object files are required, since `GHDL` knows them and automatically adds them. - -Now, it is time to :ref:`run <Run:command>` the testbench, ``ghdl -r adder_tb``, and check the result on screen:: - -  adder_tb.vhdl:52:7:(assertion note): end of test - -If your design is rather complex, you'd like to inspect signals as explained in :ref:`Heartbeat <QuickStart:heartbeat>`. - -See section :ref:`simulation_options`, for more details on other runtime options. diff --git a/doc/examples/quick_start/adder/adder.vhdl b/doc/examples/quick_start/adder/adder.vhdl deleted file mode 100644 index cf60e8fbe..000000000 --- a/doc/examples/quick_start/adder/adder.vhdl +++ /dev/null @@ -1,14 +0,0 @@ -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; diff --git a/doc/examples/quick_start/adder/adder_tb.vhdl b/doc/examples/quick_start/adder/adder_tb.vhdl deleted file mode 100644 index 4a3fca5e4..000000000 --- a/doc/examples/quick_start/adder/adder_tb.vhdl +++ /dev/null @@ -1,57 +0,0 @@ ---  A testbench has no ports. -entity adder_tb is -end adder_tb; - -architecture behav of adder_tb is -  --  Declaration of the component that will be instantiated. -  component adder -    port (i0, i1 : in bit; ci : in bit; s : out bit; co : out bit); -  end component; - -  --  Specifies which entity is bound with the component. -  for adder_0: adder use entity work.adder; -  signal i0, i1, ci, s, co : bit; -begin -  --  Component instantiation. -  adder_0: adder port map (i0 => i0, i1 => i1, ci => ci, s => s, co => co); - -  --  This process does the real job. -  process -    type pattern_type is record -      --  The inputs of the adder. -      i0, i1, ci : bit; -      --  The expected outputs of the adder. -      s, co : bit; -    end record; -    --  The patterns to apply. -    type pattern_array is array (natural range <>) of pattern_type; -    constant patterns : pattern_array := -      (('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')); -  begin -    --  Check each pattern. -    for i in patterns'range loop -      --  Set the inputs. -      i0 <= patterns(i).i0; -      i1 <= patterns(i).i1; -      ci <= patterns(i).ci; -      --  Wait for the results. -      wait for 1 ns; -      --  Check the outputs. -      assert s = patterns(i).s -        report "bad sum value" severity error; -      assert co = patterns(i).co -        report "bad carry out value" severity error; -    end loop; -    assert false report "end of test" severity note; -    --  Wait forever; this will finish the simulation. -    wait; -  end process; - -end behav; | 
