aaa.c中有一个函数
int myadd(int a, int b){
return a+b;
}
并使用 aaa.c 构建到静态库中
gcc -c aaa.c -o aaa.o && ar -cr libaaa.a aaa.o
和一个共享库使用
gcc -c aaa.c -o aaa.o && gcc -shared -fPCI -o libaaa.so aaa.o
然后我写了一个文件call.c,并尝试调用函数myadd()
在 libaaa.so 中,但失败了。
请给我一些建议,
test.c:
#include <linux/init.h>
#include <linux/module.h>
#include <linux/kernel.h>
MODULE_LICENSE("Dual BSD/GPL");
extern int myadd(int a, int b);
static int hello_init(void)
{
int c = 0;
printk(KERN_ALERT "hello,I am Destiny\n");
c = myadd(1, 2);
printk(KERN_ALERT "res is (%d)\n", c);
return 0;
}
static void hello_exit(void)
{
printk(KERN_ALERT "goodbye,kernel\n");
}
module_init(hello_init);
module_exit(hello_exit);
MODULE_AUTHOR("Destiny");
MODULE_DESCRIPTION("This is a simple example!\n");
MODULE_ALIAS("A simplest example");
这个 Makefile 会将两个 c 文件都制作成 call.ko,并且它会起作用。但这不是我想要的。
生成文件:
KVERSION = $(shell uname -r)
obj-m = call.o
call-objs = aaa.o test.o
Debug:
make -C /lib/modules/$(KVERSION)/build M=$(PWD) modules
All:Debug
cleanDebug:
make -C /lib/modules/$(KVERSION)/build M=/home/Destiny/myProject/kernel/cbtest/ clean
clean:cleanDebug
installDebug:Debug
rmmod /lib/modules/2.6.18-348.12.1.el5/test/call.ko
/bin/cp call.ko /lib/modules/$(KVERSION)/test/
depmod -a
insmod /lib/modules/2.6.18-348.12.1.el5/test/call.ko
install:installDebug
main.o : defs.h
Ko 文件运行在内核空间,而不是运行应用程序的用户空间。 libc或libc++等是为用户空间应用程序准备的。所以你不能链接libc/c++函数,就像你不能链接内核中的任何libc函数一样。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)