IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Linux Discussion :

Threads et CPU : comment ça marche ?


Sujet :

Linux

  1. #1
    Membre expérimenté
    Profil pro
    Inscrit en
    août 2006
    Messages
    1 086
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : août 2006
    Messages : 1 086
    Points : 1 725
    Points
    1 725
    Par défaut Threads et CPU : comment ça marche ?
    Bonjour

    J'ai une question pas très facile à poser.

    Lorsque le noyau éxecute un thread, comment le CPU (on part du principe qu'il n'y a qu'un seul coeur) sait-il qu'à tel moment il faut passer la main et revenir au noyau afin qu'il fasse tourner un autre thread ?
    Y a-t-il un système d'interruption matérielle, ou autre chose ?

    Je suppose que le schéma fonctionne comme cela :

    noyau -> thread 1 -> arrêt -> noyau -> thread 2 -> arrêt -> ... -> noyau -> thread 1 -> arrêt -> ...

    J'ai fouillé dans les sources linux mais à aucun endroit je ne trouve d'instructions (assembleur) qui communiquent directement avec le matériel. Je ne trouve que des fonctions. Du coup, je me demande comment tout cela fonctionne.

    Merci pour vos infos.

  2. #2
    Expert éminent
    Homme Profil pro
    Analyste/ Programmeur
    Inscrit en
    juillet 2013
    Messages
    3 755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste/ Programmeur

    Informations forums :
    Inscription : juillet 2013
    Messages : 3 755
    Points : 8 413
    Points
    8 413
    Par défaut
    Ce ne sont pas de "threads" (fil d'exécution en français) mais des processus

    La différence entre "threads" et processus est le fait que les "threads" se partagent la mémoire (en gros 1 processus contient de la mémoire - la pile, ... - et des "threads")

    C'est un sujet assez vaste qui touche à l'ordonnancement. Commence par préemptif (<- lien wiki en français)

  3. #3
    Responsable Systèmes


    Homme Profil pro
    Technicien maintenance
    Inscrit en
    août 2011
    Messages
    13 766
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : août 2011
    Messages : 13 766
    Points : 31 409
    Points
    31 409
    Par défaut
    Et cliques sur le lien "ordonanceur" du lien fourni.
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur la création d'un système : http://chrtophe.developpez.com/tutoriels/minisysteme/
    Mon article sur le P2V : http://chrtophe.developpez.com/tutoriels/p2v/
    Consultez nos FAQ : Windows, Linux, Virtualisation

  4. #4
    Membre expérimenté
    Profil pro
    Inscrit en
    août 2006
    Messages
    1 086
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : août 2006
    Messages : 1 086
    Points : 1 725
    Points
    1 725
    Par défaut
    Merci pour vos réponses.

    Je crois avoir trouvé la réponse à ma question :

    On utilise également les interruptions pour commuter les tâches dans les systèmes multi-tâches. Généralement, une interruption périodique est déclenchée par une horloge (souvent 100 ou 1 000 Hz), et l'ordonnanceur est alors mis en action. Il peut commuter les tâches en modifiant la tâche de retour de l'interruption.
    Je vais continuer à chercher d'amples informations à ce sujet.

  5. #5
    Responsable Systèmes


    Homme Profil pro
    Technicien maintenance
    Inscrit en
    août 2011
    Messages
    13 766
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : août 2011
    Messages : 13 766
    Points : 31 409
    Points
    31 409
    Par défaut
    Une interruption matérielle, ça interrompt la tâche en cours du processeur. Au retour de celles-ci, l'ordonnanceur va en profiter pour élire le prochain processus à qui donner la main selon son algorithme.
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur la création d'un système : http://chrtophe.developpez.com/tutoriels/minisysteme/
    Mon article sur le P2V : http://chrtophe.developpez.com/tutoriels/p2v/
    Consultez nos FAQ : Windows, Linux, Virtualisation

Discussions similaires

  1. CPU et GPU comment ça marche ?
    Par Clercq dans le forum Moteurs 3D
    Réponses: 7
    Dernier message: 02/11/2009, 17h00
  2. [SYNEDIT] -> Comment ça marche ?
    Par MaTHieU_ dans le forum C++Builder
    Réponses: 2
    Dernier message: 18/01/2004, 20h11
  3. [TP][Turbo Vision] comment ça marche ??
    Par Costello dans le forum Turbo Pascal
    Réponses: 7
    Dernier message: 05/08/2003, 01h24
  4. [update][req. imbriquee] Comment ca marche ??
    Par terziann dans le forum Langage SQL
    Réponses: 3
    Dernier message: 11/07/2003, 13h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo