当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 8 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 编译内核模块的问题
帖子发表于 : 2008-06-18 12:13 
头像

注册: 2008-03-31 16:12
帖子: 94
送出感谢: 0 次
接收感谢: 0 次
大家好,我写了一个内核模块的helloworld程序,以演示这个问题。
以下程序我实验过。

//helloworld.c
#include <linux/module.h>
#include "rel.h"

int init_module(void)
{
printk("<1> Hello World!\n");
p("abc");

return 0;
}

void cleanup_module(void)
{
printk("<1> Goodbye!\n");
}

MODULE_LICENSE("GPL");

//--------------------------------------------------------

//rel.c

#include "rel.h"
#include <linux/module.h>

void p(char *ch)
{
printk("%s\n", ch);
}

//--------------------------------------------------------

//rel.h
#ifndef _REL_H_
#define _REL_H_

void p(char*ch);

#endif

//--------------------------------------------------------
//Makefile
obj-m+=helloworld.o
obj-m+=rel.o
KERNEL_DIR:=/lib/modules/$(shell uname -r)/build
PWD:=$(shell pwd)
all:
make -C $(KERNEL_DIR) M=$(PWD) modules
clean:
rm *.o *.ko
//--------------------------------------------------------

编译之后显示这个问题:
[root@localhost module]# make
make -C /lib/modules/2.6.23.1-42.fc8/build M=/home/zongzw/实例程序/module modules
make[1]: Entering directory `/usr/src/kernels/2.6.23.1-42.fc8-i686'
Building modules, stage 2.
MODPOST 2 modules
WARNING: "p" [/home/zongzw/实例程序/module/helloworld.ko] undefined!
make[1]: Leaving directory `/usr/src/kernels/2.6.23.1-42.fc8-i686'

该如何解决呢,看到网上有很多人碰到这个问题,但是没有看到解决方案。。。
就是在说我自己实现的这个p函数没有定义。该如何是好?

谢谢了。


页首
 用户资料  
 
2 楼 
 文章标题 :
帖子发表于 : 2008-06-18 13:32 
头像

注册: 2006-09-21 14:28
帖子: 2376
送出感谢: 0 次
接收感谢: 0 次
yuki@yuki-laptop:/tmp$ cat rel.h
#ifndef _REL_H_
#define _REL_H_

void p(char*ch);

#endif
yuki@yuki-laptop:/tmp$ cat rel.c
#include "rel.h"
#include <linux/module.h>

void p(char *ch)
{
printk("%s\n", ch);
}
yuki@yuki-laptop:/tmp$ cat helloworld.c

//helloworld.c
#include <linux/module.h>
#include "rel.h"

int init_module(void)
{
printk("<1> Hello World!\n");
p("abc");

return 0;
}

void cleanup_module(void)
{
printk("<1> Goodbye!\n");
}

MODULE_LICENSE("GPL");

#ifndef _REL_H_
#define _REL_H_

void p(char*ch);

#endif
yuki@yuki-laptop:/tmp$

yuki@yuki-laptop:/tmp$ make
make -C /lib/modules/2.6.24-19-generic/build M=/tmp modules
make[1]: Entering directory `/usr/src/linux-headers-2.6.24-19-generic'
CC [M] /tmp/helloworld.o
CC [M] /tmp/rel.o
Building modules, stage 2.
MODPOST 2 modules
WARNING: "p" [/tmp/helloworld.ko] undefined!
CC /tmp/helloworld.mod.o
LD [M] /tmp/helloworld.ko
CC /tmp/rel.mod.o
LD [M] /tmp/rel.ko
make[1]: Leaving directory `/usr/src/linux-headers-2.6.24-19-generic'
yuki@yuki-laptop:/tmp$


_________________
http://lee.youxu.info/


页首
 用户资料  
 
3 楼 
 文章标题 :
帖子发表于 : 2008-06-18 13:33 
头像

注册: 2006-09-21 14:28
帖子: 2376
送出感谢: 0 次
接收感谢: 0 次
另,编程问题应该发到 C/Java 那个板块。

请版主移动


_________________
http://lee.youxu.info/


页首
 用户资料  
 
4 楼 
 文章标题 :
帖子发表于 : 2008-06-18 14:16 
头像

注册: 2008-03-31 16:12
帖子: 94
送出感谢: 0 次
接收感谢: 0 次
不好意思,我没有看明白,你的输出中还是有那个提示啊。


页首
 用户资料  
 
5 楼 
 文章标题 :
帖子发表于 : 2008-06-18 16:44 

注册: 2007-06-13 11:25
帖子: 60
送出感谢: 0 次
接收感谢: 0 次
你的makefile有问题。
helloworld.o怎么引用rel.o中的p()??
用下面的修改试试
module-objs := helloworld.o rel.o
obj-m+=module.o


页首
 用户资料  
 
6 楼 
 文章标题 :
帖子发表于 : 2008-06-18 23:19 
头像

注册: 2006-09-21 14:28
帖子: 2376
送出感谢: 0 次
接收感谢: 0 次
我能力有限,不会:D:D


_________________
http://lee.youxu.info/


页首
 用户资料  
 
7 楼 
 文章标题 :
帖子发表于 : 2008-06-19 17:54 
头像

注册: 2008-03-31 16:12
帖子: 94
送出感谢: 0 次
接收感谢: 0 次
netstone 写道:
你的makefile有问题。
helloworld.o怎么引用rel.o中的p()??
用下面的修改试试
module-objs := helloworld.o rel.o
obj-m+=module.o


这是正确答案!!谢谢netstone

原先不明白 .o 和 -objs 是等价的。


页首
 用户资料  
 
8 楼 
 文章标题 :
帖子发表于 : 2008-06-19 17:55 
头像

注册: 2008-03-31 16:12
帖子: 94
送出感谢: 0 次
接收感谢: 0 次
flyinflash 写道:
我能力有限,不会:D:D


没事^_^


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 8 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 1 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译