Faire un don ! | | style | statistiques | contactez-nous | plan | lettre d'information

Journal : PowerTOP : Un outil pour réduire la consommation d'énergie sous GNU/Linux

Posté par herodiade () le 14 mai 2007
Serait-ce l'un des premiers bénéfices de la nouvelle orientation d'Intel en faveur de Linux pour leur solutions mobiles ?
Arjan van de Ven, développeur chez Intel, vient d'annoncer la sortie d'un outil permettant d'identifier les applications et pilotes Linux les plus gourmands en énergie de façon très simple et lisible : PowerTOP liste ces mauvais citoyens en ordre décroissant, à la façon de l'utilitaire top(1). Il indique aussi le nombre d'éveils des processeurs par seconde et une estimation de la consommation actuelle en watt. Très user friendly, l'outil affiche même des conseils d'amélioration en fonction de votre configuration noyau (par exemple il recommande, si ce n'est déjà fait, d'activer NO_HZ, CONFIG_USB_SUSPEND, CONFIG_HPET et CONFIG_CPU_FREQ_GOV_ONDEMAND mais de désactiver CONFIG_IRQBALANCE et CONFIG_ACPI_DEBUG). Pas besoin d'être un développeur chevronné donc : tout utilisateur de GNU/Linux doté d'un PC portable devrait pouvoir utiliser cet outil (en revanche, il faut penser à signaler aux développeurs les problèmes de consommation d'énergie que cela permet de découvrir dans leurs logiciels ;).

Un noyau 2.6.21 (ou plus récent) est nécessaire au fonctionnement de PowerTOP, car celui-ci intègre le support des dynticks / tickless idle développé par Ingo Molnar et Thomas Gleixner. Cette fonctionnalité, à activer avec la nouvelle option de configuration CONFIG_NO_HZ, évite au noyau de s'éveiller hz fois par seconde s'il n'a rien à faire. PowerTOP devrait être utilisable sur les processeurs x86 non-Intel, quoique certaines informations (en particulier les informations remontées par l'ACPI concernant les C-states des CPUs) ne seront accessibles qu'avec les processeurs Intel dits « mobiles » (processeurs pour les portables).

PowerTOP détermine ces informations sur la consommation électrique en identifiant les applications et les pilotes qui « réveillent » le noyau (donc les CPUs) très fréquement (par exemple lorsqu'on utilise une mauvaise API pour surveiller un fichier, un répertoire, un changement d'heure, la connexion d'un périphérique USB, un changement de configuration réseau, lorsqu'un pilote est sollicité en permanence par des nuées d'IRQ, ...) ou les application qui réveillent régulièrement le noyau pendant trop longtemps. En effet, les fonctionnalités ACPI d'économie d'énergie ne sont réellement effectives que lorsque le noyau maintient les processeurs dans un des états (C-state) de repos (C3, ou mieux, C4) ; toute application qui sollicite le noyau très fréquemment (par un appel système par exemple) - même pour une tache très simple, rapide, sans gros calculs - conduit les CPUs à basculer en mode « non économique » (C-states C0 ou C1). L'ajout d'une fonctionnalité permettant d'identifier les applications les plus consommatrices d'accès disques (très gourmands en énergie) est envisagée.

Pour les développeurs, et de de façon plus synthétique : si votre application surveille (en anglais « poll », « monitor », ...) en permanence le système pour être avertie de changements d'états potentiels (par exemple l'arrivée de données dans un répertoire ou sur une socket) il est préférable d'utiliser les API (comme select(2), poll(2) et inotify(7)) permettant d'attendre passivement que le noyau la prévienne lorsque c'est utile plutôt que de réveiller le noyau plusieurs fois par seconde en vérifiant depuis l'application si le changement a eu lieu. Il convient aussi de regrouper autant que possible les lectures ou écritures sur le disque dur.

Voila quelques exemples (plutôt centrés sur le bureau Gnome) de problèmes déjà découverts - et en général, patchés - pour l'essentiel par les développeurs d'Intel :

  • Certaines options du noyau ont une influence considérable (voir les recommandation indiquées plus haut).

  • Certains logiciels se révèlent très gourmands, et réveillent le noyau des centaines, voir des milliers de fois par secondes alors que des solutions alternatives existent. Firefox, Evolution, gnome-power-manager, gaim (maintenant appelé Pidgin), ntpd (celui de ntp.org, pas openntpd, qui est mieux ;), dhcdbd, le mixer_applet2 de gnome, les pilotes intel i915 et ipw2100, les pilote appletouch (pour les macs) et ibm_acpi se sont révélés être de très grands consommateurs de ressources. Intel a écrit un patch dans la plupart des cas.

  • L'utilisation des graphismes 3D est souvent très gourmande (il faut donc éviter Beryl/Compiz lorsque son portable tourne sur batterie et qu'on veut économiser de l'énergie).

  • Une simple animation persistante dans le navigateur web force xorg à se réveiller régulièrement. Plus intéressant : le curseur clignotant (blinking cursor) du terminal gnome réveille xorg très souvent, même lorsque le terminal n'a pas le focus ou lorsqu'il est en arrière plan. Vous pouvez désactiver ce clignotement à partir des options de configuration de gnome-terminal.

  • Sur un macbook, on gagne une heure d'autonomie lorsqu'on décharge le module uhci_hcd (note : ce module est nécessaire pour avoir le support du clavier, mais ça donne une indication utile pour les développeurs).


Voila. À nous de jouer maintenant : avec cet outil nous pouvons très facilement repérer les gros consommateurs de ressources (pilotes et logiciels) sur nos distributions, avec notre matériel/pilotes, nos logiciels et nos configurations préférés. Apparemment les développeurs d'Intel ne se sont pas penchés sur le bureau KDE. Il serait aussi intéressant de voir l'influence de certaines options de configuration d'xorg et de comparer les divers pilotes (par ex. "ati" vs. "radeon" vs. "fglrx" ou bien "nv" vs. "nouveau" vs. "nvidia", et l'impact de leurs options de configuration respectives comme Composite, EnablePageFlip, etc.) par exemple. N'oubliez pas : pour que les résultats soient pertinents, il faut faire tourner PowerTOP avec un noyau 2.6.21 ou plus, activer CONFIG_NO_HZ, et ne pas brancher le portable sur le secteur (tourner sur la batterie).

Il nous faut remonter les problèmes dans les bugstrackers des logiciels et distributions concernés. Il y aura ainsi de fortes chances pour que les prochaines versions de nos distributions nous apportent quelques heures d'autonomie supplémentaires sur nos portables ou PDA (« plusieurs heures » est un objectif à portée de main, il me semble, si l'on considère aussi que ces distributions incluront un 2.6.21+ avec « dynticks », voir un 2.6.23 avec les corrections pour hal, et peut-être les patchs d'Intel) :)


À vos portables ! ;)

> Lire le journal (30 commentaires, moyenne: 3,3).  

Vous avez demandé le commentaire #833187.

enfin...

Posté par Albert () le 14/05/2007 à 14:44. (lien). Évalué à 3.

on va peut etre avoir des batteries sous linux qui tiennent aussi longtemps que sous windows. C'est une excellente nouvelle! Vivement que tous les changements soient inclus dans les differentes distributions. La prochaine serie d'update (niveau distribution) risque de faire de tres nombreux heureux.

  • [^]Re: enfin...

    Posté par Hrundi V. Bakshi () le 14/05/2007 à 14:53. (lien). Évalué à 5.


    aussi longtemps


    Plus ?

    [^]Re: enfin...

    Posté par darklumina () le 14/05/2007 à 14:55. (lien). Évalué à 4.

    J'ai un ThinkPad X31.
    Ma batterie tient aussi longtemps sous linux que sous windows.
    Un peu moins de 2h parce que c'est pas bien de completement décharger la batterie... sinon j'doit faire un peu plus de 2h sous linux.
    Ca tient 2h en désactivant le wifi (pas de wifi chez moi) et en utilisation bureautique + surf sans flash (abusif qui prend 100% du cpu).

    Je suis assez content, le pc est plutot réactif meme avec un vieux 4200tr/min.

    Mais j'vais faire un tour dans mon noyau et faire le ménage... j'vais peut etre grapiller quelques minutes....

    • [^]Re: enfin...

      Posté par krumtrash () le 15/05/2007 à 09:04. (lien). Évalué à 1.

      Rahhh Lovely les thinkpads et particulièrement le X31.

      C'est vraiment la rolls des portables:

      très solide (titane magnesium) et hyper rigide
      bien conçu
      design intemporel (et très beau mais ce n'est pas partager par tout le monde;-) )
      fonctionnalités qui tue (think led)
      bonne autonomie
      le trackpoint de qualité
      le touché du clavier (et sans touche windows sur les pre-lenovo)
      bien supporté par linux
      la garantie 3ans international de base

      http://www.thinkwiki.org/wiki/Category:X31

      Pour les ceusses à la recherche d'un ultra portable d'occase, je vous conseille vivement le X31 (et dérivé) qui se trouve sur les sites de ventes entre 300 et 400 Euros.
      Ca peut paraitre cher mais la qualité est vraiment au dessus des portables full plastoque, full clinquant et full marketing que l'on peut trouver actuellement.

      • [^]Re: enfin...

        Posté par Vincent P (page perso, ) le 18/05/2007 à 12:22. (lien). Évalué à 1.

        Je confirme tout ca, possédant un X41 depuis un an et demi. Clavier tip top notamment.
        Seul point noir: pour un ultraportable, on apprécierait une autonomie plus longue: 1h40-1h50 chez moi je trouve ca peu. Ca se corrige avec des batteries 9cellules ceci étant.
        Peut etre que PowerTOP changera justement un peu la donne de ce coté la en plus.

        Et 300/400¤ c'est pas tres cher, étant donné que neuves ces machines sont pas vraiment bon marché (1400¤ environ le X61 sur internet).

    [^]Re: enfin...

    Posté par Christophe Merlet (page perso, ) le 14/05/2007 à 15:36. (lien). Évalué à 1.

    C'est amusant, c'est la première fois que j'entends dire que les batteries dure plus longtemps sous Windows que sous Linux !!!