linux 怎么调用内核导出的函数

linux 怎么调用内核导出的函数,第1张

Linux内核没有导出的函数不能调用,即使包含了头文件,也会出现符号未定义的警告,并在加载模块时失败。

以下是我的测试例子:

#include <linux/module.h>

#include <linux/syscalls.h>

MODULE_LICENSE("GPL")

MODULE_AUTHOR("Linmiaohe")

MODULE_DESCRIPTION("try to evole sys_umount")

extern asmlinkage long sys_umount(char __user *name, int flags)

static int __init sys_umount_init(void)

{

sys_umount("./proc",0)

return 0

}

static void __exit sys_umount_exit(void)

{

printk(KERN_INFO "***********sys_umount module has been unregistered*************\n")

}

module_init(sys_umount_init)

module_exit(sys_umount_exit)

Linux库有动态静态两种,动态通常用.so为后缀,静态用.a为后缀。例如:libhello.so libhello.a 为了在同一系统中使用不同版本的库,可以在库文件名后加上版本号为后缀,例如: libhello.so.1.0,由于程序连接默认以.so为文件后缀名。所以为了使用这些库,通常使用建立符号连接的方式。 ln -s libhello.so.1.0 libhello.so.1 ln -s libhello.so.1 libhello.so 动态库和静态库的区别: 当要使用静态的程序库时,连接器会找出程序所需的函数,然后将它们拷贝到执行文件,由于这种拷贝是完整的,所以一旦连接成功,静态程序库也就不再需要了。然而,对动态库而言,就不是这样。动态库会在执行程序内留下一个标记‘指明当程序执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的缺省 *** 作是首先连接动态库,也就是说,如果同时存在静态和动态库,不特别指定的话,将与动态库相连接。 两种库的编译产生方法: 第一步要把源代码编绎成目标代码。以下面的代码hello.c为例,生成hello库: /* hello.c */ #include void sayhello() { printf("hello,world\n")} 用gcc编绎该文件,在编绎时可以使用任何全法的编绎参数,例如-g加入调试代码等


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8369668.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-15
下一篇 2023-04-15

发表评论

登录后才能评论

评论列表(0条)

保存