以两个C文件为例:
将本该被分别编译成adc_device.ko和adc_driver.ko的adc_device.c、adc_driver.c编译成一个ko文件!
采用方法:
第一步、修改C文件
1、去掉adc_device.c文件里module_init(xxx)、module_exit(yyy)中xxx、yyy 函数原型的关键字static
2、注销adc_device.c文件里module_init(xxx)、module_exit(yyy)函数
3、在adc_driver.c文件里添加用关键字extern声明的上述xxx、yyy函数
4、在adc_driver.c文件里module_init(mmm)、module_exit(nnn)中mmm、nnn 函数原型合适地方调用xxx、yyy函数
注意:当把多个C文件编译成一个.ko文件时, C文件里的module_init、module_exit 会提示重定义,
故一个ko里边只能有一个module_init和一个module_exit!
第二步、编写Makefile文件(关键部分)
obj-m += adc.o
adc-objs := adc_device.o adc_driver.o
就这样,将本该被分别编译成adc_device.ko和adc_driver.ko的adc_device.c、adc_driver.c
原文:https://blog.csdn.net/dcx1205/article/details/39041461
以上是经过查询的结果,现在是实践结果,只是作为练习使用:
<first.c>
#include <linux/init.h>
#include <linux/module.h>
#include "second.h"
extern int second_func(void);
static inline int __init
first_init(void)
{
printk("this is in %s\n", __func__);
second_func();
return 0;
}
static inline void __exit
first_exit(void)
{
printk("this is in %s\n", __func__);
second_func();
}
module_init(first_init);
module_exit(first_exit);
<second.c>
#include "second.h"
int
second_func(void)
{
printk("this is in %s\n", __func__);
return 0;
}
EXPORT_SYMBOL(second_func);
<second.h>
#ifndef __SECOND_H__
#define __SECOND_H__
#include <linux/init.h>
#include <linux/module.h>
extern int second_func(void);
#endif
Makefile
KERN_DIR = /lib/modules/`uname -r`/build/
obj-m := alex.o
alex-objs:=first.o second.o
all:
make -C $(KERN_DIR) M=$(shell pwd) modules
clean:
make -C $(KERN_DIR) M=$(shell pwd) modules clean
经过验证,可用