从Tiny-4412开箱到启动Linux内核

lin
  Tiny-4412这款开发板相信大家都挺熟悉的,尤其是学习安卓驱动开发也是挺多人会使用这款开发板的,但是随开发板所赠送的映像文件资料真的是不忍直视,臃肿的资料且实用性欠佳,论坛上发帖求助也是没人理睬(此处手动哭泣脸 | _ |)。
      嵌入式交通第三区提醒您:
      学习嵌入式千万条  方便实惠第一条
        资料不规范  学者两行泪

正片开始,本文主要从以下几个方面入手:
1.嵌入式开发环境的搭建;
  主要是交叉编译链的安装;
2.u-boot的烧写;
3.linux内核的烧写;
4.挂载文件系统(网络文件系统)。
本文所用到的资源如下:
交叉编译链:arm-linux-gcc-4.5.1-v6-vfp-20120301
uboot版本: uboot-tiny4412-1506
Linux内核版本:linux-3.5-20151029

1.嵌入式开发环境的搭建

关于开发环境的配置之前写过相关的帖子,此处就不再赘述了,献上链接
   基于Ubuntu 18.04打造嵌入式arm开发环境
   此外还需要讲讲的就是DNW工具的安装,之后的相关文件烧写到开发板需要借助该工具。
   相关依赖的库的安装:

sudo apt-get install libelf-dev

编译dnw-linux工具包
   编译成功后生成dnw可执行文件,以及相关设备驱动:
在这里插入图片描述
将生成的可执行文件复制到用户可执行程序目录,并加载设备驱动。

sudo cp dnw  /usr/local/bin/
sudo insmod secbulk.ko

2.u-boot的烧写

2.1编译uboot
uboot目录
解压文件并编译

unzip uboot-tiny4412-1506.zip
cd uboot-tiny4412-1506
unzip uboot_tiny4412-master.zip
cd uboot_tiny4412-master
make tiny4412_config
make

编译成功之后执行以下操作

cd sd_fuse
make

2.2首先借助SD卡,进行u-boot映像文件的烧写
在2.1操作的uboot的路径下

cd tiny4412/
sudo ./sd_fusing.sh /dev/sdb

之后一张SD的启动卡就制作完成了。
烧写成功
2.3将SD卡插入开发板,并将启动开关拨向SD卡启动一侧,上电开机!
Tiny4412-Uboot
2.4弃用SD卡,将uboot烧写进EMMC内存中去。
2.4.1首先对Tiny4412的EMMC内存进行分区

格式化EMMC
fdisk -c 1 320 2057 520
格式化相关分区 1: 2: 3: 4
fatformat mmc 1:1        //将分区1格式化为Fat文件格式
ext3format mmc 1:2       //将分区2、3、4格式化为ext3格式
ext3format mmc 1:3
ext3format mmc 1:4

2.4.2烧写uboot到EMMC
(注:需要先完成DNW工具的安装)
1)上电开启开发板,在uboot加载倒计时结束前,按任意键进入uboot管理终端。

emmc open 1

在这里插入图片描述
emmc开启成功,在emmc开启之后需要进行连续的烧录,烧写完成之后就可以关闭emmc。
2)使用dnw工具,在uboot终端输入dnw命令。

dnw

在这里插入图片描述
此时uboot终端提醒OTG cable Connected ,设备连接成功,可以进行DNW下载。
3)在Ubuntu虚拟机端,进入uboot所在的目录

cd /1702/exynos/uboot_tiny4412-1506
sudo  dnw sd_fuse/tiny4412/E4412_N.bl1.bin

在这里插入图片描述
此时uboot终端打印相关提示信息,下载完成!
在这里插入图片描述
接下来就可以进行第一步的烧录E4412_N.bl1.bin到emmc,在uboot终端输入以下命令。

mmc write 1 0xc0000000 0 0x10

在这里插入图片描述
烧录成功!
烧录bl2.bin文件,烧录步骤同上。

dnw

在Ubuntu虚拟机输入:

sudo  dnw sd_fuse/tiny4412/bl2.bin

在这里插入图片描述
在这里插入图片描述
在uboot终端输入以下命令进行烧录

mmc write 1 0xc0000000 0x10 0x1C

在这里插入图片描述
接下来还需要对u-boot.bin、tzsw.bin文件进行烧写,就不再一一赘述。

uboot终端:
    dnw
虚拟机终端:
   sudo dnw u-boot.bin
uboot终端:
    mmc write 1 0xc0000000 0x30 0x21D
uboot终端:
    dnw
虚拟机终端:
   sudo dnw sd_fuse/tiny4412/E4412_tzsw.bin
uboot终端:
    mmc write 1 0xc0000000 0x2c0 0xB8

将上述文件都烧录完成之后,需要将emmc关闭。(记住一定要关闭emmc)
在ubo终端输入:

emmc close 1

在这里插入图片描述
好的,至此uboot已经烧写到emmc内存成功,可以取出SD卡,将Tiny4412的启动开关拨向另一侧,重新上电启动!
在这里插入图片描述

3.制作内核镜像并烧写

3.1配置linux内核

tar xzf linux-3.5-20151029.tgz
cd linux-3.5
cp tiny4412_linux_deconfig .config
make menuconfig

Tiny4412所使用的uboot不支持trustzone,内核必须禁止trustzone后编译才能启动;如果是superboot,此日期前的应该能启动,此日期后的则必须是启用trustzone后编译的内核才能启动。
在这里插入图片描述
禁止trustzone
在这里插入图片描述
配置成功
在这里插入图片描述
编译内核:

make zImage -j4

3.2烧写内核镜像进emmc内存
1)Ubuntu中的minicom

dnw 0x4008000

2)虚拟机

cd  /1702/exynos/linux-3.5
dnw arch/arm/boot/zImage

3)引导启动内核

bootm 0x4008000

在这里插入图片描述
4)烧写内核至emmc

dnw 0x40008000
cd  /1702/exynos/linux-3.5
dnw arch/arm/boot/zImage
movi write kernel 0 0x40008000

**设置uboot启动参数**
set bootcmd "movi read kernel 0 0x40008000;bootm 0x40008000"
save

在这里插入图片描述

4.挂载网络文件系统

(注:网络文件系统的制作以及NFS服务的使用后续的帖子会补上)
设置uboot启动参数:

set bootargs console=ttySAC0,115200 root=/dev/nfs nfsroot=192.168.2.201:/works/nfs_root/fs_mini_tiny4412 ip=192.168.2.123:192.168.2.201:192.168.2.1:255.255.255.0::eth0:off
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@菠萝菠萝哒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值