Arquitectura activada por transporte

La arquitectura activada por transporte ( TTA ) es una variante de la arquitectura de microprocesador en la que los programas gestionan directamente las conexiones internas (buses) entre unidades de procesador (por ejemplo, ALU , archivo de registro ). Los cálculos son un efecto secundario de la transferencia de datos entre bloques: la escritura de datos en el puerto de entrada ( puerto de activación ) de un dispositivo funcional hace que este comience a procesarlos. Debido a su estructura modular, la arquitectura TTA es adecuada para el diseño de procesadores orientados a problemas ( ASIP), mientras que los procesadores TTA son más versátiles y económicos que los aceleradores de hardware para funciones fijas.

Normalmente, un procesador TTA tiene varios buses de transporte y muchas unidades funcionales (FU) conectadas a estos buses. La abundancia de FU le permite lograr paralelismo a nivel de instrucción . La concurrencia la determina estáticamente el programador. En este sentido, y debido a la gran longitud de la instrucción máquina, las arquitecturas TTA se asemejan a las arquitecturas de palabra de instrucción muy larga (VLIW). La instrucción para el TTA consta de varias ranuras, una ranura para cada bus. Cada ranura determina cómo se transferirán los datos en un bus determinado. Un control tan completo permite algunas optimizaciones que son imposibles para las arquitecturas clásicas. Por ejemplo, es posible transferir datos explícitamente entre diferentes FU sin almacenar datos intermedios en un archivo de registro.



Los procesadores con arquitecturas de clase TTA estaban disponibles comercialmente.

Comparación con VLIW

Estructura

Los procesadores con arquitectura de clase TTA constan de varias unidades funcionales independientes y archivos de registro, que están conectados por buses de transporte y sockets.

Dispositivo funcional

Cada unidad funcional realiza una o más operaciones. Es posible implementar tanto las operaciones aritméticas más simples (suma de enteros) como operaciones arbitrarias complejas específicas de la aplicación de destino. Los operandos se transfieren a la FU a través de los puertos de la FU. El resultado de la operación se transmite a través del puerto de salida de la FU.

Cada FU puede implementar una canalización computacional independiente .

El acceso a la memoria y la interacción con dispositivos externos es manejado por FU especiales. La FU para el acceso a la memoria a menudo se denomina unidad de carga/almacenamiento .

Dispositivo de control

El dispositivo de control controla el proceso de ejecución del programa. Tiene acceso a la memoria de instrucciones para recibir las próximas instrucciones de la máquina. También implementa comandos de salto. Por lo general, el dispositivo de control está canalizado y se asignan etapas: carga, decodificación, ejecución de instrucciones.

Registrar archivos

Los archivos de registro (RF) contienen matrices de registros de propósito general que almacenan variables de programa. Al igual que las FU, las RF tienen puertos de entrada y salida. La cantidad de puertos de entrada y salida (la cantidad de RON leídos simultáneamente desde la matriz) puede ser diferente para diferentes RF.

Buses y enchufes

Programación

Un ejemplo de una operación de suma para un procesador TTA hipotético:

r1 -> ALU.operand1

r2 -> ALU.add.trigger

ALU.result -> r3

Retrasos en la operación

Uno de los principios fundamentales de TTA es simplificar el hardware complicando el software.

Implementaciones

Notas

Véase también

Enlaces