Arquitectura de computadoras infraestructura de software
This presentation is the property of its rightful owner.
Sponsored Links
1 / 47

Arquitectura de Computadoras Infraestructura de software PowerPoint PPT Presentation


  • 82 Views
  • Uploaded on
  • Presentation posted in: General

Arquitectura de Computadoras Infraestructura de software. ITCR SSC – I Semestre 2012. Prueba corta #1. Aspectos básicos sobre los ciclos de búsqueda y ejecución de instrucciones Además formule las instrucciones en un lenguaje simbólico por ejemplo: mov A, (940 ). La semana anterior….

Download Presentation

Arquitectura de Computadoras Infraestructura de software

An Image/Link below is provided (as is) to download presentation

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.


- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -

Presentation Transcript


Arquitectura de computadoras infraestructura de software

Arquitectura de ComputadorasInfraestructura de software

ITCR SSC – I Semestre 2012


Prueba corta 1

Prueba corta #1

  • Aspectos básicos sobre los ciclos de búsqueda y ejecución de instrucciones

  • Además formule las instrucciones en un lenguaje simbólico por ejemplo: mov A, (940)


La semana anterior

La semana anterior…

  • Conceptos introductorios sobre Organización y Arquitectura de Computadoras:

    • Definiciones

    • Modelo de Von Neumann

    • Pasos para la ejecución de instrucciones (ciclo de búsqueda, ciclo de ejecución)


Algunos otros aspectos

Algunos otros aspectos…

Conceptos de Organización y Arquitectura de Computadoras


Organizaci n a nivel de bloques y buses

Organización a Nivel de Bloques y Buses

  • Modelo Von Neumann ampliado

    • Bus: Conjunto de líneas común a varios bloques que permite la comunicación entre ellos.


Interrupciones

Interrupciones

  • Mecanismo por el cual otros módulos pueden alterar la secuencia normal de programa

  • Ejemplo:

    • I/O: Del controlador E/S (dato en memoria)


Ejemplo

Ejemplo


Arquitectura de buses tradicional

Arquitectura de Buses Tradicional


Arquitectura de buses de altas prestaciones

Arquitectura de Buses de Altas Prestaciones


Para recordar powermacg5

Para recordar… PowerMacG5


Para recordar sony ps2

Para recordar… Sony PS2


Conexi n con el sistema operativo

Conexión con el Sistema Operativo


Arquitectura de computadoras

Arquitectura de Computadoras

Infraestructura de software


Contenidos

Contenidos

  • Distintos niveles de abstracción

  • Infraestructura de software

    • Ensamblador

    • Linker

    • Loader

    • Lenguajes de Alto nivel

    • Simuladores

    • Relación con Sistema Operativo


Niveles de abstracci n

Niveles de abstracción

6. Nivel de Usuario

  • A este nivel encontramos las «aplicaciones»

  • Por ejemplo:

    • Procesadores de Texto

    • Paquetes gráficos

    • Juegos

  • Los niveles «más bajos» son completamente invisibles al usuario final


Niveles de abstracci n1

Niveles de abstracción

5. Lenguajes de Alto Nivel

  • Consisten en lenguajes como C++, C#, JAVA, Lisp. Pascal

  • Comprenden distintos paradigmas de programación (imperativo, funcional, lógico, orientado a objetos)

  • Dichos lenguajes son traducidos (compiladores e intérpretes) a un lenguaje que la máquina pueda entender.

  • Los lenguajes compilados se traducen en lenguaje ensamblador y luego se montan en código máquina (en este momento se pasa al siguiente nivel de abstracción)

  • A pesar de que un programador debe saber acerca de los tipos de datos y las instrucciones disponibles para esos tipos, no necesita saber acerca de cómo estos tipos se aplican en realidad.


Niveles de abstracci n2

Niveles de abstracción

4. Lenguajes ensamblador

  • Comprende algún tipo de lenguaje ensamblador (recordemos que varían de acuerdo a la arquitectura)

  • Los lenguajes compilados (de alto nivel) se traducen en primera instancia en ensamblador, para luego ser traducidos a lenguaje máquina


Niveles de abstracci n3

Niveles de abstracción

3. Software del sistema

  • Trata con las instrucciones del sistema operativo.

  • En este nivel es responsable de los procesos de:

    • Multiprogramación,

    • Protección de la memoria,

    • La sincronización procesos,

    • y otras funciones importantes.

  • Por lo general, las instrucciones producto de la traducción del lenguaje ensamblador a lenguaje de máquina pasan a través de este nivel sin modificar


Niveles de abstracci n4

Niveles de abstracción

2. Arquitectura del conjunto de instrucciones (ISA), o nivel de la máquina

  • Consiste en el lenguaje de máquina reconocido por la arquitectura particular de un sistema

  • Los programas escritos en lenguaje máquina pueden ser ejecutados directamente por los circuitos electrónicos sin ninguna necesidad de compiladores, traductores o compiladores.


Niveles de abstracci n5

Niveles de abstracción

1. Nivel de control

  • Una unidad de control asegura que las instrucciones se decodifican y se ejecuta correctamente y que los datos se mueve donde y cuando debe ser.

  • La unidad de control interpreta las instrucciones de máquina, una a la vez, desde el nivel superior, provocando las diversas acciones requeridas.

  • Pueden estar impresas/escritas en el hardware (hardwired /cableadas) o microprogramadas

  • Para el caso de las unidades de control escritas en el hardware, las señales de controlprovienen directamente de los bloques de componentes de lógica digital, por lo tanto es de suponer que son sumamente rápidas por estar basadas en componentes físicos.


Niveles de abstracci n6

Niveles de abstracción

1. Nivel de control

  • La otra opción, consiste en las unidades de control microprogramadas.

  • En este caso, se cuenta con un programa escrito en leguaje de bajo nivel implementado directamente por el hardware.

  • Como es de suponer, son populares ya que se pueden modificar con «relativa facilidad», no obstante, como era de esperar, esta capa adicional; y la traducción respectiva produce una ejecución de instrucciones mucho más lenta.


Niveles de abstracci n7

Niveles de abstracción

0. Lógica digital

  • En este nivel encontramos los componentes físicos de un sistema computacional, compuertas y cables.

  • Representan los principales bloques de componentes, los cuales proveen las distintas implementaciones de lógica matemática, comunes en todos los sistemas computacionales.


Ensamblador linker y loader

Ensamblador, Linker y Loader

Conceptos y generalidades


Ensamblador linker y loader1

Ensamblador, Linker y Loader


Ensamblador linker y loader2

Ensamblador, Linker y Loader

  • Compilador

    • Traduce un programa implementado en un lenguaje de alto nivel a lenguaje ensamblador

  • Ensamblador

    • Convierte programas en lenguaje ensamblador en archivos objeto

      • Los archivos objeto contienen una combinación de instrucciones máquina, datos, e información necesario para colocar dichas instrucciones en memoria, y de una manera adecuada.


Ensamblador

Ensamblador

  • Son necesarios para:

    • Traducir las instrucciones de ensamblado y pseudo-instrucciones en instrucciones de máquina

    • Convertir números decimales, otros; especificados porprogramador en binario.

  • Por lo general, los ensambladores hacer dos «pasadas» sobre el archivo de ensamblado

    • Primer paso: lee cada línea y las etiquetas de los registros en una tabla de símbolos

    • Segundo paso: utiliza la información en la tabla de símbolos para producir código de máquina para cada línea


Formato del archivo de objeto

Formato del archivo de objeto

  • El encabezado; describe el tamaño y la posición del otras partes del archivo.

  • Segmento de texto; contiene las instrucciones de la máquina

  • Segmento de datos; contiene la representación binaria de los datos en archivo de ensamblado

  • información de reubicación; que identifica las instrucciones y los datos que dependen de las direcciones absolutas

  • Tabla de símbolos asociados con las etiquetas de direcciones externas y listas de referencias sin resolver

  • Información de depuración


Procesos para producir un archivo ejecutable

Procesos para producir un archivo ejecutable


Procesos para producir un archivo ejecutable1

Procesos para producir un archivo ejecutable


Linker vinculador enlazador

Linker (vinculador, enlazador)

  • Herramienta que combina los archivos de objetos producidos por compilación separada o ensamblado y crea un archivo ejecutable

  • Tres tareas

    • Busca en el programa para encontrar rutinas de librerías utilizadas por los programas, por ejemplo printf(), rutinas matemáticas, ...

    • Determina las posiciones de memoria que el código de cada módulo podría ocupar y traslada estas instrucciones porajuste las referencias absolutas

    • Resuelve las referencias de los archivos


Loader cargador

Loader (cargador)

  • Parte del sistema operativo que trae un archivo ejecutable que residen en el disco hacia la memoria e inicia su ejecución

  • Pasos

    • Leer el encabezado del archivo ejecutable para determinar el tamaño de segmentos de texto (instrucciones) y datos

    • Crear un nuevo espacio de direcciones para el programa

    • Copiar las instrucciones y los datos en el espacio de direcciones

    • Copiar los argumentos pasados ​​al programa en la pila

    • Inicializa los registros de máquina, incluyendo la pila (stack ptr)

    • Salta a una rutina de inicio que copia los argumentos de programa dela pila a los registros y llama a larutina principal


M todos num ricos

MÉTODOS NUMÉRICOS

Aritmética de la computadora

(repaso sobre aspectos básicos)


Aritm tica de la computadora recordemos

Aritmética de la computadora (recordemos…)

  • El usuario se comunica con la computadora en sistema decimal, es decir, introduce en ella y extrae de ella números en base decimal.

  • Al recibir los datos, para poder trabajar con ellos, la computadora los convierte al sistema binario, su lenguaje natural de operación.

  • Todas las operaciones se efectúan en binario y los resultados obtenidos, antes de ser entregados al usuario, la máquina los convierte al sistema decimal.

  • Claro está que la computadora realiza estos procesos a enormes velocidades, de manera que el usuario no se entera de lo que sucede del proceso


Aritm tica de la computadora recordemos1

Aritmética de la computadora (recordemos…)

  • Sin embargo, al efectuar las conversiones y realizar los cálculos se suscitan pequeños errores que, si no se prevén, pueden propagarse y arrojar resultados muy inexactos o totalmente absurdos.

  • Por eso es tan importante el entender la aritmética de las computadoras e identificar las situaciones en que pueden ocurrir errores severos.

  • La operación interna de una computadora se basa en la aritmética binaria, en la que la base es 2 y sólo hay dos símbolos: 0 y 1, pues la memoria de la máquina consiste en un vasto número de dispositivos de registro magnético y electrónico, cada uno de los cuales sólo puede presentar uno de dos posibles estados: magnetizado en un sentido, representando al cero, o magnetizado en el otro sentido, representando al uno.


Aritm tica de la computadora recordemos2

Aritmética de la computadora (recordemos…)

  • Cada dispositivo magnético es un dígito binario, denominado bit (abreviatura de "binary digit").

  • Los bits se agrupan en unidades llamadas palabras, las cuales pueden contener 8, 16, 32 o 64 bits, dependiendo de la computadora de que se trate

  • También se utilizan la unidades denominadas bytes, constituidos generalmente por 8 bits, y utilizados como particiones de palabras, para representar caracteres. Así, por ejemplo, una palabra de 32 bits consta de 4 bytes.

  • La manera en que se usan los bits para registrar los números enteros y los números fraccionarios, varía en función del diseño de la computadora


Algunos n mero para recordar

Algunos número para recordar…


Primero un repaso n meros enteros sin signo

Primero, un repaso, “Números enteros sin signo”

  • Resolvamos lo siguiente:

    Convertir 147 decimal a binario

Si leemos los remanentes de abajo hacia arriba tenemos


Primero un repaso n meros enteros sin signo1

Primero, un repaso, “Números enteros sin signo”

  • Resolvamos lo siguiente:

    Convertir 217 decimal abase 3


Primero un repaso n meros enteros sin signo2

Primero, un repaso, “Números enteros sin signo”

  • Resolvamos lo siguiente:

    Convertir C5F (16) a base 10

    = 12 * (16^2) + 5 (16^1) + 15 (16^0)

    = 12 * 256 + 5 * 16 + 15 * 1

    = 3072 + 80 + 15

    = 3167


Ejercicios

Ejercicios

  • Convertir a binario los números decimales: 321, 1462, 205, 1023, 1024, 135, 45 y 967

  • Convertir a decimal los números binarios: 111001, 101000, 100000001, 01111000, 0000011 y 10101

  • Convertir a base tres los números decimales 76, 458 y 222

  • Convertir a base 16: 3197 (10), 219 (10), 6560 (10), 110 (2), 1001011 (2)


Para la pr xima semana

Para la próxima semana…

  • Analizar y repasar los conceptos correspondientes a la Aritmética para computadoras

    • Repaso Sistemas Numéricos

    • Diseño general de una ALU

    • Enteros con y sin signo

    • Suma, resta y operaciones lógicas

  • Lectura complementaria (se adjunta en el Blog y TEC Digital)


Arquitectura de computadoras infraestructura de software

FIN


  • Login