SEPC-S2

De Ensiwiki
Aller à : navigation, rechercher


Page ensiwiki du cours de Système d'Exploitation et Programmation Concurrente, semestre 2.

Vous trouverez sur cette page:

  • Les supports de cours
  • Les supports de TD et TP

Les annales et d'autres trucs chouettes se trouvent sur la page générale du cours de SEPC.

Supports de cours

Vous pouvez trouver les slides du semestre 1 ici

Travaux dirigés et Travaux pratiques

Rappels de C (salle machine)

Le sujet est ici : [1]

TP 1 : Shell

Environnement de travail

  • Les squelettes sont prévus pour fonctionner avec l'environnement de référence de l'Ensismag (à base de centOS 7, celui des PC et des VM). Des Debian et Ubuntu récentes devraient fonctionner sans problème non plus. Tous les outils sont tous disponibles en standard dans votre distribution Linux.
  • Les Makefile pour la compilation et la construction du rendu, sont générés à l'aide de cmake
  • Si vous voulez utiliser git plus avant, la page git du wiki avec des liens vers les tutoriaux.

Sujet

     man fork
     man 2 open (il y a beaucoup de open: les appels systèmes sont en section 2)
     info libc (doc de référence avec des explications détaillées et des exemples complets de code))
     info libc "process creation example" (l'exemple de code de la section Process)
     info info (tutorial de info)
  • Sources: elles sont dans un entrepôt git sur le site github.com (branche master, le défaut). On peut les obtenir en faisant :
  git clone https://github.com/gmounie/ensimag-shell.git

L'entrepôt est le même pour tout le monde. Il n'est donc accessible qu'en lecture. Les commandes commme git push ne devraient pas fonctionner. Vous ne pouvez pas y sauvegarder vos travaux.

  • Les tests automatiques pour le shell utilisent un module standard pour le test des programmes interactifs du langage ruby (le paquetage de test est nommé ruby-test-unit dans une debian récente)
  • Le shell utilise l'interpréteur scheme guile (version 1.8 ou 2.0)(guile-2.0-dev dans une debian récente)
  • FAQ TP Shell

Couplage mémoire (salle machine)

  • Sujet du TP couplage mémoire
  • Sources: elles sont dans un entrepôt git sur le site github.com (branche master, le défaut). On peut les obtenir en faisant :
  git clone https://github.com/gmounie/ensimag-shmem.git

TP 2 : threads

Présentation

Sujet

  git clone https://github.com/gmounie/ensimag-video.git
    • L'entrepôt est le même pour tout le monde. Il n'est donc accessible qu'en lecture. Les commandes commme git push ne devraient pas fonctionner. Vous ne pouvez pas y sauvegarder vos travaux.
    • Ce TP utilise les bibliothèques ogg, theora, vorbis et SDL2 (>= 2.0.4), ainsi que les entêtes de développement de ces bibliothèques (les include pour la compilation)

(noms Debian/Ubuntu: libsdl2-dev libogg-dev libvorbis-dev libtheora-dev.)

    • Sur certaines machines de l'ensimag, l'accélération de l'affichage par la SDL2 ne fonctionne pas bien. Vous pouvez la désactiver :
 Dans src/ensitheora.c, la ligne 34
  renderer = SDL_CreateRenderer(screen, -1, 0);
 peut être remplacée par
  renderer = SDL_CreateRenderer(screen, -1, SDL_RENDERER_SOFTWARE);

Encodage des vidéos

Pour encoder une vidéo en théora et vorbis, vous pouvez utilisez l'utilitaire à tous faire ffmpeg

    ffmpeg  -i fichierVideoOriginal.mpg -vcodec libtheora -acodec libvorbis fichierReEncodeeEnTheoraVorbis.ogv 

Les enseignants