多个.c文件编译成.ko文件

以两个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

编译成一个adc.ko文件!

原文: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

经过验证,可用

猜你喜欢

转载自blog.csdn.net/weixin_37867857/article/details/84504902