原本是开始学EDA时开的博客,但最近转向嵌入式学习,但这还是我比较喜欢和常来的地方,也非常希望走过的朋友能留下你们的足迹。QQ:94073982。ARM-Linux的学习群:群号:60696568(嵌入式Linux-s3c2410)。欢迎加入。

内核模块编译入门程序(转)

上一篇 / 下一篇  2008-04-29 15:40:33

最近手上是的工作不多,闲的慌,就想弄个linux玩玩
装的是vm + linux (redhat9 ) 2。4。20-8 的内核

下面是我实现内核模块编译平台的笔记,现在记录下来希望对碰到和我一样问题的朋友有帮助。

首先vi hello.c
原程序网上的个篇PDF文档
#define MODULE
#include <linux/module.h>

int init_module(void)
{
printk("Hello,World!\n");
return 0;
}

void cleanup_module(void)
{
printk("Goodbye cruel world \n");
}
gcc –c hello.c
出现下面的提示
hello.o: kernel-module version mismatch
hello.o was compiled for kernel version 2.4.20
while this kernel is version 2.4.20-8.

按文档修改, 是因为 内核和模块版本不一致
修改方法: /usr/include/linux/version.h 里的定义 2.4.20  改为 2.4.20-8
重新编译,正常了

然后insmod ./hello.o出现了第二个问题:

Warning: loading hello.o will taint the kernel: no ******
See http://www.tux.org/lkml/#export-tainted for information about tainted modules
Module hello loaded, with warnings

网上搜索资料,
于是知道了,在原程序中加入MODULE_******("GPL");


int init_module(void)
{
MODULE_******("GPL");
printk("Hello,World!\n");
return 0;
}

在编译后,然后 insmod ./hello.o

没有出现文档描述的那样,在终端显示 “hello world”
要执行命令:
dmesg
在最下面显示
Hello,World!

Rmmod  hello 后
再dmesg,显示
Goodbye cruel world

查看模块加载是否成功

$cat /proc/modules

或可以用
Lsmod

从中可以看到hello 这个模块,这就是我加载的。

现在看来,程序很简单,非常简单地,但对于一个linux 的layman来说, 哀,难呀

做了这么多年嵌入开发,各种型号的MCU,ARM用了是不少,但都是裸奔的, 跑过一次WINCE,后来项目还停了,也在朋友那弄个44B0的开发板玩过vxworks,. linux 这个却从未接触过地, 路还漫长的说,还好,兴趣和积极性没有被打灭 哈哈

 

再加一例:

/*helloworld.c*/
/*2008-04-30*/
#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_******("Dual BSD/GPL");

static int hello_init(void)
{
  printk("Hello world!\n");
  return 0;
}

static void hello_exit(void)
{
  printk("Goodbye,cruel world!\n");
}

module_init(hello_init);
module_exit(hello_exit);

1.gcc -O2 -DMODULE -D__KERNEL__ -c helloworld_module.c
2.insmod ./helloworld_module.o
如果出现说版本不匹配,则insmod -f ./helloworld_module.o
3.查看
lsmod或者cat /proc/modules可以看到helloworld_module
dmesg可以看到内核打印信息

(也可以tail /var/log/messages查看)

2410 挂载U盘:mount -t /dev/scsi/host0/bus0/target0/lun0/part1 /tmp/usb/


TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2008-12-05  
 123456
78910111213
14151617181920
21222324252627
28293031   

数据统计

  • 访问量: 19151
  • 日志数: 129
  • 文件数: 1
  • 建立时间: 2007-07-30
  • 更新时间: 2008-11-28

RSS订阅

Open Toolbar