Descargar

Dependencias para el paralelismo en un Computador (página 2)

Enviado por Pablo Turmero


Partes: 1, 2
edu.red DEPENDENCIAS DE CONTROL Ejemplo: En ambos casos no sabemos cual será la próxima instrucción a ser ejecutada después del test. Pero, en el primer caso no hay dependencia de control, y en el segundo caso sí la hay. ¿Por qué? for (i=0;i< 0) a[i] = 1; }

for (i=1;i< 0) a[i] = 1; } 11

edu.red DEPENDENCIAS DE RECURSOS Tenemos dependencias de recursos cuando recursos compartidos del procesador (ej. ALU, UF coma flotante, buses, etc.) son demandados por instrucciones diferentes al mismo tiempo.

Ejemplo: Dependencias por ALU Dependencias de almacenamiento S3 S4 Ejemplo:

S1: load R1, A S2: load R2, B S3: add R3,R1,R2 S4: sub R4,R1,R2 12

edu.red La transformación de código secuencial en paralelo puede realizarse: Manualmente por el programador (paralelismo explícito). Automáticamente por el compilador (paralelismo implícito). En ambos casos, el “particionamiento” del código (decomposition) es un paso clave. El particionamiento o división del código determina sí (y cómo) un segmento de código puede ser ejecutado en paralelo o en un orden en particular. La detección de segmentos paralelos requiere la verificación de las relaciones de dependencia. CONDICIONES PARA EL PARALELISMO 13

edu.red Conjunto de condiciones formales que determinan si dos procesos (segmentos de programa) pueden ser ejecutados en paralelo.

Ii : Conjunto de variables de entrada al proceso Pi (read set). Oi : Conjunto de variables de salida del proceso Pi (write set). “Variables”: operandos a ser loaded/stored en registros o posiciones de memoria. CONDICIONES DE BERNSTEIN 14

edu.red CONDICIONES DE BERNSTEIN Consideremos los procesos P1 y P2 y sus conjuntos de entrada (I1, I2) y salida (O1, O2)

Condiciones de Bernstein (dependencias de datos) I1 n O2 = 0 (antidependencia) I2 n O1 = 0 (flujo) O1 n O2 = 0 (salida)

Si se verifican las tres condiciones, P1 y P2 pueden ejecutarse en paralelo, esto lo denotamos como :

P1 || P2 15

edu.red CONDICIONES DE BERNSTEIN En resumen, si P1 || P2 el orden de ejecución de dos procesos es irrelevante, en tanto que: La salida de uno no es usada como entrada por el otro No escriben sobre las mismas variables de salida

Propiedades de la relación de paralelismo || : Conmutativa: Pi || Pj <=> Pj || Pi NO transitiva: Pi || Pj and Pj || Pk =/> Pi || Pk Asociativa: (Pi || Pj) || Pk => Pi || (Pj || Pk)

Por tanto, no es una relación de equivalencia. 16

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Detectar que instrucciones del siguiente código pueden ejecutarse concurrentemente Instrucción 1 x:=y+1 Instrucción 2 y:=x-2 Instrucción 3 z=a+b-7

17

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Detectar que instrucciones del siguiente código pueden ejecutarse concurrentemente Lo primero es establecer qué variables se acceden en modo lectura. En las instrucciones vemos que son: Para la instrucción 1 es la variable "y”. Para la instrucción 2 es la variable "x”. Para la instrucción 3 son las variables "a", "b”. También necesitaremos saber qué variables se acceden en modo escritura. Son las siguientes:  Para la instrucción 1 es la variable "x”. Para la instrucción 2 es la variable "y”. Para la instrucción 3 es la variable "z".

18 I1 x:=y+1 I2 y:=x-2 I3 z=a+b-7

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Ahora aplicamos las tres condiciones: Condición 1: La intersección entre las variables de lectura de un conjunto de instrucciones C1 y las variables de escritura de un conjunto C2 debe ser vacía. Instrucciones 1 y 2 ? No cumple la condición

Instrucciones 1 y 3 ? Cumple la condición

Instrucciones 2 y 3 ? Cumple la condiciónte

19 I1 x:=y+1 I2 y:=x-2 I3 z=a+b-7

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Condición 2: La intersección entre las variables de escritura de un conjunto de instrucciones C1 y las variables de lectura de un conjunto C2 debe ser vacía. Instrucciones 1 y 2 ? No cumple la condición

Instrucciones 1 y 3 ? Cumple la condición

Instrucciones 2 y 3 ? Cumple la condición

20 I1 x:=y+1 I2 y:=x-2 I3 z=a+b-7

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Condición 3: La intersección entre las variables de escritura de un conjunto de instrucciones C1 y las variables de escritura de un conjunto C2 debe ser vacía. Instrucciones 1 y 2 ? Cumple la condición

Instrucciones 1 y 3 ? Cumple la condición

Instrucciones 2 y 3 ? Cumple la condición

21 I1 x:=y+1 I2 y:=x-2 I3 z=a+b-7

edu.red CONDICIONES DE BERNSTEIN: Ejemplo Ahora podemos saber qué instrucciones pueden ejecutarse concurrentemente 22 I1 x:=y+1 I2 y:=x-2 I3 z=a+b-7

edu.red CONDICIONES DE BERNSTEIN Observar que la condición Ii n Ij != 0 no impide el paralelismo. Si tenemos n procesos, la violación de alguna de las condiciones impide total o parcialmente la ejecución en paralelo de P1…Pn 3*n*(n-1)/2

Qué ocurre con las otras dependencias? Cualquier instrucción que dependa de condiciones de tiempo de ejecución no puede ponerse en forma paralela (subscripts, tests, Branches cond. …). Los ficheros pueden tratarse e introducirse en los conjuntos de entrada I y salida O. 23

edu.red CONDICIONES DE BERNSTEIN Ejemplo: Detectar el paralelismo del siguiente código. Suponiendo que cada instrucción requiere 1 paso (no pipeline). Suponiendo que tenemos dos sumadores disponibles (pipeline). P1: C = D*E P2: M = G+C P3: A = B+C P4: C = L+M P5: F = G/E 24

edu.red CONDICIONES DE BERNSTEIN 25

edu.red CONDICIONES DE BERNSTEIN 26

edu.red CONDICIONES DE BERNSTEIN Generalización: Las condiciones de Bernstein a nivel de instrucción pueden extenderse a niveles superiores, como segmentos de código, subrutinas, procesos, programas. Las dependencias a niveles altos se infieren de las dependencias a niveles inferiores. 27

Partes: 1, 2
 Página anterior Volver al principio del trabajoPágina siguiente