Traduciendo y ejecutando programas - PowerPoint PPT Presentation

1 / 51
About This Presentation
Title:

Traduciendo y ejecutando programas

Description:

Traduciendo y ejecutando programas El camino de un programa en C Compilador Compilador Traduce de lenguaje C a lenguaje ensamblador. Hola Mundo en C # include – PowerPoint PPT presentation

Number of Views:74
Avg rating:3.0/5.0
Slides: 52
Provided by: TESI5
Category:

less

Transcript and Presenter's Notes

Title: Traduciendo y ejecutando programas


1
Traduciendo y ejecutando programas
2
El camino de un programa en C
3
Compilador
  • Compilador
  • Traduce de lenguaje C a lenguaje ensamblador.

4
Hola Mundo en C
  • include ltstdio.hgt
  • void main ()
  • printf ("Hola mundo\n")

5
Ensamblador (BCC55)
  • ifdef ??version
  • if ??version GT 500H
  • .mmx
  • endif
  • endif
  • model flat
  • ifndef ??version
  • ?debug macro
  • endm
  • endif
  • ?debug S "hola_mundo.c"
  • ?debug T "hola_mundo.c"
  • _TEXT segment dword public use32 'CODE'
  • _TEXT ends
  • _DATA segment dword public use32 'DATA'
  • _DATA ends
  • _BSS segment dword public use32 'BSS'
  • _BSS ends
  • DGROUP group _BSS,_DATA

6
Ensamblador (BCC55)
  • _TEXT segment dword public use32 'CODE'
  • _main proc near
  • ?live1_at_0
  • void main ()
  • push ebp
  • mov ebp,esp
  • printf ("Hola mundo\n")
  • _at_1
  • push offset s_at_
  • call _printf
  • pop ecx

7
Ensamblador (BCC55)
  • _DATA segment dword public use32 'DATA'
  • s_at_ label byte
  • s_at_0
  • db "Hola mundo",10,0
  • align 4
  • _DATA ends
  • _TEXT segment dword public use32 'CODE'
  • _TEXT ends
  • public _main
  • extrn _printfnear
  • ?debug D "c\Borland\BCC55\Include\_nfile.h"
    10459 6176
  • ?debug D "c\Borland\BCC55\Include\_null.h"
    10459 6176
  • ?debug D "c\Borland\BCC55\Include\_defs.h"
    10459 6176
  • ?debug D "c\Borland\BCC55\Include\_stddef.h"
    10459 6176
  • ?debug D "c\Borland\BCC55\Include\stdio.h"
    10459 6176
  • ?debug D "hola_mundo.c" 14910 22993
  • end

8
Programa Ensamblador
  • Acepta un programa en lenguaje ensamblador y
    genera un archivo objeto.
  • El archivo objeto contiene
  • Instrucciones en lenguaje de máquina.
  • Datos.
  • Información necesaria para cargar el programa en
    memoria.

9
Típico OBJ de Unix
  1. Encabezado. Describe el tamaño y posición de
    otras secciones del archivo objeto.
  2. Segmento de texto. Contiene el código en lenguaje
    máquina.
  3. Segmento de datos estáticos. Variables accesibles
    durante todo el programa (globales y variables
    static de C).
  4. Información de relocalización. Identifica
    instrucciones que dependen de direcciones
    absolutas.

10
Típico OBJ de Unix
  • Tabla de símbolos. Etiquetas que no han sido
    definidas como variables externas.
  • Información útil para un debugger. Permite
    asociar instrucciones de máquina con líneas del
    código fuente original.

11
Microsoft COFF
  • Common Object File Format.
  • Inicialmente definido para Unix V, fue extendido
    por Microsoft para Windows 3.1.
  • Se usa en todas las versiones de Windows de 32 y
    64 bits.

12
Microsoft COFF
13
Linker
  • Pega (link) varios archivos objeto compilados
    posiblemente por separado.
  • Resuelve referencias externas e internas.
  • En algunos sistemas como Windows, el linker
    relocaliza el código.
  • Produce un solo archivo ejecutable.

14
Relocalización
  • Ensamblador
  • bne t0, t1, brinco if t0 ! t1 goto
    brinco
  • brinco etc.
  • Lenguaje máquina
  • 1000 bne 8, 9, 1020
  • 1020 etc.

15
Relocalización
  • La instrucción
  • 1000 bne 8, 9, 1020
  • está asumiendo que va ser cargada en la
    dirección 1000.
  • Los sistemas operativos modernos (multiusuario
    y/o multitarea) cargan en memoria varios
    programas a la vez y pueden ser colocados en
    áreas distintas cada vez que corren.

16
Relocalización
  • La solución (para este caso) es hacer el brinco
    relativo.
  • 1000 bne 8, 9, 20
  • En general, hay que guardar información sobre
    dependencias en el código.

17
Ejemplo archivo objeto A
Encabezado Nombre Procedure A
Encabezado Tamaño de código 0x100
Encabezado Tamaño de datos 0x20
Segmento de texto Dirección Instrucción Significado
Segmento de texto 0 lw a0, 0(gp) a0 ? MemX
Segmento de texto 4 jal 0 call B
Segmento de texto
Segmento de datos 0 (X)
Segmento de datos
Información de relocalización Dirección Tipo de instrucción Dependencia
Información de relocalización 0 lw X
Información de relocalización 4 jal B
Tabla de símbolos Etiqueta Dirección
Tabla de símbolos X ---
Tabla de símbolos B ---
18
Ejemplo archivo objeto B
Encabezado Nombre Procedure B
Encabezado Tamaño de código 0x200
Encabezado Tamaño de datos 0x30
Segmento de texto Dirección Instrucción Significado
Segmento de texto 0 sw a1, 0(gp) MemY ? a1
Segmento de texto 4 jal 0 call A
Segmento de texto
Segmento de datos 0 (Y)
Segmento de datos
Información de relocalización Dirección Tipo de instrucción Dependencia
Información de relocalización 0 sw Y
Información de relocalización 4 jal A
Tabla de símbolos Etiqueta Dirección
Tabla de símbolos Y ---
Tabla de símbolos A ---
19
Ejemplo - relocalizando
  • El procedimiento A necesita encontrar la
    dirección de la variable X y del procedimiento B.
  • El procedimiento B necesita encontrar la
    dirección de la variable Y y del procedimiento A.
  • En MIPS, el segmento de texto comienza en la
    dirección 400,00016.
  • A se carga a partir de 400,00016 y como el código
    de A mide 10016, B se carga a partir de
    400,10016.

20
Ejemplo - relocalizando
  • El segmento de datos comienza en la dirección
    10,000,00016.
  • Los datos de A se cargan en 10,000,00016 y como
    miden 2016, los datos de B se cargan en
    10,000,02016.
  • El registro gp se inicializa en 10,008,00016.
  • Los datos de A se accesan con gp 8,00016.
  • Los datos de B se accesan con gp 7,98016.
  • Con esta información, el linker puede relocalizar
    el código y generar un archivo ejecutable.

21
Ejemplo - ejecutable
Encabezado Tamaño de código 0x300
Encabezado Tamaño de datos 0x50
Segmento de texto Dirección Instrucción
Segmento de texto 0x400,000 lw a0, 0x8000(gp)
Segmento de texto 0x400,004 jal 0x400100
Segmento de texto
Segmento de texto 0x400,100 sw a1, 0x8020(gp)
Segmento de texto 0x400,104 jal 0x400000
Segmento de texto
Segmento de datos Dirección
Segmento de datos 0x10,000,000 (X)
Segmento de datos
Segmento de datos 0x10,000,020 (Y)
Segmento de datos
22
Referencias externas
  • Se generan al compilar archivos por separado.
  • Archivo hola.c
  • void foo (void) // prototipo
  • void main ()
  • foo () // referencia externa

23
Referencias externas
  • Archivo mundo.c
  • include ltstdio.hgt
  • void foo ()
  • printf ("hola mundo\n")

24
Referencias externas
  • Compilación usando Borland C 5.5
  • bcc32 c hola.c
  • Compila sin ligar y genera hola.obj
  • bcc32 c mundo.c
  • Compila sin ligar y genera mundo.obj
  • bcc32 hola.obj mundo.obj
  • Invoca al linker y genera hola.exe

25
Archivos ejecutables
  • Definición del Merriam-Webster
  • Archivo que hace que una computadora realice
    tareas de acuerdo a instrucciones codificadas.
  • Formatos más comunes
  • a.out (Unix)
  • .com (CP/M y MS-DOS)
  • .exe (MS-DOS y Windows) formalmente llamado PE
    (Portable executable).

26
Microsoft PE
  • Portable Executable.
  • Formato
  • Encabezado EXE de MS-DOS (por compatibilidad).
  • Mini-programa MS-DOS This program cannot be run
    in DOS mode.
  • Encabezado PE.
  • Encabezados de las secciones.
  • Sección .text código.
  • Sección .data datos estáticos.

27
Microsoft PE
  1. Sección .edata tabla de símbolos exportados
    (usado por DLLs).
  2. Sección .idata tabla de símbolos importados.
  3. Sección .rdata datos de solo lectura (constantes
    y strings).
  4. Sección .tls variables globales que pueden ser
    accesadas como variables locales por hilos
    (threads).
  5. Sección .rsrc recursos como menús y diálogos.
  6. Sección .reloc información de relocalización.

28
Microsoft PE
29
Cargadores
  • Conocidos en inglés como loaders.
  • Carga el programa ejecutable en la memoria y le
    cede el control.
  • En algunos sistemas operativos como MS-DOS el
    cargador es el que relocaliza el código.

30
Cargador típico de Unix
  • Lee el ejecutable y determina el tamaño de los
    segmentos de texto y datos.
  • Crea un espacio de direcciones suficientemente
    grande para el texto y los datos.
  • Copia las instrucciones y datos a la memoria.
  • Copia los parámetros del programa principal (si
    es que existen) en la pila.

31
Cargador típico de Unix
  1. Inicializa los registros incluyendo el apuntador
    a la pila (sp).
  2. Brinca a una rutina de start-up que copia los
    parámetros en los registros y llama a la rutina
    principal.
  3. Cuando la rutina principal regresa, la rutina de
    start-up termina el programa con una llamada al
    sistema de exit.

32
Resumen
  • Compilador. Traduce el programa a lenguaje
    ensamblador.
  • Ensamblador. Genera un archivo objeto por cada
    archivo en ensamblador.
  • Linker. Resuelve referencias, relocaliza y genera
    un ejecutable.
  • Cargador. Carga el ejecutable en memoria y lo
    corre.
  • El compilador típico incluye los 3 primeros
    pasos.
  • El cargador es parte del sistema operativo.

33
Camino de un programa en Java
34
Compilador
  • El compilador de Java genera un archivo class por
    cada clase compilada.
  • El archivo class contiene
  • Tabla de métodos válidos con sus bytecodes.
  • Información extra, como la clase padre.
  • Los bytecodes son las instrucciones de la máquina
    virtual de Java (JVM) y son independientes del
    hardware.
  • Compila una vez, corre donde sea (compile once,
    run anywhere).

35
JVM
  • La máquina virtual de Java interpreta y ejecuta
    los bytecodes.
  • Algunas JVMs incluyen un compilador JIT
    (just-in-time) que compila los bytecodes a código
    máquina conforme el programa está corriendo.

36
(No Transcript)
37
Explicación
  • Algunos mnemónicos usan un prefijo
  • a dirección.
  • b byte (8 bits).
  • i entero (32 bits).
  • s short (16 bits).
  • I8 es una constante de 8 bits.
  • I16 es una constante de 16 bits.

38
Explicación
  • La JVM usa una pila para guardar resultados
    intermedios.
  • Los operandos se guardan en la pila, se hace la
    operación y se sacan.
  • El compilador sabe el tamaño máximo de la pila de
    operandos para cada método y le asigna espacio en
    el frame actual.

39
Explicación
  • TOS tope de la pila.
  • NOS siguiente posición debajo del TOS.
  • NNOS siguiente posición debajo del NOS.
  • pop. Quita el TOS.
  • pop2. Quita el TOS y el NOS.
  • push. Agrega un elemento a la pila.
  • Const se refiere al pool de constantes de la
    clase creado por la JVM al momento de correr.
  • Frame a las variables en el frame local del
    método.

40
Diferencias entre JVM y MIPS
  1. Para guardar resultados temporales MIPS usa
    registros, JVM una pila.
  2. Tamaño de instrucción MIPS 4 bytes, JVM de 1 a 5
    bytes para ahorrar espacio.
  3. JVM tiene seguridad integrada. Por ejemplo, en un
    arreglo, la JVM checa que la referencia al
    arreglo sea válida y que el índice esté dentro
    del límite.

41
Diferencias entre JVM y MIPS
  1. Para que el recolector de basura encuentre los
    apuntadores vivos, JVM tiene instrucciones
    distintas para operar con direcciones y para
    operar con enteros.
  2. JVM tiene instrucciones complejas como crear
    espacio para un arreglo o invocar un método.

42
Comparación entre JVM y MIPS
  • Compilar el siguiente código en C/Java a MIPS y
    JVM
  • while (savei k)
  • i 1

43
MIPS
  • s3 i, s5 k, s6 dirección de save
  • ciclo
  • sll t1, s3, 2 t1 i 4 / t1 tiene el
    offset
  • add t1, t1, s6 t1 apunta a savei
  • lw t0, 0(t1) t0 savei
  • bne t0, s5, Exit if savei ? k goto Exit
  • add s3, s3, 1 i
  • j ciclo goto ciclo
  • Exit

44
JVM
  • i, k y save son las primeras tres variables
    locales.
  • 0 aload_3 push variable local 3 (save)
  • 1 iload_1 push variable local 1 (i)
  • 2 iaload pop TOS y NTOS y push savei
  • 3 iload_2 push variable local 2 (k)
  • 4 if_icompne, Exit compara TOS y NTOS, los saca
    y brinca si no son iguales
  • 7 iinc, 1, 1 i
  • 10 go to 0 brinca al inicio (byte 0)

45
Comparación entre JVM y MIPS
  • MIPS 6 instrucciones, 24 bytes.
  • JVM 7 instrucciones, 13 bytes.
  • La diferencia es mayor si tomamos en cuenta que
    la JVM checa automáticamente que los accesos al
    arreglo estén dentro del rango.
  • Ciclo while modificado en MIPS para checar rangos
    ocupa 11 instrucciones, es decir, 44 bytes.

46
Ciclo while en MIPS
  • s3 i, s5 k, s6 dirección de save
  • s6 apunta a la lista de métodos legales para
    save
  • s6 4 apunta al tamaño del arreglo
  • s6 8 apunta a save0 (primer elemento)
  • lw t2, 4(s6) t2 tamaño del arreglo
  • ciclo
  • slt t0, s3, 0 if i lt 0
  • bne t0, zero, IndexOutOfBounds goto Error
  • slt t0, s3, t2 if i ? tamaño
  • beq t0, zero, IndexOutOfBounds goto Error

47
Ciclo while en MIPS
  • sll t1, s3, 2 t1 i 4 / t1 tiene el
    offset
  • add t1, t1, s6 t1 apunta a savei
  • lw t0, 8(t1) t0 savei
  • bne t0, s5, Exit if savei ? k goto Exit
  • add s3, s3, 1 i
  • j ciclo goto ciclo
  • Exit

48
Invocando métodos en Java
  • El compilador escoge el método apropiado
    dependiendo del tipo (clase) del objeto.
  • El compilador genera código para
  • Revisar que objeto no sea nulo, y en su caso
    brincar a una rutina de error.
  • Cargar la lista de métodos válidos para ese
    objeto. La primera palabra guarda un apuntador a
    esa tabla.
  • Cargar la dirección del método apropiado, dejando
    la dirección de regreso en la pila.
  • Brincar al inicio del método.

49
Compilado vs. Interpretado
  • Ventaja de un programa interpretado
    portabilidad.
  • Ventaja de un programa compilado rapidez de
    ejecución.
  • Los compiladores JIT tratan de reducir esa
    ventaja.

50
Compilado vs. Interpretado
51
Conceptos importantes
  • Compilador.
  • Ensamblador.
  • Linker.
  • Cargador o loader.
  • Relocalización.
  • Referencias internas.
  • Referencias externas.
  • Intérprete.
  • Compilador JIT (just-in-time).
Write a Comment
User Comments (0)
About PowerShow.com