[[Vorlage(Getestet,oneiric,natty,maverick,lucid)]] {{{#!vorlage Wissen [:Pakete_installieren: Installation von Paketen] [:Paketinstallation_DEB: Ein einzelnes Paket installieren] [:Editor: Einen Editor mit Root-Rechten öffnen] [:Terminal: Ein Terminal öffnen] [:Packprogramme: Archive entpacken] [:Programme_kompilieren: Programme kompilieren] [:GNOME_Panel: Ein Applet zum Panel hinzufügen] [:KDE_Systemeinstellungen: Ein Programm zum KDE-Autostart hinzufügen] [:Xfce_Panel: Erweiterungen für das Xfce Panel] [:Paketquellen_freischalten/PPA#PPA-hinzufuegen: PPA hinzufügen] }}} [[Inhaltsverzeichnis(2)]] [[Bild(Wiki/Icons/hd.png, 64, align=left)]] Dieser Artikel beschreibt den Softwareteil des aktiven Festplattenschutzes für IBM/Lenovo ThinkPads unter Linux, den [http://www.thinkwiki.org/wiki/HDAPS IBM Active Protection System Linux Driver (HDAPS)] {en}. Seit 2003 verfügen viele ThinkPad-Modelle auf der Hauptplatine über einen Bewegungs-Sensor, ein sogenanntes [wikipedia_en:Accelerometer:], das vor allem dazu dienen soll, den Lesearm der Festplatte im Falle eines Sturzes innerhalb von Millisekunden zu "parken", damit die Festplatte nicht beschädigt wird. Einen ähnlichen Sensor haben u.a. Notebooks von Acer (''"GraviSense"'') und Apple (''"Sudden Motion Sensor"''). In jüngerer Zeit werden bestimmte Festplatten-Modelle für Notebooks mit einem integrierten Sensor ausgestattet, meist als ''"Free Fall Sensor"'' bezeichnet. Dieser Festplattentyp sorgt ohne Softwareunterstützung eigenständig für den Parkvorgang. Die Sensordaten jedoch sind nicht für die unten beschriebenen weiteren Anwendungen zugänglich. Trotz eines vorhandenen Sensors unterstützt HDAPS jedoch nicht ThinkPads der Baureihen SL, L, Edge sowie das X100e, da hier eine andere Hardware eingesetzt wird, für die kein Treiber existiert. Aus dem gleichen Grund funktioniert HDAPS auch nicht mit Notebooks anderer Hersteller sowie mit Nicht-ThinkPad-Baureihen von Lenovo. = Installation = __Vorbemerkung:__ es ist von Vorteil die im folgenden angegebenen Pakete für Kernelmodul und Überwachungsdämon einzeln nacheinander zu installieren. Tut man es stattdessen in einem Schritt, so zieht der Überwachungsdämon zunächst ein veraltetes Kernelmodul an, was einen Neustart erforderlich macht. == Kernelmodul hdaps installieren == Das in den offiziellen Kerneln enthaltene Modul `hdaps` ist für den Festplattenschutz nicht geeignet, deshalb wird hier eine gepatchte Version aus dem Projekt [:TP-SMAPI:tp-smapi] verwendet. Zu installieren ist das Paket: {{{#!vorlage Paketinstallation tp-smapi-dkms }}} {{{#!vorlage Hinweis Die ThinkPad-Modelle T420(s), T520, W520 und X220 benötigen eine neuere Version von '''tp-smapi-dkms''' als sie in den Ubuntu-Paketquellen bis 11.04 enthalten ist. Die Installation ist in [:TP-SMAPI#ThinkPad-T420-s-T520-W520-X220: tp-smapi] beschrieben. Ab 11.10 kann das Paket aus den Ubuntu-Paketquellen verwendet werden. }}} == Überwachungsdämon hdapsd installieren == Für den Dämon ist das Paket {{{#!vorlage Paketinstallation hdapsd }}} zu installieren. = Konfiguration = Die Konfiguration des Überwachungsdämons wird in der Datei '''/etc/default/hdapsd''' vorgenommen, die mit Root-Rechten editiert werden muss [3]. {{{ START=yes # falls hdaps beim Systemstart mitgestartet werden soll DISK=sda # oder sdb, hda, hdb; je nach Festplatte bzw. Kernel; entspricht Option -d SENSITIVITY=15 # höhere Werte bedeuten geringere Empfindlichkeit und umgekehrt; entspricht Option -s FORCEENABLE="no" # hdaps für die Platte erzwingen mit "yes"; entspricht Option -f OPTIONS="" # weitere Optionen }}} Der Punkt `SENSITIVITY` stellt die Empfindlichkeit ein (''höhere'' Werte bedeuten eine ''geringere'' Empfindlichkeit). {{{#!vorlage Warnung Einige Benutzer berichten, daß mit dem Vorgabewert 15 der Schutz zu empfindlich eingestellt ist. Es empfiehlt sich daher, stets einen [#Funktionstest Funktionstest] zu machen und gegebenenfalls den Wert zu erhöhen. Andernfalls besteht die Gefahr frühzeitigen Verschleißes der Festplatte(n). }}} Die Option `-a` kann hinzugefügt werden, um bei Benutzung der internen Tastatur die Empfindlichkeit automatisch zu senken. Bei einigen Festplatten wird die HDAPS-Fähigkeit fälschlicherweise nicht erkannt; dann probehalber `FORCEENABLE="yes"` setzen. Nach einer Anpassung der Konfiguration ist stets der Dämon mit {{{#!vorlage Befehl sudo /etc/init.d/hdapsd restart }}} neu zu starten. = Funktionstest = Für den Test ist zunächst der bei der Installation automatisch im Hintergrund gestartete Dämon anzuhalten [4] {{{#!vorlage Befehl sudo /etc/init.d/hdapsd stop }}} und im Vordergrund wieder zu starten mit {{{#!vorlage Befehl sudo hdapsd -d sda -s 15 }}} Beim Funktionstest wird '''/etc/default/hdapsd''' nicht gelesen, da der Dämon direkt gestartet wird. Deshalb ist die Empfindlichkeit (und ggf. andere Optionen) wie gezeigt in der Kommandozeile anzugeben. Nun das ThinkPad sanft "schütteln"; es sollten Ausgaben ähnlich dieser erscheinen: {{{ Sun Oct 25 22:17:34 2009: Starting hdapsd Sun Oct 25 22:17:34 2009: WARNING: You did not supply any devices to protect, trying autodetection. Sun Oct 25 22:17:34 2009: Adding autodetected device: sda Sun Oct 25 22:17:34 2009: Selected interface: HDAPS Sun Oct 25 22:17:35 2009: Selected HDAPS input device: /dev/input/event21 Sun Oct 25 22:17:36 2009: parking Sun Oct 25 22:17:37 2009: un-parking Sun Oct 25 22:17:40 2009: parking Sun Oct 25 22:17:41 2009: un-parking }}} Nach dem Test den Dämon mit [[Vorlage(Tasten, ctrl+c)]] beenden und wieder im Hintergrund starten mit {{{#!vorlage Befehl sudo /etc/init.d/hdapsd start }}} == Problembehebung == === Fehlermeldung "Error! Not parked ..." === Erscheint beim Funktionstest die Meldung {{{ Error! Not parked when we thought we were... (paged out and timer expired?) }}} so gibt es zwei mögliche Ursachen: 1. Es laufen mehrere Instanzen des Dämons, die sich gegenseitig in die Quere kommen 1. Die Festplatte ist nicht HDAPS-fähig (gilt insbesondere, wenn schon `FORCEENABLE="yes"` gesetzt ist) Den ersten Fall kann man überprüfen mit {{{#!vorlage Befehl ps -ef | grep hdapsd | grep -v grep }}} Wenn keine Ausgabe erfolgt, ist kein Dämon gestartet. Andernfalls stoppt man alle Instanzen mit {{{#!vorlage Befehl sudo killall hdapsd }}} und prüft erneut wie oben gezeigt. Schlägt danach der Funktionstest erneut mit derselben Meldung fehl, so trifft die zweite Möglichkeit zu. In diesem Fall könnte ein Firmware-Update der Festplatte Abhilfe schaffen. Auf dieser [http://www.thinkwiki.org/wiki/Problem_with_APS_harddisk_parking#Supported.2Funsupported_harddrive_firmwares Seite] {en} sind bekannte, nicht funktionierende Festplatten bzw. Firmware-Versionen mit "not parked" gekennzeichnet. === Fehlermeldung "WARNING: Could not find hdaps input device ..." === Die Ausgaben {{{ WARNING: Could not find hdaps input device (No such file or directory). You may be using an incompatible version of the hdaps module. Falling back to reading the position from sysfs (uses more power). Use '-y' to silence this warning. Could not open /sys/devices/platform/hdaps/sampling_rate: No such file or directory. Do you have the hdaps module loaded? }}} weisen darauf hin, daß das [#Kernelmodul-hdaps-installieren Installieren des Kernelmoduls] fehlgeschlagen ist. Dadurch wird das ungeeignete Modul `hdaps` aus dem Standard-Kernel verwendet. Dies kann man zusätzlich mit dem folgendem Befehl prüfen {{{#!vorlage Befehl modinfo hdaps }}} Das ''falsche'' Modul aus dem Standard-Kernel liefert {{{ filename: /lib/modules/KERNEL-VERSION/drivers/hwmon/hdaps.ko ... }}} Das ''richtige'' Modul aus '''tp-smapi-dkms''' liefert {{{ filename: /lib/modules/KERNEL-VERSION/updates/dkms/hdaps.ko ... }}} === Fehlermeldung "Could not find a suitable interface" === Die Ausgabe {{{ Could not find a suitable interface }}} weist darauf hin, dass das Modul `hdaps` nicht geladen werden konnte. Weitere Informationen zur Ursache liefert der Befehl {{{#!vorlage Befehl sudo modprobe -v hdaps }}} Sollte dort die Ausgabe {{{ WARNING: Error inserting thinkpad_ec (/lib/modules/.../thinkpad_ec.ko): No such device or address }}} erscheinen, so sollte man mit den in [http://wiki.ubuntuusers.de/tp-smapi#Problembehebung tp-smapi (Abschnitt Problembehebung)] beschriebenen Maßnahmen fortfahren. === Fehlermeldung "Could not read from /sys/block/sda/device/unload_heads ..." === Ursache der Meldungen {{{ Could not read from /sys/block/sda/device/unload_heads: Operation not supported Could not detect any devices. }}} ist, dass die Festplatte nicht HDAPS-fähig ist bzw. die Fähigkeit nicht erkannt wird. Letzteres ist bei älteren IDE-Festplatten nach dem ATA-Standard < 7 der Fall. Solche Festplatten erkennt man an der Ausgabe des Befehls {{{#!vorlage Befehl sudo hdparm -I /dev/sda }}} {{{ Standards: Used: ATA/ATAPI-6 T13 1410D revision 3a Supported: 6 5 4 }}} Zur Behebung kann man versuchsweise `hdapsd` mit der Option `-f` (und Angabe des Geräts) aufrufen: {{{#!vorlage Befehl sudo hdapsd -d sda -s 15 -f }}} War der Test mit `-f` erfolgreich, kann man die Einstellung in '''/etc/default/hdaps''' übernehmen: {{{ FORCEENABLE="yes" }}} {{{#!vorlage Hinweis Um in diesem Fall sicherzustellen, daß die Köpfe tatsächlich geparkt werden, sollte man auf das beim Parken entstehende leise Klickgeräusch achten! }}} Erscheint hingegen mit `-f` die Fehlermeldung {{{ Error! Not parked ... }}} so ist höchstwahrscheinlich die Festplatte nicht HDAPS-fähig. Weitere Hinweise dazu im betreffenden [#Fehlermeldung-Error-Not-parked Abschnitt]. = Optionale Anwendungen = Um den aktuellen Zustand der Festplatte dauernd im Blick zu haben, existieren einige Panel-Applets und Visualisierungsprogramme, welche die Daten des Sensors und das Verhalten des HDAPS-Dämons überwachen und darstellen. Inzwischen sind aber auch eine Reihe eher spielerischer Anwendungen entstanden, welche auf die Ablesungen insbesondere des Sensors zurückgreifen, um durch Klopfzeichen oder Schwenken des Laptops Prozesse auszulösen und Programme zu steuern. Einige Beispiele hierzu sind [#Weitere-HDAPS-basierte-Anwendungen am Ende dieses Artikels] zusammengetragen. == Panel-Anzeige des Festplattenschutzes == Für den [:Avant_Window_Navigator:] gibt es das ThinkHDAPS Applet. === Unter Gnome === Gnome-Benutzern stehen das '''gnome-hdaps-applet''' und [https://github.com/thpani/thinkhdaps HDAPSicon] {en} zur Verfügung. gnome-hdaps-applet ist im [http://thinkpad-wiki.org/Ubuntu_ThinkPad_Extras_PPA ThinkPad Extras PPA] (ab Ubuntu 10.04) erhältlich, das als Paketquelle freizuschalten [10] ist: [[Vorlage(PPA, linrunner/thinkpad-extras, key 02D65EFF, lucid, maverick, natty)]] Anschließend installiert man das Paket: {{{#!vorlage Paketinstallation gnome-hdaps-applet, ppa }}} Alternativ kann man gnome-hdaps-applet aus dem Quellcode übersetzen. Dazu wird folgendes Paket benötigt [1]: {{{#!vorlage Paketinstallation libpanel-applet2-dev }}} Der Quellcode des Applet kann [http://www.zen24593.zen.co.uk/hdaps/ hier] {en} heruntergeladen werden, nach dem Entpacken [6] ist es mit folgendem Befehl zu kompilieren [6]: {{{#!vorlage Befehl gcc $(pkg-config --cflags --libs libpanelapplet-2.0) -o gnome-hdaps-applet gnome-hdaps-applet.c }}} Das Programm ist nun nach '''/usr/bin/''' zu kopieren; zudem ist in '''/usr/share/pixmaps/''' ein Unterordner '''gnome-hdaps-applet''' zu erstellen, in welchen die '''png'''-Dateien aus dem Archiv zu kopieren sind: {{{#!vorlage Befehl sudo cp gnome-hdaps-applet /usr/bin/ # Programm nach /usr/bin/ kopieren sudo mkdir /usr/share/pixmaps/gnome-hdaps-applet/ # Unterordner gnome-hdaps-applet erstellen sudo cp *.png /usr/share/pixmaps/gnome-hdaps-applet/ # png-Dateien kopieren sudo cp GNOME_HDAPS_StatusApplet.server /usr/lib/bonobo/servers/ # kopiert GNOME_HDAPS.. nach /usr/lib/bonobo/servers/ }}} Nach erfolgter Installation kann das Applet auf dem üblichen Weg [7] zum Panel hinzugefügt werden. === Unter KDE === ==== Installation aus dem Quellcode ==== Auch für KDE-Benutzer steht mit [http://www.kde-apps.org/content/show.php?content=41710 khdapsmonitor] {en} ein Panel-Applet zur Verfügung. Zum Kompilieren werden folgende Pakete benötigt: {{{#!vorlage Paketinstallation kdelibs4-dev libqt4-dev automake }}} Nach dem Herunterladen und Entpacken des Quellcode-Archivs ist es mit dem Linux-üblichen Dreischritt zu kompilieren und zu installieren: {{{#!vorlage Befehl ./configure --without-arts make sudo make install }}} {{{#!vorlage Hinweis Ab Ubuntu 8.10 bzw. Kernel 2.6.27 ist es erforderlich, zuvor den Quellcode mit diesem [attachment:Festplattenschutz/khdapsmonitor-0.1-2.patch:Patch] {dl} zu versehen. }}} Nach erfolgter Installation kann unter ''"Menü -> Rechner -> Systemeinstellungen -> Erweitert -> Autostart"'' das Programm ''"System -> KHDAPSMonitor"'' zum Autostart hinzugefügt werden [8]. ==== Installation aus einem PPA ==== Für Ubuntu Lucid Lynx 10.04 existiert ein PPA, aus dem das Programm installiert werden kann. [[Vorlage(PPA, dominik-stadler/dsta-lucid-ppa, key 29E526FC, lucid)]] Anschließend kann man das notwendige Paket {{{#!vorlage Paketinstallation khdapsmonitor, ppa }}} installieren. Nach erfolgreicher Installation ist nur noch das Icon in den Systemabschnitt der Kontrollleiste zu bringen. Dazu muss man im Programm ''"Systemeinstellungen -> Erweitert -> [:Autostart:]"'' ein neues Programm hinzufügen. Dazu klickt man auf den Knopf ''"Programm hinzufügen..."'' um ein Programm hinzuzufügen. In diesen Fall gibt man dann einfach ''"khdapsmonitor"'' ein, bestätigt und wählt dann das richtige Icon aus. Nach einer Neuanmeldung ist das Icon im Systemabschnitt der Kontrollleiste zu finden. === Unter Xfce === Seit Ubuntu 9.10 gibt es auch für Xfce ein Plugin zum Visualisieren des HDAPS-Status. Dazu installiert man das Paket {{{#!vorlage Paketinstallation xfce4-hdaps }}} und fügt danach das Applet dem Panel hinzu [10]. === Unter Unity === Seit Ubuntu 11.04 und der Umstellung auf [:Unity:], existiert das Gnome-Panel nicht mehr. Darum kann '''gnome-hdaps-applet''' nicht mehr verwendet werden. Unity-Benutzern steht alternativ [http://gnome-hdaps-osd.sourceforge.net/ gnome-hdaps-osd] zur Verfügung. Diese Lösung ist auch kompatibel zu GNOME 3. == Visualisierungen der Raumlage == [[Bild(hdaps-gl.png, 400, align=right)]] Es bestehen verschiedene kleine Anwendungen, die die aktuelle Raumlage des Laptops anzeigen können. Empfohlen sei hier [http://sourceforge.net/projects/hdaps/files/hdaps-gl/ hdaps-gl] {en}. === Installation aus PPA === Seit Ubuntu 9.10 ist für das Programm kein Paket mehr aus den offiziellen Ubuntu-Quellen erhältlich. Es ist jedoch aus dem [:Festplattenschutz#Unter-Gnome: oben bereits erwähnten ThinkPad Extras PPA] verfügbar. Nach Freischaltung des PPA [10] installiert man das Paket {{{#!vorlage Paketinstallation hdaps-utils, ppa }}} [[Vorlage(Fremd, Quelle)]] Die Echtzeit-Visualisierung kann danach mit folgendem Befehl aufgerufen werden [4]: {{{#!vorlage Befehl hdaps-gl }}} Beim Neigen des Notebooks bleibt die Raumlage des von '''hdaps-gl''' angezeigten Notebooks stabil. Neigt es sich in die falsche Richtung, so ist [#Orientierung-der-Raumachsen-korrigieren die Orientierung der Raumachsen zu korrigieren]. Ähnliche Funktionen bieten das [sourceforge:hdaps/files/hdapsgl-applet: hdapsgl-applet] {en} und [sourceforge:hdaps/files/wmhdaps/:wmhdaps] {en}. Mit '''hdaps-utils''' wird auch ein Programm namens `hdaps-pivot` installiert, das Lageveränderungen numerisch an die Konsole ausgibt. Es wird mit folgendem Befehl gestartet: {{{#!vorlage Befehl hdaps-pivot }}} Dieselben Funktionen bieten als Panel-Applet auch [http://sourceforge.net/projects/hdaps/files/gnome-tilt/ gnome-tilt] {en} und die [http://members.dslextreme.com/users/billw/gkrellm/gkrellm.html GKrellM]-Erweiterung [http://sourceforge.net/projects/hdaps/files/gkhdaps/ gkhdaps] {en} . Eine spielerische Visualisierung der Laptop-Raumlage bietet [http://www.cs.cmu.edu/~ecc/software.html Gyroscope] {en}, das die Bildschirmausgabe auch bei schief stehendem Laptop horizontal belässt. == Orientierung der Raumachsen korrigieren == {{{#!vorlage Hinweis Die hier beschriebene Konfiguration ist für eine korrekte Funktion nur des Festplattenschutzes nicht notwendig! }}} Das Kernelmodul '''hdaps''' enthält eine Tabelle mit den richtigen Voreinstellungen für die Orientierung der Raumachsen vieler ThinkPad-Modelle. Für eine Änderung dieser Voreinstellungen (auch im Fall unbekannter Modelle) ist entweder beim Laden des Kernelmoduls '''hdaps''' der Modul-Parameter ``invert`` oder zur Laufzeit das Sysfs-Attribut '''/sys/devices/platform/hdaps/invert''' einzustellen. ||<-3 rowclass="titel" tablestyle="width: 30%; text-align: right; float: right; margin-left: 15px"> Parameter invert || || Wert || R || P || || 0 || X || Y || || 1 || -X || -Y || || 2 || -X || Y || || 3 || X || -Y || || 4 || Y || X || || 5 || -Y || -X || || 6 || -Y || X || || 7 || Y || -X || Der Parameter `invert` kann die Werte 0 bis 7 annehmen. In der nebenstehenden Tabelle geben X und Y die Ausgänge des Sensors, R ein seitliches Neigen des Notebooks und P ein Neigen nach vorne oder hinten an. Am einfachsten ermittelt man die richtige Einstellung durch Ausprobieren: {{{#!vorlage Befehl sudo sh -c "echo W > /sys/devices/platform/hdaps/invert" hdaps-gl }}} wobei `W` durch den gewünschten Wert zu ersetzen ist. Nach jeder Änderung des Parameters muß '''hdaps-gl''' neu gestartet werden. Soll die so ermittelte Einstellung dauerhaft eingerichtet werden, ist mit einem Editor mit Root-Rechten[4] die Konfigurationsdatei '''/etc/modprobe.d/hdaps.conf''' mit folgendem Inhalt zu erstellen: {{{ options hdaps invert=W }}} = Links = == Intern == * [:TP-SMAPI: tp-smapi] – ThinkPad-spezifische Akkufunktionen * [:Accelerometer:] – Auslesen des Beschleunigungssensors bei Apple MacBooks == Allgemeine Informationen == * [http://www.pc.ibm.com/presentations/us/thinkvantage/56/index.html?shortcut=aps& APS-Video von IBM] {en} * Die Einträge im [http://www.thinkwiki.org ThinkWiki] zu [http://www.thinkwiki.org/wiki/Active_Protection_System APS], [http://www.thinkwiki.org/wiki/HDAPS HDAPS] und [http://www.thinkwiki.org/wiki/Tp_smapi tp-smapi] (alle {en} ) * [https://sourceforge.net/mailarchive/forum.php?forum_name=hdaps-devel Mailingliste der Entwickler des Linux-Treibers] {en} * Technische Daten zum Sensor [http://www.analog.com/en/prod/0,2877,ADXL320,00.html http://www.analog.com/en/prod/0,2877,ADXL320,00.html] {en} == Weitere HDAPS-basierte Anwendungen == === Kommandos auslösen über den HDAPS-Sensor === * Arbeitsfläche wechseln durch Antippen des Laptops: [http://weblogs.mozillazine.org/gerv/archives/2006/09/stablilised_smackpad.html SmackPad] {en} bzw. [http://www.gnome.org/~fherrera/gtollina.c gtollina] {es} und [http://people.ksp.sk/~mic/Projects/Rotate rotate.py] {sk} für [:Compiz:]-Benutzer. * Beliebige Befehle auslösen, Programme starten, Passworteingaben ersetzen durch [http://www-128.ibm.com/developerworks/linux/library/l-knockage.html?ca=dgr-lnxw01Knock-Knock Klopfzeichen an den Bildschirmrand] {en} oder durch [http://www.ibm.com/developerworks/opensource/library/os-linuxthinkpad/ Schwenken des ganzen Laptops] {en} === Programme und Programmsteuerungen === * Spiele wie [http://developer.berlios.de/projects/ppracer/ Planet Penguin Racer] {en} und [http://neverball.org/ Neverball] {en} über Laptop-Schwenkungen steuern: [http://www.almaden.ibm.com/cs/people/marksmith/sdl.html Accelerometer Game Control] {en} * Einen Bewegungs-Alarm einbauen: [http://www.thinkwiki.org/wiki/Script_for_theft_alarm_using_HDAPS] {en} (Vorsicht: dies ist kein wirksamer Diebstahlschutz!) == Fremdquellen == * [http://thinkpad-wiki.org/Ubuntu_ThinkPad_Extras_PPA Ubuntu ThinkPad Extras PPA] {de} – Pakete aus dem Abschnitt [:Festplattenschutz#Optionale-Anwendungen: Optionale Anwendungen], Kernel mit PHC-Patch und andere Zusätze # tag: Hardware, System, Notebook