Revisión actual |
Tu texto |
Línea 1: |
Línea 1: |
| {{Back|Sistemas Operativos}}
| |
|
| |
| ==Ejercicio 01:== | | ==Ejercicio 01:== |
| <br>a) | | <br>a) |
Línea 7: |
Línea 5: |
| <br>d) | | <br>d) |
| <br>e) | | <br>e) |
|
| |
| * Función del controlador de tráfico:
| |
| - LLevar el control de los canales(procesador E/S), las unidades de contol(UC) y los perifericos por medio de los bloques de control de ambos <br>tres (Base de datos para administracion de perifericos).
| |
| - Determinar si es posible realizar el pedido de E/S.
| |
| - Determinar la ruta de transferencia de datos <br> (canal - uc - periferico).
| |
|
| |
|
| |
| * Función del Manipuladores de Perifericos (Drivers):
| |
| - Arma el programa que ejecutara el canal correspondiente.
| |
| - Emite la instruccion de arranque del dispositivo.
| |
| - Procesas las interrupciones que lanza el dispositivo.
| |
| - Maneja errores del mismo.
| |
| - Establece la estrategia de acceso al disp. (fcfs, scan, c-scan, posición angular, look, c-look, mascorto primero, etc)
| |
|
| |
| * Función del Planificador de E/S:
| |
| - Determina el orden en que se asignan los pedidos a cualquiera de las tres estructuras (Canal, Uc, Periferico),<br> ya sea por prioridad o por algun algoritmo.(es igual que con los procesos comunes y el planificador de la carga ,<br> salvo que estos no se interrumpen sino hasta q terminen por completo)
| |
|
| |
|
| |
| * Base de datos para administracion de perifericos
| |
| - Bloque de Control de Periférico:
| |
| > id
| |
| > estado del perif
| |
| > lista de UCs asociadas
| |
| > lista de pedidos asociados
| |
| - Bloque de Control del Procesador de E/S:
| |
| > id
| |
| > estado del canal
| |
| > lista de UCs asociadas
| |
| > lsita de pedidos asociados
| |
| - Bloque de Control de la Unidad de Control;
| |
| > id
| |
| > estado de la UC
| |
| > lista de disp. asociados
| |
| > lsita de canales asociados
| |
| > lsita de pedidos asociados
| |
|
| |
|
| |
|
| |
|
| |
| -
| |
|
| |
|
| ==Ejercicio 02[*]:== | | ==Ejercicio 02[*]:== |
Línea 56: |
Línea 14: |
|
| |
|
| ==Ejercicio 03:== | | ==Ejercicio 03:== |
| <br>a) Tener caminos alternativos, permite la tolerancia a fallos , es decir si empieza a fallar un camino, entonces podemos acceder al disp por otro. | | <br>a) |
| cita del apunte no ficial de la catedra : "Si deja de funcionar algún procesador de E/S todavía podremos acceder al periférico pasando por el otro."
| | <br>b) |
| | | <br>c) |
| | | <br>d) |
| <br>b) si es posible , por medio de las siguiente r utas : | |
| D2 --> UC(A) --> Canal(1)
| |
| D1 --> UC(B) --> Canal(2)
| |
| | |
| cita del apunte no ficial de la catedra :"Asimismo también es deseable proveer la posibilidad de transferencias simultáneas si el camino lo permite"
| |
| | |
| | |
| <br>c) El planificador de tráfico | |
| <br>d) ... | |
|
| |
|
| ==Ejercicio 04[*]:== | | ==Ejercicio 04[*]:== |
| <br>a) | | <br>a) |
| <br>ms en 1/8 rev = 1/8 rev * 8ms / 1rev = 1ms | | <br>ms en 1/8 rev = 1/8 rev * 8ms / 1rev = 1ms |
| <br>Total = 2 + 0.8*10 + 1 + 2 + (0.8*10 + 7) + 7 = 35 ms | | <br>Total = 2 + 0.8*10 + 1 + 2 + (0.8*10 + 9) + 9 = 39 ms |
| <br>b) (Pista,Registro) = (0,2)-(10,2)-(10,3)-(20,3)-(20,4)-(10,5) (el total es 2+8+1+8+1+8+1 = 29 ms) | | <br>b) (Pista,Registro) = (0,2)-(10,2)-(10,3)-(20,3)-(20,4)-(10,5) (el total es 2+8+1+8+1+8+1 = 29 ms) |
| <br>c) Saber el posicionamiento de la cabeza es necesario para algoritmos como "el mas corto primero", "scan", etc | | <br>c) |
| | |
| | |
| <br>d) | | <br>d) |
|
| |
|
Línea 83: |
Línea 30: |
|
| |
|
| ==Ejercicio 06[*]:== | | ==Ejercicio 06[*]:== |
| = Informacion necesaria para el manipulador o driver : =
| |
| > Cual es el dispositivo y a cual lugar exacto del mismo se desea acceder.
| |
| > (el driver arma el programa para el canal pero incompleto, sin las rutas)
| |
| > Luego el planificador de trafico le pasa las rutas de transferencia de la informacion y completa el programa para el canal.
| |
| <nowiki>
| |
| cita del apunte no oficial:
| |
| " Una vez que la administración de la información ha determinado en qué lugar exacto del periférico se debe realizar la E/S, cuál es el periférico concretamente sobre el que se desea operar, le pasa esta información a la
| |
| administración de periféricos.
| |
| La primera rutina que interviene es el manipulador de periféricos el cual con los datos que recibe constru-
| |
| ye el programa de canal ya que conoce cuál es el periférico concreto, de qué tipo de periférico se trata y sabe si la
| |
| operación es de lectura o de grabación. Lo único que no conoce en este momento es qué ruta se utilizará para
| |
| realizar la transferencia y, deja esta información aun sin completar."
| |
| .
| |
| .
| |
| .
| |
| " Como ya obtuvimos la ruta entonces podemos invocar al Manipulador de Periféricos a efectos de que complete su programa de canal con la ruta obtenida."
| |
|
| |
| </nowiki>
| |
|
| |
|
| ==Ejercicio 07[*]:== | | ==Ejercicio 07[*]:== |
Línea 175: |
Línea 104: |
| <br>b) | | <br>b) |
| <br>c) | | <br>c) |
|
| |
|
| |
| [[Category:Prácticas]]
| |