(二)linux内核镜像制作

(一)目的

在进行嵌入式开发的时候,我们往往会先在电脑上安装交叉编译器,然后编译目标板上的代码,最后把代码下载到电路板中,嵌入式系统组成包括:BootLoader+kernel+filesystem+application,前面我们已经制作好了BootLoader,这一节我们制作一个kernel镜像

(二)工具

  • linux-3.5版本内核
  • Ubuntu 16.04
  • linux交叉编译环境(我已经安装过,没有安装的可以下载arm-linux-gcc-4.5.1-v6-vfp-20120301.tgz)

这里说明一点我们获取linux内核一般可以从linux官方获取,或者从开发板的厂商那获取,我比较推荐第二种,因为第一种还需要我们进行有关硬件的配置

(三)操作流程

1、将linux-3.5-20141114.tar拷贝到Linux系统中

2、解压linux-3.5-20141114.tar

tar -xvf linux-3.5-20141114.tar

3、进入解压后的目录

make menuconfig:打开配置界面,若无法打开需要安装库
apt install ncurses-dev

图一
运行make menuconfig打开上面的窗口可以进行内核功能的删减
按下面的步骤修改一个地方:

System Type  --->    
[ ] Support TrustZone-enabled Trusted Execution Environment   //按空格取消该模块

4、修改内核的顶层Makefile
因为最终内核运行到arm开发板,编译需要在PC端,所以需要使用到交叉编译器,在Makefile里指定交叉编译器为arm-linux-
图二
5、拷贝Linux3.5目录下的tiny4412_linux_defconfig为默认配置文件

cp  tiny4412_linux_defconfig   .config

6、编译内核

make -j8

若出现一下错误:

Can't use 'defined(@array)' (Maybe you should just omit the defined()?) at kernel/timeconst.pl line 373.
/driver/linux-3.5/kernel/Makefile:133: recipe for target 'kernel/timeconst.h' failed
make[1]: *** [kernel/timeconst.h] Error 255
make[1]: *** 正在等待未完成的任务....

修改kernel/timeconst.pl的373行:

if (!defined(@val)) {@val = compute_values($hz);}
为
if (@val) {@val = compute_values($hz);}

7、烧写内核到SD卡

编译完成会提示:Kernel: arch/arm/boot/zImage is ready

将SD卡插入读卡器并连接到Ubuntu

cd arch/arm/boot
dd iflag=dsync oflag=dsync if=./zImage of=/dev/sdb  seek=1057

大概持续40秒

8、验证是否烧写成功
将SD卡拔出插到自己的开发板上验证,启动后在串口里会提示内核启动的流程即为成功

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js+css实现骰子的随机转动

网上找的例子&#xff0c;然后增添了新的东西&#xff0c;在这里展示一下...... 效果图预览&#xff1a; <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html x…

linux安装交叉编译环境

&#xff08;一&#xff09;交叉编译器的简介 &#xff08;1&#xff09;本地编译 在了解交叉编译之前我们首先介绍一下另一个概念&#xff1a;本地编译 之前所做的C开发属于本地编译&#xff0c;即在当前PC下&#xff08;x86的CPU下&#xff09;&#xff0c;直接编译出可以运…

jsp实现邮件的发送

如果程序出现 454 Authentication failed, please open smtp flag first! 错误&#xff0c;那么一般是邮箱没有开通POP3/SMTP服务&#xff0c;登录邮箱&#xff0c;在设置中开启该服务即可 &#xff01; 另外需要的jar包如下: imap.jar, mail.jar, smtp.jar, 可以自己在网上下…

linux的mount和umount指令使用

mount即挂在操作&#xff0c;磁盘或分区创建好文件系统后需要挂载到一个目录&#xff08;一般mount在/mnt下&#xff09;才能使 用&#xff0c;和winsdows不同的是在linux下需要手动挂载。 用法&#xff1a;mount [-t文件系统] [选项] 设备目录注意&#xff1a;[ ]为可选项…

斐波那契的四种求法

首先看一下斐波那契的矩阵表示&#xff1a; 数列的递推公式为&#xff1a;f(1)1&#xff0c;f(2)2&#xff0c;f(n)f(n-1)f(n-2)(n>3) 用矩阵表示为&#xff1a; 进一步&#xff0c;可以得出直接推导公式&#xff1a; #include<iostream> #include<cstring> #i…

利用STM32制作红外测温仪之软件设计(MLX90614)

目录&#xff08;一&#xff09;工程目录如图&#xff1a;&#xff08;二&#xff09;main函数实现&#xff1a;&#xff08;三&#xff09;MLX90614测温代码实现前面介绍了使用 STM32制作红外测温仪硬件设计,今天来说一下软件的实现&#xff0c;具体的程序&#xff0c;完整的k…

Windows下使用Dev-C++开发基于pthread.h的多线程程序

一、下载Windows版本的pthread 目前最新版本是&#xff1a;pthreads-w32-2-9-1-release.zip。 二、解压pthread到指定目录 我选择的目录是&#xff1a;E:\DEV-CPP\Pthread完成后&#xff0c;该目录会多出三个文件夹&#xff1a;Pre-built.2&#xff0c;pthreads.2&#xff0c;Q…

(三)linux之根文件系统的制作

&#xff08;一&#xff09;准备工作 Ubuntu 16.04系统linux-3.5内核:linux-3.5-20190929交叉编译工具arm-linux-gcc-4.5.1-v6-vfp-20120301.rarbusybox源码包&#xff1a;busybox-1.21.1.rar &#xff08;二&#xff09;工具介绍 &#xff08;1&#xff09;交叉编译器 这个…

c/c++多线程模拟系统资源分配(并通过银行家算法避免死锁产生)

银行家算法数据结构 &#xff08;1&#xff09;可利用资源向量Available 是个含有m个元素的数组&#xff0c;其中的每一个元素代表一类可利用的资源数目。如果Available[j]K&#xff0c;则表示系统中现有Rj类资源K个。 &#xff08;2&#xff09;最大需求矩阵Max 这是一个nm的…

(四)Linux内核模块化编程

目录&#xff08;一&#xff09;模块化编程简介&#xff08;二&#xff09;安装卸载模块命令.&#xff08;三&#xff09;将自定义功能添加到内核三种方法&#xff08;1&#xff09;修改Kconfig和Makefile&#xff08;2&#xff09;直接修改功能对应目录下的Makefile文件&#…

基于X86平台的PC机通过网络发送一个int(32位)整数的字节顺序

1.字节顺序  字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序&#xff0c;通常有小端、大端两种字节顺序。小端字节序指低字节数据存放在内存低地址处&#xff0c;高字节数据存放在内存高地址处&#xff1b;大端字节序是高字节数据存放在低地址处&#xff0c;低字…

Linux内核空间和用户空间

在Linux系统中存在进程的概念&#xff1a; 进程的分类&#xff1a; 用户进程&#xff1a;运行在用户空间的进程被称为用户进程 内核进程:运行在内核空间的进程被称为内核进程 进程的空间&#xff1a; 系统会为每一个进程分0-4G的虚拟寻址空间&#xff0c;在4G的空间中 0-3G&…

codeforces Round #320 (Div. 2) C. A Problem about Polyline(数学) D. Or Game(暴力,数学)

解题思路&#xff1a;就是求数 n 对应的二进制数中有多少个 1 #include <iostream> #include<cstdio> using namespace std; int main(){int n;cin>>n;int ans 0; // while(n){//这也是一种好的方法 // n n&(n-1); // ans; // }while(n…

(五)Linux之设备驱动模型

目录&#xff08;一&#xff09;Linux内核驱动简介&#xff08;二&#xff09;杂项设备驱动模型&#xff08;1&#xff09;相关接口&#xff08;2&#xff09;杂项设备注册过程&#xff08;三&#xff09;早期经典字符设备驱动模型&#xff08;1&#xff09;相关接口&#xff0…

操作系统页面置换算法(opt,lru,fifo,clock)实现

选择调出页面的算法就称为页面置换算法。好的页面置换算法应有较低的页面更换频率&#xff0c;也就是说&#xff0c;应将以后不会再访问或者以后较长时间内不会再访问的页面先调出。 常见的置换算法有以下四种&#xff08;以下来自操作系统课本&#xff09;。 1. 最佳置换算法(…

(六)Linux之设备驱动模型(续)

前面我们学习了杂项设备驱动模型、早期经典字符设备驱动模型,这一小节来讲解Linux中的标准字符设备驱动。 目录&#xff08;一&#xff09;为什么引入标准字符设备驱动模型&#xff08;二&#xff09;相关接口&#xff08;三&#xff09;注册流程&#xff08;四&#xff09;程序…

N个数依次入栈,出栈顺序有多少种?

对于每一个数来说&#xff0c;必须进栈一次、出栈一次。我们把进栈设为状态‘1’&#xff0c;出栈设为状态‘0’。n个数的所有状态对应n个1和n个0组成的2n位二进制数。由于等待入栈的操作数按照1‥n的顺序排列、入栈的操作数b大于等于出栈的操作数a(a≤b)&#xff0c;因此输出序…

(七)linux函数接口的使用

前面我们讲解了字符设备的驱动模型&#xff0c;有了前面的基础后&#xff0c;今天学习函数接口就比较容易了 目录&#xff08;一&#xff09;open函数接口&#xff08;二&#xff09;read函数接口&#xff08;三&#xff09;lseek函数接口&#xff08;四&#xff09;用户空间和…

(八)linux驱动之ioctl的使用

这篇文章给大家讲解一下ioctl的简单使用&#xff0c;关于ioctl更详细的教程后面有机会单独写出来 &#xff08;一&#xff09;什么是ioctl ioctl是设备驱动程序中对设备的I/O通道进行管理的函数。所谓对I/O通道进行管理&#xff0c;就是对设备的一些特性进行控制&#xff0c;例…

(九)linux中断编程

目录&#xff08;一&#xff09;linux中断的介绍&#xff08;二&#xff09;内核中断的操作过程&#xff08;三&#xff09;实例代码&#xff08;一&#xff09;linux中断的介绍 linux内核中的中断通过中断子系统来管理。linux系统中有专门的中断子系统&#xff0c;原理很复杂…