韦东山Linux教学视频中的makefile文件详细介绍

news/2024/12/21 13:06:02/

前言

(1)在学习韦东山Linux教学视频的时候,他的makefile并没有做详细的介绍。以至于我学了很长时间对他的makefile文件不理解。所以本文将会详细介绍韦东山Linux教学视频中的makefile文件含义。
(2)注意:我使用的是韦东山的配套i.max6ull pro开发板。如果是其他系列开发板,makefile文件的KERN_DIR = 需要改成你的Linux内核路径。
(3)阅读本文之前,需要具备一定的makefile语法基础,如果没有,请先学习Linux-GCC介绍+入门级Makefile使用的Makefile介绍部分。
(4)强调:我这里只是帮助各位理解韦东山老师的makefile文件是什么意思,保证你看完之后能够对这个文件进行更改,但是不保证你能够自己从0写一个makefile。

韦东山makefile文件源代码

以下是韦东山老师的makefile文件,我加了一些注释。


# 1. 使用不同的开发板内核时, 一定要修改KERN_DIR
# 2. KERN_DIR中的内核要事先配置、编译, 为了能编译内核, 要先设置下列环境变量:
# 2.1 ARCH,          比如: export ARCH=arm64
# 2.2 CROSS_COMPILE, 比如: export CROSS_COMPILE=aarch64-linux-gnu-
# 2.3 PATH,          比如: export PATH=$PATH:/home/book/100ask_roc-rk3399-pc/ToolChain-6.3.1/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin 
# 注意: 不同的开发板不同的编译器上述3个环境变量不一定相同,
#       请参考各开发板的高级用户使用手册# 内核源码路径
KERN_DIR = /home/book/100ask_imx6ull-sdk/Linux-4.9.88all:# -C表示将当前的工作目录切换到指定目录中,也就是Linux内核源码路径# M=表示模块源码目录# pwd表示获取当前文件路径,因为makefile一般和模块源码在同一个路径,所以这里可以直接使用pwd指令# modules表示编译模块make -C $(KERN_DIR) M=`pwd` modules # 将ledtest.c 编译成开发板能够执行的可执行文件ledtest$(CROSS_COMPILE)gcc -o ledtest ledtest.c clean:# 将模块清空	make -C $(KERN_DIR) M=`pwd` modules clean# 清除过度文件modules.order,这句话没有用处,上一句也会清除modules.order文件rm -rf modules.order# 删除可执行文件ledtestrm -f ledtest# 参考内核源码drivers/char/ipmi/Makefile
# 要想把a.c, b.c编译成ab.ko, 可以这样指定:
# ab-y := a.o b.o
# obj-m += ab.o# make工具根据名字将.c编译成.ko模块
obj-m += leddrv.o chip_demo_gpio.o

前期准备工作—设置交叉编译工具链

(1)因为开发板和电脑端的架构是不一样的。所以他们的可执行文件是不同的,在电脑端能够运行的可执行文件,开发板是跑不了的,反之同理。
(2)为了能够让我们编译出开发板能够执行的可执行文件,就需要先设置交叉编译工具链。
(3)如果是跟着韦东山老师的视频课程的来的,教程编译工具链应该是永久配置好的。(详情可看嵌入式Linux应用开发完全手册V5_IMX6ULL_Pro开发板,第三篇环境搭建与开发板操作,2.6.3节配置交叉工具链)
(4)因为韦东山老师的文档对交叉工具链配置已经很详细了,所以我不再赘述。这里只是会讲解如何查看自己是否永久配置好交叉工具链。
(5)打开终端,输入指令: vim ~/.bashrc

在这里插入图片描述

(6)
<1>进入VIM编辑器之后,输入: /PATH
<2>如果能够跳转,并且找到如下图的三行文字,就表示交叉工具链已经被配置好了。如果没有进行跳转,说明没有被配置好。

在这里插入图片描述

(7)如果没有配置好交叉编译工具链,就在命令行输入如下三行指令。(注意,如果是韦东山配套的i.max6ull就是执行这个。其他的板子请自行寻找你的交叉工具链配置方法)

export ARCH=arm
export CROSS_COMPILE=arm-buildroot-linux-gnueabihfexport- 
PATH=$PATH:/home/book/100ask_imx6ull-sdk/ToolChain/arm-buildroot-linux-gnueabihf_sdk-buildroot/bin

代码详细介绍

KERN_DIR = …介绍

(1)这一句是进行赋值操作,我们会发现,这个makefile中还有其他的KERN_DIR 。
(2)这个就相当于C语言的赋值,a = 3。那么此时变量a就是3了,后面只要出现字符a,并且字符a没有再次赋值,那么a就是代表数字3。
(3)这个是用来指定Linux的内核路径的。因为我们编译文件,需要使用到Linux库函数,所以需要指定Linux路径。

KERN_DIR = /home/book/100ask_imx6ull-sdk/Linux-4.9.88

all:介绍

(1)如果有makefile 的基础概念知识,就知道这是一个判断语句。
(2)因为all:是第一个判断语句,而且all永远不存在,所以只要在终端执行make指令,就会执行all:下面的指令。

all:
[TAB]命令

make -C $…介绍

(1)-C表示将当前的工作目录切换到指定目录中,也就是Linux内核源码路径。因为我们需要调用Linux内核库函数。
(2)M=表示模块源码目录,也就是我们写的驱动.c文件。
(3)这里的’pwd’效果和在终端执行pwd指令效果是一样的,都是获得当前文件路径。为makefile一般和模块源码在同一个路径,所以这里可以直接使用pwd指令。
(4)最后面的modules表示编译模块

make -C $(KERN_DIR) M=`pwd` modules 

在这里插入图片描述

$(CROSS_COMPILE)gcc … 介绍

(1)看到这一段代码,可能有些人会有疑惑,CROSS_COMPILE是什么东西?代码里面没有出现过这个玩意啊。
(2)CROSS_COMPILE就是我们在配置交叉编译工具链的时候设置的玩意。 export CROSS_COMPILE = arm-buildroot-linux-gnueabihf- ,所以说,CROSS_COMPILE就是arm-buildroot-linux-gnueabihf- 。那么$(CROSS_COMPILE)gcc就是arm-buildroot-linux-gnueabihf-gcc,看到这,大家是不是熟悉起来了。没错,就是编译开发板能够执行的可执行文件。
(3)所以这句话就是让应用层的.c文件编译成开发板能够执行的可执行文件。

$(CROSS_COMPILE)gcc -o ledtest ledtest.c 

clean: 介绍

这个其实是makefile基础知识,如果我们在命令行输入make clean。就会执行clean:下面的命令。

make -C $(KERN_DIR)…介绍

这个指令就是删除产生的.ko文件,.o文件,过渡文件modules.order等东西。

make -C $(KERN_DIR) M=`pwd` modules clean

rm -rf modules.order介绍

清除过渡文件modules.order,这句话没有用处,make -C $(KERN_DIR) M=pwd modules clean也会清除modules.order文件

rm -rf modules.order

rm -f ledtest介绍

这个就是删除开发板的可执行文件ledtest

rm -f ledtest

obj-m += …介绍(重点!!!)

(1)make工具根据名字将.c编译成.ko模块。例如,leddrv.c就会被识别到,编译成leddrv.ko。chip_demo_gpio.c就会被识别到,编译成chip_demo_gpio.ko。

obj-m += leddrv.o chip_demo_gpio.o

(2)为了加深理解,如果我们讲chip_demo_gpio.o稍微改一下。假如我们不小心少些了一个o,把chip_demo_gpio.o写成了chip_demo_gpi.o会发送什么呢?

在这里插入图片描述

如何根据自身需求更改这个makefile

(1)首先,我们需要知道自己的内核源码路径。然后将自己的内核源码路径更改一下。
(2)根据自己要编译成模块的.c文件名字来在obj-m +=写数据。比如我们想让SR04.c文件编译成SR04.ko模块。obj-m += SR04.o这样写即可。

在这里插入图片描述


http://www.ppmy.cn/news/955207.html

相关文章

vite 引入局部组件 必须带.vue

11:03:47 AM [vite] Internal server error: Failed to resolve import “./components/layoutsHeader” from “src/views/layouts/layouts.vue”. Does the file exist? 在这里插入图片描述

进度分享:ChatGPT搭建h5网页

最近几天在捣鼓ChatGPT h5网页的搭建&#xff0c;发现相对于游戏小程序实在要简单的多&#xff0c;而且有了一点收获&#xff0c;分享一下。 具体做h5网页的流程简单说一下&#xff0c;与ChatGPT小程序差不多&#xff0c;服务器最好使用海外的&#xff0c;提前备好备案好的域名…

使用GPT-2模型怎么搭建ChatGPT系统

答&#xff1a;ChatGPT系统可以通过将GPT-2模型和自然语言处理(NLP)技术结合起来搭建。首先&#xff0c;使用GPT-2模型进行语言建模&#xff0c;然后使用NLP技术对语言进行分析&#xff0c;最后由ChatGPT系统接管讨论&#xff0c;从而与用户进行自然对话。

2023 最新ChatGPT网页源码 无需KEY打开即用

买了些key放着也是放着&#xff0c;所以干脆集成到源码里面了&#xff0c;不需要大家输入key密钥就可以用&#xff0c;上传到宝塔搭建即可!

你不问它不说:ChatGPT 创建的大部分代码都不安全

聚焦源代码安全&#xff0c;网罗国内外最新资讯&#xff01; 编译&#xff1a;代码卫士 ChatGPT 是OpenAI 公司用于聊天机器人的大型语言模型&#xff0c;它生成的代码大部分都是不安全的&#xff0c;而且它虽然能够指出其缺点却无法提醒用户注意代码的不当之处。 就在学术界如…

ubuntu搭建Chuanhu-ChatGPT框架

备忘录&#xff1a; 创建一个本地目录mkdir my_chuanhu_chatgptcd my_chuanhu_chatgptgit clone https://github.com/GaiZhenbiao/ChuanhuChatGPT.gitpip3 install -r requirements.txt配置环境 a.复制配置文件cp config_example.json config.json b.修改配置文件中的代理ur…

chatgpt助力建站

在chatgpt辅助下&#xff0c;开发了几款便捷的好用在线工具。功能持续更新中。在让gpt输出代码的同时要不断调试&#xff0c;它可能给你错误的代码。 good1use.com

OpenAI文档翻译——搭建第一个自己的ChatGPT应用

这篇主要是讲了重头到位创建一个基于OpenAI API的应用程序的过程&#xff0c;同时给出了Node.js、Python版本的实例代码。应用程序的构建总体来说是很简单的就是一个接口调用&#xff0c;前提是我们需要提供密匙。 如果想要获取更好的结果返回一个是可以给模型提供一些列子从而…