小白自制Linux开发板 三. Linux内核与文件系统移植
1.Linux内核
事实上对于F1C100S/F1C200S,Linux官方源码已经对licheepi nano进行支持。所以我们完全可以通过licheepi nano的配置文件进行移植。
1.1. 下载内核源码
进入Linux系统官网:
https://www.kernel.org/
这里面列出的都是一些主要版本,如主线版本,上时间支持版本,个人推荐使用最新的长时间支持版本(5.10.69)。但是因为我这个项目是在参考一位大神的文档的基础上构建的,所以使用的是5.7.1版本,接下来就给一个选择其他版本的方式。
选择任意一项点击 [browse]
在新打开页面选择 【summary】点击【tag】中的【…】切换下载
下载后完成后,将代码复制到Ubuntu虚拟机并解压源码。
【文章福利】小编推荐自己的Linux内核技术交流群:【1143996416】整理了一些个人觉得比较好的学习书籍、视频资料共享在群文件里面,有需要的可以自行添加哦!!!(含视频教程、电子书、实战项目及代码)
【腾讯文档】Linux内核源码技术学习路线+视频教程代码资料Linux内核源码技术学习路线+视频教程代码资料
1.2.配置编译
与上一篇中编译u-boot一样,我们也需要配置对Linux编译进行配置:指定架构类型指定交叉编译工具项目配置
指定架构,就这个很好理解,就是指定CPU类型,就是配置为Arm就行,交叉编译工具即为上一篇已经安装好的编译工具。
用VS打开Linux内核代码,找到Makefile文件:
修改如下配置:
如果没找到ARCH 或 CROSS_COMPILE字段,自己手动添加也行,如下图所示:事实上这两个字段可以不用指定,在进行make的时候加上对应的参数就行,这里为了避免麻烦,所以直接放到了makefile文件中
接下来就是指定项目配置了,这个操作就是让Linux内核认F1C100S/F1C200S这颗soc。
进入内核源码中的arch/arm/configs目录中,可以看到有很多开发板的配置文件,其中sunxi_defconfig是全志的配置文件,但是该配置文件非常不全,需要额外配置大量的选项,一般选项多大上千个,这里先使用licheepi_nano的配置文件。
https://files.cnblogs.com/files/twzy/linux-licheepi_nano_defconfig.zip
下载该文件,解压出linux-licheepi_nano_defconfig,然后将其放到arch/arm/configs/目录下
然后通过终端进入Linux-5.7.1根目录,输入命令:
进入图形配置界面,如图所示:
该界面和u-boot配置一样,所以操作方式也是一样的,上下键移动选项,使用空格键进行选中或取消选择,同样通过空格键或回车键,进入子选项配置,通过Tab键选择保存和退出即可返回上级菜单或命令行界面,也可以直接双击Esc键返回上级目录。
1.3 配置TF卡设备树信息
我们在完成内核配置后还需要配置TF卡的设备树配置,否则即便是能正常运行内核,在加载文件系统的时候还是会有问题,在这里配置很简单:
在linux-5.7.1/arch/arm/boot/dts 目录下,分别修改suniv-f1c100s.dtsi、suniv-f1c100s-licheepi-nano.dts 两个文件(记住这两个文件、以后我们修改的地方多了^_^)
修改suniv-f1c100s.dtsi文件
首先添加头文件(如果有则忽略)
在soc->pio 下添加如下代码
soc下添加如下代码
如图,图中的配置可能与读者实际内容不一致,这是因为我改了很多东西,忽略即可,只需要红色框中的内容即可。
修改suniv-f1c100s-licheepi-nano.dts文件,在根节点添加如下代码
外部添加mmc0使能代码
位置如下图
接下来执行make命令开始编译内核和设备树相关的文件了
首次进行编译,通常会需要很长时间,编译完成后,就会在在arch/arm/boot目录下生成内核文件:zImage,在arch/arm/boot/dts目录下设备树文件:suniv-f1c100s-licheepi-nano.dtb 。
在编译过程中,因为所配置Ubuntu系统的差异,可能会因缺少某些组件导致编译报错,不要慌,将对应的错误关键信息复制到搜索引擎后安装即可,一下是作者碰到的两个编译报错,如果有必要可以提前安装:
linux-内核编译配置 lexer.lex.c错误
解决方法:
编译Linux内核时遇到:“error : openssl/bio.h :No such file or folder”
安装openssl:
1.4 TF分区配置
在上一篇中提到过u-boot 中的bootcmd 配置了Linux内核文件和设备树文件存放位置,即TF卡的0:1分区中,而且我们已经得到了对应的文件,那我们应该怎么操作呢。
还记得我们在上一篇中安装的Gparted软件吗,如果不记得,可以通过以下命令安装:
把需要写入系统的TF卡插到电脑的USB上,打开该软件,可以看到此时有两个存储设备,一个是sda另一个是sdb,其中sdb就是我们的TF卡。如图:
选中sdb,我们可以看到分区表中显示为未分配,对于常规Linux嵌入式系统我们需要分两个区,一个是存放zImage和dtb文件,即在bootcmd中配置的0:1分区,另一个区存放根文件系统。对于第一个分区,格式为fat16格式,因为u-boot只能识别这个格式,对于第二个区,一般为ext4格式,为Linux内核识别的格式。下面开始分区吧。
选中未分配空间并右击鼠标,点击[新建],然后填写相关属性,然后点击[添加],所示。
需要注意【之前的空余空间】选择1M,这是给u-boot预留的(u-boot在分区表中是无法看到的),【新大小】选择32M ,【文件系统】选择fat16,【卷标】输入boot。
我们这里可以用相同的方式新建第二分区——ext4分区,如下图
这里我们设置为100M,文件系统为ext4,卷标为rootfs,然后添加添加。
配置好分区表后,点击工具来中的【对钩】使配置的分区表生效。
配置分区完毕后,我们就可以在文件管理器中看到挂载的两个分区,如图
1.5 内核复制与执行
那么,我们将刚才生成好的zImage和dtb文件复制到TF卡的BOOT分区中
退出TF卡,插入开发板,上电,按重启,我们就可以看到u-boot启动完成后,自动进入了内核启动环节,但是启动后一会就报错了,因为挂载文件系统产生错误。
内核移植就基本结束了,要想让小板真正的运行起来,还需要Linux的文件系统,那开始吧。
2.文件系统移植
根文件系统(rootfs)是内核启动后挂载的第一个文件系统,如果没有根文件系统,内核将无法开启shell以及其他进程。实际上内核启动后会先挂载一个虚拟的文件系统,这个虚拟文件系统是在内存中运行的,其主要运行核心进程,虚拟文件系统挂载之后才挂载硬盘(TF卡或者emmc)上的根文件系统。
制作文件系统也有很多方式,如通过busyBox、Buildroot等工具制作。
本次使用Buildroot,制作过程相对简单,兼容性好,由于根文件系统制作比较简单。
进入buildroot官网
https://buildroot.org/downloads
这里选择buildroot2018.2.11版本,将下载好软件包传入Ubuntu系统中,然后解压并进入源码目录中,输入清理命令。主要用于初始化一些设置,命令如下:
然后输入以下命令进入配置界面
此时会终端进入图形配置界面,如图:
2.1 Target options配置
先选择Target options选项,进行对应芯片soc相关的配置,如图:
配置如图所示,下面是对其的解释第一个选项为架构选择,这里选择ARM架构小端模式,第二个为输出的二进制文件格式,这里选择EFL格式,第三个为架构体系,这里选择arm926t,因为F1C200S/F1C100S的架构就是这个架构,第四个为矢量浮点处理器,这里不勾选,因为对于F1C200S/F1C100S而言,其内部没有浮点运算单元,只能进行软浮点运算,也就是模拟浮点预运算。第五个为应用程序二进制接口,这里选择EABI,原因是该格式支持软件浮点和硬件实现浮点功能混用。第六个为浮点运算规则,这里使用软件浮点第七个选择指令集,这里选择ARM指令集,因为thumb主要针对Cortex M系列而言的,对于运行操作系统的A系列以及ARM9和ARM11而言,使用的都是32位的ARM指令集。
按【Tab键】选择<save>进行保存,按【Esc键】回到上一级配置界面。
2.2 Build options配置
进入第二个Build options选项,配置如图
按T【ab键】选择<save>进行保存,按【Esc键】回到上一级配置界面。
2.3 Toolchain配置
进入第三个Toolchain选项,配置如图:
这里我们选择一些C\C++相关的库,这样我们就可以在开发板上直接编译程序了,保存返回。
2.4 System configuration配置
对于System configuration选项,这里主要是配置一些系统登录时候显示的内容,配置如图
这里主要配置了登录时候显示的内容和root账号登录密码,接下来保存配置并且退回到命令行界面。
然后执行构建文件系统命令:
因为是首次编译,而且buildroot在制作文件系统的时候需要联网组件,所以会编译很久,那么“去和妲己玩耍吧”
当你终于被别人坑的自闭的时候,文件系统大概也许可能已经编译完毕了。Linux内核源码/内存调优/文件系统/进程管理/设备驱动/网络协议栈-学习视频教程-腾讯课堂
2.5 文件系统移植与执行
此时在源码的output/images目录下有一个rootfs.tar,这个文件就是最终生成的根文件系统镜像,现在只需要将该镜像解压到TF卡的第二分区即可。插入TF卡到电脑端,进入out/images目录,然后输入
此时可以看到TF卡的rootfs分区中有文件系统了
插入开发板,连接好串口,打开串口助手或者其他串口终端软件,可以看到根文件系统成功挂载,同时进入shell交互,用户名默认为root,密码:123456,进入root账号后
那么恭喜,你已经拥有了自己的Linux发行版。
至此我们完成了全部的系统移植任务,从下一篇开始我们将会升级我们的硬件设备和做一些更加有意义的东西,期待吗?
2.6 升级逼格
我们发现登录进自制的Linux系统后,命令行前置无论怎样只显示一个#号,逼格略低呀,怎么处理呢?
修改/etc/profile文件
重启小板,就可以看到与与常规Linux一样的操作体验了,只是root账号的时候还是显示$符号
需要注意的是,在开发板运行过程中,如果想要重启,请先执行
命令正常关闭系统后,在按重启按钮,否则有很大概率回造成文件系统损坏。
3. 点个灯吧
还记得我们在第一篇中提到过的我们自制小开发板的唯一的那个外设——LED灯吗?
那我们就利用Linux提供的GPIO系统通过shell命令进行点灯实验吧。
我们首先需要回到文件系统制作菜单
按如下方式进行配置,然后编译完rootfs,重新写入小板
通过硬件可知LED灯连接的是PE6接口,低电平亮灯
这里我们先要了解一下GPIO编号和值的计算方式引脚编号 = 控制引脚的寄存器基数 + 控制引脚寄存器位数批注:引脚编号是gpiochipxxx下的base + 第几个GPIO,也就是base加偏移,偏移的是位数。例如gpiochip34 下的第1个GPIO那么编号就是34 + 1 = 35
对于F1C200S/F1C100S这里:A=0、B=1、C=2D=3、E=4 ……、32是固定值、6就是偏移量
举个栗子(如果使想用 PE6,那么引脚编号就可能等于 4 x 32 + 6 = 134。
这是一些参考命令
输入如下命令:
效果如下:
我们这里借助Linux内建的GPIO子系统进行了电灯实验,但是真正Linux灵魂点灯是要通过驱动方式来实现的,但是谁让我是小白呢,以后再说吧。
2024最新激活全家桶教程,稳定运行到2099年,请移步至置顶文章:https://sigusoft.com/99576.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。 文章由激活谷谷主-小谷整理,转载请注明出处:https://sigusoft.com/97815.html