嵌入式Linux系列第4篇:Kernel编译下载
ninehua 2024-11-19 08:23 47 浏览
1.引言
本篇接上一篇,给大家介绍Linux Kernel的编译和下载运行,达到的预期效果是都下载到板子后,可以正常通过串口登录到Linux系统里。
2.Linux Kernel编译
NUC972 Linux Kernel下载地址为 github.com/OpenNuvoton/NUC970_Linux_Kernel
下载完成后,放到Ubuntu虚拟机的~/nuc972/kernel 文件夹下,解压缩。
编译前还记得前两篇文章说的吧,我们先source /home/topsemic/nuc972/toolchain/environment.sh
进入到内核目录,第一步先执行make nuc972_defconfig 生成.config文件,
这一步是不是很眼熟,和上一讲uboot编译是类似的。
第二步执行:make uImage,编译内核,报错了,错误是不是和编译uboot也类似啊。
同样的我们也是要改Makefile
这次我们用vim来改一次,
提示我们不支持vim这个指令,那我们安装一下吧,人家都给提示了,输入sudo apt install vim
下面是安装过程
OK,安装完毕,Ubuntu系统安装个东西真是方便啊,一条指令就搞定了。输入vim Makefile 显示如下:
花花绿绿的看着不错啊,先找到设置交叉编译链的地方,具体方法如下图1、2、3步骤描述
修改方法第一篇博客介绍的大家还记得吗?先输入I,进入到插入模式,然后修改即可
然后ESC退出插入模式,最后输入:wq保存退出即可。
以后大家多使用vim吧。
修改完Makefile后,再一次make uImage,
靠,什么情况,又报错了,我记得之前没遇到这个错误啊。
网上查了下,说是和文件系统有关,是权限的问题,使用sudo 编译就行,于是我激动的sudo make uImage,咦
这个命令找不动,不应该啊,我已经source了,而且输入arm-none- Table键也能找到啊,
于是又寻求度娘,有人说Makefile路径问题,于是我再改一次,把绝对路径加上
再来一次,
这次倒是没有刚才arm-none-linux-gnueabi-gcc找不到的问题,不过还是有一开始提示的错误:
这是怎么回事? 我灵机一动,上面提示没有../rootfs
于是,我cd .. ,回到上级目录,mkdir rootfs 建了一个rootfs文件夹,再次进入到内核目录,输入sudo make uImage
这一次看起来不太一样,好像要成功的样子,
不过最后还是有点小问题,还是目录没有的问题,我们再回到上级目录建个文件夹image
最后再来一次sudo make uImage
怎么还有错误,我之前编译根本没有这些问题的啊,郁闷了。。。
再次上网搜索,说这个命令是uboot编译出来的,因为没有找到它的原因,我看了下我的uboot 里tools目录,果然是有这个命令的,
有网友说把它复制到交叉编译链的bin目录里就行了,于是我放进去尝试,还是有问题,最后又百度,有网友说还得改个名字,前面得加上交叉编译的名字,于是加上arm-none-linux-gnueabi-,
最后再次编译,终于大功告成,不容易啊!
在image目录里的970uimage就是我们需要的文件了。
3.烧写kernel
1)具体怎么烧录,上一篇已经描述过了,这里要注意烧写地址:
2)另外上一节已经把uboot烧写进去了,这里不再重复了
3)这里还要再烧个env.txt
板子里有三个东西就可以了。
4.运行
1)使用debug串口连接上后,会进入如下界面
2)这时参考官方文档输入set bootcmd nboot 0x7fc0 0 0x200000\; bootm 0x7fc0
提示如下:
这什么情况,官方文档逗我玩呢??
后来发现把set 改为setenv就好了,写文档的人得靠点谱啊,不然真是坑人啊。
然后再输入 saveenv
3)按下复位键,这时就呼呼的跑起来了
靠,又出现错误了,这个足足卡了我1个多小时今天晚上。
最后也是灵光一现,定位到是上面编译内核时提示的rootfs文件夹有问题那里,难道我自己随便建个空的rootfs就可以吗?
另外回忆之前我用别人提供好的bsp包没出现这个问题,那里默认是有rootfs文件目录的,于是把那里的rootfs搞过来,解压后,再重新编译下(先sudo make clean,再sudo make uImage)并重新下载一次就ok了。我猜测内核里用到rootfs文件夹里的东西。 原来都没有考虑过这个问题啊我。
最后成功的现象是:
可以成功登陆进去,输入指令了!
至于这个rootfs文件夹里东西是怎么来的,我们下篇文章再说。
5.结束语
本篇文章写下来,自己收获了很多,本以为之前调通的东西,很容易就操作出来了,没想到遇到这么多新的问题,不过遇到问题是好事,会让你思考一些原来没有注意到的地方。
顺便提下,这里内核默认用的ramdisk根文件系统,这个文件系统是存在RAM里的,所以你在里面写入东西,一断电就没有了。这和常规在NAND上的Yaffs2文件系统不一样。下一篇介绍如果换成NAND Yaffs2文件系统。
经过这一篇的讲解,你如果实际动手实现后,应该对嵌入式Linux更加感兴趣了吧,相当于我们会重装系统了。虽然困难重重,但是不要放弃。
有任何问题欢迎大家留言交流讨论。
下期会给大家介绍如何改成NAND Yaffs2文件系统。
该系列往期文章见:
相关推荐
- 配合制导弹药!土耳其推出反无人机武器系统,可全天候拦截无人机
-
【军武次位面】作者:FriedrichLau据报道,日前土耳其军队装备了一款名为Sahin"沙欣"的反无人机武器系统。该系统由土耳其Aselsan公司开发,旨在摧毁迷你或小型无人机,...
- 威纶通常见问题18 威纶通触摸屏密码使用的相关介绍
-
密码1:屏右下角的系统设定列(向左的箭头)进入密码提醒:上传下载的默认密码均为6个1,若不慎忘记密码,因已加密所以原厂也无法解开,请妥善保管密码。若因不可抗力因素造成的忘记密码,只能将屏恢复出厂设置然...
- 轻松学会威纶通触摸屏上传与反编译
-
说到上传,大家并不陌生,上传顾名思义:就是把实际触摸屏画面上传到电脑EasyBuilderPro软件上,上传的作用是什么呢?可以修改触摸屏上原有的画面,所以说在上传这两字在工控中是非常重要的,接下来进...
- DLL 可以被反编译吗?(dll文件可以编辑吗)
-
DLL可以被反编译,但存在一定难度DLL(动态链接库)是一种二进制文件,包含了可执行代码和数据。虽然它不像高级语言源代码那样容易被理解,但可以通过一些反编译工具进行逆向分析。不过,反编译后的结果通常...
- 复古游戏反编译工具遭任天堂下架 工具名或为诱因
-
Reddit用户mhjhacker1近日发表文章称,自己开发的一款“复古主机游戏逆向工程”工具被其他用户使用,反编译了一款任天堂四十年前的游戏,因而遭到了Itch.io的下架。而相关的另外三个工具也遭...
- protobuf之序列化数据和反序列化数据基础知识
-
什么是protobufProtocalBuffers(简称protobuf)是谷歌的一项技术,用于结构化的数据序列化、反序列化。ProtocolBuffers是一种语言无关、平台无关、可扩展的...
- MT管理器-简单实战-去除启动页(mt管理器去除登录界面)
-
每次打开APP都要看着启动页2秒,很烦人,既然如此我们把它去掉吧。学过Android开发的都知道,APP的每个界面都是一个Activity,然后你点击桌面上的图标之后,其实是启动了这个...
- 这两个强大的开源C#反编译逆向工具,探索C#桌面应用的小秘密
-
C#的应用也比较多,有时候,我们想要研究一下别人的优秀的项目,可能会借助一些非常规手段来学习。下面,我就分享几款开源的C#反编译工具。dnSpydnSpy是一个用C#开发,开源的调试器和.NET汇...
- 一款开源的.NET程序集反编译、编辑和调试神器
-
致力于发掘、评测和推荐各种高效实用的工具和软件,帮助您在工作和生活中事半功倍。项目介绍dnSpyEx是dnSpy项目的非官方Fork维护版本,一款开源、功能强大的.NET反编译工具和调试器,可用于在没...
- 记一次噩梦般的经历--论学会反编译的重要性
-
最近在做一个android项目,因为非开源,github上也没购有私有库,所以就没有提交github管理。昨天我感觉写到了一定程度,一个小的版本已经出来了,于是就想U盘和网盘都备份一下。结果出现了下面...
- 奇!AI(人工智能)能不能反编译二进制代码为高级语言Java或者C?
-
一直很好奇某些软件的制作过程,使用的算法。因为自己实现的,写的稀烂,虽然功能达到了,但处理速度和处理效率很低下,于是也尝试使用一些反编译软件,如IDAPro软件。想看看人家怎么实现,怎么做到效果那么...
- 你知道 Java 中关键字 enum 是一个语法糖吗?反编译枚举类
-
持续创作,加速成长!这是我参与「掘金日新计划·10月更文挑战」的第7天,点击查看活动详情写下这篇文章,也纯属于是一个机缘巧合,我一个非常要好的朋友程,也是刚刚踏上工作岗位。这个问题也是他踏上岗位...
- SpringBoot项目Jar包加密,防止反编译
-
场景最近项目要求部署到其他公司的服务器上,但是又不想将源码泄露出去。要求对正式环境的启动包进行安全性处理,防止客户直接通过反编译工具将代码反编译出来。方案第一种方案使用代码混淆采用proguard-m...
- 安卓移动应用代码安全加固系统设计及实现
-
安卓平台已经逐渐成为最受欢迎的移动终端操作系统,基于安卓系统的软件应用数量众多,同时安全威胁也在不断增加。介绍了Android系统的安全风险及加固的核心技术,据此提出了一种安卓应用程序的安全加固系统,...
- 代码安全之代码混淆(代码混淆器是干什么的)
-
防止核心代码泄露以及代码合并每日辛辛苦苦码的代码被轻松破解?机密核心模块被盗用?数据库地址和语句暴露?……这些都是由代码未混淆加密,从而进行泄露的我们目前DLL文件存在的风险:一、直接引用二、反编译...