<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.mkcs.at/wikien/index.php?action=history&amp;feed=atom&amp;title=Linux_Module</id>
	<title>Linux Module - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.mkcs.at/wikien/index.php?action=history&amp;feed=atom&amp;title=Linux_Module"/>
	<link rel="alternate" type="text/html" href="https://wiki.mkcs.at/wikien/index.php?title=Linux_Module&amp;action=history"/>
	<updated>2026-05-03T19:33:02Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.12</generator>
	<entry>
		<id>https://wiki.mkcs.at/wikien/index.php?title=Linux_Module&amp;diff=85&amp;oldid=prev</id>
		<title>MkWikiEnSysOp: 5 revisions imported</title>
		<link rel="alternate" type="text/html" href="https://wiki.mkcs.at/wikien/index.php?title=Linux_Module&amp;diff=85&amp;oldid=prev"/>
		<updated>2018-06-28T17:19:36Z</updated>

		<summary type="html">&lt;p&gt;5 revisions imported&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;This documents contains my experiences with Linux Kernel Module development. They are needed for my bachelor thesis #1.&lt;br /&gt;
&lt;br /&gt;
== testdev.c ==&lt;br /&gt;
&lt;br /&gt;
It is about making a kernel module like this one: [http://linux.die.net/lkmpg/x569.html The Linux Kernel Module Programming Guide - Chapter 4. Character Device Files]. I copied the source from chapter 4.1 to a file, renamed it to &amp;quot;testdev.c&amp;quot; and replaced&lt;br /&gt;
&lt;br /&gt;
 #define DEVICE_NAME &amp;quot;chardev&amp;quot;&lt;br /&gt;
&lt;br /&gt;
with&lt;br /&gt;
&lt;br /&gt;
 #define DEVICE_NAME &amp;quot;testdev&amp;quot;&lt;br /&gt;
&lt;br /&gt;
Next, I corrected an error that might be caused by either changes in the kernel interfaces or by a stricter compiler. In line 72, I removed the assignment, so that the code looks like this:&lt;br /&gt;
&lt;br /&gt;
 unregister_chrdev(Major, DEVICE_NAME);&lt;br /&gt;
&lt;br /&gt;
Then I removed the following two lines (if (ret &amp;lt; 0)...) because they don&amp;#039;t make any sense any more, because ret isn&amp;#039;t assigned any more.&lt;br /&gt;
&lt;br /&gt;
== Makefile ==&lt;br /&gt;
&lt;br /&gt;
 obj-m += testdev.o&lt;br /&gt;
 &lt;br /&gt;
 all:&lt;br /&gt;
 	make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules&lt;br /&gt;
 &lt;br /&gt;
 clean:&lt;br /&gt;
 	make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean&lt;br /&gt;
&lt;br /&gt;
== Loading and unloading ==&lt;br /&gt;
&lt;br /&gt;
Any actions takes by the kernel and the module can be watched using&lt;br /&gt;
&lt;br /&gt;
 tail -f /var/log/syslog&lt;br /&gt;
&lt;br /&gt;
Loading the kernel module:&lt;br /&gt;
&lt;br /&gt;
 insmod testdev.ko&lt;br /&gt;
&lt;br /&gt;
Yields something like the following in /var/log/syslog:&lt;br /&gt;
&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.347595] testdev: module license &amp;#039;unspecified&amp;#039; taints kernel.&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.347611] Disabling lock debugging due to kernel taint&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349748] I was assigned major number 251. To talk to&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349764] the driver, create a dev file with&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349777] &amp;#039;mknod /dev/testdev c 251 0&amp;#039;.&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349787] Try various minor numbers. Try to cat and echo to&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349798] the device file.&lt;br /&gt;
 Oct 10 06:31:27 eeepc1104 kernel: [25056.349807] Remove the device file and module when done.&lt;br /&gt;
&lt;br /&gt;
Check that module is loaded:&lt;br /&gt;
&lt;br /&gt;
 cat /proc/modules | grep &amp;quot;testdev&amp;quot;&lt;br /&gt;
&lt;br /&gt;
Outputs something like:&lt;br /&gt;
&lt;br /&gt;
 testdev 12655 0 - Live 0xf8771000 (P)&lt;br /&gt;
&lt;br /&gt;
Then create device file (see hint in /var/log/syslog):&lt;br /&gt;
&lt;br /&gt;
 mknod /dev/testdev c 251 0&lt;br /&gt;
&lt;br /&gt;
Very nice:&lt;br /&gt;
&lt;br /&gt;
 root@eeepc1104:/home/michael/Projects/Tests/testdev# cat /dev/testdev &lt;br /&gt;
 I already told you 0 times Hello world!&lt;br /&gt;
&lt;br /&gt;
Unload module:&lt;br /&gt;
&lt;br /&gt;
 rmmod testdev&lt;br /&gt;
&lt;br /&gt;
Removing device node:&lt;br /&gt;
&lt;br /&gt;
 rm /dev/testdev&lt;br /&gt;
&lt;br /&gt;
[[Category:Linux]]&lt;/div&gt;</summary>
		<author><name>MkWikiEnSysOp</name></author>
	</entry>
</feed>