ARQUITECTURA DE COMPUTADORAS
MATERIA: ARQUITECTURA DE COMPUTADORAS
REPORTE DE MICROPROCESADORES
AÑO ESCOLAR:2021-2022
CATEDRATICO
YASSER MARÍN LOMBAR
ESCOLARIDAD
ESCOLARIZADO
ESTUDIANTE
MARTÍNEZ MURRIETA JOSÉ IVÁN
NUMERO DE CONTROL
19TE0558
FECHA DE ENTREGA
22 DE JUNIO 2021
INTRODUCCIÓN
¿Qué es un procesador?
Lo primero que tendremos que definir es qué es un microprocesador para saber todo lo demás. El microprocesador es el cerebro de un ordenador o computadora, está compuesto por un circuito integrado encapsulado en un chip de silicio que lo componen millones de transistores. Su función es procesar los datos, controlar el funcionamiento de todos los dispositivos del ordenador, al menos de gran parte de ellos y lo más importante: se encarga de realizar las operaciones lógicas y matemáticas.
Si nos damos cuenta, todos los datos que circular por nuestra máquina son impulsos eléctricos, compuestos por señales de unos y ceros llamados bits. Cada una de estas señales se agrupan en un conjunto de bits que forman las instrucciones y los programas. El microprocesador es el encargado de dar sentido a todo esto realizando operaciones básicas: SUMA, RESTA, AND, OR, MUL, DIV, OPUESTO E INVERSO. Entonces tenemos que el microprocesador:
- Decodifica y ejecuta las instrucciones de los programas cargados en la memoria principal del ordenador.
- Coordina y controla todos los componentes que forman el ordenados y los periféricos que están conectados a este, mouse, teclado, impresora, pantalla, etc.
Los procesadores suelen ser actualmente de forma cuadrada o rectangular y se encuentran colocados sobre un elemento llamado zócalo fijado a la placa base. Esta se encargará de distribuir los datos entre el procesador y el resto de elementos conectados a ella.
Arquitectura de una computadora
En las siguientes secciones veremos todo la arquitectura de un procesador.
Arquitectura de Von Neumann
Desde la invención de los microprocesadores hasta día de hoy estos están basados en una arquitectura que divide el procesador en varios elementos que luego veremos. Esta recibe el nombre de arquitectura de Von Neumann. Es una arquitectura inventada en 1945 por el matemático Von Neumann que describe el diseño de un computador digital dividido en una serie de partes o elementos.
Los procesadores actuales aún están basados en su gran mayoría en esta arquitectura básica, aunque lógicamente se han introducido gran cantidad de elementos nuevos hasta contar con los extremadamente completos elementos que hoy día tenemos. Posibilidad de múltiples números en un mismo chip, elementos de memoria en varios niveles, procesador de gráficos incorporado, etc.
Partes internas de una computadora
Las partes básicas de una computadora según esta arquitectura son las siguientes:
- Memoria: es el elemento en donde se guardan las instrucciones que ejecuta el computador y los datos sobre los que operan las instrucciones. Estas instrucciones reciben el nombre de programa.
- Unidad Central de Proceso o CPU: es el elemento que ya hemos definido anteriormente. Es el encargado de procesar las instrucciones que le llegan de la memoria
- Unidad de entrada y salida: permite la comunicación con los elementos del exterior.
- Buses de datos: son las pistas, vías o cables que conectan físicamente los elementos anteriores.
Elementos de un microprocesador
Una vez definidas las partes principales de una computadora y habiendo entendido como circula la información por ella.
- Unidad de control (UC): es el elemento que se encarga de impartir las órdenes mediante las señales de control, por ejemplo, el reloj. Busca las instrucciones en la memoria principal y las pasa al decodificador de instrucciones para que se ejecuten. Partes internas:
- Reloj: genera una onda cuadrada para sincronizar las operaciones del procesador
- Contador de programa: contiene la dirección de memoria de la siguiente instrucción que se va a ejecutar
- Registro de instrucciones: contiene la instrucción que se está ejecutando actualmente
- Secuenciador: genera ordenes elementales para el procesamiento de la instrucción.
- Decodificador de instrucciones (DI): se encarga de interpretar y ejecutar las instrucciones que llegan, extrayendo el código de operación de la instrucción.
- Unidad aritmético lógica (ALU): se encarga de hacer los cálculos aritméticos (SUMA, RESTA, MULTIPLICACION, DIVISION) y operaciones lógicas (AND, OR, …). Partes internas.
- Circuito operacional: contienen los multiplexores y circuitos para hacer operaciones.
- Registros de entrada: se almacenan los datos y operado antes de entrar al circuito operacional
- Acumulador: almacena los resultados de las operaciones realizadas
- Registro de estado (Flag): almacena ciertas condiciones que deben ser tenidas en cuenta en operaciones posteriores.
- Unidad de coma flotante (FPU): este elemento no estaba en el diseño original de la arquitectura, posteriormente fue introducido cuando las instrucciones y cálculos se hicieron más complejos con la aparición de los programas representados gráficamente. Esta unidad se encarga de realizar las operaciones en coma flotante, es decir, números reales.
- Banco de registros y la memoria caché (Cache): los procesadores actuales cuentan con una memoria volátil que hace de puente desde la memoria RAM hasta la CPU. Esta es mucho más rápida que la memoria RAM y se encarga de acelerar los accesos del microprocesador a la memoria principal.
- Bus frontal (Front Side Bus, FSB): También se conoce como bus de datos, bus principal o bus de sistema. Es la vía o canal que comunica el microprocesador con la placa base, concretamente con el chip llamado puente norte o nothbridge. Este se encarga de controlar el funcionamiento del bus principal de la CPU, la RAM y los puertos d expansión como son los PCI-Express.Los términos utilizados para definir a este bus son “Quick Path Interconnect” para Intel y “Hypertransport” para AMD
- Bus trasero (Back Side BUS, BSB): este bus comunica la memoria cache de nivel 2 (L2) con el procesador, siempre y cuando esta no esté integrada en el propio núcleo de la CPU. En la actualidad todos los microprocesadores disponen de memoria cache integrada en el propio chip, por lo que este bus también forma parte del mismo chip.
Microprocesador de dos o más núcleos
En un mismo procesador no solamente tendremos estos elementos distribuidos en su interior, sino que además ahora se encuentran replicados. Dispondremos de varios núcleos de procesamiento o lo que es lo mismo varios microprocesadores dentro de la unidad. Cada uno de estos contará con su propia memoria caché L1 y L2, normalmente la L3 se reparte entre ellos, a pares o en conjunto.
Además de esto contaremos con una ALU, UC, DI y FPU para cada uno de los núcleos por lo que la velocidad y capacidad de procesamiento se multiplican en función de la cantidad de núcleos que tenga. También aparecen nuevos elementos dentro de los microprocesadores:
- Controlador de memoria integrado (IMC): Ahora con la aparición de varios núcleos el procesador cuenta con un sistema que le permite acceder directamente a la memoria principal.
- GPU integrada (iGP): la GPU se encarga del procesamiento de gráficos. Estos son en su mayoría operaciones de coma flotante con cadenas de bits de gran densidad, por lo que el procesamiento es mucho más complejo que los datos de programa normales. Debido a esto, existen gamas de microprocesador que implementan en su interior una unidad exclusivamente destinada al procesamiento de gráficos.
Algunos procesadores, como los AMD Ryzen, no integran tarjeta gráfica interna. Sólo sus APU 😉
Funcionamiento de un microprocesador
Un procesador funciona mediante instrucciones, cada una de estas instrucciones es un código binario de una determinada extensión que la CPU es capaz de entender.
Un programa, por tanto, es un conjunto de instrucciones y para ejecutarlo se debe realizar de forma secuencial, esto es, ejecutando en cada paso o período de tiempo una de estas instrucciones. Para ejecutar una instrucción hay varias fases:
- Búsqueda d la instrucción: traemos la instrucción desde la memoria al procesador
- Decodificación de la instrucción: la instrucción se divide en códigos más simple entendibles por la CPU
- Búsqueda de operados: con la instrucción cargada en la CPU hay que buscar el operador que corresponder
- Ejecución de la instrucción: se realiza la operación lógica o aritmética necesaria
- Almacenamiento del resultado: el resultado se almacena en la memoria caché
Cada procesador trabaja con un determinado conjunto de instrucciones, estas han ido evolucionando a la vez que los procesadores. La denominación de x86 o x386 se refiere al conjunto de instrucciones con las que un procesador trabaja.
Tradicionalmente a los procesadores de 32 bits se las ha llamado también x86, esto se debe a que en esta arquitectura han trabajado con este conjunto de instrucciones desde el procesador Intel 80386 que fue el primero en implementar una arquitectura de 32 bits.
Este conjunto de instrucciones es necesario actualizarlo para trabajar más eficientemente y con programas más complejos. A veces vemos que en los requisitos para que un programa se ejecute vienen un conjunto de siglas como SSE, MMX, etc. Estas son el conjunto de instrucciones con las que un microprocesador puede lidiar. Así tenemos:
- SSE (Streaming SIMD Extensions): dotaron a las CPU para trabajar con operaciones en coma flotante.
- SSE2, SSE3, SSE4, SSE5, etc: distintas actualizaciones de este conjunto de instrucciones.
Incompatibilidad entre procesadores
Todos recordamos cunado un sistema operativo de Apple o se podía ejecutar en un PC con Windows o Linux. Esto es debido al tipo de instrucciones de los distintos procesadores. Apple usada procesadores PowerPC, que trabajaban con unas instrucciones distintas a Intel y AMD. De esta forma existen varios diseños de instrucciones:
- CISC (Complex Instruction Set Computer): es la que utilizan Intel y AMD, se trata de utilizar un conjunto de pocas instrucciones, pero complejas. Tienen mayor consumo de recursos, al ser instrucciones más completas que necesitan varios ciclos de reloj.
- RISC (Reduced Instruction Set Computer): es la que utilizaban Apple, Motorola, IBM y PowerPC, estos son procesadores más eficientes al contar con más instrucciones, pero de menor complejidad.
Actualmente ambos sistemas operativos son compatibles porque Intel y AMD implementan una combinación de arquitecturas en sus procesadores.
Proceso de ejecución de una instrucción
- El procesador se reinicia al recibir una señal de RESET, de esta forma se prepara el sistema recibiendo una señal de reloj que determinará la velocidad del proceso.
- En el registro CP (contador de programa) se carga la dirección de memoria en la que empieza el programa.
- La unidad de control (UC) emite la orden para traer la instrucción que la RAM tiene almacenada en la dirección de memoria que hay en el CP.
- A continuación, la RAM envía el dato y este se coloca en el bus de datos hasta que se almacena en el RI (Registro de instrucción).
- La UC gestiona el proceso y la instrucción pasa al decodificador (D) para hallar el significado de la instrucción. Seguidamente esta pasa por la UC para ser ejecutada
- Una vez que se sabe cuál es la instrucción y qué operación se debe realizar, se cargan ambas en los registros de entrada (REN) de la ALU.
- La ALU ejecuta la operación y coloca el resultado en el bus de datos y al CP se le suma 1 para ejecutar la siguiente instrucción.
Como saber si un procesador es bueno
Para saber si un microprocesador es bueno o malo debemos fijarnos en cada uno de sus componentes internos:
Anchura del bus
La anchura de un bus determina el tamaño de los registros que pueden circular por él. Esta anchura debe coincidir con el tamaño de los registros del procesador. De esta forma tenemos que la anchura que tiene el bus representa el registro más grande que este es capaz de transportar en una sola operación.
Directamente relacionado con el bus estará también la memoria RAM, este debe ser capaz de almacenar cada uno de estos registros con la anchura que estos tengan (esto se llama ancho de palabra de la memoria).
Lo que tenemos actualmente en cuando a ancho de bus es 32 bits o 64 bits, es decir, podremos transportar, almacena y procesar de forma simultánea cadenas de 32 o 64 bits. Con 32 bits teniendo cada uno la posibilidad de ser 0 o 1 podremos direccionar una cantidad de memoria de 232 (4GB) y con 64 bits 16 EB Exabytes. Esto no significa que tengamos 16 Exabytes de memoria en nuestro equipo, sino que representa la capacidad de dirección y utilizar una determinada cantidad de memoria. De aquí sale la famosa limitación de los sistemas de 32 bits de direccionar solamente 4 GB de memoria.
En definitiva, mientras más ancho de bus más capacidad de trabajo
Memoria caché
Estas memorias son mucho más pequeñas que la memoria RAM pero mucho más rápidas. Su función es almacenar las instrucciones que justamente se van a procesar o las últimas procesadas. Mientras más memoria caché, mayor será la velocidad de transacciones que la CPU pueda coger y soltar.
Aquí debemos de ser conscientes de que todo lo que llega al procesador provienen del disco duro, y este se puede decir que es tremendamente más lento que la memoria RAM y aún mucho más que la memoria caché. Es por este motivo por lo que se diseñaron estas memorias en estado sólido, para solución el gran cuello de botella que es el disco duro.
Y nos preguntaremos, porqué entonces no fabrican solamente memorias cachés de gran tamaño, la respuesta es simple, porque son muy caras.
Velocidad interna del procesador
La velocidad internet es casi siempre es lo más llamativo cuando miramos un procesador. “El procesador va a 3,2 GHz”, pero, ¿qué es esto? La velocidad es la frecuencia de reloj a la que trabajar el microprocesador. Cuanto mayor sea esta velocidad más cantidad de operaciones por unidad de tiempo será capaz de realizar. Esto se traduce en mayor rendimiento, por eso mismo existe la memoria caché, para acelerar la toma de datos por parte del procesador para hacer siempre el máximo de operaciones por unidad de tiempo.
Esta frecuencia de reloj viene dada por una señal de onda cuadrada periódica. El tiempo máximo para hacer una operación es de un período. El periodo es la inversa de la frecuencia.
Pero no todo es velocidad. Hay muchos componentes que influyen en la velocidad de un procesador. Si por ejemplo tenemos un procesador de 4 núcleos a 1,8 GHz y otro de un solo núcleo a 4,0 GHz, es seguro que el de cuatro núcleos es más rápido.
Velocidad del Bus
Al igual que es importante la velocidad del procesador, también es importante la velocidad del bus de datos. La placa base siempre trabaja a una frecuencia de reloj mucho menor que la del microprocesador, por este motivo vamos a necesitar un multiplicador que ajuste estas frecuencias.
Si por ejemplo tenemos una placa base con un bus a una frecuencia de reloj de 200 MHz un multiplicador de 10x alcanzará una frecuencia de CPU de 2 GHz.
HISTORIA DEL MICROPROCESADOR
La gran innovación del circuito integrado es la de hospedar en el mismo espacio los componentes (transistores) que realizan los cálculos y los conductores (circuitos) que transfieren la corriente de un componente a otro. Antes de la invención del circuito integrado (también llamado microchip), las computadoras electrónicas ocupaban habitaciones enteras, necesarias para contener los transistores y los miles de cables eléctricos que los conectaban. Con el microchip, la potencia de un procesador ahora cabe en la palma de nuestra mano, dentro de un smartphone.
No es posible identificar un momento preciso en la historia que condujo a la invención del microprocesador. «No fue una verdadera invención, en el sentido tecnológico del término», dijo Gordon Moore, inventor de la ley que lleva su nombre y que rige la evolución tecnológica. «El descubrimiento fundamental fue la conciencia de que finalmente era posible realizar lo que todos decían que algún día haríamos». A principios de 1969, el microprocesador cruzó la frontera que existía entre la teoría y la factibilidad real.
Aunque probablemente ya existieran algunos prototipos militares, el nacimiento oficial del microprocesador se remonta a principios de la década de 1970. Por mano del físico italiano Federico Faggin y su equipo de trabajo en Intel. En 1968, el científico descubrió que el silicio era un mejor soporte que el germanio para la producción de circuitos basados en semiconductores de óxido metálico (los llamados MOS). Faggin se dio cuenta de que, a través de un complicado proceso físico-químico, era posible obtener rejillas de óxido de metal, de unos pocos nanómetros, capaces de autoalinearse en placas de silicio-germanio.
La evolución de los microprocesadores
A partir de este trabajo, en 1971, nació el Intel 4004, que pasó a la historia como el primer microprocesador comercial del mundo. El 4004 integraba en un solo chip una potencia de cálculo superior a la del Eniac, la primera computadora electrónica del mundo. Intel lo anunció triunfalmente como “un ordenador programable de un solo chip que abría una nueva era de la electrónica».
En realidad, el Intel 4004 no podía hacer mucho. Solo sumaba y restaba a cuatro bits. Aprovechando y perfeccionando la tecnología del 4004, se llegó al primer microchip de ocho bits: el 8008. En 1973, la compañía Computer Terminals Corporation (Datapoint), en Texas, contactó a Intel para comprar un circuito integrado en la que estaba trabajando. Finalmente, la compañía texana no lo usó e Intel lo puso en el mercado como el 8008. Así se abría el mercado de los microprocesadores.
En 1974, vio la luz el 8080, el primer microprocesador que se insertó en un PC. Pero el modelo que realmente triunfó en el mercado fue el famoso 8088 que, introducido en 1979 por Intel, fue instalado en millones de ordenadores IBM. En los años siguientes, el desarrollo de los microprocesadores fue increíble y llegaron otros modelos firmados por Intel: 80286, 80386, 80486, Pentium, Pentium II, Pentium III y Pentium IV. Todos estos siguen usando el diseño original del 8088, incluso si realizan operaciones a una velocidad de 5.000 veces superior.
Esencial
- Conjunto de productos8th Generation Intel® Core™ i3 Processors
- Nombre de códigoProductos anteriormente Kaby Lake R
- Segmento verticalMobile
- Número de procesadori3-8130U
- EstadoLaunched
- Fecha de lanzamientoQ1'18
- Litografía14 nm
- Precio recomendado para clientes$281.00
Especificaciones de la CPU
- Cantidad de núcleos2
- Cantidad de subprocesos4
- Frecuencia básica del procesador2,20 GHz
- Frecuencia turbo máxima3,40 GHz
- Caché4 MB Intel® Smart Cache
- Velocidad del bus4 GT/s
- TDP15 W
- Frecuencia de descenso de TDP configurable800 MHz
- Descenso de TDP configurable10 W
Información adicional
- Opciones integradas disponiblesNo
- Hoja de datosVer ahora
Especificaciones de memoria
Gráficos de procesador
- Gráficos del procesador ‡Gráficos Intel® UHD 620
- Frecuencia de base de gráficos300 MHz
- Frecuencia dinámica máxima de gráficos1.00 GHz
- Memoria máxima de video de gráficos32 GB
- Salida de gráficoseDP/DP/HDMI/DVI
- Compatibilidad con 4KYes, at 60Hz
- Resolución máxima (HDMI 1.4)‡4096x2304@24Hz
- Resolución máxima (DP)‡4096x2304@60Hz
- Resolución máxima (eDP - panel plano integrado)‡4096x2304@60Hz
- Compatibilidad con DirectX*12
- Compatibilidad con OpenGL*4.4
- Intel® Quick Sync VideoYes
- Tecnología Intel® Clear Video HDYes
- tecnología Intel® de video nítidoYes
- Cantidad de pantallas admitidas ‡3
- ID de dispositivo0x5917
Opciones de expansión
- Revisión de PCI Express3,0
- Configuraciones de PCI Express ‡1x4, 2x2, 1x2+2x1 and 4x1
- Cantidad máxima de líneas PCI Express12
Especificaciones del paquete
- Zócalos compatiblesFCBGA1356
- Máxima configuración de CPU1
- TJUNCTION100°C
- Tamaño de paquete42mm X 24mm
Tecnologías avanzadas
- Compatible con la memoria Intel® Optane™ ‡Yes
- Tecnología Intel® Speed ShiftYes
- Tecnología Intel® Turbo Boost ‡2,0
- Idoneidad para la plataforma Intel® vPro™ ‡No
- Tecnología Intel® Hyper-Threading ‡Yes
- Tecnología de virtualización Intel® (VT-x) ‡Sí
- Tecnología de virtualización Intel® para E/S dirigida (VT-d) ‡Yes
- Intel® VT-x con tablas de páginas extendidas (EPT) ‡Yes
- Intel® Transactional Synchronization Extensions – New InstructionsNo
- Intel® 64 ‡Yes
- Conjunto de instrucciones64-bit
- Extensiones de conjunto de instruccionesIntel® SSE4.1, Intel® SSE4.2, Intel® AVX2
- Estados de inactividadYes
- Tecnología Intel SpeedStep® mejoradaYes
- Tecnologías de monitoreo térmicoYes
- Intel® Flex Memory AccessYes
- Tecnología de protección de la identidad Intel® ‡Yes
- Programa Intel® de imagen estable para plataformas (SIPP)No
- Tecnología Intel® de respuesta inteligenteYes
- Tecnología Intel® My WiFiYes
Seguridad y fiabilidad
Instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, Intel 64, NX, VMX, AES, AVX, AVX2, FMA3
Comentarios
Publicar un comentario