内核模块cal.ko:
#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL")
int add(int a, int b) {
return a+b
}
int sub(int a, int b) {
return a-b
}
static int sym_init() {
return 0
}
static int sym_exit() {
return 0
}
module_init(sym_init)
module_exit(sym_exit)
EXPORT_SYMBOL(add)
EXPORT_SYMBOL(sub)
内核模块hello.ko
#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL")
MODULE_AUTHOR("David Xie")
MODULE_DESCRIPTION("Hello World Module")
MODULE_ALIAS("a simplest module")
static int age = 10
module_param(age, int, S_IRUGO)//allow all user to use this param
int add(int a, int b)
int sub(int a, int b)
static int hello_init(void)
{
printk("<0>"" Hello World! age = %d\n", add(10, 20))//调用内核模块cal.ko里面的add函数
return 0
}
static void hello_exit(void)
{
printk("<0>""hello exit %d\n", sub(30,10))//调用内核模块cal.ko里面的sub函数
}
module_init(hello_init)
module_exit(hello_exit)
可以生成多个内核模块的makefile
ifneq ($(KERNELRELEASE),)
obj-m := cal.o hello.o
cal-objs := operator.o
hello-objs := main.o
else
KDIR := /lib/modules/2.6.32-21-generic/build
all:
make -C $(KDIR) M=$(PWD) modules
clean:
rm -f *.ko *.o *.mod.o *.mod.c *.symvers *.order
endif
此时在当前目录执行make就会产生cal.ko和hello.ko两个内核模块
红帽linux中C语言编程调用数学函数参考案例如下所示:当需要调用函数的个数比较少时,可以直接在main函数中包含该文件,比如一个文件夹下包含add.c和main.c文件。
文件add.c定义两个整数相加的函数,code如下:#include#includeintadd(inta,intb){intz;z=a+b;returnz;},主函数main.c的code如下:#include#include#include"add.c"intmain(){inti,j,k;i=1;j=2;k=add(i,j);printf("iaddj=%d",k);},编译生成可执行文件:gcc-omainmain.c,执行:./main。
Linux下对文件 *** 作有两种方式:系统调用(system call)和库函数调用(Library functions)。系统调用实际上就是指最底层的一个调用,在linux程序设计里面就是底层调用的意思。面向的是硬件。而库函数调用则面向的是应用开发的,相当于应用程序的api...欢迎分享,转载请注明来源:内存溢出
评论列表(0条)