
第 1 章 Linux内核配置及编译 1.1 解压内核 建立源码目录
![]() 该目录下以patch结尾的文件为ST官方提供的补丁文件,linux-5.4.31.tar.xz为标准linux源码包。 解压标准内核源码
![]() 进入内核源码目录下
![]() 1.2 添加STMicroelectronics官方补丁 解压linux内核源码后得到的是Linux社区的标准内核源码,接下来需要将ST官方提供的源码补丁添加到标准内核中。
该命令会将上层目录下所有的patch补丁文件应用到当前的内核中。 1.3 生成标准板配置文件 生成multi_v7_defconfig默认配置
在默认multi_v7_defconfig配置中加入ST官方提供的fragment config
生成自己的默认配置文件
取消git中的SHA1
1.4 配置内核 导入交叉编译工具链(如果还未安装SDK可参考《SDK工具链安装》章节进行安装)
验证开发工具是否安装正确,显示版本信息如下图所示。
![]() 在编译前如果需要编译额外的功能或者驱动,可以使用meunconfig来对内核进行配置。
![]() 可以在如上菜单中对内核进行详细的配置。 1.5 编译内核
![]() 编译后在内核源码目录下,能够在生成一个vmlinux文件,该文件是没有经过压缩的内核镜像,这个镜像导出了所有的内核符号可以用作仿真调试。 ![]() 此外在arch/arm/boot目录下还生成了一个uImage文件,这就是经过压缩的内核镜像。可以用作系统启动。 ![]() 1.6 编译内核模块
该操作会将内核中配置为模块的源码进行编译,最终得到ko文件。 ![]() 1.7 生成设备树 以参考板DK1设备树文件stm32mp15xx-dkx.dtsi和stm32mp157a-dk1.dts为参考,增加stm32mp15xx-fsmp1x.dtsi和stm32mp157a-fsmp1a.dts: 对stm32mp15xx-fsmp1x.dtsi内容进行整理,去掉没有被使用的节点信息和明显与FS-MP1A的硬件没有关系的节点信息。下文内容是删掉了所有暂不使用的节点信息,整理出一个相对简单的设备树文件,确保内核可以正常启动。后续各个外设移植时会陆续增加文件的相关内容。 在arch/arm/boot/dts/ 目录下新建 stm32mp15xx-fsmp1x.dtsi:
在arch/arm/boot/dts/ 目录下新建 stm32mp157a-fsmp1a.dts:
重新编译设备树文件
编译完成后会在arch/arm/boot/dts/目录下生成stm32mp157a-fsmp1a.dtb文件 ![]() 将编译好的设备树文件与内核的uImage文件,复制到ubuntu主机的/tftpboot文件夹下,当使用tftp方式下载内核与设备树文件时会用到。
1.8 配置tftp 在linux系统移植中,我们使用tftp下载的方式来验证结果。使用tftp下载需要构建pxelinux相关的目录。此部分可参考《通过tftp方式下载linux内核及设备树》章节进行搭建。 如果环境搭建已经搭建完成,需要将ubuntu主机中的/tftpboot/pxelinux.cfg/01-00-80-e1-42-60-17文件内容,暂时替换为如下内容,在后续的移植过程中会根据不同的需求进行修改。
修改01-00-80-e1-42-60-17文件后,继续按照《通过tftp方式下载linux内核及设备树》章节中的描述进行启动。 由于目前还未对源码进行任何修改,在内核启动过程中会停留在如下地方。 ![]() 后续会通过对系统源码的修改,逐渐完成整个系统的启动和对外围设备的驱动。 ———————————————— 版权声明:左月先生 |
基于STM32MP1和STM32MP2在嵌入式Linux平台上部署有效的安全保护机制
利用STM32MP1和STM32MP2为嵌入式Linux提供有效的安全措施:供当今决策者参考的3条宝贵经验
STM32MP1 WiFi连接
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【STM32MPU 安全启动】 TF-A BL2 TrustedBoot原理学习
《STM32MPU安全启动》学**结
《STM32MPU安全启动》学习笔记之optee 如何加载CORTEX-M核和使能校验
《STM32MPU安全启动》学习笔记之TF-A BL2校验optee和uboot的流程以及如何使能
《STM32MPU 安全启动》课程学习心得+开启一扇通往嵌入式系统安全领域深处的大门。
《STM32MPU安全启动》 课程学习心得