多個.c檔案編譯成.ko檔案
阿新 • • 發佈:2018-12-08
以兩個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
經過驗證,可用