Dieser Artikel ist größtenteils für alle Ubuntu-Versionen gültig.
Dieser Artikel beschreibt den Umgang mit Kernelmodulen und den Hilfsmitteln, die das System bietet, um Module zu verwalten.
Grundsätzlich besitzt der Linux-Kernel einen monolithischen Aufbau, allerdings bietet er auch die Möglichkeit, Module zur Laufzeit zu laden und entladen. Unter einem Kernelmodul versteht man im Allgemeinen einen Teil bzw. eine Erweiterung des Kernels. So sind z.B. alle Hardwaretreiber (z.B. WLAN-Karte, Soundkarte...) als Modul angelegt.
Die meisten Linux-Distributionen inklusive Ubuntu machen starken Gebrauch von Kernelmodulen, da so die bestmögliche Hardwarekompatibilität mit nur einem "allgemeinen" Kernel erreicht werden kann. In der Regel werden alle notwendigen Module beim Systemstart und falls nötig zur Laufzeit geladen, so dass der Nutzer sich nicht weiter darum kümmern muss (bzw. es oft noch nicht einmal mitbekommt).
Installiertes Werkzeug für den Umgang mit den Modulen sind kmod bzw. die module-init-tools. Etwa um 2012 wurden letztere vom Projektleiter allerdings zu einem toten Projekt erklärt und nicht weiter verfolgt, module-init-tools wurden durch das neuere Werkzeug kmod ersetzt. In den noch unterstützten Versionen von Ubuntu z.B. Trusty Tahr die noch module-init-tools neben kmod nutzen, sind diese als Übergangspaket zur Unterstützung von kmod implementiert. Ab Ubuntu Xenial Xerus ist nur noch kmod in der Standardinstallation enthalten.
Weitere Hinweise für die Anwendung von kmod siehe
man kmod
Die Programme zum Umgang mit den Modulen sind grundsätzlich in der Standardinstallation enthalten, können aber ansonsten über die Pakete
kmod
mit apturl
Paketliste zum Kopieren:
sudo apt-get install kmod
sudo aptitude install kmod
bzw. bis einschließlich Precise:
module-init-tools
mit apturl
Paketliste zum Kopieren:
sudo apt-get install module-init-tools
sudo aptitude install module-init-tools
installiert werden [1].
Installiert man in neueren Ubuntu Versionen module-init-tools, so wird kmod als Abhängigkeit vorausgesetzt. Daraus folgt, kmod ist zwar das neuere Werkzeug, arbeitet aber auch unter module-init-tools. Grundsätzlich kann aber das Werkzeug module-init-tools bei Nutzung von kmod entfernt werden.
Im Folgenden werden einige wichtige Befehle für den Umgang mit Modulen kurz vorgestellt. Alle Befehle werden im Terminal [2] aufgerufen. Das Laden, Entladen sowie Erstellen von Abhängigkeiten erfordert Root-Rechte!
Mit den Befehlen
kmod list
oder
lsmod
können alle aktuell geladenen Module angezeigt werden. lsmod
wie auch kmod list
kennen keine weiteren Optionen, die Ausgaben sind identisch. Beispielausgabe:
Module Size Used by btrfs 835954 0 raid6_pq 97812 1 btrfs xor 21411 1 btrfs ufs 74890 0 qnx4 13317 0 hfsplus 107516 0 hfs 54677 0 minix 36140 0 ntfs 97369 0 msdos 17332 0 jfs 181348 0 xfs 912173 0 libcrc32c 12644 2 xfs,btrfs nls_iso8859_1 12713 0 usb_storage 62209 0 pci_stub 12622 1 vboxpci 23194 0 vboxnetadp 25670 0 vboxnetflt 27613 0 vboxdrv 409768 3 vboxnetadp,vboxnetflt,vboxpci bnep 19624 2 rfcomm 69160 0 bluetooth 391196 10 bnep,rfcomm joydev 17381 0 fglrx 8085343 587 kvm_amd 59987 0 snd_hda_codec_hdmi 46254 1 kvm 451511 1 kvm_amd snd_hda_codec_realtek 61438 1 snd_hda_intel 52355 9 edac_core 62291 0 snd_hda_codec 192906 3 snd_hda_codec_realtek,snd_hda_codec_hdmi,snd_hda_intel snd_seq_midi 13324 0 k10temp 13126 0 serio_raw 13462 0 snd_seq_midi_event 14899 1 snd_seq_midi snd_hwdep 13602 1 snd_hda_codec snd_rawmidi 30144 1 snd_seq_midi edac_mce_amd 22617 0 snd_pcm 102099 3 snd_hda_codec_hdmi,snd_hda_codec,snd_hda_intel snd_page_alloc 18710 2 snd_pcm,snd_hda_intel sp5100_tco 13979 0 snd_seq 61560 2 snd_seq_midi_event,snd_seq_midi i2c_piix4 22155 0 snd_seq_device 14497 3 snd_seq,snd_rawmidi,snd_seq_midi snd_timer 29482 2 snd_pcm,snd_seq amd_iommu_v2 19054 1 fglrx wmi 19177 0 snd 69238 29 snd_hda_codec_realtek,snd_hwdep,snd_timer,snd_hda_codec_hdmi,snd_pcm,snd_seq,snd_rawmidi,snd_hda_codec,snd_hda_intel,snd_seq_device,snd_seq_midi mac_hid 13205 0 soundcore 12680 1 snd parport_pc 32701 0 ppdev 17671 0 it87 43113 0 hwmon_vid 12783 1 it87 lp 17759 0 parport 42348 3 lp,ppdev,parport_pc pata_acpi 13038 0 hid_generic 12548 0 usbhid 52570 0 hid 106148 2 hid_generic,usbhid psmouse 106678 0 pata_atiixp 13271 0 r8169 67581 0 ahci 25819 6 mii 13934 1 r8169 libahci 32560 1 ahci
Wie man sieht, wird in der ersten Spalte der Modulname angezeigt, in der zweiten Spalte der belegte Speicher in Bytes und in der dritten Spalte die Anzahl der Prozesse und Module, die dieses Modul benutzen, gefolgt von einer Liste der Modulnamen, die dieses Modul benutzen.
Mit Hilfe des Befehls modinfo
werden Informationen zu einem bestimmten Modul angezeigt. Die allgemeine Syntax lautet:
modinfo MODULNAME
wobei MODULNAME
durch das entsprechende Modul ersetzt werden muss. Beispiel:
modinfo snd
Ausgabe:
filename: /lib/modules/2.6.20-15-generic/kernel/sound/core/snd.ko alias: char-major-116-* license: GPL description: Advanced Linux Sound Architecture driver for soundcards. author: Jaroslav Kysela <perex@suse.cz> srcversion: 3BE4E61EB0303AD5846B8A6 depends: soundcore vermagic: 2.6.20-15-generic SMP mod_unload 586 parm: major:Major # for sound driver. (int) parm: cards_limit:Count of auto-loadable soundcards. (int)
Wie man sieht, erfolgt die Ausgabe zeilenweise sortiert nach verschiedenen Kategorien. Diese sind für alle Module gleich. Interessant ist die Zeile "depends", da man hier sieht, von welchen Modulen dieses Modul abhängt. "Abhängt" bedeutet, dass das entsprechende Modul oder ggf. auch mehrere Module geladen sein müssen, bevor dieses Modul geladen werden kann. Dies ist besonders bei Verwendung von insmod von Interesse.
modinfo kennt einige Optionen, welche in den Manpages ausgeführt sind.
Mit modprobe
können Module zur Laufzeit des Systems ge- und entladen werden. modprobe löst dabei automatisch Abhängigkeiten auf, d.h. wenn das zu ladende Modul andere Module voraussetzt, werden diese automatisch in der richtigen Reihenfolge mit geladen bzw. werden Module automatisch mit entfernt, welche nur aus Abhängigkeitsgründen geladen wurden. Dies setzt allerdings voraus, dass die Abhängigkeiten richtig hinterlegt sind, siehe Abschnitt depmod.
Die allgemeine Syntax von modprobe lautet:
sudo modprobe OPTIONEN MODULNAME(N)
Die gängigsten Optionen sind :
Optionen von modprobe | |
Option | Beschreibung |
-v | Man erhält eine ausführliche Ausgabe der Aktionen von modprobe. |
-n oder --dry-run | Simuliert das Laden des Moduls, lädt es aber nicht. |
-a | Es werden alle in der Kommandozeile angegebenen Module geladen. Diese Option muss immer dann verwendet werden, wenn mehrere Module auf einmal geladen werden sollen. |
--show-depends | Es werden alle Abhängigkeiten des Moduls angezeigt. |
-r | die angegebenen Module werden entladen. |
Eine vollständige Übersicht erhält man in den Manpages zu modprobe.
Möchte man ein Modul bei jedem Systemstart laden, so muss man nicht jedes Mal modprobe ausführen, sondern automatisiert den Vorgang.
Module können auch - alternativ zu modprobe - mit dem Befehl insmod
geladen werden. Die Verwendung von insmod hat allerdings den Nachteil, dass eventuelle Abhängigkeiten der Module nicht automatisch aufgelöst werden. insmod lädt ein Modul nur, wenn alle Abhängigkeiten erfüllt sind bzw. vorher "von Hand" aufgelöst wurden. Daher wird insmod im täglichen Betrieb eher selten verwendet.
Die allgemeine Syntax von insmod lautet:
sudo insmod MODULNAME
Eine zweite Möglichkeit, ein Modul aus dem Speicher zu entfernen ("entladen"), ist der Befehl rmmod
. Im Gegensatz zu modprobe -r
werden Module, die aus Abhängigkeitsgründen zum entfernenden Modul im Kernel geladen wurden, nicht mit entfernt.
Die allgemeine Syntax von rmmod lautet:
sudo rmmod OPTIONEN MODULNAME
Für den "normalen" Betrieb benötigt man in der Regel keine Optionen. Diese sind in den Manpages zu rmmod aufgeführt.
Manche Module können erst genutzt bzw. geladen werden, wenn andere Module geladen sind, da sie von diesen abhängen. Diese Abhängigkeiten sind in der Datei /lib/modules/<Kernelversion>/modules.dep hinterlegt. Diese Datei mit korrekt angelegten Abhängigkeiten wird bei der Installation von Ubuntu hinterlegt, so dass keine Änderungen vorgenommen werden müssen. Installiert man zusätzliche eigene Module, so sollte die Datei modules.dep neu erstellt werden. Dies geschieht über den Befehl depmod
.
Die allgemeine Syntax von depmod lautet:
sudo depmod OPTIONEN
Die zwei wichtigsten Optionen sind:
Optionen von depmod | |
Option | Beschreibung |
-A | Es wird zuerst geprüft, ob neue Module hinzugekommen sind. Wenn nicht wird keine neue Datei erstellt. |
-n | Das Erstellen der neuen Datei wird simuliert, ohne die Aktionen wirklich durchzuführen. |
Die weiteren Optionen sind in der Manpage von depmod aufgeführt.
Möchte man ein Modul, welches der Kernel nicht automatisch mit lädt, beim Systemstart automatisch laden, so trägt man den Modulnamen einfach in die Datei /etc/modules ein. Dazu öffnet man diese Datei mit einem Editor mit Root-Rechten [3] und macht die entsprechenden Einträge, wobei pro Zeile nur ein Modulname eingetragen werden darf. Ab dem nächsten Systemstart werden alle Module (zusätzlich) geladen, die dort eingetragen sind.
Soll ein Modul immer mit einer bestimmten Option geladen werden, kann dies über eine entsprechenden Konfigurationsdatei in /etc/modprobe.d festgelegt werden. Diese Datei existiert nicht standardmäßig - wenn sie gebraucht wird, muss sie mit Root-Rechten [3] angelegt werden. Es gibt nur einen Eintrag pro Zeile. Um eine Option zu setzen, beginnt man mit einem options
:
options modulname_1 optionenname_1=XX options modulname_2 optionenname_2=YY
Mehrere Moduloptionen setzen:
options modulname optionenname_a=XX optionenname_b=XX optionenname_c=XX
Beispiel:
options iwlwifi 11n_disable=1 fw_restart=1
Die benötigte Datei /etc/modprobe.d/MODULNAME_options.conf einschließlich der Optionseinträge für ein bestimmtes Kernelmodul kann sehr einfach durch eine einzige Befehlszeile im Terminal [2] angelegt werden.
Über einen kombinierten Shell-Befehl wird die Datei mit entsprechendem Inhalt erzeugt:
echo "options MODULNAME optionenname_a=XX optionenname_b=XX" | sudo tee /etc/modprobe.d/MODULNAME_options.conf
Siehe auch Shell/Umleitungen
Beispiel:
echo "options iwlwifi 11n_disable=1 fw_restart=1" | sudo tee /etc/modprobe.d/iwlwifi_options.conf
Welche Optionen das verwendete Kernelmodul bietet zeigen folgende Abfragen:
modinfo MODULNAME -F parm modinfo MODULNAME | grep parm
Siehe auch grep
Beispiel:
modinfo iwlwifi -F parm modinfo iwlwifi | grep parm
Die Optionen werden nach einem Systemneustart oder manuellem entladen/laden des Moduls übernommen.
Unter bestimmten Umständen kann es sinnvoll sein, das Laden von bestimmten Modulen explizit zu verbieten. Dies geschieht durch den Eintrag des entsprechenden Moduls in eine so genannte Blacklist-Datei. Diese Dateien befinden sich im Verzeichnis /etc/modprobe.d. In der Regel sind schon einige Einträge in der /etc/modprobe.d/blacklist.conf zu finden.
Die Datei legt man mit einem Editor mit Root-Rechten an [3] (bzw. öffnet eine vorhandene Datei) und fügt einen Dateieintrag nach folgendem Schema hinzu, je ein Eintrag pro Zeile:
blacklist modulname_1 blacklist modulname_2
Die Sperrlisten haben üblicherweise den Namen blacklist-Modulname.conf, d.h. der Dateiname kann frei gewählt werden, sollte aber mit dem Präfix blacklist- beginnen um direkt über die Funktion zu informieren. Darüber hinaus existiert auch eine "allgemeine" Datei, die nur den Namen blacklist.conf trägt. Diese Datei sollte man allerdings nicht komplett überschreiben, sondern bei Bedarf weitere Einträge anhängen.
Auch hier kann dies über einen kombinierten Shell-Befehl in einem Zug durchgeführt werden:
Eintrag an bestehende Sperrliste /etc/modprobe.d/blacklist.conf anhängen:
echo "blacklist prism54" | sudo tee -a /etc/modprobe.d/blacklist.conf
Neue Sperrliste anlegen bzw. bestehende überschreiben:
echo "blacklist prism54" | sudo tee /etc/modprobe.d/blacklist_prism54.conf
Siehe auch Shell/Umleitungen
Sollte ein benötigtes Modul nicht automatisch bei Systemstart geladen werden, so kann dies an einem entsprechenden Sperreintrag liegen. Bestehende Sperrlisten nach einem Eintrag mittels grep durchsuchen:
grep -i MODULNAME /etc/modprobe.d/*
Beispiel:
grep -i prism54 /etc/modprobe.d/*
Entsprechende Einträge wie oben gezeigt mittels grep suchen und über sed auskommentieren, Modul also wieder entsperren:
sudo sed -i "s/blacklist MODULNAME/#blacklist MODULNAME/g" $(egrep -lo 'blacklist MODULNAME' /etc/modprobe.d/*)
Beispiel:
sudo sed -i "s/blacklist prism54/#blacklist prism54/g" $(egrep -lo 'blacklist prism54' /etc/modprobe.d/*)
Manchmal kann es erforderlich sein, das initramfs mit dem Befehl update-initramfs -u
zu aktualisieren, wenn die Module trotz Blacklisting nach einem Neustart wieder geladen werden.
Wer wissen möchte, welche Module auf dem eigenen Rechner verfügbar (nicht geladen!) sind, der kann sich mit dem Befehl [2]
basename -s ".ko" $(find /lib/modules/$(uname -r) -type f -name "*.ko")
eine komplette Liste anzeigen lassen. Allerdings ist die Liste extrem lang (der Kernel bringt mehrere hundert Module mit...), daher ist es eventuell günstiger, die Modulverzeichnisse mit einem Dateimanager zu durchforsten. Die Module liegen alle in den Unterverzeichnissen von /lib/modules/KERNELVERSION/kernel/
Module-Assistant - Module nachträglich erstellen und installieren
DKMS - Module automatisch aktualisieren
Diese Revision wurde am 14. November 2016 02:29 von noisefloor erstellt.