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 #831986.

Compléments

Posté par herodiade () le 14/05/2007 à 16:34. (lien). Évalué à 10.

Quelques compléments en vrac :

* Concernant le coût des accès disques : ça dépend, évidement, de l'utilisation des caches.
* Le driver fglrx d'ATI est tout pourri (ah bon ? ;). Il semblerait que le driver propriétaire de NVIDIA ne soit pas brillant non plus.
* Lorsque vous faites vos mesures, laissez vos applications favorites mouler passivement en arrière plan. Inutile de constater que mencoder ou Blender en plein calculs sont gourmands : on le sait déjà, et c'est normal. De même les mesures sont plus intéressantes pour des logiciels résidant longtemps en mémoire (par exemple Thunderbird, Amarok, Lifarea, les daemons comme d-bus, esd ou avahi, etc.) que pour les logiciels qui ne tournent pas longtemps sur l'ordinateur (comme ls, cp, mv, ps, find, & co).
* Lorsque PowerTOP vous indique qu'une application est très gourmande alors qu'elle n'a pas de raison évidente de travailler (elle tourne en arrière plan, par exemple), vous pouvez savoir ce qu'elle fait avec strace -p $(pidof monapplication) et ltrace -p $(pidof monapplication)
* Beagle (beagled précisément) peut être extrêmement gourmand
* Annoncé il y a seulement 3 jours, PowerTOP est déjà intégré dans les versions de développement de Debian, Mandriva et Gentoo.
* Une nouvelle version (1.1) de PowerTOP vient de sortir. Le logiciel est maintenant capable de recommander la désactivation des daemons connus pour être gourmands et peu utiles, lorsqu'il détecte leur présence.
* L'outil blktrace permet déjà de surveiller les I/O disques ( http://www.gelato.org/pdf/apr2006/gelato_ICE06apr_blktrace_b(...) )

Quelques autres paramètres à prendre en compte pour améliorer l'autonomie de son portable :

* Préférer les portables avec de petits écrans (indication relevée sur l'IRC #powertop, où Keith Packard dit qu'il a 7h d'autonomie sur son portable à écran 10", et Arjan Van de Ven arrive à 8h ! ), ou réduire la luminosité si c'est possible.
* Les périphériques USB sont souvent alimentés par ce biais, et parfois très gourmands pour d'autres raisons encore. Les débrancher lorsqu'on ne s'en sert pas.
* Complètement désactiver le bluetooth et le wifi lorsqu'ils ne sont pas utilisés (et décharger les modules noyau qui les utilisent).
* Éviter autant que possible d'utiliser le lecteur de CD ou DVD
* Et bien sûr les autres trucs indiqués dans le journal (désactiver la 3D/Beryl, le curseur clignorant de gnome-terminal, config du kernel 2.6.21, etc...)

  • [^]Re: Compléments

    Posté par Albert () le 14/05/2007 à 20:32. (lien). Évalué à 4.

    Complètement désactiver le bluetooth et le wifi lorsqu'ils ne sont pas utilisés (et décharger les modules noyau qui les utilisent).

    C'est typiquement le genre de truc qui devrait etre configurable de facon user friendly mais encore faudrait il pouvoir degager le module du noyau sans trop de probleme (par exemple je ne suis jamais arrive a enlever completement les modules bluetooth du mon portable).

    Pourquoi pas une interface posant la question sur les periphs a degager du kernel lorsque l'on est sur batterie. Il semblerait que cela soit une truc plus que faisable maintenant. Le jour ou cela va fonctionner sur un portable pour l'utilisateur lambda ca va etre un reel changement!

    • [+] [^]Re: Compléments

      Posté par fmaz fmaz () le 15/05/2007 à 06:44. (lien). Évalué à -1.

      Pour vire un module pénible, rm marche très bien.