1. Mechanismus des Linux-Kernel-Treibermoduls Statisches Laden: Kompilieren Sie das Treibermodul in den Kernel und laden Sie es, wenn der Kernel gestartet wird. Dynamisches Laden: Kompilieren Sie das Treibermodul als ko und laden Sie es, wenn der Kernel gestartet wird. 2. Schreiben Sie den Kerneltreiber #include <linux/module.h> #include <linux/init.h> statische int __init test_init(void) { return 0; //Gib 0 zurück, um Erfolg anzuzeigen, gib eine negative Zahl zurück, um das Lademodul zu beenden} //__init Nachdem der Kernel den Treiber initialisiert hat, geben Sie den Codebefehlsbereich dieser Funktion frei static void __exit test_exit(void) { .... } //__exit gibt an, dass diese Funktion nur verwendet wird, wenn der Treiber deinstalliert und nach der Verwendung freigegeben wirdmodule_init(test_init); //Geben Sie test_init als Modulinitialisierungsfunktion anmodule_exit(test_exit); //Geben Sie test_exit als Deinstallationsfunktion zum Beenden des Moduls anMODULE_LICENSE("GPL"); //Geben Sie die unterstützten Protokolle anMODULE_AUTHOR("Autor"); MODULE_DESCRIPTION("Beschreibung"); MODULE_VERSION("Version"); #define __init __section(.init.text) #define __initdata __section(.init.data) char __initdata buf[] = "Hallo Welt"; #define __exitdata __section(.exit.data) #define __exit __section(.exit.text) ///////////// test 1768 0 - Live 0xbf03c000 Modulname, belegte Speichergröße, Anzahl der Aufrufe, Gültigkeit, Speicheradresse, an der sich das Modul befindet 3. Makefile des Treibermoduls
4. Überprüfen Sie die Treiberausgabemeldung cat /var/log/Nachrichten Schwanz /var/log/Nachrichten 5. Printk-Pegelkontrolle /usr/src/kernels/2.6.18-194.el5-i686/include/linux/kernel.h <linux/kernel.h> #define KERN_EMERG "<0>" /* System ist unbrauchbar */ #define KERN_ALERT "<1>" /* Aktion muss sofort ausgeführt werden */ #define KERN_CRIT "<2>" /* kritische Bedingungen */ #define KERN_ERR "<3>" /* Fehlerbedingungen */ #define KERN_WARNING "<4>" /* Warnbedingungen */ #define KERN_NOTICE "<5>" /* normaler, aber signifikanter Zustand */ #define KERN_INFO "<6>" /* informativ */ #define KERN_DEBUG "<7>" /* Meldungen auf Debug-Ebene */ Die Standardstufe ist Verwendung:
Wenn die von der printk-Funktion verwendete Ebene niedriger ist als die aktuelle Ebene Ändern Sie die Pegelausgabe Zusammenfassen Das Obige ist der vollständige Inhalt dieses Artikels. Ich hoffe, dass der Inhalt dieses Artikels einen gewissen Lernwert für Ihr Studium oder Ihre Arbeit hat. Vielen Dank für Ihre Unterstützung von 123WORDPRESS.COM. Wenn Sie mehr darüber erfahren möchten, schauen Sie sich bitte die folgenden Links an Das könnte Sie auch interessieren:
|
<<: Vue-Routing zum Implementieren der Login-Abfangung
>>: Tutorial zur Remote-Verbindung mit einer MySQL-Datenbank unter Linux
Um Node-red mit der Datenbank (mysql) zu verbinde...
In diesem Artikel finden Sie den spezifischen Cod...
Die Warnhinweise in diesem Artikel haben nichts m...
Normalerweise definieren wir zuerst die Dockerfil...
In diesem Artikel wird der spezifische Code für J...
Es gibt die folgenden vier häufig verwendeten Met...
Wenn Sie den Docker-Container nach dem Betreten d...
Inhaltsverzeichnis defineComponent-Überladungsfun...
In diesem Artikel wird der spezifische Code von j...
Verwendung des ALTER-Befehls in MySQL zum Bearbei...
Vorwort Wie wir alle wissen, ist in Linux alles e...
Die aktuellste Version von CentOS ist CentOS 8. A...
Inhaltsverzeichnis Kurzbeschreibung: 1. Vier Merk...
Vorwort Jede Anwendung, die in JavaScript geschri...
1. Installationsumgebung Docker unterstützt die f...