烧写uboot、linux镜像、根文件系统到开发板

2024-06-09 04:20

本文主要是介绍烧写uboot、linux镜像、根文件系统到开发板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

烧写uboot、linux镜像、根文件系统到开发板

环境介绍

本博客使用x6818开发板。

公司:三星

ARM架构

Cortex-A53核

型号:S5P6818

特性:8核,最高主频2GHz

烧写uboot

使用网络烧写

网络烧写上位机是Ubuntu虚拟机。

  1. 先利用上位机,给TF卡烧写uboot,然后将TF卡插到下位机的TF0卡槽中。连接好电源口、网口、串口。电源口给开发板供电,网口用于传输可执行文件、系统镜像等,串口用于传输uboot命令、打印调试等。Ubuntu虚拟机配置成桥接模式,桥接到主机的以太网网卡上,用一根网线直接连接电脑网口和开发板网口。在下位机上电时,cpu会以TF0->TF1->MCC的顺序去读取uboot信息,并将uboot加载到内存同时cpu会跳到uboot,去执行其代码。因为我们将烧写了uboot的TF卡插到了TF0卡槽,所以cpu会直接读取TF0上的uboot。

  2. Ubuntu安装tftp服务

    apt-get install tftpd-hpa 
    
  3. 如果需要的话可以通过tftp的配置文件修改共享目录的位置,如下:

    # 修改TFTP_DIRECTORY参数即可修改共享目录。
    vim /etc/default/tftpd-hpa
    
  4. 为Ubuntu虚拟机配置一个静态ip,ip可以随便取,我取Ubuntuip为192.168.200.3、网关为192.168.200.2子网掩码是255.255.255.0。这里配置静态ip的教程参考Ubuntu配置静态ip。

  5. 通过串口工具SecureCRT,向uboot发送命令,配置下位机uboot的ip地址、serverip、网关:

    # 打印uboot环境变量,注意重要的两个环境变量:
    # ipaddr=192.168.1.165      // 此乃开发板的IP地址
    # serverip=192.168.1.164    // 此乃上位机的IP地址
    # gatewayip=192.168.1.2     // 网关
    print # 设置本机的IP地址为192.168.200.4
    setenv ipaddr 192.168.200.4# 设置服务器的IP地址为192.168.200.3
    setenv serverip 192.168.200.3# 设置网关的IP地址为192.168.200.2
    setenv gatewayip 192.168.200.2
    # 保存
    saveenv# 再次确保环境变量是对滴!
    print# 下位机ping上位机
    # 如果出现is not alive:表示失败,继续ping一下,第一次总是不成功的
    # 如果出现is alive:表示成功,继续后续网络下载操作
    ping 192.168.200.3
    
  6. 从上位机Ubuntu共享目录下载uboot:

    # 将上位机的ubootpak.bin文件下载到下位机的内存0x48000000处,
    tftp 0x48000000 ubootpak.bin
  7. 将内存中的uboot数据烧写到mmc:

    # 烧写到mmc上,以0x200(512)作为起始地址,烧写0x78000这么多字节,这里是以字节为单位!
    update_mmc 2 2ndboot 0x48000000 0x200 0x78000
    
  8. 拔掉TF0卡槽的TF卡,按下复位键,可以观察到串口工具SecureCRT有uboot的打印信息。

至此uboot网络烧写介绍完毕!如果你希望宿主机可以利用vscode的remote插件连接上桥接在以太网卡的虚拟机,可以把宿主机的以太网卡手动配置一个静态ip, 注意,ip的网络地址、子网掩码、网关地址一定要和虚拟机保持一致! 如下:

在这里插入图片描述

使用USB烧写

这里演示Win作为上位机,USB烧写uboot,Ubuntu其实是一样的道理。

  1. 同样,先利用上位机,给TF卡烧写uboot,然后将TF卡插到下位机的TF0卡槽中。连接好电源口、OTG USB口、串口。电源口给开发板供电,USB口用于传输可执行文件、系统镜像等,串口用于传输uboot命令、打印调试等。在下位机上电时,cpu会以TF0->TF1->MCC的顺序去读取uboot信息,并将uboot加载到内存同时cpu会跳到uboot,去执行其代码。因为我们将烧写了uboot的TF卡插到了TF0卡槽,所以cpu会直接读取TF0上的uboot。

  2. 串口工具执行fastboot命令,此时命令行终端卡住不动,等待上位机fastboot客户端程序发送要下载的文件。

  3. 上位机(windows)注意安装fastboot驱动。

  4. 在windows自带的终端执行命令:

    # 对于ubuntu系统:
    # 先安装fastboot:sudo apt-get install fastboot
    # 再运行此烧写命令:sudo fastboot flash ubootpak ubootpak.bin
    fastboot flash ubootpak ubootpak.bin
    
  5. 拔掉TF0卡槽的TF卡,按下复位键,可以观察到串口工具SecureCRT有uboot的打印信息。

USB烧写uboot介绍完毕!

烧写linux镜像以及根文件系统

rootfs_ext4.img:根文件系统。

uImage:linux内核的二进制可执行文件。

两个文件都文件位于:porting_resource目录下

开发板mmc的分区规划如下:

   EMMC分区规划如下:0-------512----------1M--------------65M---------------819M--------------剩余保留      uboot	        uImage	        rootfs	            大片第一分区	    第二分区        第三分区            暂时不分mmcblk0boot0   	mmcblk0p1    mmcblk0p2	# linux内核给每个分区指定的名称

使用网络烧写

  1. 将文件uImage拷贝到上位机Ubuntu下的/srv/tftp共享目录,保证上下位机网络通畅

  2. 通过串口,使用uboot自带的分区命令fdisk(以字节为单位),对下位机的mmc进行分区:fdisk 2 2 0x100000:0x4000000 0x4100000:0x2f200000

    第一个参数:首先TF卡,SD卡,EMMC硬件特性一模一样,统称MMC。如果传递0:表示对SD0卡槽的TF进行分区。如果传递1:表示对SD1卡槽的TF进行分区。如果传递2:表示对EMMC进行分区。

    第二个参数:表示要分两个分区,分别是uImage和rootfs所在的分区。注意:uboot所在的分区由linux内核自己来分。

    最后两个参数:0x100000:0x4000000:指定第二分区uImage所在的分区起始地址和大小。0x4100000:0x2f200000:指定第三分区rootfs所在的分区起始地址和大小

  3. 利用SecureCRT通过串口发送uboot命令控制下位机的uboot,使用tftp命令从上位机共享文件中拷贝uImage、rootfs_ext4.img,并将其烧录到mmc:

    # 以下命令都是通过串口发送给uboot执行# 利用tftp服务从上位机的共享目录中下载uImage到下位机内存0x480000000
    tftp 0x48000000 uImage  # 将uImage从内存的0x48000000写入到EMMC的0x800起始地址(以sector=512字节为单位),烧写0x3000这么多块(6M)
    mmc write 0x48000000 0x800 0x3000 # 利用tftp服务从上位机的共享目录中下载rootfs_ext4.img到下位机内存0x480000000
    tftp 0x48000000 rootfs_ext4.img # 将rootfs从内存的0x48000000写入到EMMC的0x20800起始地址(以sector=512字节为单位),烧写0x32000这么多块(100M)
    mmc write 0x48000000  0x20800  0x32000
    
  4. 设置uboot的环境变量,让其启动后,加载内核到内存指定地址,并且为内核提供启动参数,指定根文件系统的位置:

    # 以下命令都是通过串口发送给uboot执行# 设置加载启动内核的环境变量,从参数中我们可以看到,uboot会将内核放在0x48000000处
    setenv bootcmd mmc read  0x48000000 0x800 0x3000 \; bootm 0x48000000
    # 保存
    saveenv# 设置内核启动之后定位根文件系统的启动参数
    # root=/dev/mmcblk0p2:告诉linux内核将来要挂接找的根文件系统rootfs在第三分区
    # init=/linuxrc:linux内核一旦找到根文件系统rootfs,执行的第一个进程就是根目录下的linuxrc程序,注意:linuxrc会帮你启动第一号进程:/sbin/init
    # console=ttySAC0,115200:指定将来linux内核打印输出的信息通过第一个串口来输出到上位机上,波特率115200
    # ttySAC0:第一个串口
    # ttySAC1:第二个串口...
    # maxcpus=1:只启动一个CPU核,CPU0核
    # lcd=wy070ml:指定LCD显示屏的型号
    # tp=gslx680-linux:指定触摸屏的型号
    setenv bootargs root=/dev/mmcblk0p2 init=/linuxrc console=ttySAC0,115200 maxcpus=1 lcd=wy070ml  tp=gslx680-linux
    # 保存
    saveenv
    
  5. 使用uboot命令启动操作系统:

    # 以下命令都是通过串口发送给uboot执行# 直接运行bootcmd环境变量的命令启动下位机linux系统
    boot# 等待系统启动就OK了!
    

使用USB烧写

  1. 同网络烧写步骤2,进行emmc分区。

  2. 串口工具执行fastboot命令,此时命令行终端卡住不动,等待上位机fastboot客户端程序发送要下载的文件。

  3. linux镜像以及根文件系统的烧写使用fastboot命令进行USB烧写:

    # 使用fastboot,烧写到emmc的地址是在uboot的配置文件已经配置好的,不需要用户手动指定。
    # 如有需要,可以更改uboot的配置文件重新编译uboot、烧写uboot,可以使USB烧写地址改变。# 将uImage烧写到下位机EMMC的第二分区上,注意:uI(大写的i)mage。
    fastboot  flash boot uImage
    # 将rootfs_ext4.img烧写到EMMC第三分区上
    fastboot  flash system rootfs_ext4.img
    
  4. 配置步骤同网络烧写步骤4、5。


本章完结

这篇关于烧写uboot、linux镜像、根文件系统到开发板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1044203

相关文章

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

docker 重命名镜像的实现方法

《docker重命名镜像的实现方法》在Docker中无法直接重命名镜像,但可通过添加新标签、删除旧镜像后重新拉取/构建,或在DockerCompose中修改配置文件实现名称变更,感兴趣的可以了解一下... 目录使用标签(Tagging)删除旧的php镜像并重新拉取或构建使用docker Compose在Do

Linux五种IO模型的使用解读

《Linux五种IO模型的使用解读》文章系统解析了Linux的五种IO模型(阻塞、非阻塞、IO复用、信号驱动、异步),重点区分同步与异步IO的本质差异,强调同步由用户发起,异步由内核触发,通过对比各模... 目录1.IO模型简介2.五种IO模型2.1 IO模型分析方法2.2 阻塞IO2.3 非阻塞IO2.4

Linux中查看操作系统及其版本信息的多种方法

《Linux中查看操作系统及其版本信息的多种方法》在服务器运维或者部署系统中,经常需要确认服务器的系统版本、cpu信息等,在Linux系统中,有多种方法可以查看操作系统及其版本信息,以下是一些常用的方... 目录1. lsb_pythonrelease 命令2. /etc/os-release 文件3. h

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF