Tema 7 - Buses de Interconexion
Tema 7 - Buses de Interconexion
Tema 7 - Buses de Interconexion
Buses de interconexin
1. Introduccin. Estructura del bus y uso bsico.
Clases de buses y jerarquas
2. Elementos de diseo de un bus:
Tipos de buses, anchura del bus, temporizacin, mtodo de arbitraje y tipos de transferencia de datos
3. Arbitraje del bus
4. Ejemplos de buses estndar
PCI, SCSI, USB y FireWire, AGP y PCI-Express
10 de mayo de 2009
Bibliografa
Computer Architecture: A Quantitative Approach (3rd or 4th ed.), John L. Hennessy y
David A. Patterson. Morgan Kaufmann Publishers, Inc.
Organizacin y arquitectura de computadores (7th ed.), William Stallings. Prentice Hall.
Organizacin de Computadores, C. Hamacher, Z. Vranesic y S. Zaky. Mc Graw Hill, 2003.
Computer Organization and Design: The hardware/software interface (3rd ed.), David A.
Patterson and John L. Hennessy. Morgan Kaufmann Publishers, Inc.
GAC: Grupo de Arquitectura de Computadores. Dpt. Electrnica e Sistemas. Universidade da Corua.
Introduccin
Las distintas unidades funcionales de un computador necesitan comunicarse. Deben existir, por lo tanto, lneas para interconectar estos mdulos.
Read
Memory
Write
N Words
Address
Data
Read
N1
I/O Module
Write
Address
M Ports
Internal
Data
External
Data
Address
Instructions
Interrupt
Signals
Internal
Data
Interrupt
Signals
External
Data
Data
Data
CPU
Control
Signals
Data
Introduccin
Un bus es un canal de comunicacin compartido que utiliza un conjunto de lneas para
conectar mltiples subsistemas. Cada cable o lnea transmite un nico bit de informacin
en un determinado momento.
Ventajas:
versatilidad
bajo coste
Desventaja: supone un cuello de botella, limitando la productividad mxima del sistema.
A la hora de disear un sistema de buses, el reto consiste en cubrir la demanda de
comunicacin del sistema y permitir la conexin de un gran nmero de dispositivos de
E/S.
Caractersticas deseables:
heterogeneidad
escalabilidad
baja latencia
alto ancho de banda
Principal problema en el diseo de un BUS: la velocidad mxima (y por tanto el rendimiento) est fuertemente limitada por cuestiones fsicas:
longitud del bus
nmero de dispositivos conectados
Y tambin por la necesidad de dar soporte a una gran variedad de dispositivos con muy
distintas latencias y anchos de banda
Los crecientes problemas que presentan las cada vez ms altas velocidades de transmisin en mltiples hilos paralelos hacen que la industria se encuentre en plena transicin:
de buses paralelos compartidos a interconexiones punto-a-punto de alta velocidad
con switches.
Las lneas de datos del bus proporcionan el camino para transmitir datos entre
los mdulos del sistema. El nmero de lneas del bus de datos determina el nmero
mximo de bits que es posible transmitir al mismo tiempo.
Las lneas de direccin se utilizan para designar (direccionar) la fuente o el destino
de los datos situados en el bus de datos. La anchura del bus de direcciones determina la cantidad mxima de memoria (y de dispositivos de E/S) direccionable en el
sistema.
Las lneas de control se emplean para gestionar el acceso y el uso de las lneas de
datos y direccin, sealizando peticiones y reconocimientos e indicando qu tipo de
informacin pasa por las lneas de datos.
Clasificacin segn las caractersticas elctricas:
Unidireccionales con un transmisor y mltiples receptores
Unidireccionales con mltiples transmisores y un nico receptor
Bidireccionales
Algunas lneas de control tpicas son:
Escritura en memoria (Memory Write)
Lectura de memoria (Memory Read)
Escritura de E/S (I/O Write)
Lectura de E/S (I/O Read)
Transferencia reconocida (Transfer ACK )
Peticin de bus (Bus Request)
Cesin de bus (Bus Grant)
Peticin de interrupcin (Interrupt Request)
Interrupcin reconocida(Interrupt ACK )
Reloj (Clock)
Inicio (Reset)
Apple Macintosh II
IBM RS-6000
Ms configuraciones
Diseo de un bus
Tipo de bus
Temporizacin
Dedicado
Direccin
Sncrono
Multiplexado
Datos
Asncrono
Uno
Lectura
Escritura
Lectura-modificacin-escritura
Lectura-despus de-escritura
Mtodo de arbitraje
Bloque
Centralizado
Distribuido
Temporizacin
Bus sncrono. Entre sus lneas de control se incluye una seal de reloj. El protocolo para
la comunicacin es fijo y est gobernado por la seal de reloj se asume que los envos
llegan correctamente.
Ventajas: Puede funcionar a gran velocidad y se puede implementar con un sistema secuencial sencillo.
Inconvenientes: No es adecuado para mezclar dispositivos con grandes diferencias de velocidad. Su diseo tiene que ser muy cuidadoso. Problema del sesgo del reloj (clock skew).
Los buses de memoria suelen ser sncronos.
Bus asncrono. Sin reloj. Las transmisiones de datos se coordinan con un protocolo de
handshaking entre emisor y receptor: un evento origina el siguiente, y as sucesivamente.
Ventajas: Permite la conexin de dispositivos de un amplio rango de velocidades diferentes.
Escalan mejor tanto con el nmero de dispositivos como con los cambios tecnolgicos en
los mismos. No hay problemas de sesgo de reloj, por lo que permite distancias ms largas.
Inconvenientes: Es ms lento, debido a la sobrecarga introducida para sincronizar a emisor
y receptor. Puede necesitar un cierto nmero de lneas de control adicionales para implementar el protocolo. Es ms difcil predecir el tiempo que va a llevar una determinada
transaccin.
Los buses de E/S son habitualmente asncronos.
Ejemplo de escritura.
Temporizacin
Otro ejemplo diferente de protocolo handshaking para realizar una lectura asncrona:
0. El protocolo comienza con el maestro (el procesador, por ejemplo) poniendo una
direccin de memoria en el bus de datos y activando la seal de peticin de lectura
(ReadReq).
1. El esclavo (la memoria, por ejemplo) ve la peticin y coge la direccin de memoria
del bus de datos, activando la seal de aceptacin (ACK ).
2. El maestro ve activa la seal de ACK y libera el bus de datos y desactiva la seal
de peticin de lectura, que sirve de aviso al esclavo.
3. El esclavo ve la desactivacin de la seal de peticin y contesta as mismo con la
desactivacin de la seal de ACK.
4. Cuando el esclavo tiene listo el dato a leer lo pone en el bus y activa la seal que
indica que el dato est listo (DataReady).
5. El maestro ve la seal DataReady, con lo que sabe que el dato est listo en el bus y
realiza su lectura. Cuando completa la operacin activa la seal de ACK.
6. El esclavo ve la seal de ACK, lo que le dice que el maestro ya tiene el dato ledo, y
desactiva la seal DataReady y libera el bus de datos.
7. Por ltimo, el maestro responde a la desactivacin de DataReady con la bajada de
su seal de ACK, lo que da por concluida la transmisin.
Esquemas de arbitraje
Gestin del uso del bus por parte de mltiples maestros.
Dos factores a considerar:
prioridad
imparcialidad (fairness)
Clasificacin genrica de tcnicas de arbitraje:
1. Arbitraje en serie (daisy chain arbitration). La lnea de concesin de bus (grant)
recorre los dispositivos desde el ms hasta el menos prioritario. Las prioridades se
determinan as en funcin de la posicin del dispositivo en el bus.
Decisiones de diseo
Rendimiento vs. Coste
Opcin
Alto rendimiento
Ancho de bus
lneas de datos y direcciones indep.
Ancho de bus
Ms ancho es ms rpido
Tamao transfers transfer bloq de mltiples palabras
Maestros de bus
mltiples maestros (req. arbitraje)
S. Aumenta ancho de banda (neTransac. partida
cesita varios maestros)
Temporizacin
sncrono
Bajo coste
lneas de datos y direcciones multiplexadas
Menos ancho es ms barato
transfer bloq. de una palabra
un nico maestro
No. Conexin continua ms barata (y con menor latencia)
asncrono
Despus de PCI:
PCI-X (PCI eXtended): diseado para aumentar el rendimiento (hasta 1 GB/s) en la
conexin de dispositivos con grandes necesidades de ancho de banda: Gigabit Ethernet,
fibra ptica, procesadores en un cluster. . . Es compatible con PCI.
AGP (Accelerated Graphics Port): interfaz diseada por Intel, basndose en PCI, para
conexin de tarjetas grficas. Introduce canal punto-a-punto dedicado de 32 bits - 66 M hz
para acceso de procesador grfico a memoria principal (1X 266 M Bs/s).
PCI Express: diseado para sustituir tanto a PCI como a AGP. Basado en canales serie
punto-a-punto (200 M Bs/s por canal).
Bus PCI
Variedad de configuraciones diferentes, con uno o ms procesadores.
Conjunto de funciones de uso general.
Temporizacin sncrona y esquema de arbitraje centralizado.
COMANDO
Reconocimiento de interrupcin
Ciclo especial
Lectura de E/S
Escritura en E/S
Reservado
Reservado
Lectura de memoria
Escritura en memoria
Reservado
Reservado
Lectura de configuracin
Escritura de configuracin
Lectura mltiple de memoria
Ciclo de direccin dual
Lectura de lnea de memoria
Escritura e invalidacin de memoria
Transferencias de datos
Cada transferencia de datos en el bus PCI es una transaccin nica.
Transaccin PCI: 1 fase de direccionamiento + 1 o ms fases de datos.
Todos los eventos se sincronizan en transiciones de bajada del reloj (mitad de ciclo de
reloj).
Los dispositivos del bus interpretan las lneas del bus en los flancos de subida (comienzo
del ciclo del bus).
Fase de direccionamiento
1. Maestro de bus identifica dispositivo destino (esclavo) y tipo de transaccin
2. Maestro de bus activa la sea F RAM E#
3. Cada dispositivo conectado al bus PCI decodifica la direccin para determinar si
pertenece a su espacio de direcciones. El dispositivo al que pertenece la direccin
activa la seal DEV SEL#
Fase de datos
1. Las seales C/BE# determinan el nmero de bytes habilitados para la transmisin
en el bus de datos
2. Las seales IRDY # y T RDY # controlan la transferencia. Los datos son transmitidos solo cuando ambas seales estn activada.
Duracin y finalizacin de la transaccin
1. El maestro de bus mantiene la seal F RAM E# activada desde el comienzo de la
transaccin hasta que est preparado para finalizar la fase de datos
2. La finalizacin de la transaccin se indica mediante la desactivacin de F RAM E#
junto con la activacin de IRDY #
3. Cuando el ltimo dato ha sido transferido se libera el bus mediante la desactivacin
de IRDY #
Transaccin de lectura
CLK
FRAME#
AD
ADDRESS
C/BE#
BUS CMD
d
c
DATA-1
Byte Enable
DATA-2
DATA-3
Byte Enable
Byte Enable
Data Transfer
Wait
Data Transfer
Wait
Wait
TRDY#
Data Transfer
g
IRDY#
DEVSEL#
Address Phase
Data Phase
Data Phase
Data Phase
Wait State
Wait State
Bus Transaction
Wait State
a) El maestro del bus ha obtenido control del bus e inicia transaccin activando F RAM E#.
Esta lnea permanecer activa hasta que el maestro se disponga a finalizar la ltima fase
de datos. El maestro sita la direccin de comienzo de lectura en el bus de direcciones y
la orden de lectura en las lneas C/BE#
b) A partir del comienzo del segundo ciclo de reloj el dispositivo del que se lee reconocer
su direccin en las lneas AD.
c) El maestro libera lneas AD. Ciclo de cambio para evitar contienda. Maestro cambia
informacin en C/BE# para habilitar las lneas de AD a utilizar. Tambin activa IRDY #
para indicar que est preparado para recibir primer dato.
d) El dispositivo de lectura seleccionado activa DEV SEL# para indicar que ha reconocido
la direccin y va a responder. Sita dato solicitado en AD y activa T RDY # para indicar
que hay un dato vlido en el bus.
e) El maestro lee el dato al comienzo del cuarto ciclo.
f) En este ejemplo dispositivo de lectura requiere tiempo para preparar segundo bloque de
datos. Desactiva T RDY # para indicar a maestro que NO proporcionar nuevo dato en
siguiente ciclo. Maestro no leer bloque de datos hasta el sexto ciclo.
g) Dispositivo de lectura coloca tercer dato en el bus. Ahora es maestro el que no est
preparado para leer el dato, desactivando IRDY #.
h) El maestro desactiva F RAM E#, para indicar a dispositivo que es el ltimo dato a transferir, y activa IRDA# para indicar que est listo para completar la transferencia.
i) El maestro desactiva IRDY #, liberando el bus. El esclavo desactiva T RDY # y DEV SEL#.
El arbitraje se solapa con la comunicacin del maestro de bus actual, de forma que no se pierden
ciclos: arbitraje de bus solapado u oculto.
La especificacin PCI no indica un algoritmo particular de arbitraje.
Ejemplo de procedimiento de arbitraje:
CLK
REQ#-A
REQ#-B
GNT#-A
a
b
c
e
GNT#-B
FRAME#
IRDY#
TRDY#
AD
Address
access-A
Data
Address
Data
access-B
La interfaz externa
Interfaz de comunicacin mdulo E/S - perifrico
Interfaz paralela vs. interfaz serie