PDF de programación - Procesadores de palabra de instrucción muy larga (VLIW) v.2012

Imágen de pdf Procesadores de palabra de instrucción muy larga (VLIW) v.2012

Procesadores de palabra de instrucción muy larga (VLIW) v.2012gráfica de visualizaciones

Publicado el 12 de Julio del 2018
790 visualizaciones desde el 12 de Julio del 2018
344,9 KB
28 paginas
Creado hace 11a (05/10/2012)
Procesadores de palabra de

instrucción muy larga

(VLIW)
v.2012

William Stallings, Organización y Arquitectura de

Computadores, 5ta. ed., Capítulo 13: Paralelismo a nivel de

instrucciones y procesadores superescalares. 6ta. ed., Chapter

15: The IA-64 Architecture.

John Hennessy – David Patterson, Arquitectura de

Computadores – Un enfoque cuantitativo 4ª Ed, Capítulos 2 y 3.



Introducción
Explotación Superescalar del ILP

VENTAJAS

- El HW resuelve todo: detecta el paralelismo, emite, renombra

registros, etc.

- Compatibilidad binaria: puedo agregar unidades funcionales sin

cambiar el ISA.

DESVENTAJAS

- Hardware muy complejo, se llega rápidamente a un límite.
- Ventana de ejecución limitada por el hardware, lo cual limita la

capacidad de detección de instrucciones paralelas.



Introducción
La alternativa: VLIW

 Varias operaciones que pueden ser

ejecutadas en paralelo (ILP) se
empaquetan en una instrucción
larga, una por cada UF disponible.

 La detección del paralelismo la hace

el compilador (off-line).
 Luego de la captación y

decodificación de una instrucción, las
operaciones contenidas son emitidas
en paralelo.

 Si el compilador no encuenbtra

instrucciones, coloca NOP. Depende
del ILP.



CACHE

No existe HW de detección



Introducción
Ventajas VLIW
 Hardware simple.
 Puede incrementarse el número de unidades funcionales (UFs) sin

agregar hardware de detección adicional.

 Bajo consumo de potencia.
 Los buenos compiladores pueden detectar paralelismo según un
análisis global del programa completo, por lo tanto se elimina el
problema de la ventana de ejecución.



Introducción
Desventajas VLIW
✗ Gran número de registros visibles, necesarios para mantener

las UFs activas (operandos y resultados).

✗ Gran capacidad de transporte entre las UFs y los registros, y

entre los registros y la memoria.

✗ Gran ancho de banda entre el cache de instrucciones y la unidad

de captación, debido a las instrucciones largas.

 Baja densidad de código, debido a las operaciones vacías.
 Incompatibilidad binaria: si agrego UFs, el número de

operaciones simultáneas se incrementa, aumenta el ancho de la
instrucción, y por lo tanto el código binario anterior no se puede
ejecutar en la nueva máquina.



Arquitecturas VLIW
Principales técnicas utilizadas por
el compilador
El compilador debe alterar la secuencialidad del código (sin alterar el
resultado) para mejorar el ILP, y explotar así el paralelismo disponible
en la máquina (MLP).
El problema, como siempre, son los saltos condicionales.
Estas técnicas son útiles en superescalares, pero acá son
fundamentales, ya que no existe detección por hardware. Las
principales son:
Loop Unrolling (para repeticiones [FOR/WHILE])
Trace Scheduling (para bifurcaciones [IF/ELSE])

Recordar el teorema de Dijkstra, base de la programación estructurada

Secuencia, Bifurcación y Repetición



Arquitecturas VLIW - Técnicas de compilación
Loop Unrolling - Ejemplo
for(i=959;i>=0;i--)
x[i] = x[i] + s;

Datos: x es un array y s una
cte., ambos en punto flotante
doble precisión (64 bits).

UF segmentadas:
2 memoria (2c para LOAD o
STORE double)
2 FP (3c para ADD double)
1 enteros/salto (1c)
R1 contiene la dirección del
último elemento de x, y F2
contiene el valor de s.
Secuencial: 7680c (960x8)
VLWI: 5760c (960x6)
S=8/6=1,33



Desplazado 8 porque ya se hizo la resta



for(i=959;i>=0;i-=2){
x[i] = x[i] + s;
x[i-1] = x[i-1] + s;}

Loop unrolling

x2

VLIW utiliza más Registros
Explícitos (F6).
Secuencial: 6720c (14x480)
VLWI: 2880c (6x480)
S=14/6=2,6
[Sacc=7680/2880=2.66]
Mejora también el
secuencial!



for(i=959;i>=0;i-=3){
x[i] = x[i] + s;
x[i-1] = x[i-1] + s;
x[i-2] = x[i-2] + s;
}



Loop unrolling

x3

Secuencial: 6400c
(20x320)
VLWI: 2240c (7x320)
S=20/7=2,85

Unrolling x4: 1680c
Unrolling x6: 1280c

Loop unrolling

x8

for(i=959;i>=0;i-=2){
x[i] = x[i] + s; x[i-1] = x[i-1] + s;
x[i-2] = x[i-2] + s; x[i-3] = x[i-4] + s;
x[i-4] = x[i-4] + s; x[i-5] = x[i-5] + s;
x[i-6] = x[i-6] + s; x[i-7] = x[i-7] + s;
}

Serían necesarios
2x(16+1) registros. Si
tengo 32 no alcanza...
Notar que aumenta
mucho el tamaño del
programa (antes 5 inst,
ahora 45).



VLWI: 1080c (S~=7)

Loop unrolling

xn

TERMINAR:
Existe un nivel óptimo de unrolling.
Aceleración máxima vs. optimización de recursos.
Graficar S=f(n).
En este ejemplo debería resultar que el n óptimo es 10.
Cuánto vale Smax? Cuántos registros son necesarios?

PREGUNTA: Es correcto que con 5 unidades funcionales consiga S>5?



Arquitecturas VLIW - Técnicas de compilación
Trace Scheduling

Se trata de una técnica de compilación que realiza predicción de
bifurcaciones (compile time branch prediction). [IF/ELSE]
Permite buscar instrucciones independientes más allá de saltos
condicionales.

Se realiza en tres pasos:
1. Trace selection
2. Instruction scheduling
3. Replacement and compensation



Trace Scheduling
Ejemplo
if(c!=0)b=a/c;
else{b=0; h=0;}
f=g+h;



c!=0 ... 14c
c=0 ... 11c



Trace Scheduling
Ejemplo (cont)
1. Trace selection
Se selecciona la secuencia mas probable (trace), utilizando predicción
de saltos durante la compilación.
Se puede mejorar con profiling (ejecución del programa con
secuencias típicas de entrada y recolección de estadísticas respecto
de los saltos).
2. Instruction scheduling
Se reacomodan las operaciones del trace más probable en una nueva
secuencia de instrucciones largas del procesador.



2 UF PF sin usar

Trace Scheduling
Ejemplo (cont)
3. Replacement and compensation
Se reemplaza el trace original con la nueva secuencia.
Se agrega código adicional a ejecutarse en caso que la predicción
falle (no alcanza con agregar el trace no elegido!). El resultado debe
ser el mismo.
MAL

BIEN



Si acertó ... 5c ... S=14/5=2.8
Si no acertó ... 6c ... S=11/6=1.8



Código de compensación

Trace Scheduling
Características principales

No es lo mismo que la ejecución especulativa de los superescalares.
Es una optimización del compilador tal que el camino más probable
se ejecute más rápido, a expensas de hacer más lento al menos
probable.
Siempre se toma el camino correcto. Si no es el predicho por el
compilador, la ejecución será más lenta a causa del código de
compensación.
Esto no implica que el procesador VLIW no pueda utilizar predicción
de saltos y ejecución especulativa para mejorar el rendimiento del
pipeline.



Arquitecturas VLIW
Algunos ejemplos actuales

EMBEDDED:
 Philips Trimedia (nxp.com): DSP multimedia.
 Texas TMS320C6xxx (ti.com): DSP multimedia.

DESKTOP/SERVER:
 Transmeta Crusoe y Eficeon (transmeta.com): x86 compatible por
Code Morphing, low power, mobile.
 Intel & HP: EPIC (Explicitly Parallel Instruction Computing) ->
Arquitectura IA-64 (Itanium e Itanium 2).



La arquitectura IA-64

Desarrollada por Intel y Hewlett-Packard. No es un VLIW puro. Lo
llaman EPIC (Explicit Parallel Instruction Computing) processor.
Características VLIW:
 Detección del ILP por compilador.
 Instrucción larga (128 bits con 3 operaciones).
Características propias:
 Template.
 Ejecución con predicados.
 Carga especulativa.



Arquitectura IA-64
Organización general

Los registros (enteros y fp) son de 64 bits.
Los registros de predicado son de 1 bit.
8 o más unidades funcionales.



Arquitectura IA-64
Formato de instrucciones

5-bits

14

6

7

7

7

41

Cada instrucción contiene 3 operaciones de 41 bits y un template de
5. No quiere decir que las tres operaciones se puedan ejecutar en
paralelo, eso lo indica el template. Cada operación tiene un código de
14 bits, una dirección de registro de predicado de 6 bits (para los 64
registros) y 3 direcciones de registros de 7 bits (tiene 128 registros).



Arquitectura IA-64
Template
La 'plantilla' indica qué instrucciones pueden ejecutarse en paralelo,
conectando a su vez con instrucciones vecinas, por lo que
operaciones de diferentes instrucciones pueden ejecutarse
simultáneamente.
No es necesario dejar operaciones sin utilizar (NOP), mejorando la
densidad del código.
Mejora la compatibilidad binaria, ya que puedo agregar UFs sin
cambiar las instrucciones.
Si, según el tremplate, existen más operaciones listas para ser
ejecutadas que UFs disponibles, se ejecutan secuencialmente.
La programación en assembler es casi imposible.



Arquitectura IA-64
Ejecución con predicado
Cada operación puede referirse a un predicado (registro de 1 bit).
Sólo se realiza el commit de la operación si el predicado vale 1. Una
operación sin predicado se ejecuta incondicionalmente.
Sintaxis:

<Pi> INSTRUCCION

Asignación de predicados: Si la expresión es verdadera
Pj=1,Pk=0. Si es falsa Pj=0,Pk=1.

Pj,Pk = Expresión.

Asignación predicada de predicados:

<Pi> Pj,Pk = Expresión.

Ejemplo de utilización: Branch predication.



Arquitectura IA-64
Branch predication
No confundir con branch prediction. Es una forma de ejecución
condicional.
Se dejan ejecutar en paralelo las dos ramas de un salto condicional,
antes de conocer la condición. Se hace el commit de la rama correcta
(con predicados) al conocerse la condición.
Un paso más allá de trace scheduling, en que se perdía tiempo
adicional si se selecciona el trace incorrecto.
Técnica de compilación muy agresiva.
if (a!=0)
j=j+1;
else
k=k+1;

P1,P2=EQ(R0,#0)
<P1> ADDI R2,R2,#1
<P2> ADDI R1,R1,#1
// Las 3 ejecutan en 1 ciclo



Arquitectura IA-64
Carga especulativa
Permite adelantar cargas desde memoria, incluso fuera de los límites
del bloque, y manejarla más eficientemente si produce un page fault.



Arquitectura IA-64
Conclusiones
La arquitectura presenta algunas características interesantes que
merecen ser resumidas:
Tienen un muy buen rendimiento con baja frecuencia de clock, lo que
le permite trabajar a bajas temperaturas.
Tienen una gran memoria
  • Links de descarga
http://lwp-l.com/pdf12481

Comentarios de: Procesadores de palabra de instrucción muy larga (VLIW) v.2012 (0)


No hay comentarios
 

Comentar...

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad