JZ2440使用笔记之熟悉uboot和Linux的移植
目录
一、点亮开发板:移植uboot、Linux内核、文件系统
1.1 配置上位机交叉编译环境
1.2 制作U-boot镜像文件
1.3 通过oflash.exe / openJTAG 烧写u-boot.bin到nand flash
1.4 U-boot的参数设置
1.5 制作Linux kernel镜像文件
1.6 制作文件系统镜像文件
1.7 配置上位机环境服务器环境
1.8 在U-boot下通过网络下载烧写Linux内核和文件系统
二、U-boot启动Linux内核原理简析
一、点亮开发板:移植uboot、Linux内核、文件系统
1.1 配置上位机交叉编译环境,
上位机:Ubuntu 16.04.2
1. 下载交叉编译工具: arm-linux-gcc-3.4.5-glibc-2.3.6.tar.bz2
2. 解压: tar -xvf arm-linux-gcc-3.4.5-glibc-2.3.6.tar.bz2
3. 查看解压后的路径: pwd
4. 配置环境变量:sudo vim /etc/profile 在文件最后加上 export PATH=$PATH:/home/qingzhu/Download/gcc/bin/
5. 使新的环境变量生效: source /etc/profile
6. 验证:执行 arm-linux-gcc -v 能看到打印出版本信息说明成功 (如果执行./arm-linux-gcc -v 都报错:no such file or directory, 可能是64位系统兼容问题,执行 sudo apt-get install lib32ncurses5 lib32z1)
1.2 制作U-boot镜像文件:
1. 下载源代码与补丁文件:u-boot-1.1.6.tar.bz2 u-boot-1.1.6_jz2440.patch(开发板配套光盘里有)
2. 解压源代码: tar -xvf u-boot-1.1.6.tar.bz2
3. 打补丁:进入解压后的目录,执行 patch -p1 < ../u-boot-1.1.6_jz2440.patch (实际上就是配置u-boot使其能驱动JZ2440)
3. 修改提示信息(这里是实验u-boot的参数可以通过 CFG_XXX 来配置):/include/configs/100ask24x0.h
4. 返回根目录执行配置: make 100ask24x0_config
5. 编译: make
6. 编译完成会在源代码根目录生成: u-boot.bin(用于下载到开发板),同时在tools目录下生成 mkimage工具(用来制作uImage)
1.3 通过oflash.exe / openJTAG 烧写u-boot.bin到nand flash:
1. 安装:OpenOCD with GUI setup.exe
2. 把u-boot.bin复制到oflash.exe的同目录,运行oflash.exe按提示操作(或者修改cfg.txt:oflash.exe的配置文件)
3.开机,看到新的u-boot的提示信息变成OpenJTAG-qingzhu(如下)
1.4 U-boot的参数设置:
1. 下面显示的是在 /include/configs/100ask24x0.h 中设置的一些u-boot的参数:
2. 下图是在u-boot的命令行下通过 print 命令查看u-boot的参数设置:
1.5 制作Linux kernel镜像文件:
1. 获取源代码linux-2.6.22.6.tar.bz2 和补丁文件linux-2.6.22.6_jz2440.patch
2. 解压源代码,进入解压后的目录,打补丁:patch -p1 < ../linux-2.6.22.6_jz2440.patch
3. 打完补丁根目录下会有config_ok的文件,把它重命名为.config(如果我们自己执行make menuconfig来配置内核,最终也是为了生成.config)
4. 编译:make
5. 编译完成,会生成:/arch/arn/boot/zImage(经过压缩的可直接运行的内核镜像)
6. 制作uImage(为了能被u-boot引导):uImage方式是uboot本身发明的支持linux启动的镜像格式
mkimage -A arm -O linux -T kernel -e 0x30007fc0 -a 0x30007fc0 -n linux-2.6.22.6 -d zImage uImage
(0x30007fc0是从u-boot中获取的,在u-boot中执行 print查看)
1.6 制作文件系统镜像文件:
1. 下载解压busybox源代码,修改Makefile(比如:修改平台为arm,编译工具为arm-linux-等);
2.执行配置:make menuconfig(如果make版本太高会出现兼容性问题,需修改Makefile,并安装libncurses5-dev);
3. 编译:make
4. 安装:make install(指定一个目录,这样不会破坏pc的环境);
5. 在指定目录下会生成 /bin/ /sbin/ /usr/ linuxrc;
6. 创建其他必须的目录:/etc/ /dev/ /lib/ ....
7. 制作文件系统镜像文件:
mkyaffs2image 目录 xxx.yaffs2
1.7 配置上位机环境服务器环境
现在JZ2440的nand flash已经被我们烧录好了u-boot,通过uboot的网络功能 tftp
>>>>>>>>>
搭建 tftp 服务器:
1. 在线安装:apt-get install tftp-hpa tftpd-hpa
2. 建立传输目录:mkdir /tftpboot
3. 设置访问权限:chmod 777 /tftpboot
4. 修改配置文件:vim /etc/default/tftpd-hpa3
TFTP_USERNAME = "tftp"
TFTP_DIRECTORY = "/tftpboot"
TFTP_ADDRESS = "[::]:69"
TFTP_OPTIONS = "-l -c -s"
Note:
1. tftp下载文件的命令:tftp 服务器IP -g 待下载文件名 -l 目标文件名(比如:tftp 192.168.1.101 -g ledtest -l ./ledtest)
2. 如果下载出现“TFTP ERROR: ‘Permission denied’”,更改服务器上待下载文件的权限:chmod 777 待下载文件
3. 重启tftp服务: sudo service tftpd-hpa restart
ARM开发板的IP地址以及访问的tftp服务器的地址是在uboot里面写死的;
所以要在上位机上安装tftp服务器并配置静态ip地址;
配置eth0静态IP:
比如要设置静态IP为 192.168.1.101:在vim /etc/network/interfaces文末加上如下代码:
auto eth0
iface eth0 inet static
address 192.168.1.101
gateway 192.168.1.1
netmask 255.255.255.0
network 192.168.1.0
1.8 在U-boot下通过网络下载烧写Linux内核和文件系统:
现在我们已经做备好linux内核和文件系统的镜像文件:uImage和xxx.yaffs2
u-boot也已经烧录到nand flash里面(开发板烧录好u-boot之后,就“活了”,因为接下来的linux内核和文件系统的烧录都可以通过u-boot提供的命令来实现)
下面显示的是nand flash的分区信息:是在u-boot的源代码里面写死的
bootloader params kernel root
|------ 256KB ------|----- 128KB -----|---------------- 2MB -----------------|------------.....------------------|
0 4_0000 6_0000 26_0000
开机进入u-boot shell:
// 烧写Linux kernel
tftp 30000000 uImage // 把内核镜像下载到内存30000000
nand erase kernel // 擦除kernel分区
nand write.jffs2 30000000 kernel // 把内存30000000的内容烧写到kernel分区
// 烧写文件系统(yaffs2)
tftp 30000000 xxx.yaffs2 // 把文件系统镜像下载到内存30000000
nand erase root // 擦除root分区
nand write.yaffs2 30000000 0x260000 $(filesize) // 把内存30000000的内容烧写到root分区,0x260000是root分区的起始地址,$(filesize)表示只烧写文件大小的区域(否则默认会烧写整个root分区,这样可以节省时间)
二、U-boot启动Linux内核原理简析
2.1 uImage结构与U-boot的命令行:
u-boot的使用的是busybox的hush shell,自带了很多命令,比如当我们在u-boot shell环境下执行命令 boot,他会去启动linux,简单分析一下这个过程:
1. 首先获取环境变量 bootcmd;
2. nand命令把内核读到内存中,bootm命令表示从内存的某个位置启动。
3. 在u-boot命令行输入:boot (会根据bootcmd参数来启动Linux Kernel)
4. 下图是红色部分是uImage比zImage多出来的文件头(在u-boot/include/image.h中定义了uImage的文件头结构,共64bytes):
包含如下信息:0x27051956是uImage的魔数;包含OS的类型,架构等等信息。
2.2 U-boot启动的大致流程:
1. u-boot在源代码里配置了一些参数(比如串口的波特率,命令行的提示信息等)给自己用(类似BIOS的 setup menu里面配置的参数);
2. 同时u-boot也会传递参数给Linux kernel(比如 noinitrd 就是告诉linux kernel在加载文件系统时没有initrd可用);
JZ2440使用笔记之熟悉uboot和Linux的移植的更多相关文章
- 驱动开发学习笔记. 0.02 基于EASYARM-IMX283 烧写uboot和linux系统
驱动开发读书笔记. 0.02 基于EASYARM-IMX283 怎么烧写自己裁剪的linux内核?(非所有arm9通用) 手上有一块tq2440,但是不知道什么原因,没有办法烧boot进norflas ...
- 【4412嵌入式开发板学习笔记】认识uboot
转自迅为讨论群:http://www.topeetboard.com 重要说明:这份笔记不是4412开发配套的,是我在网上看视频的时候下载上课老师的笔记后修改的.所以我试了一下笔记上的uboot命令, ...
- 驱动开发学习笔记. 0.07 Uboot链接地址 加载地址 和 链接脚本地址
驱动开发学习笔记. 0.07 Uboot链接地址 加载地址 和 链接脚本地址 最近重新看了乾龙_Heron的<ARM 上电启动及 Uboot 代码分析>(下简称<代码分析>) ...
- 【课程分享】深入浅出嵌入式linux系统移植开发 (环境搭建、uboot的移植、嵌入式内核的配置与编译)
深入浅出嵌入式linux系统移植开发 (环境搭建.uboot的移植.嵌入式内核的配置与编译) 亲爱的网友,我这里有套课程想和大家分享,假设对这个课程有兴趣的,能够加我的QQ2059055336和我联系 ...
- 【linux】U-BOOT与linux kernel通信: struct tag
欢迎转载,转载时需保留作者信息. 邮箱:tangzhongp@163.com 博客园地址:http://www.cnblogs.com/embedded-tzp Csdn博客地址:http://b ...
- uboot引导linux内核过程详解【转】
http://blog.chinaunix.net/uid-7828352-id-4472376.html 写的不错,尤其是uboot向linux内核传递参数的过程写的比较详细.
- Tutorial 01_熟悉常用的Linux操作和Hadoop操作
(一)熟悉常用的Linux 操作cd 命令:切换目录 (1) 切换到目录“/usr/local” (2) 切换到当前目录的上一级目录 (3) 切换到当前登录Linux 系统的用户的自己的主文件夹 ...
- Linux 学习笔记之超详细基础linux命令(the end)
Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 14---------------- ...
- Linux 学习笔记之超详细基础linux命令 Part 14
Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 13---------------- ...
随机推荐
- npm WARN install Refusing to install vue-router as a dependency of itself
今天在使用npm安装插件的时候提示如下错误: npm WARN install Refusing to install vue-router as a dependency of itself npm ...
- 使用ReentrantLock和Condition来代替内置锁和wait(),notify(),notifyAll()
使用ReentrantLock可以替代内置锁,当使用内置锁的时候,我们可以使用wait() nitify()和notifyAll()来控制线程之间的协作,那么,当我们使用ReentrantLock的时 ...
- 【CF480D】Parcels DP
[CF480D]Parcels 题意:有一个栈,有n个物品,每个物品可以选或不选.如果选了第i个物品,则获得$v_i$的收益,且第i个物品必须在$in_i$时刻入栈,$out_i$时刻出栈.每个物品还 ...
- java中jdbc源码解读
在jdbc中一个重要的接口类就是java.sql.Driver,其中有一个重要的方法:Connection connect(String url, java.util.Propeties info); ...
- hdu 2097 sky数(进制转换)
Sky数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- mybatis08--关联查询多对一
根据省会的id查询出省会和对应国家的信息 01.多表的连接查询 修改对应的实体类信息 /** *国家的实体类 */ public class Country { private Integer cId ...
- Spring Security的核心拦截器
1. HttpSessionContextIntegrationFilter 位于过滤器顶端,第一个起作用的过滤器. 用途一,在执行其他过滤器之前,率先判断用户的session中是否已经存在一个Sec ...
- Node.js的进程管理
众所周知Node基于V8,而在V8中JavaScript是单线程运行的,这里的单线程不是指Node启动的时候就只有一个线程,而是说运行JavaScript代码是在单线程上,Node还有其他线程,比如进 ...
- Oracle课程档案。第十一天
读一致性:oracle通过多版本与闪回机制保证读一致性.保证从某个时间点开始查询是一致的.在Oracle中主要通过SCN版本号来控制系统修改的版本,典型的例子是我们可以通过在同一个查询中得到同一个对象 ...
- js中级小知识3
函数: 函数在调用的时候,会形成一个私有作用域,内部的变量不会被外面访问,这种保护机制叫闭包.这就意味着函数调用完毕,这个函数形成的栈内存会被销毁. 有些时候我们不希望他被销毁. 函数归属谁跟它在哪调 ...