2021-09-17 18:52:44 +00:00
|
|
|
# Introducción a SSOO
|
|
|
|
Un SO es un conjunto de programas que permite manejar el hardware del equipo.
|
|
|
|
Gestiona todos los recursos de hardware y provee servicios a los programas de
|
|
|
|
aplicación de software, ejecutándose en modo privilegiado respecto de los
|
|
|
|
restantes. Tiene entre sus objetivos la **seguridad y abstracción**.
|
|
|
|
|
|
|
|
## Seguridad
|
|
|
|
Para evitar que un programa acceda direcciones de memoria indebidas, hace uso de
|
|
|
|
un modo privilegiado para correr estas instrucciones y/o acceder a estas
|
|
|
|
direcciones.
|
|
|
|
|
|
|
|
## Abstracción
|
|
|
|
Esto ayuda a enmascarar los recursos físicos, permitiendo su manejo con
|
|
|
|
funciones más generales.
|
|
|
|
|
|
|
|
## Funciones de SSOO
|
|
|
|
|
|
|
|
- Gestión de memoria
|
|
|
|
- Gestión de ficheros
|
|
|
|
- Gestión de dispositivos (E/S)
|
|
|
|
- Gestión de procesos
|
|
|
|
- Gestión de la red
|
|
|
|
- Protección y seguridad
|
|
|
|
|
|
|
|
## Generaciones
|
|
|
|
- Generación I:
|
|
|
|
- Tubos de vacío y tarjetas perforadas
|
|
|
|
- Generación II:
|
|
|
|
- Sustitución de válvulas de vacío con transistores
|
|
|
|
- Comunicación con lenguajes más avanzados
|
|
|
|
- Surge Fortran
|
|
|
|
- Generación III:
|
|
|
|
- Circuitos integrados
|
|
|
|
- Multiprogramación
|
|
|
|
- Microchip
|
|
|
|
- Generación IV:
|
|
|
|
- Los primeros PC
|
|
|
|
- Invención del microprocesador
|
|
|
|
- Generación V:
|
|
|
|
- Cambio a IA
|
|
|
|
- Generación VI:
|
|
|
|
- Computadoras basadas en redes neuronales artificiales
|
|
|
|
|
|
|
|
## Ley de Moore
|
|
|
|
Cada 2 años se duplica el número de transistores en un integrado.
|
|
|
|
|
|
|
|
## Tipos de SSOO
|
|
|
|
|
|
|
|
- Por código:
|
|
|
|
- Monolítico
|
|
|
|
- Único programa dividido en subrutinas
|
|
|
|
- Jerárquico
|
|
|
|
- Varias capas de seguridad y privilegios que se denominan 'rings'
|
|
|
|
- Por usuario:
|
|
|
|
- Monousuario
|
|
|
|
- Multiusuario
|
|
|
|
- Por tareas:
|
|
|
|
- Monotarea
|
|
|
|
- Multitarea
|
|
|
|
- Por proceso
|
|
|
|
- Uniproceso: el SO sólo puede manejar un solo procesador
|
|
|
|
- Multiproceso: puede manejar más de un procesador
|
|
|
|
- Asimétrica: un procesador maestro que accede recursos de sistemas y
|
|
|
|
distribuye la carga
|
|
|
|
- Simétrica: los procesos son enviados por el SO a cualquier procesador
|
|
|
|
disponible.
|
2021-09-22 18:42:00 +00:00
|
|
|
|
|
|
|
## Gestión de Procesos
|
|
|
|
Cuando se ejecuta un programa se realizan tareas de cálculo de la CPU y labores
|
|
|
|
de E/S. Cuando hay varios procesos, ambos pueden usar a la vez la E/S, pero
|
|
|
|
**sólo uno** puede usar la CPU a la vez. Esta **multiprogramación** da una
|
|
|
|
(falsa) sensación de procesos en paralelo. Distinguimos entre dos tipos de
|
|
|
|
procesos:
|
|
|
|
- Los limitados por proceso: alto consumo CPU, bajo en E/S
|
|
|
|
- Los limitados por E/S: bajo consumo CPU, alto en E/S
|
|
|
|
|
|
|
|
Un proceso puede tener los siguientes estados:
|
|
|
|
- Nuevo
|
|
|
|
- Listo, En Espera/Preparación
|
|
|
|
- Terminado
|
|
|
|
- Transición
|
|
|
|
- Ejecución/Activo
|
|
|
|
- Bloqueado
|
2021-09-23 15:21:50 +00:00
|
|
|
|
2021-09-29 18:55:15 +00:00
|
|
|
### Apropiación
|
|
|
|
- **Planificación no apropiativa:** deja ejecutar al proceso en CPU hasta que
|
|
|
|
finalice, se bloquee, espere por otro proceso o termine de forma voluntaria.
|
|
|
|
Es decir, una vez que la CPU se le asigna ésta ya no se le puede quitar.
|
|
|
|
- **First Come First Serve (FCFS)**
|
|
|
|
- **Shortest Job First (SJF)**
|
|
|
|
- **Planificación apropiativa:** El planificador puede desalojar al proceso en
|
|
|
|
CPU durante su ejecución y cambiarlo por otro.
|
|
|
|
- **Preemptive Shortest Process Next (PSPN)**
|
|
|
|
- **Prioridades**
|
|
|
|
- **Turno Rotatorio (Round-Robin)**
|
2021-10-06 09:50:06 +00:00
|
|
|
- **Multi-Level Queue**
|
2021-09-29 18:55:15 +00:00
|
|
|
|
2021-09-23 15:21:50 +00:00
|
|
|
## Gestión de Memoria
|
|
|
|
Cuando un sistema es monoprograma, entonces el único proceso tiene acceso pleno
|
|
|
|
a toda la memoria de la máquina. Mas cuando hay varios programas, tiene que
|
|
|
|
haber un sistema para asignar la memoria a los diferentes procesos.
|
|
|
|
|
|
|
|
El sistema operativo también se tiene que ocupar de no dejar que un proceso
|
|
|
|
acceda a la memoria de otro - y por supuesto no del sistema operativo. Esto se
|
|
|
|
soluciona sobre todo con la memoria virtual, tal que el proceso cree que tiene
|
|
|
|
toda la memoria (incluso más grande que el tamaño físico de la memoria), y la
|
|
|
|
CPU se ocupa de traducir las direcciones. Cuando se intenta usar más memoria de
|
|
|
|
lo que hay en memoria física, se hace uso de un almacenamiento secundario que se
|
|
|
|
llama __swap__.
|
|
|
|
|
|
|
|
Para gestionar la memoria se suele usar una estructura lógica de __páginas__. Si
|
|
|
|
es demasiado pequeña entonces sobrecarga el sistema al tener que gestionar
|
|
|
|
tantas. Mas si es demasiado grande se desaprovecha espacio.
|
2021-09-29 18:55:15 +00:00
|
|
|
|
|
|
|
**Fichero:** Unidad lógica de almacenamiento de información.
|
2021-09-30 14:37:42 +00:00
|
|
|
|
|
|
|
- Asignación Contigua (continuous blocks)
|
|
|
|
- Asignación Enlazada (linked list)
|
|
|
|
- Asignación Indexada (bitmap)
|