Edc Bol1
Edc Bol1
Edc Bol1
Problema 1
Un registro universal (RU8) de 8 bits tiene la siguiente descripción:
- Entradas de datos: 8 en paralelo (X7-0) y dos en serie (r y l), una para desplazamiento
a derecha (r) y otra a izquierda (l).
- Salidas de datos: 8 en paralelo (z7-0).
- Entradas de control: la del reloj (Ck) y dos para las distintas operaciones (S1S0, con 00
para inhibición, 01 para desplazamiento a la derecha, 10 para desplazamiento a
izquierda y 11 para carga en paralelo).
Descríbalo a nivel RT. Especifique un registro equivalente cuyo control se efectúe con
sólo una entrada activa por cada operación de cambio de datos. Diséñelo utilizando un
RU8.
Problema 2
Describa a nivel RT un contador ascendente mod-64 con puesta a cero, carga en
paralelo e inhibición.
Problema 3
Un registro A con n etapas individuales se acopla a un bus cuyas líneas llevan los bits B.
Los componentes del registro A son biestables SR. Dibuje el diagrama lógico de un cir-
cuito asociado a una etapa del registro que nos permita ordenar la transferencia a la
etapa del bit que resulte cuando Ai hace la operación AND con Bi, esto es, Ai ← AiBi.
Repítalo para Ai ← Ai + Bi, Ai ← Ai ⊕ Bi, Ai ← A i ⊕ B i .
Problema 4
Se desea realizar la operación MAB: B ← A
4.1 Dibuje la celda básica de B con biestables RS.
4.2 Suponga que encontramos aceptable realizar una transferencia registro a
registro en dos pasos, es decir, primero borramos B y después cargamos B
con el contenido de A. Demuestre que en este caso podemos usar menos
hardware que en el apartado 1. Dibuje la celda básica de B y las señales
para dicha transferencia síncrona.
Problema 5
Sobre un registro A deben realizarse las tres operaciones siguientes, siendo B el con-
tenido de n bits de un bus de datos:
Pág. 1 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 6
Se definen las siguientes operaciones de desplazamiento a la derecha:
- LSR (Logic Shift Right):
Se trata del llamado desplazamiento lógico, en el que el bit de entrada serie es 0.
- ASR (Arithmetic Shift Right):
Se trata del llamado desplazamiento aritmético, en el que el bit de entrada serie es el bit
de signo.
- ROR (Rotation Right):
Se trata de la llamada rotación, en la que el bit de entrada serie coincide con el bit de
salida serie.
6.1 Describa las tres operaciones a nivel RT para un registro de n bits, repre-
sentando el circuito correspondiente.
6.2 Realice los tres circuitos anteriores para el caso n = 8 utilizando el registro
74198.
6.3 Realice un circuito basado en 74198 que permita realizar las siguientes fun-
ciones:
A1 A0 Operación
00 LSR
01 ASR
1- AOR
X7-0
8
Dsr Dsl MR S1 S0
0 - - Puesta a 0 asíncrona
MR 74198
[8] 100 Inhibición
S1
101 Desplazamiento izqda.
S0
110 Desplazamiento dcha.
8 111 Carga en paralelo
CK
O7-0
Pág. 2 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 7
Compare las siguientes declaraciones RT:
a) A + B: E ← C + D
b) A + B: E ← C ∨ D
c) C + D: E ← A + B
d) A • B: E ← C ∧ D
e) A • B: E ← C • D
f) A • B: E ← C x D
Problema 8
Se dispone de un registro con terminales de entrada y salida separados que posee una
única señal de control para escritura, W. Se pretende incorporar este registro a un
sistema ya dado a través de un bus 3-estados bidireccional. Describa cómo se imple-
menta la incorporación.
Problema 9
Se dispone de cuatro registros con datos (R0, R1, R2 y R3) y una ALU, todo de n bits. Se
desea diseñar un sistema que permita a cualquiera de los registros ser operandos
fuente y/o destino del resultado. El registro fuente del dato A es seleccionado por dos
bits, A1 y A0; el de B, por B1 y B0; y el de destino, por D1 y D0. Muestre la estructura del
sistema e indique cómo se realiza una operación en los siguientes casos:
9.1 Un esquema de conexión basado en multiplexado, usando registros con ter-
minales de entrada y salida separados.
9.2 Un esquema de conexión basado en buses triestado, usando registros con
terminales de entrada y salida separados.
9.3 Usando registros con terminales de datos bidireccionales.
Añada, en cada caso, los dispositivos que se necesiten.
Indique, también en cada caso, la secuencia de activación de las señales de control de
los dispositivos indicando de dónde provienen.
Problema 10
En un sistema digital se desean implementar las siguientes micro-operaciones condi-
cionales:
W: M ← MBR (El dato de MBR se escribe en memoria)
R: MBR ← M (Se lee de memoria un dato y se escribe en MBR)
E: MBR ← EXR (Se carga en MBR el dato de un registro externo EXR).
Pág. 3 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 11
Un procesador posee los siguientes registros: un contador de programa (PC) y un regis-
tro de direcciones de memoria (MAR) de 16 bits, un registro de datos de memoria (MDR)
de 24 bits y un registro de instrucciones (IR) de 8 bits. MAR podrá ser cargado con el
contenido de PC (cuando se activa una señal LPC) o con los 16 bits menos significativos
de MDR (cuando se activa una señal LMDR). Los 8 MSB de MDR se almacenarán en IR
(cuando se active una señal TMDR).
11.1 Indique a nivel RT las transferencias hacia MAR y hacia IR, y dibuje un dia-
grama de bloques del procesador.
11.2 Se dispone de circuitos integrados, cada uno de los cuales incluye un regis-
tro o un contador de 8 bits. Indique cuántos circuitos integrados se necesitan
para construir el sistema indicado, mostrando su ubicación en el diagrama
de bloques anterior.
11.3 Diseñe MAR utilizando el Circuito Integrado 74198.
11.4 Diseñe MAR utilizando el C.I. 74298.
IA3-0 IB3-0
4 4
S CIR
S 74298
CIR[4] 0 CIR ← IA
Ck 1 CIR ← IB
Q3-0
Nota: C.I. 74298 ver problema 6.
Pág. 4 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 12
En la unidad de datos de la figura se activan las señales de acuerdo con la siguiente
secuencia de control.
ciclo EN d1 d0 S1 S0
1 0 1 1 0 0
2 1 1 1 1 1
3 0 0 0 0 1
4 0 0 1 1 0
5 1 0 0 0 0
6 0 1 0 1 1
S1 0 1 2 3
S0 n x MUX 4:1
n
n
n n n n
A B C D
n n n n
0
d1
1
d0 2
3
EN
Pág. 5 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 13
La figura muestra una carta ASM de un sistema así como la unidad de datos correspon-
diente. En dicha carta, x e y son entradas que pueden tener cualquier valor binario, per-
maneciendo constantes desde que Xs se hace 1.
13.1 Proporcione la descripción Verilog de la unidad de datos
13.2 Especifique todos los errores de la carta, comentándolos brevemente.
Ra Rb Rc
Wa A Wb B Wc C
Za Zb Zc
0
Xs
1
S=1
1 0
x. y
C←B B←C
0 1
x+y 0 1
x
A←B 0
C←0 y A←C
1
C←A
sí no
C=0
B←A A←B
Pág. 6 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 14
Considere un sistema con tres registros (A, B, C) de ocho bits. Ha de tener lugar la
siguiente secuencia de operaciones en el orden que se describen:
Cuando se activa una señal de comienzo (Xs), los datos de entrada se cargan en A. El
complemento de los datos de A se cargan en C. Finalmente, los datos de C se
almacenan en B. Con los datos de A y B se hace la operación OR y el resultado se
almacena en C. Finalmente, los datos de C son situados en las líneas de salida, tras lo
cual el sistema va al estado de espera.
14.1 Describa las operaciones a nivel RT.
14.2 Diseñe la unidad de datos que pueda realizarlas.
14.3 Haga la carta ASM de las señales a activar por el control.
14.4 Proporcione la descripción Verilog de las unidades de datos y de control
14.5 ¿Habría que hacer algún cambio para imponer que las líneas de salida estu-
viesen en alta impedancia cuando no mostraran el dato? En su caso,
¿cuáles son?
Problema 15
Se desea realizar la siguiente microoperación:
K T0 A ← B0
T1 A ← B1
T2 A ← B2
T3 A ← B3
NOR (T0+T1+T3+T4) NOP
donde K identifica esta microoperación, T0-T3 son las variables de entrada, los registros
son de ocho bits y, en cada instante, hay como mucho una señal de entrada a 1 (esto es,
Ti.Tj = 0 ∀i, j).
15.1 Represente el bloque ASM correspondiente.
15.2 Muestre una implementación del circuito que realiza esta instrucción en los
dos casos siguientes:
a) Los registros Bi tienen salida estándar en paralelo.
b) Los registros Bi tienen salida triestado (alta impedancia) en paralelo.
Pág. 7 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 16
Para la unidad de datos de la figura:
Rt
Wt RT Ra
∇ ∇ A Wa
Rb
A b ALU a ∇ B Wb
S 8
Rac Rc
∇ C
Wac ACUM Wc
Zac ∇
8
8
SHL
A→B→C
Problema 17
Para la unidad de datos de la figura anterior, obtenga la carta ASM de un controlador
que permita realizar la operación siguiente:
C = 4 * (A + B).
Nota: La entrada SHL del acumulador produce un desplazamiento lógico hacia la
izquierda, introduciendo un “0” por la derecha.
Problema 18
Para la unidad de datos de la figura, obtenga la carta ASm una unidad de control bas-
ada en registro de desplazamiento de forma que, en función de dos bits de entrada I1, I0,
pueda elegirse entre una de las cuatro macrooperaciones siguientes:
1) A ← A + 2B 3) C ← A - 2B
2) A ← A - 2B 4) C ← 2A + 2B
Pág. 8 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Rt Rsh
Wt RT SHIFT REG. Wsh
∇
SHL
8 8
SEL 0 MUX 1
Ra
∇ A Wa
Rb
A b ALU a ∇ B Wb
S 8
Rac Rc
ACUM ∇ C Wc
Wac
Zac ∇
8
8
Problema 19
Para la unidad de datos de la figura, obtenga la carta ASM de un controlador que per-
mita escribir en B el número de “1” que hay en A. El contador C1 es de tres bits (mod. 8)
y el C2 de 8 bits (mod. 256). ¿Qué cambio hay que introducir para escribir en B el
número de “0” de A?
Nota: Zi = Puesta a 0 síncrona.
Ii = Incremento.
CYi = CARRY.
Pág. 9 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Wa Wb
A[8] B[8]
Ra Rb
8 8
8
8 3 8
Rd CY1 CY2
Wd REG. DESP. C1 C2
SHR
R1 W 1 I 1 Z 1 R2 W2I2 Z2
Problema 20
Para la unidad de datos que se presenta, se quiere realizar un sistema digital capaz de
comparar dos números de 8 bits (A y B), y almacenar en A el mayor de ellos y en B el
menor. Tras finalizar la operación, el sistema generará una señal de FIN.
20.1 Defina correctamente las operaciones de los registros.
20.2 Obtenga la carta ASM.
20.3 Sin añadir elementos nuevos, ¿se puede simplificar la arquitectura de esta
unidad de proceso? Razone la respuesta.
A[8] C[8]
1 E E>F
E=F
B[8] D[8] F E<F
1
8
CONT. mod-8
Pág. 10 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 21
La figura muestra la solución al último apartado del problema anterior. Recordemos que
se trata de almacenar en A el mayor y en B el menor de los datos previamente
almacenados en A y B. Determine la carta ASM para esta unidad.
Ra Rc
Wa A[8] iL C[8]
SHLa Wc
A7
Rb
Wb B[8] iL
SHLb
8 UP
B7 CONT. mod-8 CY
CL
Problema 22
En la unidad de datos de la figura se han representado todos los componentes y los
caminos de datos. Suponga que, además, existe disponible una señal, FIN, que se pone
a 1 cuando se han sumado n bits. Se desea realizar las tres macrooperaciones
siguientes:
C←A+B
C←A
C←B
22.1 Especifique las señales de control y operaciones de los registros y el
biestable.
22.2 Obtenga la carta ASM del controlador
22.3 Proporcione la descripción Verilog de las unidades de datos y control.
Pág. 11 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
A[n]
A0 1 Cin
a
B[n] Sumador C[n]
completo
1 b
B0 Cout
IN
Biestable
OUT
Problema 23
Diseñe un sistema digital (ver figura), que opere como sigue. Sincronizado con Ø1,
recibe por XS un pulso de un ciclo de duración y, a continuación, 8 bits de datos en serie
por una línea Din.
El sistema, de forma sincronizada con Ø2, en primer lugar debe generar por XO un pulso
de un ciclo de duración y, seguidamente, retransmitir por Dout los 8 bits de datos recibi-
dos.
XS
XO
Din SISTEMA
Φ1 DIGITAL Dout
Φ2
CLK
q
1 T
Problema 24
Un número decimal de dos dígitos se almacena en dos registros de cuatro bits en forma
BCD. El registro M contiene los dígitos más significativos; el L, los menos. Los números
se transfieren para que aparezcan en un registro R de ocho bits. Para efectuar la trans-
ferencia se dispone de un bus de cuatro bits accesible a M y L, pero sólo a las cuatro
Pág. 12 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 25
Haga la carta ASM de un ascensor que circula entre dos pisos (1o y 2o). En cada piso
hay un pulsador para llamar al ascensor (L1 y L2) y dentro del ascensor hay dos pulsa-
dores (B1 y B2) para elegir el piso de destino. En cada piso existe un sensor que detecta
la llegada del ascensor y activa una señal (T1 para el 1er piso y T2 para el 2o).
25.1 Si el ascensor está en movimiento y se pulsa algún interruptor debe
continuar hasta alcanzar el piso destino.
25.2 Antes de iniciar el movimiento hay que dar la orden de cerrar la puerta del
ascensor (señal CP) y al finalizar el recorrido hay que dar la orden de abrir la
puerta (señal AP).
25.3 Para que el ascensor se mueva hay que activar las señales SUBE o BAJA
hasta que alcance el piso destino.
Problema 26
Un sistema digital tiene como unidad de datos lo representado en la figura. Inicialmente,
al menos uno de los bits de A es un cero. El sistema debe dar como salida el número
binario de la posición del “0” menos significativo de la palabra almacenada en el registro
A.
26.1 Describa, a nivel RT, los componentes de esta unidad de datos.
26.2 De la carta ASM.
26.3 Si el valor inicial de A es: 10101011, represente en el tiempo (hasta que se
ha generado la salida deseada) los siguientes parámetros: BUS, señales de
control (RA, S1, S0, CLC, UP) y las salidas del sistema digital.
26.4 ¿Cuál es el contenido de RU8 y de CONT tras regresar al estado de
espera?
Pág. 13 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 27
Un sistema digital debe analizar su línea de entrada X con objeto de contabilizar el
número de pulsos de esa señal que tiene de anchura 1, 2 ó 3 ciclos de reloj. El sistema
dispone de tres salidas (z1, z2, z3) con las que se indica cuál de los tres tipos de pulsos
es más numeroso. (Por ejemplo, si se han recibido siete pulsos de un ciclo de reloj, cua-
tro pulsos de dos ciclos y nueve pulsos de tres ciclos, el sistema generaría como salida
z1z2z3 = 001). Desde que se le da la orden de comienzo, se deberán analizar 256 ciclos
de reloj, volviéndose después al estado inicial. Diseñe dicho sistema, utilizando los sub-
sistemas habituales.
Nota 1: Nunca se recibirán pulsos de más de tres ciclos de reloj.
Nota 2: En caso de igualdad se activan las salidas correspondientes.
Pág. 14 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 28
Un sistema digital (ver figura) consiste en una cerradura electrónica que se abre
mediante una combinación adecuada de 8 bits. La combinación está almacenada en el
sistema. El modo de operación es como sigue:
RESET
LEE
INTENTA
Sistema ABRE
BIT Digital
Ck
- La señal RESET lleva al sistema al estado inicial (no hay que incluirla dentro de la carta
ASM ya que se considera asíncrona).
- La señal BIT indica el bit correspondiente de la combinación (comenzando por el más
significativo).
- La señal LEE (al activarse) indica que se puede leer la entrada BIT.
- La señal INTENTA (al activarse) indica que ya se ha introducido la combinación y si es
correcta se abrirá la caja (poniéndose la salida ABRE a 1).
28.1 Diseñe la unidad de datos del sistema.
28.2 Exprese el algoritmo de control mediante una carta ASM.
Problema 29
Se desea diseñar la unidad de control del nuevo modelo de lavadora V-1000 que tiene
las siguientes especificaciones:
- El ciclo de lavado, que se inicia al activar la orden de comienzo Xs, consta de prela-
vado (P), lavado (L), aclarado (A) y centrifugado (C), que se harán en ese orden. La
máquina procederá a cada operación cuando la unidad de control active la correspondi-
ente señal (P, L, A o C).
- La lavadora V-1000 dispone, fuera de la unidad de control, de un contador con señales
de puesta a cero (CLS) y de incremento (I), así como cuatro salidas que se activan
cuando transcurre el tiempo de prelavado (TP), el de lavado (TL), el de aclarado (TA) y el
de centrifugado (TC). Cada uno de estos tiempos (TC, TA, TL y TP) se contabilizan desde
cero.
- El ciclo de lavado se divide en dos subciclos. Uno de duración fija TL y otro variable
que termina cuando se activa un “Sensor de Ropa Limpia” (SRL = 1).
Pág. 15 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Problema 30
Se desea diseñar una calculadora que realice la suma, resta o multiplicación de dos
datos de entrada sin signo de 12 bits (ver figura). Para ello, su diseño se descompondrá
en dos partes.
1) Realización de SUMA y RESTA.
Los dos datos de entrada se captarán tras activarse la señal ENTRA. Después, el
sistema operará según cuál de las dos señales (SUMA o RESTA) esté activa. Sólo una
de estas señales podrá estar activa. El resultado se mostrará en el bus de salida R. Si
A<B, al ejecutar RESTA se hará B−A y se activará la salida Signo_Menos.
30.1 Diseñe una unidad de datos propia para este problema. Esto es, no tiene por
qué parecerse a la dada en teoría. En todo caso, deberá estar especificada
y dimensionada adecuadamente.
30.2 Determine la carta ASM.
2) Además, realización de MULT.
Al sistema anterior se incorporará la multiplicación A * B, cuando se active MULT, que se
hará sumando A tantas veces como indique B.
30.3 Rediseñe la unidad de datos anterior para incorporar esta nueva operación
(la unidad de datos no puede incluir un multiplicador como subsistema).
Redimensione la unidad para que no existan problemas de desbordamiento.
30.4 Obtenga la carta ASM global.
Pág. 16 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
A B
12 12
Xs
ENTRA FIN
SUMA
RESTA Signo_Menos
MULT
+|*
A B
Problema 31
Se va a calcular el producto aritmético P de dos números X e Y (P = X.Y). Para ello se
van a emplear tres contadores CX, CY y CP. Al comienzo del proceso se cargan los ope-
randos X e Y en sus respectivos contadores CX y CY. El contador CP contendrá el
resultado al final del proceso. El producto se obtiene incrementando CP un total de P
veces. Para conseguir esto se decrementa CX hasta que llega a cero en cuyo caso se
decrementa una vez CY y se vuelve a cargar X en CX. Naturalmente, cuando CY llega a
cero CX se ha decrementado un total de X.Y veces. Si al mismo tiempo se ha ido incre-
mentando CP tendremos en ese contador el resultado esperado.
31.1 Describa a nivel RT CX, CY y CP.
31.2 Obtenga la carta ASM del sistema.
Problema 32
Un formato asíncrono para transmitir en serie un carácter de 8 bits (D0-D7) se muestra
en la siguiente figura. El primer bit, que sirve para avisar al receptor del inicio del
carácter (bit de start), es un 0 lógico. A continuación vienen los 8 bits del dato, empe-
zando por el menos significativo, el D0. Posterior al D7 viene el bit de paridad impar P y,
por último, un bit de stop que es 1 lógico. La duración de cada uno de estos bits es Tbit.
Pág. 17 de 18
Boletín 1: Diseño de sistemas digitales a nivel RT
Tbit Tbit
X D0 D 1 D2 D3 D 4 D5 D6 D7 P
X SISTEMA
Bit de start Bit de stop
Tbit
Xs ERROR_PARIDAD
clk
ERROR_TRAMA
16 ciclos
X
1er ciclo 8o ciclo
clk
Se desea diseñar un sistema digital capaz de recoger los bits de datos en este formato y
almacenarlos en el registro RCREG. El reloj del sistema es mucho más rápido que la
señal X; en concreto, el periodo es de Tbit/16, esto es, existen 16 ciclos de reloj por cada
bit de entrada. Tras la activación de la señal Xs el sistema operará de la forma siguiente:
- Si en un ciclo de reloj el sistema detecta X = 0, espera 8 ciclos (punto medio de un bit)
y vuelve a leer X. Si ahora X = 1 interpreta que ha habido un error transitorio y vuelve a
esperar un bit de start correcto. Si X sigue valiendo 0 pasa a leer el mensaje para lo cual
capturará cada bit leyendo X en el medio del bit (aproximadamente el ciclo octavo (ver
figura)).
- Tras leer un dato, el sistema esperará uno nuevo sin necesidad de activarse la señal
Xs. Así mismo, el sistema debe activar la señal ERROR_PARIDAD cuando la paridad
recibida no sea la correcta y debe activar la señal ERROR_TRAMA cuando el bit de stop
es un 0 en lugar de un 1.
Diseñe el sistema digital completo.
Pág. 18 de 18