tiny4412学习(一)之从零搭建linux系统(烧写uboot、内核进emmc+uboot启动内核)【转】

本文转载自:http://blog.csdn.net/fengyuwuzu0519/article/details/74080109

版权声明:本文为博主原创文章,转载请注明http://blog.csdn.net/fengyuwuzu0519。

目录(?)[+]

  • 硬件平台:tiny4412
  • 系统:linux-3.5-20151029
  • 文件系统:busybox-1.22.1.tar.bz2
  • 编译器: arm-linux-gcc-4.5.1

目的:

使用uboot引导Linux系统,并挂接根文件系统,搭建起linux开发环境。

 

由于友善支臂提供的minitools不是开源,使用起来很不舒服。本文将记录从零使用uboot在tiny4412上搭建linux系统的。由于之前只是学了2440,完成这个流程也遇到各种,现在总结如下。其中参考了多篇博客才得以实现,具体涉及的时候会给出链接。

一、准备系统文件

1、安装交叉编译工具链

(1)解压编译器源码

[cpp] view plain copy

print?

  1. tar arm-linux-gcc-4.5.1-v6-vfp-20120301.tgz –C /

(2)执行后将把 arm-linux-gcc 安装到/opt/FriendlyARM/toolschain/4.5.1 目录。

(3)vi /etc/environment修改PATH为:

[cpp] view plain copy

print?

  1. PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/opt/FriendlyARM/toolschain/4.5.1/bin"

(4)重启内核,执行arm-linux-gcc -v查看版本。

2、编译内核

(1)解压

解压 Linux  内核源代码

tar xvzf  linux-3.5-20151029.tgz

cd  linux-3.5

(2)配置

cp  tiny4412_linux_defconfig  .config

(3)编译

make

最后在 arch/arm/boot 目录下生成 zImage

3、制作根文件系统

本身打算使用光盘自带的文件系统,结果fastboot下载的时候,文件系统始终出问题,于是采用自制文件系统。通过网络进行挂接,后面会有具体操作说明。

参考:http://blog.csdn.NET/morixinguan/article/details/50677105

编译配置安装busybox

下载源码:https://busybox.net/

tar -xvf busybox-1.22.1.tar.bz2

cd busybox-1.22.1

makedefconfig     //默认配置

make menuconfig

BusyboxSettings  --->

[*] Build BusyBoxas a static binary (no shared libs)

[ ] Build sharedlibbusybox(NEW)                                     
[*] Build with Large File Support (for accessingfiles > 2 GB)         
(arm-linux-)  Cross Compilerprefix

make -j4

makeinstall   生成:  _install

制作文件系统 

mkdir filesystem
cd filesystem
cp ../busybox-1.22.1/_install/*  .-r
mkdir   etc dev opt sys tmp mnt lib proc
mkdir  etc/init.d
vim  etc/init.d/rcS
添加

[cpp] view plain copy

print?

  1. mount -t ramfs none  /dev
  2. mount -t sysfsnone  /sys
  3. mount -t proc  none  /proc
  4. mount -t tmpfs none  /tmp
  5. /sbin/mdev  -s

保存退出
vim  etc/inittab
添加

[cpp] view plain copy

print?

  1. ::sysinit:/etc/init.d/rcS
  2. ttySAC0::askfirst:-/bin/sh

保存退出
vim  etc/profile
添加

[cpp] view plain copy

print?

  1. export  PS1="[root @ cjy \W ] #"

保存退出
mknod  dev/console  c  5  1
cp /opt/FriendlyARM/toolschain/4.5.1/arm-none-linux-gnueabi/lib/* ./lib   -r
cd ..
权限:chmod 777 filesystem -R
发布文件系统
vim   /etc/exports
添加
/work/nfs/filesystem      *(rw,sync,no_root_squash)

保存退出
检查文件系统是否已经发布
showmount -e 192.168.1.123
现在网络文件系统以及可以共享,后面会给单板接上网线,然后设置uboot参数、单板IP,及nfs等参数。

4、编译uboot

光盘自带的uboot,无法直接使用,上电后只会打印OK。但是官方论坛可以下载到1506可以使用的uboot,链接如下:http://www.arm9home.net/read.php?tid-80810.html。也可以使用这篇博客体提供的uboot:http://blog.csdn.Net/lizuobin2/article/details/52825033

下载后配置,编译即可产生uboot。

本人使用的uboot下载链接:http://download.csdn.net/detail/fengyuwuzu0519/9886366

[cpp] view plain copy

print?

  1. tar xzf uboot_tiny4412-20130729.tgz
  2. cd uboot_tiny4412
  3. make tiny4412_config
  4. make

编译 用于生成bl2 的工具

[cpp] view plain copy

print?

  1. cd sd_fuse;
  2. make

假设SD卡已被PC Linux识别为/dev/sdc, 以root用户运行以下命令即可:

[cpp] view plain copy

print?

  1. cd sd_fuse/tiny4412
  2. ./sd_fusing.sh  /dev/sdc

到此我们准备好了

(1) 内核

(2) 文件系统

(3) Uboot

接下来就是如何下载,并启动内核,挂接文件系统了。

二、下载系统文件,并启动内核。

2.1、下载uboot到emmc

参考:

http://www.cnblogs.com/pengdonglin137/articles/4161084.html

http://www.arm9home.net/read.php?tid-83474.html

(1)之前我们已经将uboot下载到SD卡,现在从SD卡启动uboot,可以看到如下信息:

(2)查看设备的分区表信息

fdisk -p 0

fdisk -p 1

设备mmc1的分区信息,即eMMC分析,注意这个是superboot分区信息,我们就用这个分区。

分区1 是FAE分区, 分区2 是给system的,分区3是user-data, 分区4 是 cache.

(3)格式化eMMC

u-boot模式下输入如下指令来格式化eMMC设备。
#uboot:fdisk -c 1 320 2057 520
执行后会返回分区信息,继续格式话分区1,2,3,4
#uboot:fatformat mmc 1:1
这句话意思是对mmc 1设备的第一分区格式作fat格式化。
#uboot:ext3format mmc 1:2
#uboot:ext3format mmc 1:3
#uboot:ext3format mmc 1:4
上面三个指令是分别对eMMC的分区2,3,4作ext3格式化。
到此我们完成了对eMMC的设备的格式化。

(4)如果提示如下错误:

Error: No MBR is found at SD/MMC.                                            
Hint: use fdisk command to make partitions.
则先执行指令"fdisk -c 0",执行过程如下:
#fdisk -c 0                                                        
fdisk is completed

对emmc初始化后,我们开始使用dnw来下载uboot到emmc中。现在我们就需要装一下linux的dnw工具,注意dnw是下载到内存,把固件数据缓存起来,然后烧录到eMMC中。

(5)Linux下DNW工具安装:

主要参考了:

http://blog.sina.com.cn/s/blog_69dd1a09010196bf.html

http://blog.csdn.net/u011452544/article/details/39393857

http://blog.csdn.net/morixinguan/article/details/70478650

1.首先解压缩文件:
# tar xvf dnw_for_linux.tar.gz
另:在Ubuntu下右键解压也很方便

目录如下:
dnw_linux/
dnw_linux/secbulk/
dnw_linux/secbulk/Makefile
dnw_linux/secbulk/secbulk.c
dnw_linux/dnw/
dnw_linux/dnw/dnw.c
其中secbulk.c是PC端USB驱动, dnw.c是写入工具

2 编译并加载secbulk.c内核模块

$cd secbulk
$make -C /lib/modules/`uname -r`/build M=`pwd` modules
编译成功后在当前目录下可以看到secbulk.ko

3.编译完成后,会生成secbulk.ko文件:
# ls
Makefile       Module.symvers  secbulk.ko     secbulk.mod.o
modules.order  secbulk.c       secbulk.mod.c  secbulk.o

4.加载模块到Linux内核:
# sudo insmod ./secbulk.ko        (注意要在root权限下)
# dmesg        (查看是否加载成功)
secbulk:secbulk loaded

usbcore:registered new interface driversecbulk        (看到这样两行就说明成功了)

开机的时候不会自动加载.ko文件,这样每次都要先加载才可以使用,此时将其加入开机脚本,
使其得到自动加载,编辑/etc/init.d/rc.local 在最后加上 insmod /所在路径/secbulk.ko。

5.下面开始编译dnw工具
# cd ../dnw
# gcc -o dnw dnw.c

(编译完成,会看到dnw可执行文件)

6.将文件copy到/usr/local/bin目录
# sudo cp dnw /usr/local/bin
这样就可以在shell下面直接使用dnw命令了

但是问题出现了,当我使用这个dnw下载bl2.bin的时候,会出现校验错误。但是下载其他文件均没有问题,于是网上各种寻找DNW工具,看安装,最后通过和另一个版本的DNW结合,解决了这个问题,uboot也完整的下载到了emmc中。下载链接:http://download.csdn.net/detail/fengyuwuzu0519/9886362

(6)DNW下载好了,我们可以把uboot下载到emmc了。

#uboot:emmc open 1
提示:eMMC OPEN Success.!!

上面提示emmc开启成功,注意说明,emmc一旦打开,需要连续烧录,烧录完成后可以关闭emmc

#uboot:dnw
提示:OTG cable Connected!

Now, Waiting forDNW to transmit data(等待DNW下载)

打开虚拟机,进入uboot所在目录

cd /work/uboot_tiny4412

dnw  sd_fuse/tiny4412/E4412_N.bl1.bin

此时u-boot中断会提示传送校验完成,此时已经把bl1.bin通过USB传送到了memeory的0xc0000000起始地址,大小8KB.

接下来我们烧录bl1.bin到eMMC中,u-boot下继续输入:
#uboot:mmc write 1 0xc0000000 0 0x10
会提示写入信息,说明已经写入成功。这个是把刚才从PC端通过dnw下载下来的bl1.bin固件下载到emmc中,起始0, 16个block, 一个block是512B, 16*512=8*1024=8KB. 这个是bl1.bin的存放位置。
以此类推,烧录bl2.bin. u-boot.bin, tzsw.bin

#uboot:dnw

#虚拟机:dnw sd_fuse/tiny4412/bl2.bin

#uboot:mmc write 1 0xc0000000 0x10 0x1C

#uboot:dnw

#虚拟机:dnw u-boot.bin

#uboot:mmc write 1 0xc0000000 0x30 0x21D

#uboot:dnw

#虚拟机:dnw sd_fuse/tiny4412/E4412_tzsw.bin

#uboot:mmc write 1 0xc0000000 0x2c0 0xB8

启动分区到此全部写入完成,注意一定要关闭emmc
u-boot下继续输入:
#uboot:emmc close 1
提示:eMMC CLOSE Success.!!

现在uboot已经完整的烧入到emmc,我们可以将开关波动到NAND一侧,从emmc启动,发现uboot输出已经变成了:

2.2、下载内核到emmc

参考:http://blog.csdn.net/lizuobin2/article/details/52825033

内核下载我们采用fastboot下载,uboot已经支持了fastboot。

安装windows下fastboot工具

如果你已经安装了Android Studio,那么你已经有fastboot工具,在目录

F:\AndroidSDK\platform-tools下有fastboot.exe AdbWinApi.dll

我也提供一下fastboot下载链接:http://download.csdn.net/detail/fengyuwuzu0519/9886552

下载我们进入uboot,执行fastboot,并将单板的usb接到PC。提示如下:

windows下cmd进入fastboot.exe所在目录

fastboot flashkernel zImage(正常下载)

fastboot flashramdisk ramdisk-u.img(正常下载)

fastboot flash fatrootfs_qtopia_qt4.img (下载始终出错,于是放弃光盘的文件系统,使用自制的文件系统)

fastboot reboot

此时,我们已经将uboot、内核下载到单板中。

参考:http://blog.csdn.net/lizuobin2/article/details/52825033

2.3、设置uboot启动参数,启动内核,并挂接网络文件系统

uboot启动参数:
set gatewayip  192.168.1.1
set ipaddr     192.168.1.125   //板子的IP
set serverip   192.168.1.123   //PC机IP

set bootargs "root=/dev/nfsnfsroot=192.168.1.123:/work/nfs/filesystem ip=192.168.1.125console=ttySAC0,115200 lcd=S70 ctp=2"

save

set bootcmd moviread kernel 0 40008000;movi read rootfs 0 41000000 100000;bootm 4000800041000000

reset

内核启动信息:

时间: 2024-10-24 18:37:05

tiny4412学习(一)之从零搭建linux系统(烧写uboot、内核进emmc+uboot启动内核)【转】的相关文章

讯为开发板的最小LINUX系统烧写及U盘的挂载及卸载

fdisk -c 0 fatformat mmc 0:1ext3format mmc 0:2ext3format mmc 0:3ext3format mmc 0:4 fastboot fastboot.exe flash kernel zImage fastboot.exe flash ramdisk ramdisk-uboot.imgfastboot.exe flash system system.img fastboot -w fastboot reboot 挂载U盘,在根目录下操作moun

LINUX内核分析第三周学习总结——构造一个简单的Linux系统MenuOS

LINUX内核分析第三周学习总结——构造一个简单的Linux系统MenuOS 黄韧(原创作品转载请注明出处) <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 回顾: [计算机三个法宝] 1)存储程序计算机 2)函数调用堆栈 3)中断 [操作系统两把宝剑] 1)中断上下文的切换:保存现场和恢复现场 2)进程上下文的切换 一.使用gdb跟踪调试内核从start_kernel到init进程启动 使用实验楼的虚拟机打开

linux基础学习第二十一天之自动化安装linux系统(kickstart)

内容: 利用kickstart进行自动化安装linux系统 制作光盘.U盘启动盘 一.系统自动化安装: 1.anaconda 由前面的学习我们知道,系统的启动流程: bootloader-->kernel(initramfs)-->rootfs-->/sbin/init 所以,bootloader完全可以由光盘来进行引导,在引导的过程中在借助kickstart来进程自动安装 Anaconda是RedHat.CentOS.Fedora等Linux的安装管理程序.它可以提供文本.图形等安装管

【Linux】基于VMware搭建Linux系统

本篇文章侧重于操作,主要内容大致包括: 两大类操作系统简要介绍 VMware Workstation Pro 15简要介绍及安装 CentOS简要介绍及基于Wi'n'dows 操作系统的安装 一 关于操作系统的介绍 1.Windows 系统 Window操作系统,是我们再熟悉不过的系统了. 客户端操作系统:windows xp(已过时),win7,win8,win10 服务器操作系统:windows server 2008(R2),windows server 2012(R2),windows

python学习笔记(8)-实现linux系统python命令行光标移动

本节点标题1.实现python命令行光标移动1.1.首先查看有没有安装readline-devel1.2.其次查看readline-devel正确的包名并安装1.3.最终编译安装python =======================================================================================================================1.实现python命令行光标移动在linux系统里,python移动

嵌入式Linux之旅——环境搭建篇之烧写整个系统

上一小结我们已经烧写完u-boot,我烧写的u-boot是板子厂家定制的,本小节将利用这个u-boot烧写整个系统.当然,在系统移植篇的时候也会涉及到如何定制一个u-boot. 烧写整个系统我们一个叫dnw的工具,dnw是一个USB工具,通过USB发送文件给具有USB下载功能的bootloader.也就说我用的厂家定制的u-boot已经具备了USB下载功能.我需要先安装一些库: sudo apt-get install libncurses5:i386 libstdc++6:i386 zlib1

Linux学习之路2-linux系统烧写

fastboot烧写方式 准备工作: 硬件– 串口线连接开发板串口con3到PC的串口– OTG线连接开发板的OTG接口和PC的USB接口软件– 串口工具(超级终端),默认波特率为115200– 烧写工具“USB_fastboot_tool”工具– PC机安装USB驱动(Android adb驱动) 镜像组合– Uboot 镜像“u-boot-iTOP-4412.bin”– 内核镜像“zImage”– 文件系统“ramdisk-uboot.img”和“system.img “步骤: • 拷贝前面

Linux系统如何写C/C++程序

前言,本文介绍的利用linux系统编写C/C++语言程序是在CentOS 环境下实现的,在编程之前,您得先安装Linux系统或者Linux虚拟机,一切准备好之后我们就可以开始编程了. (1).开启电脑或Linux虚拟机(本人使用的是虚拟机) (2)创建文件 点击左上角应用程序->系统工具->终端 得到如下结果 (3)编辑文件 在输入框中输入vim hello.c  //这里vim指创建一个文件.hello.chello是文件名可随意取, //.c是文件类型,这里指创建一个名称为hello的c文

一键烧写Linux,USB烧写Linux,裸机调试准备

一键烧写linux步骤 A:格式化SD卡,格式为FAT32(尽量用SD卡,其他需要转接板的卡可能会有问题) B:利用PC烧写工具SD_Writer.exe将SD卡启动文件mmc.bin烧写进SD卡中 a:启动SD_Writer.exe(win7需要以管理员身份运行) b:board model 选择6410 c:sd volume(SD盘符),首先点击scan自动搜寻,错误的话手动调整 d:sd type类型为auto(win7还需要点击format格式化SD卡) e:os type选择linu