输入:apt-cache search linux-source //查看内核版本
输入:apt-get install linux-source-3.0.0 //获取对应版本的内核,默认安装在/usr/src目录下
见:
Ubuntu下构建内核源码树的方法 |
ubuntu下编译本机模块是否需要下载内核源码呢?
答案是可以的。
dmesg | tail -1 命令用于查看载入内核后打印的数据。
在ubuntu下,也可根据下载的源代码编译模块,若要使模块能够运行在本机中,下载的内核源码版本最好与本机一致。当然也可以根据交叉编译器开发嵌入式系统的模块。
makefile版本1:
obj-m := mod_test.o
KERNELBUILD :=/lib/modules/$(shell uname -r)/build
default:
make -C $(KERNELBUILD) M=$(shell pwd)
modulesclean:
rm -rf *.o *.ko *.mod.c .*.cmd *.markers *.order *.symvers .tmp_versions
在有源码情况下,makefile版本2:
obj-m := mod_test.o
命令行输入:
make -C /usr/src/linux26/ SUBDIRS=$PWD modules
即可产生模块。如果内核版本不同,会出现无法加载的问题。可以用modinfo mod_test.ko查看。
vi /lib/modules/`uname -r`/build/Makefile 可查看makefile中的内核版本号
http://blog.csdn.net/sabalol/article/details/2076610
Makefile为,
PWD = $(shell pwd)
KERNEL_SRC = /usr/src/linux-source-2.6.15/
obj-m := test.o
module-objs := test.o
all:
$(MAKE) -C $(KERNEL_SRC) M=$(PWD) modules
clean:
rm *.ko
rm *.o
在test.c和Makefile所在的目录下运行make,如果看到类似输出
make -C /usr/src/linux-source-2.6.15/ M=/home/vmeth modules
make[1]: Entering directory `/usr/src/linux-source-2.6.15'
CC [M] /home/vmeth/hello.o
Building modules, stage 2.
MODPOST
CC /home/vmeth/hello.mod.o
LD [M] /home/vmeth/hello.ko
make[1]: Leaving directory `/usr/src/linux-source-2.6.15'
一般用下面的Makefile,
# Makefile2.6
ifneq ($(KERNELRELEASE),)
#kbuild syntax. dependency relationshsip of files and target modules are
listed here.
mymodule-objs := hello.o
obj-m := hello.o
else
PWD := $(shell pwd)
KVER ?= $(shell uname -r)
KDIR := /lib/modules/$(KVER)/build
all:
$(MAKE) -C $(KDIR) M=$(PWD)
clean:
rm -rf .*.cmd *.o *.mod.c *.ko .tmp_versions
endif
KERNELRELEASE 是在内核源码的顶层Makefile中定义的一个变量,在第一次读取执行此
Makefile时,KERNELRELEASE没有被定义,所以make将读取执行else之后的内容。
当make的目标为all时,-C $(KDIR) 指明跳转到内核源码目录下读取那里的Makefile;M=
$(PWD) 表明然后返回到当前目录继续读入、执行当前的Makefile。
当从内核源码目录返回时,KERNELRELEASE已被被定义,kbuild也被启动去解析kbuild
语法的语句,make将继续读取else之前的内容。else之前的内容为kbuild语法的语句,
指明模块源码中各文件的依赖关系,以及要生成的目标模块名。
每个内核的名字都包含了它的版本号,这也是 uname -r 命令显示的值。