obj-m :=$(MODULE_NAME).o
#KERNELDIR ?= /lib/modules/$(shell uname -r)/build
KERNELDIR = /home/octeon/OCTEON-SDK/linux/kernel_2.6/linux
PWD := $(shell pwd)
all:
$(MAKE) -C $(KERNELDIR) M=$(PWD)
gcc -o ${MODULE_NAME} my_user.c
clean:
rm -fr *.ko *.o *.cmd
obj-m := hello.o
KDIR:=/lib/modules/$(shell uname -r)/build
# PWD=$(shell pwd)
all:
make -C $(KDIR) M=$(PWD) modules
clean:
make -C $(KDIR) M=$(PWD) clean
obj-m := hello.o表示编译后生成hello.o模块。
$(KDIR) 指定了内核源码的路径,“M=”表示这是个外部模块,M=$(PWD) 指定了该模块文件所在的路径。
注: makefile预定义了$(PWD)变量,此处可以不必重复定义。
如果是多个源文件编译出一个模块,假设模块名是test.ko,那么源文件名不能有test.c
obj-m := test.o
test-objs := file1.o file2.o file3.o
KDIR := /lib/modules/$(shell uname -r)/build
#PWD := $(shell pwd)
all:
make -C $(KDIR) M=$(PWD) modules
clean:
make -C $(KDIR) M=$(PWD) clean
例如:
#include <linux/init.h>
#include <linux/module.h>
static int hello_init(void)
{
printk(KERN_ALERT"Hello, world\n");
return 0;
}
static void hello_exit(void)
{
printk("Goodbye, cruel world\n");
}
module_init(hello_init);
module_exit(hello_exit);
MODULE_LICENSE("GPL");
Makefile:
obj-m:=test.o
KDIR =/usr/src/linux-2.6.23
PWD:=$(shell pwd)
all:
make -C $(KDIR) M=$(PWD) modules
clean:
make -C $(KDIR) M=$(PWD) clean
本文深入解析Linux内核编译过程中的Makefile语法与使用技巧,详细讲解了如何通过Makefile实现模块化编译,以及如何在特定环境下编译内核模块。同时提供了实例代码,帮助开发者快速上手。
760

被折叠的 条评论
为什么被折叠?



