以下是我的测试例子:
#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加入调试代码等欢迎分享,转载请注明来源:内存溢出
评论列表(0条)