**Tecnología de Computadores**

Hoja de Ejercicios

Luis Alberto Aranda Barjola



©2023 Luis Alberto Aranda Barjola.
Algunos derechos reservados. Este documento se distribuye bajo la licencia “Atribución-CompartirIgual 4.0 Internacional” de Creative Commons, disponible en <https://creativecommons.org/licenses/by-sa/4.0/deed.es>.

1. Dibuje el esquemático del circuito descrito por el siguiente código VHDL. Simplifique primero las ecuaciones lógicas para obtener el circuito mínimo.



1. Escriba un módulo en VHDL que realice la función XOR para cuatro entradas. La entrada del módulo es “a3:0” y la salida es “*y*”.
2. Escriba un módulo en VHDL llamado “*minority*” con tres entradas A, B y C, y una salida Z. La salida del módulo es TRUE cuando al menos dos de las tres entradas son FALSE.
3. Escriba el código VHDL de un decodificador de 3:8.
4. Suponiendo que dispone del código VHDL de un multiplexor de 8:1. Escriba otro código VHDL que implemente la función lógica $y=a\overbar{b}+\overbar{b}\overbar{c}+\overbar{a}bc$ utilizando uno de estos multiplexores y las puertas lógicas que necesite. Suponga que la entidad del multiplexor está definida como sigue:



1. Se desea diseñar un circuito digital en VHDL denominado MEMORY que consta de los módulos SENDER y STORAGE mostrados en el diagrama de bloques de la siguiente figura. Suponiendo que ya se dispone de los códigos VHDL de dichos módulos, escriba el código VHDL del circuito MEMORY que instancia los módulos tal y como se presentan en la figura.



1. Se desea sumar dos números en binario A y B con un sumador con acarreo anticipado. Calcule el valor de los Gi y Pi para poder implementar el sumador.

A = 1010 0001 1100 0011

B = 0101 1111 0001 0111

1. Para los mismos datos del ejercicio anterior, calcule el acarreo de salida del primer bloque de 4 bits si dicho bloque recibe un acarreo de entrada de ‘1’.
2. Hacer un LSR, ASR y ROR de 3 bits cada uno para los siguientes números:

a) 24 c) 10

b) -18 d) 32

1. Escriba el código VHDL de la ALU de la siguiente figura suponiendo que ya dispone de los códigos VHDL del sumador y los multiplexores.



1. Escriba el código VHDL del circuito presentado en la siguiente figura suponiendo que se conocen los códigos VHDL de todos los componentes a excepción de la puerta OR y del inversor.



1. Escriba el código VHDL de un flip-flop JK. Este tipo de flip-flops tiene 3 entradas (J, K y CLK) y una salida (Q). En el flanco de reloj de subida, Q mantiene el valor anterior si J = K = 0. Si J = 1, entonces Q = 1 y si K = 1 entonces Q = 0. Si ambas señales J = K = 1, entonces el valor de Q es invertido.
2. Escriba el código VHDL de un flip-flop D con señales de set (S) y reset (R). De tal modo que si se activan ambas a la vez la salida del flip-flop (Q) será el valor de la entrada D, pero invertido. En los otros casos funciona normalmente según los valores de D, S y R.
3. Dado el siguiente código VHDL, determine qué error de sintaxis se está cometiendo que hace que dicho código no funcione. Una vez funcione el código, ¿a qué frecuencia de reloj se realizará la simulación?



1. Escribir el código VHDL de un multiplexor de 4 a 1 utilizando asignación condicional. Repita el mismo diseño, pero ahora usando un “case-when”.
2. Escribir la architecture de un multiplexor de 2 a 1 cuya entidad se muestra a continuación. Utilice descripción basada en comportamiento.



1. Determine si las siguientes arquitecturas son equivalentes, es decir, si proporcionan el mismo comportamiento para una misma entidad dada. Justifique su respuesta.

 

1. Escribir el código VHDL de un proceso que simula un reloj de 20 MHz en un testbench.
2. Escriba el código VHDL de un testbench que permita simular la unidad aritmeticológica descrita en la tabla de la derecha sabiendo que A y B son señales de 8 bits. Explique los casos de ejemplo que ha elegido para la simulación y los valores de salida esperados en cada caso.
3. Escriba el código VHDL de un testbench para simular un flipflop T. Simule un reloj con un periodo de 20 ns, un pulso de reset de 30 ns de duración y una señal de entrada T que tenga el siguiente comportamiento cíclico:
* Comienza valiendo ‘0’ durante 10 ns
* Pasa a valer ‘1’ y permanece así durante 40 ns
* Vuelve a valer ‘0’ durante 30 ns
1. Escriba el código VHDL de la máquina de estados definida por la siguiente tabla de transición/salida sabiendo que se comienza en el estado S1 y que tiene un reset asíncrono activo a nivel alto. ¿Qué tipo de máquina es? Justifique su respuesta.



1. Se desea simular una máquina de estados de Moore cuya función es la de detectar un cambio de ‘0’ a ‘1’ en la señal X de entrada. Escriba el código VHDL de un testbench que permita verificar su funcionamiento sabiendo que la máquina activa su salida Z cuando detecta dicho cambio, que trabaja a una frecuencia de 50 MHz y que tiene un reset síncrono activo a nivel bajo.
2. Dibuje el diagrama de estados de la máquina de estados descrita por el siguiente código VHDL.



1. Dibuje el diagrama de estados asociado a la máquina de estados descrita por el siguiente código VHDL.



1. Escribir el código VHDL de un registro de 8 bits activo por flanco de subida con señal de habilitación asíncrona activa por nivel alto.