Ceci est une ancienne révision du document !



HAL : Hardware Abstraction Layer

HAL est la couche d'abstraction matérielle, ainsi que l'indique son nom en anglais.

Cette couche d'abstraction est simplement une interface qui rend possible l'ajout du support pour les nouveaux périphériques et les nouvelles manières de les connecter à l'ordinateur, sans modifier chaque application qui les utilise. Il maintient une liste de périphériques qui existent actuellement et peut fournir des informations à leur sujet sur demande. Elle permet de reconnaître et d'identifier les périphériques branchés à l'ordinateur, de leur fournir une adresse système…

Hal est par exemple sollicitée à chaque branchement à chaud d'un périphérique, tel qu'une clé usb ou une imprimante.

Vous pouvez lire à ce sujet les documentations sur Udev. Hal est une dépendance de Udev
Hal est donc un élément très important de votre système d'exploitation ! Il est vital que ce composant soit installé et fonctionnel !

Hal est aussi un programme : haldaemon, aussi appelé hald, chargé au démarrage du système grace à un script (script de niveau d'execution, logé dans /etc/init.d/).
Comme de nombreux services, démons et programmes vitaux pour le système d'exploitation, hal dispose aussi de son propre compte utilisateur. Cela permet qu'en cas de bug de hal, le bug ne se répande pas ailleurs dans le système (lire à ce sujet les articles sur la gestion des droits lecture/écriture/exécution et la gestion des utilisateurs).

Il vous suffit, pour cela, d'installer les paquets hal.

Pour supprimer cette application, il suffit de supprimer son paquet. La configuration de l'application sera conservée ou supprimée selon la méthode de désinstallation que vous choisirez.

Il peut arriver que vous tombiez, lors d'une mise à jour, sur un message du genre :

stephane@lug:/etc/bcron$ sudo dpkg –configure hal
Paramétrage de hal (0.5.11~rc2-1ubuntu8.2) …
* Reloading system message bus config… [ OK ] polkit-read-auth-helper: needs to be setgid polkituser
polkit-auth: NotAuthorizedToReadAuthorizationsForOtherUsers: uid 0 is not authorized to read authorizations for uid 122 (requires org.freedesktop.policykit.read)
polkit-read-auth-helper: needs to be setgid polkituser
polkit-auth: NotAuthorizedToReadAuthorizationsForOtherUsers: uid 0 is not authorized to read authorizations for uid 122 (requires org.freedesktop.policykit.read)
dpkg : erreur de traitement de hal (–configure) :
le sous-processus post-installation script a retourné une erreur de sortie d'état1
Des erreurs ont été rencontrées pendant l'exécution :
hal

On voit bien dans ce cas qu'il s'agit d'un problème avec le compte d'utilisateur polkituser, qui intervient aussi dans la configuration de hal.

Dans ce cas, faites un usermod sur le compte problématique et sur celui de hal, afin d'étendre la validité des comptes en question :

usermod -e AAAA-MM-JJ nom-du-compte , dans lequel AAAA est l'année, MM le mois, et JJ le jour de la nouvelle date de validité.


lshal

Cette commande permet de lister les périphériques pris en compte par HAL sur l'ordinateur.

Contributeurs : stephaneguedon.

  • hal.1234628318.txt.gz
  • Dernière modification: Le 18/04/2011, 14:45
  • (modification externe)