CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[C] Affecter un thread à un CPU

john-lock
john-lock
Niveau 6
25 septembre 2013 à 17:02:21

Bonjour à tous,

Dans le cadre d'un devoir sur la programmation parallèle je dois pouvoir affecter un thread particulier à un core particulier de mon processeur.

Pour ma part j'ai utilisé la fonction setaffinity() pour réaliser cela :
http://pastebin.com/8n9NYFA1

Cependant mon prof m'a parlé d'une autre fonction : la fonction sched_setscheduler(). Seulement je n'arrive pas à l'utilisé j'ai réussi à changer l'ordonnancement (FIFO, RoundRobin) mais j'ai pas réussi à affecter un thread à un core et je ne vois pas comment m'y prendre.

De plus j'ai une autre question, comment identifier les numéros des cores physiques de mon ordinateur ?
Je possède 2 cores physiques et 2 virtuels (Hyper Threading) si je lance 2 threads, et que ces deux threads se retrouvent sur le même core physique (CPU0 et CPU1 par exemple), mon programme s'éxecutera moins vite que si je lance les 2 threads sur les 2 cores distincts (CPU0 et CPU2 par exemple) ?

Merci d'avance pour votre aide :) je rencontre quelques difficultés avec cet exercice.

godrik
godrik
Niveau 30
25 septembre 2013 à 17:28:48

ahah, c'est la merde. :)
Basiquement, tu n'as aucune garantie de persistance de la numerotation des coeurs et des threads de ta machines. A chaque boot du noyau, l'ordre pourrait etre different. Google a ecrit un outil appelle likwid qui sert a en savoir un peu plus. Regarde en particulier likwid-topology qui devrait te dire pour chaque thread system a quel ressource physique le thread est associe.
Apres il te restera a associe tes threads logique (utilisateur) aux threads systems.

En general, je fais le mapping en lui meme avec pthread_setaffinity_np. Mias naturellement ca depend de la lib de thread que tu utilise.

john-lock
john-lock
Niveau 6
25 septembre 2013 à 21:11:31

Ok merci godrik je vais jeter un oeil à ton lien :)

Par contre, as tu déjà utilisé la fonction sched_setscheduler() pour affecter un thread à un CPU ? car je ne vois pas trop comment faire.

Pseudo supprimé
Pseudo supprimé 25 septembre 2013 à 21:58:04

"Basiquement, tu n'as aucune garantie de persistance de la numerotation des coeurs et des threads de ta machines. A chaque boot du noyau, l'ordre pourrait etre different."

intéressant. tu parle d'une machine avec plusieurs processeurs ou meme avec un seul processeur ? ya une raison a cela ? (que l'ordre soit aléatoire)

godrik
godrik
Niveau 30
25 septembre 2013 à 22:19:56

elite_2009, je ne sais pas exactement. J'avais un cluster ou toutes les machines avaient les memes spec materielles et le meme noyaux (tout imager en meme temps) et la numerotation n'etait pas la meme sur toute les machines.

Sous forums
  • Aide à l'achat Mac
  • Steam Deck
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Macintosh
  • Hardware
La vidéo du moment