• c文件如何编译为ko的MAKEFILE文件编写


    首先需要知道:

    obj-m = *.o

    obj-y = *.o

    上面两者的区别在于,前者才会生成ko文件,后者只是代码编译进内核,并不生成ko文件。

    生成KO文件,分两种情况:单个.c文件和多个.c文件

    1.单个.c文件

    kernel配置文件中定义

    CONFIG_RUNYEE_CAMVIB=m

    注意上面的m,表示作为一个模块进行编译,最后在MAKEFILE中需要用到的编译开关。

    然后再相应的源码目录中的MAKEFILE中添加如下语句:

    obj-$(CONFIG_RUNYEE_CAMVIB) := camvib.o

    上面的一行的作用就是编译camvib.c的源文件,同时会生成相应的camvib.ko文件,和编译生成

    的camvib.o在同一目录

    最后就是insmod动作了:

    insmod /system/lib/modules/camvib.ko

    2.多个.c文件生成ko文件

    kernel配置文件中定义

    CONFIG_TOUCHSCREEN_FOCALTECH=m

    注意上面的m,表示作为一个模块进行编译,最后在MAKEFILE中需要用到的编译开关。

    然后再相应的源码目录中的MAKEFILE中添加如下语句:

    obj-$(CONFIG_TOUCHSCREEN_FOCALTECH) += focaltech_ts.o

    focaltech_ts-objs := focaltech.o

    focaltech_ts-objs += foc altech _ctl .o

    focaltech_ts-objs += f ocaltech_ex_fu n .o

    上面的意思就是编译生成 ko文件需要三个.c文件【focaltech.c focaltech_ctl.c focaltech_ex_fun.c】,最后

    生成名为 focaltech_ts 的ko文件,注意ko文件名一定不能 为 focaltech。那么在obj-m和lpc-objs中都含有focaltech.o,

    对make来讲会产生循环和混淆,因此也不能这样书写

    最后就是insmod动作了:

    insmod /system/lib/modules/focaltech_ts.ko

    注意事项:

    1 源代码书写要保证正确,MODULE_LICENSE();是一条语句,后面要有分号;

    2 static void hello_exit()的返回类型为void;

    3 make M=`pwd` M参数后面不是单引号,而是斜点``;

    4 -c 指定包含kernel顶级Makefile的源码目录;

    5 源代码要执行make menuconfig生成默认配置,无须修改任何内容;

    6 make menuconfig 的运行可能需要安装necurses-dev;

    7 生成ko模块文件所使用的源码版本要和insmod的目标内核版本一致;

    8 2.6个版本内核下载 http://www.kernel.org/pub/linux/kernel/v2.6/;

    9 make编译可能提示没有modpost等脚本文件,可以从其它源码目录拷到当前使用源码目录下,或者利用当前源码目录下的c文件直接编译生成;

    10 如果insmod过程中出错,可以使用dmesg | tail 命令查看系统日志

    11 模块的编译和插入,对版本一致性要求很严格,如果编译依赖的内核源码版本和目标平台正在运行的内核版本不一致的话,很可能模块无法正常insert,出现诸如“-1 Invalid module format”或“no symbol version for module layout”的错误

    所以编译过程中:

    不是为正在运行的内核编译模块:

    make -C M='pwd'

    为正在运行的内核编译模块:

    make -C /lib/modules/'uname -r'/build M='pwd'

    即可以保证insmod无误;

    举例

    内核源文件my.c

    1. #include
    2. #include
    3. #include
    4. static int funcIn(void)
    5. {
    6. printk("in module");
    7. return 0;
    8. }
    9. static void funcOut(void)
    10. {
    11. printk("out module");
    12. return;
    13. }
    14. module_init(funcIn);
    15. module_exit(funcOut);
    16. MODULE_LICENSE("GPL");
    17. MODULE_AUTHOR("elfy");

    Makefile 文件

    1. obj-m:=my.o
    2. mymodule-objs:=module
    3. KDIR:=/lib/modules/$(shell uname -r)/build
    4. MAKE:=make
    5. default:
    6. $(MAKE) -C $(KDIR) SUBDIRS=$(PWD) modules
    7. clean:
    8. $(MAKE) -C $(KDIR) SUBDIRS=$(PWD) clean

    注意事项:

    1、内核目录

    2、Makefile中obj-m:=my.o 这个和源文件my.c要对应

    3、mymodule-objs:=module 这个my也是和my.c对应的

    如果源文件为your.c

    这两句话就应该改为obj-m:=your.o

    yourmodule-objs:=module

    4、查看输出的时候 用dmesg输出信息太多,可以用grep过滤一下

    dmesg | grep "keywords"

  • 相关阅读:
    1 认识 Android
    LVGL库入门教程01-移植到STM32(触摸屏)
    21.8 Python 使用BeautifulSoup库
    Ubuntu安装c/c++编译环境
    absl教程(五):Synchronization library
    洛谷P3915 斜率优化线性dp
    【Linux】系统安装
    HDU_7149
    红绿灯的设计原理
    Python数据科学入门
  • 原文地址:https://blog.csdn.net/u010823818/article/details/134069056