f1c100s 荔枝派 系统移植

一。交叉编译环境配置 

1.1下载交叉工具链:https://releases.linaro.org/components/toolchain/binaries/7.2-2017.11/arm-linux-gnueabi/

1.2解压安装

在home目录下新建 工程目录:mkdir  f1c100s_project

将windows下的gcc-linaro-7.2.1-2017.11-x86_64_arm-linux-gnueabi.tar.xz 放置在/home/f1c200s/f1c200s_project目录下

解压:tar -vxf gcc-linaro-7.2.1-2017.11-x86_64_arm-linux-gnueabi.tar.xz

其中tar解压缩命令格式如下:

选项

含义

-x

对 tar 包做解打包操作。

-f

指定要解压的 tar 包的包名。

-t

只查看 tar 包中有哪些文件或目录,不对 tar 包做解打包操作。

-C 目录

指定解打包位置。

-v

显示解打包的具体过程。

将解压的文件复制到/usr/local/arm/中

进入目录:cd   /usr/local/arm/

拷贝:sudo cp -rf /home/f1c200s/f1c200s_project/gcc-linaro-7.2.1-2017.11-x86_64_arm-linux-gnueabi ./

1.3添加该交叉编译器的环境变量

只有这样编译器才能在任何目录或者任何位置打开的终端中执行,打开~/.bashrc文件 (修改.bashrc文件,只是针对某一个特定的用户;修改/etc/profile文件,它是针对于所有的用户),写入以下内容:

cd /home/f1c200s/

打开文件:sudo vim .bashrc

在文件末尾添加: 

export PATH=$PATH:/usr/local/arm/gcc-linaro-7.2.1-2017.11-x86_64_arm-linux-gnueabi/bin

保存退出:wq。

使环境生效:source ~/.bashrc

验证是否成功:arm-linux-gnueabi-gcc -v

二. Uboot移植

bootloader主要的工作就是引导 Linux 内核启动,常见的bootloader有 U-Boot、vivi、RedBoot 等等

2.1 uboot拉取

从gitee上拉取对 Nano 进行了适配的 u-boot:

安装git工具:sudo apt-get install git

拉取代码:git clone https://gitee.com/LicheePiNano/u-boot.git

cd u-boot

# 查看分支

git branch -a

# 切换到 Nano 分支

git checkout nano-lcd800480 

u-boot对于新手来说目录层级稍显复杂,您可参考下表进行快速的熟悉和目标文件定位

2.2uboot默认配置

如上图所示,为uboot的configs目录下的两个荔枝派的配置文件,第一个licheepi_nano_defconfig    是针对TF卡的配置文件,第二个licheepi_nano_spiflash_defconfig是针对flash的启动文件,显然我们需要选择第一个配置文件编译uboot,因为我们只有TF卡一种存储介质,没有flash。下面是编译指令:

make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- licheepi_nano_defconfig

为了避免使用类似于上方的繁琐编译指令,在uboot根目录Makfile中加入如下内容:

 ARCH=arm CROSS_COMPILE=arm-linux-gnueabi-

这样我们可以通过以下简洁的代码进行uboot配置: 

# 进入u-boot目录

cd u-boot/ 

# 加载配置文件

make licheepi_nano_defconfig   (报错可能没有配置ARCH=arm CROSS_COMPILE=arm-linux-gnueabi-

  经过以上操作,默认配置文件licheepi_nano_deconfig已经写入到,/uboot/.config文件中,这是根据默认配置文件,生成的uboot的最终配置文件,这个配置文件记录了所有配置选项的宏开关,我们可以通过宏开关对其进行修改。

2.3 uboot图形界面配置

2.3.1使用make menuconfig命令进行图形界面配置

ubootEnable boot arguments 选项上点击空格,弹出Boot arguments选项,选中回车输入以下内容后回车保存。用来配置串口,等待5秒,文件系统挂载盘符  

console=tty1 console=ttyS0,115200 panic=5 rootwait root=/dev/mmcblk0p2 earlyprintk rw

setenv bootargs "console=tty1 console=ttyS0,115200 panic=5 rootwait root=/dev/mmcblk0p2 earlyprintk rw"  使用uboot 命令

2.3.2同样的操作输入bootcmd的值,输入完成后如下图所示。

load mmc 0:1 0x80008000 zImage;load mmc 0:1 0x80c08000 suniv-f1c100s-licheepi-nano.dtb;bootz 0x80008000 - 0x80c08000;

setenv bootcmd "load mmc 0:1 0x80008000 zImage;load mmc 0:1 0x80c08000 suniv-f1c100s-licheepi-nano.dtb;bootz 0x80008000 -x80c08000;" 在uboot下 使用 命令添加

如果移植在片上flash ,使用如下:bootargs=console=ttyS0,115200 panic=5 rootwait root=/dev/mtdblock3 rw rootfstype=jffs2

bootcmd=sf probe 0 50000000; sf read 0x80C00000 0x100000 0x4000; sf read 0x80008000 0x110000 0x400000; bootz 0x80008000 - 0x80C00000

2.3.3若要在套餐中附带的LCD上输出显示

请通过配置 ARM architecture --> Enable graphical uboot console on HDMI, LCD or VGA 为 Y

接着配置同级的 LCD panel timing details 为:

x:480,y:272,depth:18,pclk\khz:10000,le:42,ri:8,up:11,lo:4,hs:1,vs:1,sync:3,vmode:0

注:此块屏为为  480*272规格,如为800*480  请尝试如下配置:

x:800,y:480,depth:18,pclk\khz:33000,le:87,ri:40,up:31,lo:13,hs:1,vs:1,sync:3,vmode:0

并将 LCD panel backlight pwm pin 设为:PE6 (查自 Nano 原理图)

2.4uboot编译

在进行编译之前需要在Ubuntu 中安装 ncurses 库,否则可能编译会报错,安装命令如下:

sudo apt-get install libncurses5-dev

使用make -j8进行编译

其中-j8代表处理器核心数。编译完成,在根目录下找到u-boot-sunxi-with-spl.bin文件,该文件为最终烧录文件。

2.5烧录bin文件

只要将u-boot-sunxi-with-spl.bin烧录到tf卡的8k偏移地址处就可以了,至于为什么,上面的引用已经解释清楚了。将准备号的TF卡插入读卡器,使用如下块搬移命令进行烧写:

sudo dd if=u-boot-sunxi-with-spl.bin of=/dev/sdb bs=1024 seek=8

if    文件名:输入文件名,缺省为标准输入。即指定源文件。< if=input file >

of   文件名:输出文件名,缺省为标准输出。即指定目的文件。< of=output file >

bs  bytes:同时设置读入/输出的块大小为bytes个字节。

seek  blocks:从输出文件开头跳过blocks个块后再开始复制。

这里的输出文件(of)为主机电脑的/dev/sdb文件,也就是插入的读卡器代表的TF卡。

烧录完成,如下图所示,然后弹出读卡器之后再拔出,否则可能损坏读卡器。

2.6 uboot启动测试

将开发板使用数据线与电脑相连,打开串口调试工具,根据bootargs参数设置串口通信参数:

选中端口后,波特率设置为115200:

可以看到uboot版本和编译时间:

三 .   内核移植

3.1内核源码获取

1.下载Linux5.7.1源码,下载后完成后,将代码复制到Ubuntu中并解压。

https://mirror.bjtu.edu.cn/kernel/linux/kernel/v5.x/

  1. 在Ubuntu上创建自己的文件夹,打开终端拉取

git clone https://gitee.com/LicheePiNano/Linux.git

3.2 内核配置与编译

基础配置与编译

解压完成后,首先在顶层Makfile中指定架构和交叉编译工具。注意:arm必须是小写.

在linux源码目录下:sudo vim Makefile 

Linux内核也需要进行配置,使用荔枝派的配置文件, 在arch/arm/configs文件夹中,在根目录使用以下命令配置Linux内核:

Make f1c100s_nano_linux_defconfig (针对2拉取的代码)

可能会报错:

 使用如下命令安装组件:

sudo apt-get install flex

sudo apt-get install bison -y

make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- menuconfig 配置菜单栏

使用make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- -j8

命令编译,经过漫长的等待后,在 arch/arm/boot目录下生成内核文件:zImage,在arch/arm/boot/dts目录下设备树文件:suniv-f1c100s-licheepi-nano.dtb。

如果出现以下错误,使用sudo apt install libssl-dev命令安装对应缺失库文件即可。

修改屏幕设备树,适配当期使用的屏幕:

~/f1c100s/Linux$ sudo vim arch/arm/boot/dts/suniv-f1c100s-licheepi-nano.dts

 3.3 TF卡分区方式1:

1.初见licheepi-zero-CSDN博客

uboot移植的时候bootcmd变量记录了内核文件(zImage)和设备树(.dtb文件)的存放位置,那么现在我们就要准备好TF卡的分区,一旦编译出内核文件和设备树文件,就可以放到TF卡的指定位置,启动Linux内核。

打开终端 sudo apt-get install gparted

打开软件sudo gparted

我们需要将TF卡分区如下,其中uboot只能识别FAT16格式,EXT4格式为Linux内核识别格式。注意:一定要把上面图片中的分区删除,否则无法识别到启动文件(zImage、.dtb)。

分区 分区一 分区二

名称 kernel rootfs

分区格式 FAT16 EXT4

大小 32M(可以随意填写) 剩余空间

注意需要给uboot预留1M的空间,在【之前的空余空间】选择1M即可,在上面的可视化分区中无法看到这个预留空间。

3.4 TF卡分区 方式2:

分区【系统移植】SD卡 分区_sd卡分区-CSDN博客

先将SD 卡进行格式化。然后与虚拟机连接。

sudo fdisk -l     # 首先查看电脑上已插入的TF卡的设备号

sudo umount /dev/sdb1 # 若自动挂载了TF设备,请先卸载

sudo fdisk /dev/sdb   # 进行分区操作

# 若已存分区即按 d 删除各个分区

# 通过 n 新建分区,第一分区暂且申请为32M(足够大了...),剩下的空间都给第二分区

# w 保存写入并退出

sudo mkfs.vfat /dev/sdb1 # 将第一分区格式化成FAT

sudo mkfs.ext4 /dev/sdb2 # 将第一分区格式化成EXT4

3.5 内核烧录

将上面编译产生的zImage、suniv-f1c100s-licheepi-nano.dtb两个文件拷贝到KERNEL分区。将TF卡插好之后上电,打开串口调试,按下复位按键,等待uboot启动,5秒倒计时结束,读取两个文件,启动Linux内核。至此,Linux内核移植完成,下一步是Linux根文件系统(rootfs)。

  • 根文件系统

文件系统是对一个存储设备上的数据和元数据进行组织的机制,这种机制有利于用户和操作系统的交互。

4.1、buildroot下载

1. 方式一:

使用buildroot制作根文件系统,首先进入官网,下载根文件系统buildroot2018.2.11版本

Buildroot - Making Embedded Linux Easy

2.方式二:

首先安装一些依赖,比如linux头文件

apt-get install linux-headers-$(uname -r)

下载:wget https://buildroot.org/downloads/buildroot-2021.02.4.tar.gz

解压:tar xvf buildroot-2021.02.4.tar.gz

进入目录:cd buildroot-2021.02.4/

4.2、根文件系统制作

 解压完成后进入文件系统根目录,清理工程后,进入图形界面配置:

make clean

make menuconfig

图形配置界面如下图所示,使用方向键选择不同选项,空格进行选中,回车进行确认。

Target options选项的配置如下图所示

第一个选项为架构选择,这里选择ARM架构小端模式,

第二个为输出的二进制文件格式,这里选择EFL格式,

第三个为架构体系,这里选择arm926t,因为F1C200S/F1C100S的架构就是这个架构,

第四个为矢量浮点处理器,这里不勾选,因为对于F1C200S/F1C100S而言,其内部没有浮点运算单元,只能进行软浮点运算,也就是模拟浮点预运算。

第五个为应用程序二进制接口,这里选择EABI,原因是该格式支持软件浮点和硬件实现浮点功能混用。

第六个为浮点运算规则,这里使用软件浮点

第七个选择指令集,这里选择ARM指令集,因为thumb主要针对Cortex M系列而言的,对于运行操作系统的A系列以及ARM9和ARM11而言,使用的都是32位的ARM指令集。

Toolchain按照下方配置(打开了一些功能)可以在开发板上直接编译程序。

C library (musl) # 使用musl减小最终体积。

登录的时候会显示 “Welcome to f1c200s linux system.” ,并且我们设置了root用户密码为“root”。

配置完成后保存,使用make命令进行编译,从下面可以看出,buildroot的编译需要网络支持,以通过网络配置我们选择的内容。 当然如果你的虚拟机无法连接网络,请看虚拟机ubuntu桥接怎么联网,或者是虚拟机net模式访问互联网。

终于编译完成了!编译完成后,在buildroot根目录的output/images目录下生成一个rootfs.rar文件,这个就是我们心心念念的根文件系统。

输出文件全部在output/目录下:

images/ — 存放编译后产生的所有镜像文件( 内核镜像 , 加载引导镜像 和 根文件系统镜像)

build/ — 存放所有的组件除了构建交叉编译工具链的组件 , 在这个目录里面每一个功能对应一个子目录存放他们各自的组件.

staging/ — 包含一个类似于根文件系统等级层次的层级 . 这个目录包含了 安装的交叉编译工具链 和 所有被选择用于目标板的所有用户空间包.

target/ — 包含了根文件系统,但不能用于你的开发板的

host/ — 包含了我们需要的交叉编译工具集

3、根文件系统移植

将上面得到的rootfs.rar解压到TF卡的第二个分区,也就是rootfs分区,不要解压完成在复制过去,因为解压出来好多文件夹。两种选择,要么把压缩包复制到rootfs分区,解压后删除压缩包,要么直接解压到第二分区。使用如下命令将压缩包解压到rootfs分区后如下图所示:

sudo tar -vxf rootfs.tar  -C  /media/sd 卡分区二/

4、根文件系统加载

TF卡第二个分区内已经放置了我们制作好的根文件系统,将TF卡插到开发板上并上电启动,打开串口调试助手,设置波特率115200,可以看到下面的内容,uboot和内核启动成功。

root为管理员用户名,密码为前面设置的root

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/685263.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AI大模型日报#0606:智谱AI开源GLM-4-9B、Pika再融5.8亿

导读&#xff1a;AI大模型日报&#xff0c;爬虫LLM自动生成&#xff0c;一文览尽每日AI大模型要点资讯&#xff01;目前采用“文心一言”&#xff08;ERNIE 4.0&#xff09;、“零一万物”&#xff08;Yi-Large&#xff09;生成了今日要点以及每条资讯的摘要。欢迎阅读&#xf…

Ubuntu虚拟机安装(基于Vmware17)

Ubuntu虚拟机安装&#xff08;基于Vmware17&#xff09; Ubuntu和CentOS是两种流行的Linux发行版&#xff0c;Ubuntu默认安装了图形化桌面环境&#xff0c;对于新手来学习相对来说较为友好&#xff0c;能够满足日常的学习和使用。CentOS则通常被用于服务器环境&#xff0c;常运…

【再探】Java—Java 沙箱机制与类加载器

沙箱&#xff08;Sandbox&#xff09;机制是将Java程序限定在JVM特定的运行范围内&#xff0c;并严格限制代码对本地系统资源的访问&#xff0c;以保证代码的有效隔离&#xff0c;防止对本地系统造成破坏。 1 安全模型 类在加载过程中&#xff0c;类加载器会为类设置初始的安…

天润融通助力浪鲸卫浴,智能化革新引领客户服务新高度

头部家装品牌如何用优质服务抓住客户&#xff1f; 每年初春&#xff0c;万物复苏的同时&#xff0c;家装市场也正式进入旺季。 因为春天气温回升&#xff0c;潮气逐渐散去&#xff0c;开始进入最适合施工的季节&#xff0c;木材不易变形、油漆不易起皮&#xff0c;再加上春季…

【iOS】——Runtime学习

文章目录 一、Runtime介绍二、Runtime消息传递三、实例对象、类对象、元类对象四、isa_t结构体的具体实现五、cache_t的具体实现六、class_data_bits_t的具体实现七、Runtime消息转发动态方法解析备用接收者完整消息转发 一、Runtime介绍 iOS的Runtime&#xff0c;通常称为Obj…

人形机器人:工业领域的得力助手

人行机器人近2年显示出强劲的增长势头&#xff0c;根据最新数据预测&#xff0c;到2026年&#xff0c;中国人形机器人产业规模将突破200亿元&#xff0c;这一数字预示着人形机器人在未来社会中将扮演更加重要的角色。 在工业领域&#xff0c;由于工业环境复杂多变&#xff0c;对…

音视频直播(一)

协议基础篇 直播协议基础推流与拉流推流拉流 直播传输协议RTMP传输协议 && HTTP-FLV协议为什么RTMP做推流&#xff0c;反而很少做拉流&#xff1f;HTTP-FLV协议 RTSP协议HLS协议SRT协议 WebRTC协议应用于直播 直播协议基础 从网络上搜寻到的有关推流与拉流的示意图 从…

STM32F103VE和STM32F407VE的引脚布局

STM32F103VE vs STM32F407VE 引脚对比表 引脚 STM32F103VE STM32F407VE 备注 1 VSS VSS 地 2 VDD VDD 电源 3 VSSA VSSA 模拟地 4 VDDA VDDA 模拟电源 5 OSC_IN OSC_IN 外部时钟输入 6 OSC_OUT OSC_OUT 外部时钟输出 7 NRST NRST 复位 8 PC13 (GPIO) PC13 (GPIO) GPIO 9 PC14 (…

【MySQL】sql语句之表操作(上)

序言 在上一篇的数据库操作的内容中&#xff0c;学习了两种属性和常用的七种操作&#xff0c;学习是循序渐进的&#xff0c;库的操作学完了&#xff0c;就要开始学习表的操作了&#xff0c;而表可与数据强相关&#xff0c;比如DDL&#xff0c;即数据定义语言&#xff0c;DML&am…

JVMの静、动态绑定异常捕获JIT即时编译

在说明静态绑定和动态绑定之前&#xff0c;我们首先要了解在字节码指令的层面&#xff0c;JVM是如何调用方法的&#xff1a; 例如我有以下的代码&#xff0c;很简单就是在main方法中调用了另一个静态方法&#xff1a; public class MethodTest {public static void main(Strin…

小程序 UI 风格美不胜收

小程序 UI 风格美不胜收 小程序 UI 风格美不胜收

论文阅读《SELECTIVE DOMAIN-INVARIANT FEATURE FOR GENERALIZABLE DEEPFAKEDETECTION》

作者&#xff1a;Yingxin Lai、 Guoqing Yang1、Yifan He2、Zhiming Luo、Shaozi Li 期刊&#xff1a;ICASSP-2024 目的&#xff1a;解决泛化性的问题&#xff0c;提出了3个模块 论文整体的架构图&#xff1a;&#xff08;挑选域特征不变&#xff0c;减少对图像内容或者风格…

完全平方数

完全平方数 完全平方数动态规划 完全平方数 给你一个整数 n &#xff0c;返回 和为 n 的完全平方数的最少数量 。 完全平方数 是一个整数&#xff0c;其值等于另一个整数的平方&#xff1b;换句话说&#xff0c;其值等于一个整数自乘的积。例如&#xff0c;1、4、9 和 16 都是…

289M→259M得物包体积治理实践

一、前言 iOS应用的包体积大小是衡量得物性能的重要指标&#xff0c;过大包体积会降低用户对应用的下载意愿&#xff0c;还会增加用户的下载等待时间以及用户手机的存储空间&#xff0c;本文重点介绍在包体积治理中的新思路以及原理与实践。 二、原理介绍 Macho产物测试 我…

想要修改word文档怎么移除编辑权限?学会这两个方法,轻松搞定

日常办公和学习中&#xff0c;Word文档是我们不可或缺的工具。然而&#xff0c;有时我们可能会遇到一些设置了编辑权限的文档&#xff0c;这可能是由于文档的创建者希望控制文档的修改和传播&#xff0c;或者是因为文档在某些共享或协作环境中被设置为只读模式。在这种情况下&a…

网工内推 | 网络运维工程师,H3CIE认证优先,13薪,享股票期权

01 畅读 &#x1f537;招聘岗位&#xff1a;高级网络运维工程师 &#x1f537;职责描述&#xff1a; 1.负责线上业务网络技术运维工作&#xff0c;保障并优化线上网络质量&#xff1b; 2.规划并构建公司线上业务网络架构&#xff1b; 3.规划线上业务网络质量评估与监控体系&…

mysql中 redo日志(上)

大家好。我们知道InnoDB 存储引擎是以页为单位来管理存储空间的&#xff0c;我们进行的增删改查操作其实本质上都是在访问页面。而在真正访问页面之前&#xff0c;需要把在磁盘上的页缓存到内存中的Buffer Pool之后才可以访问。那么我们思考一个问题&#xff1a;如果我们只在内…

vue2中使用tinymce

vue2中使用tinymce的记录 本篇文章主要实现的功能&#xff1a; &#xff08;1&#xff09;【查看】时禁用编辑 &#xff08;2&#xff09;【编辑】时某些内容是不可编辑的 &#xff08;3&#xff09;【内容】前端拼接编辑器模板 &#xff08;4&#xff09;【内容】编辑器模板中…

【漏洞复现】锐捷校园网自助服务系统 login_judge.jsf 任意文件读取漏洞(XVE-2024-2116)

0x01 产品简介 锐捷校园网自助服务系统是锐捷网络推出的一款面向学校和校园网络管理的解决方案。该系统旨在提供便捷的网络自助服务&#xff0c;使学生、教职员工和网络管理员能够更好地管理和利用校园网络资源。 0x02 漏洞概述 校园网自助服务系统/selfservice/selfservice…

Java核心: 为图片生成水印

今天干了一件特别不务正业的事&#xff0c;做了一个小程序用来给图片添加水印。事情的起因是需要将自己的身份证照片分享给别人&#xff0c;手边并没有一个趁手的工具来生成图片水印。很多APP提供了水印的功能&#xff0c;但会把我的图片上传到他们的服务器&#xff0c;身份证太…