## Sumador completo de un bit - Versión VHDL Sintético

Federico Paredes <sup>1</sup>, Daniel Durán <sup>1</sup>

<sup>1</sup> Becarios de investigación

## **Importante:**

- -Verifique la instalación del **Webpack 7.1** y el **Modelsim XE 7.1 SE**. Ambos programas se pueden bajar desde www.xilinx.com.
- -Verifique también la licencia del **Modelsim** a través del programa **Licensing Wizard** provisto con la instalación.
- -Cuando comience a trabajar en el proyecto recuerde grabar periódicamente.
- 1) Abra el **Proyect Navigator**.
- 2) Sobre el menú File haga clic en New Proyect.
- 3) Complete la primera ventana con la información mostrada y haga clic en Siguiente.



4) Rellene la información de la segunda ventana de acuerdo a lo mostrado debajo y haga clic en Siguiente.



- 5) Pulse sobre **Siguiente** en las dos ventanas posteriores a la de arriba y **Finalizar** en la última.
- 6) Haga clic sobre el menú **Project** y luego en **New Source**.
- 7) En la ventana desplegada complete el nombre del archivo, seleccione **VHDL module** de la lista de la izquierda y haga clic en **Siguiente**.



8) Luego defina las entradas y salidas del sumador de acuerdo a lo mostrado en la ventana de abajo y haga clic en **Siguiente** para después hacer clic en **Finalizar**.



9) Observará a continuación el código generado automáticamente más las líneas agregadas que hacen al sumador. Copie esas dos líneas a su proyecto (delimitadas aquí entre líneas de asteriscos) y guarde el archivo.

## Simulación

Se utilizara un archivo fuente **VHDL TestBench** para la simulación del archivo sintetizable **VHDL module** anterior.

10) A continuación haga clic sobre el archivo **sumador** de la ventana **Sources in Project**, y luego clic con el botón derecho para seleccionar **New Source**.



11) En la ventana desplegada complete el nombre del archivo, seleccione **VHDL TestBench** de la lista de la izquierda y haga clic en **Siguiente**. Luego pulse sobre **Siguiente** y por último en **Finalizar**.



- 12) Observará a continuación el código generado automáticamente más las líneas agregadas que hacen al testbench. Copie esas líneas a su proyecto (delimitadas aquí entre líneas de asteriscos) y guarde el archivo.
- -- VHDL Test Bench Created from source file sumador.vhd -- 00:31:49 04/26/2006

END;

-- Notes: -- This testbench has been automatically generated using types std\_logic and -- std\_logic\_vector for the ports of the unit under test. Xilinx recommends -- that these types always be used for the top-level I/O of a design in order -- to guarante that the testbench will bind correctly to the post-implementation -- simulation model. LIBRARY ieee; USE ieee.std\_logic\_1164.ALL; USE ieee.numeric\_std.ALL; \_\_ \*\*\*\*\*\*\*\*\*\*\*\*\*\* USE ieee.std\_logic\_arith.ALL; ENTITY sumador\_Test\_sumador\_vhd\_tb IS END sumador\_Test\_sumador\_vhd\_tb; ARCHITECTURE behavior OF sumador\_Test\_sumador\_vhd\_tb IS COMPONENT sumador PORT( A : IN std\_logic; B : IN std\_logic; Cin : IN std\_logic; Z : OUT std\_logic; Cout : OUT std\_logic ); END COMPONENT; SIGNAL A : std\_logic; SIGNAL B : std\_logic; SIGNAL Cin : std\_logic; SIGNAL Z : std\_logic; SIGNAL Cout : std\_logic; BEGIN uut: sumador PORT MAP( A => A $B \Rightarrow B$ Cin => Cin, Z => Z, Cout => Cout ); -- \*\*\* Test Bench - User Defined Section \*\*\* tb : PROCESS BEGIN -- Bucle de prueba \_\_ \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* for X in 0 to 7 loop -- Bucle que genera una tabla A <= CONV\_STD\_LOGIC\_VECTOR(X,3)(0); -- de tres variables, A, B y Cin B <= CONV\_STD\_LOGIC\_VECTOR(X,3)(1);</pre> Cin <= CONV\_STD\_LOGIC\_VECTOR(X,3)(2);</pre> wait for 10 ns; end loop; \*\*\*\*\*\*\*\*\*\* wait; -- will wait forever END PROCESS; -- \*\*\* End Test Bench - User Defined Section \*\*\*

13) Haga clic sobre el archivo del banco de pruebas en la ventana Sources in Project.



14) Luego pulse sobre Simulate Behavioral Model en la ventana Processes for Source.



15) Observará la apertura del simulador Modelsim:



- 16) Haga clic la ventana wave situada en la zona media-superior derecha.
- 17) Pulse sobre el ícono de la lupa oscura (**Zoom Full**), situado junto al ícono del semáforo y utilice los botones de zoom junto a la barra de desplazamiento horizontal para obtener una imagen apreciable del funcionamiento del sumador, como se muestra a continuación.



18) De no lograr el objetivo esperado verifique los pasos realizados según lo establece este sencillo tutorial.