Crèdits
6
Tipus
Obligatòria d'especialitat (Tecnologies de la informació)
Requisits
- Prerequisit: SO
Departament
AC
Web
http://docencia.ac.upc.edu/FIB/grau/SOA
Professorat
Responsable
- Alex Pajuelo Gonzalez ( mpajuelo@ac.upc.edu )
Altres
- Juan José Costa Prats ( jcosta@ac.upc.edu )
- Yolanda Becerra Fontal ( yolandab@ac.upc.edu )
Hores setmanals
Teoria
2
Problemes
0
Laboratori
2
Aprenentatge dirigit
0
Aprenentatge autònom
6
Competències
Competències tècniques comunes
- CT6.1 - Demostrar coneixement i tenir capacitat per a administrar i mantenir sistemes, serveis i aplicacions informàtiques.
- CT6.3 - Demostrar coneixement de les característiques, funcionalitats i estructura dels Sistemes Operatius que en permeti un ús adequat, administració i disseny, així com la implementació d'aplicacions basades en els seus serveis.
- CT6.4 - Demostrar coneixement i capacitat d'aplicació de les característiques, de les funcionalitats i de l'estructura dels Sistemes Distribuïts i de les Xarxes de Computadors i d'Internet que en garanteixi l'ús i l'administració, així com el disseny i la implementació d'aplicacions basades en elles.
- CT7.1 - Demostrar coneixement de les mètriques de qualitat i saber-les utilitzar.
- CT7.2 - Avaluar sistemes hardware/software en funció d'un criteri de qualitat determinat.
- CT8.7 - Controlar versions i configuracions del projecte.
Especialitat tecnologies de la informació
- CTI1.4 - Seleccionar, dissenyar, desplegar, integrar, avaluar, construir, gestionar, explotar i mantenir les tecnologies de hardware, software i xarxes, dintre dels paràmetres de cost i qualitat adequats.
- CTI3.4 - Dissenyar software de comunicacions.
Tercera llengua
- G3.1 - Comprendre i utilitzar eficaçment manuals, especificacions de productes i altra informació de caràcter tècnic escrita en anglès.
Objectius
-
Conèixer el funcionament d'un SO real, des de que arrenca l'ordinador i la inicialització del sistema, passant per la gestió dinàmica de recursos, fins que s'apaga l'ordinador.
Competències relacionades: CTI3.4, CT6.1, CT6.3, CT6.4, CTI1.4, -
Conèixer els detalls de la implementació d'alguns dels components bàsics d'un SO real: codi d'inicialització, codi de gestió de memòria, codi de gestió de l'entrada / sortida, codi de gestió dels processos i codi de càrrega de fitxers executables.
Competències relacionades: CT6.1, CT6.3, CT7.2, CTI1.4, -
Descriure el funcionament del mecanisme d'inserció dinàmica de codi en un SO real
Competències relacionades: CT6.1, CT6.3, CT8.7, CTI1.4, -
Detallar l'estructura interna d'un mòdul de nucli identificant els diferents components juntament amb la seva relació amb la interfície genèrica del SO i lús d'estructures en memòria per al control de l'entrada / sortida.
Competències relacionades: CT6.1, CT6.3, CT8.7, CTI1.4, -
Conèixer la programació multifil, la problemàtica de l'ús compartit de memòria i la implementació de mecanismes d'exclusió mútua juntament amb el suport hardware necessari.
Competències relacionades: CTI3.4, CT6.1, CT6.3, CT6.4, CTI1.4, -
Implementar alguns dels components bàsics d'un SO real: codi d'inicialització, codi de gestió de memòria, codi de gestió de l'entrada / sortida, codi de gestió dels processos i codi de càrrega de fitxers executables utilitzant llenguatge C i assemblador sobre una arquitectura intel x86.
Competències relacionades: CTI3.4, CT6.1, G3.1, CT6.3, CT6.4, CT7.1, CT7.2, CT8.7, CTI1.4, -
Comparar i avaluar les diferents alternatives d'implementació de codi de gestió de recursos mitjançant mètriques de cost, eficiència i qualitat
Competències relacionades: CT6.1, CT6.3, CT7.1, CT7.2, CT8.7, -
Dissenyar programari de comunicacions en aplicacions multiprocés i / o multifil.
Competències relacionades: CTI3.4, CT6.4, CT7.2, CT8.7, CTI1.4, -
Saber utilitzar i entendre els documents tècnics en anglès proporcionats amb el sistema operatiu.
Competències relacionades: G3.1, CT6.3, -
Utilitzar programari de control de versions.
Competències relacionades: CT6.1, CT6.3, CT8.7,
Continguts
-
Inicialització del sistema
En aquest capítol s'explicaran totes les accions que es fan per arrencar tots els serveis que ofereix un sistema operatiu. També es descriuran i discutiran les possibles implementacions d'aquest procés en un sistema operatiu actual. -
Mecanismes d'entrada al sistema
Es descriuran i discutiran les possibles implementacions de mecanismes d'entrada al sistema junt amb el seu suport hardware. Es detallaran els aspectes més importants dels mecanismes i les dependències entre el sistema operatiu i el hardware. Es comentaran els avantatges de la implementació de tècniques de virtualització actuals. Es presentaran i discutiran les diferents implementacions de sistemes operatius actuals. -
Gestió de memòria
En aquest capítol es tractaran els següents temes: espai de adreces lògiques del procés. Sistemes de memòria basats en paginació i el seu suport hardware. Disseny i implementació de la memoria virtual. Algoritmes de reemplaç de la memòria virtual. Implementació de memòria compartida. Alternatives de disseny i implementació de sistemes de memòria en sistemes operatius actuals. -
Gestió de processos
En aquest capítol se tractaran els següents temes: implementació detallada del bloc de control del procés. Implementació detallada de la creació d'un procés. Implementació detallada de la finalització d'un procés. Implementació detallada de la carrega d'un executable. Implementació detallada del canvi de context entre processos. Descripció detallada de les estructures i algoritmes de planificació de processos. Implementació de tallada de les rutines de planificació de processos. Descripció i discussió de les diferents implementacions de planificació de processos en sistemes operatius actuals. -
Gestió de l'entrada/sortida i sistema de fitxers
En aquest capítol es tractaran els següents temes: descripció i implementació de la part independent i dependent del dispositiu. Implementació d'un descriptor de dispositius. Descripció, funcionament i implementació de les estructures relatives a la entrada/sortida i al sistema de fitxers. Descripció i implementació de l'estructura lògica del sistema de fitxers a disc. Mecanismes de comunicació a través del sistema de fitxers. Mecanismes de comunicació a través d'una xarxa. Descripció de la implementació de diversos sistemes de fitxers actuals. -
Memòria compartida
En aquest capítol es tractaran els següents temes: problemàtica de tenir memòria compartida entre diversos fluxos d'execució dins d'un procés. Condicions de carrera. Zones d'exclusió mútua. Descripció i implementació de mecanismes d'exclusió mútua en l'accés a memòria compartida, en concret, test and set, mutex i semàfors. Descripció, implementació i discussió de mecanismes d'exclusió mútua en sistemes operatius actuals. -
Extensió del nucli del sistema
En aquest capítol es tractaran els següents temes: concepte, disseny i implementació de mòduls del SO. Carrega de mòduls del nucli en temps d'inicialització del sistema i en temps d'execució. Descripció de l'accés a funcionalitats implementades en mòduls de nucli. Descripció de la relació entre mòduls de nucli i dispositius físics i lògics.
Activitats
Activitat Acte avaluatiu
Metodologia docent
L'assignatura tindrà principalment dos tipus de classe: teoria i laboratoris. Les classes de teoria seran per explicar els conceptes, dissenys i implementació dels diferents components d'un sistema operatiu actual. Aquestes classes es faran amb el suport de transparencies.Les classes de laboratori seran setmanals. Les primeres 7 setmanes es dissenyarà, implementarà i avaluarà un planificador de processos en un sistema operatiu didàctic anomenat Zeos. Les darreres 7 setmanes es dissenyaran, s'implementaran i avaluaran noves característiques del sistema operatiu.
Mètode d'avaluació
La nota final de l'assignatura està composta per la nota de la competència tècnica (CT), i la nota de la competència transversal (CTr) mitjançant la fórmula:Nota Assig = (CT + CTr)*(10/11)
On la nota màxima de CTr és 1.
La nota de la CT es pot obtenir obtenir per avaluació continuada (CTc) o excepcionalment per un examen final (CTf). Es calcula com:
CT = max (CTc, CTf)
La nota CTc està composta de diversos actes avaluatius: controls de teoria (T), i controls de laboratori (L). La fórmula per calcular aquesta nota és la següent:
CTc = 50% T + 50% L
Per a calcular T s'utilitzen dos controls amb els mateixos pesos:
T = 50% T1 + 50% T2
Per a calcular L s'utilitza un control (L1), una nota de seguiment (S) i un projecte (P):
L = 40% L1 + 10% S + 50% P
La nota de seguiment (S) s'extreurà de l'avaluació que faci el professor sobre el correcte progrés de l'alumne al laboratori.
La nota de projecte (P) correspon al disseny, seguiment i implementació final del projecte.
La nota CTf es calcula mitjançant un examen de teoria (T) i un examen de laboratori (L). Per obtenir aquesta nota és obligatori fer tots dos exàmens. Només poden optar a aquesta nota els alumnes que no hagin aprovat l'avaluació continuada. La fórmula és la següent:
CTf = 50% T + 50% L
La nota de la competència transversal (CTr) s'obtindrà durant tot el quadrimestre a través de diverses activitats. La qualificació d'aquesta competència tindrà valors A, B, C, D o NA: A correspon a un nivell excel · lent, B a un nivell desitjat, C a un nivell suficient, D a un nivell no superat i NA a no avaluat.
Bibliografia
Bàsic
-
Operating system concepts
- Silberschatz, A.; Galvin, P.B.; Gagne, G,
John Wiley & Sons,
2019.
ISBN: 9781119454083
https://discovery.upc.edu/discovery/fulldisplay?docid=alma991004148389706711&context=L&vid=34CSUC_UPC:VU1&lang=ca -
Advanced Operating Systems Course
- Becerra, Y; Costa, J.; Pajuelo, A,
Complementari
-
Understanding the Linux kernel
- Bovet, D.P.; Cesati, M,
O'Reilly,
2005.
ISBN: 9780596005658
https://discovery.upc.edu/discovery/fulldisplay?docid=alma991003076469706711&context=L&vid=34CSUC_UPC:VU1&lang=ca -
Windows internals: part 1: system architecture, processes, threads, memory management, and mor
- Yosifovich, P.; Ionescu, A.; Russinovich, M.E.; Solomon, D.A,
Microsoft Press,
2017.
ISBN: 9780735684188
https://discovery.upc.edu/discovery/fulldisplay?docid=alma991004178279706711&context=L&vid=34CSUC_UPC:VU1&lang=ca -
Operating systems: internals and design principles
- Stallings, W,
Pearson Education Limited,
2017.
ISBN: 9781292214306
https://discovery.upc.edu/discovery/fulldisplay?docid=alma991001576049706711&context=L&vid=34CSUC_UPC:VU1&lang=ca
Web links
- Pàgina web de l'assignatura http://docencia.ac.upc.edu/FIB/grau/SOA/
Capacitats prèvies
L'estudiant ha de tenir les capacitats técniques que li otorguen les assignatures cursades previament a més de un nivell d'anglés técnic mitjà com per llegir i entendre una documentació.En quant a capacitats técniques les podriem resumir en:
-En quant a sistemes operatius: Coneixement dels conceptes bàsics d'un sistema operatiu junt amb programació d'aplicacions fent servir la interficie genèrica de crides al sistema tot impartit a Sistemes Operatius.
-En quant a estructura de computadores: Coneixement dels elements principals d'un ordenador, relacio d'aquests elements entre si, representació interna de dades i coneixements de llenguatge màquina.
-En quant a programació: Capacitat de fer programes complexos i modularitzats desde cero que incloguin definició de tipus de dades, referències amb punters i codi en ensamblador. Compilació i muntatge d'executables.