机顶盒软件组成及启动流程

2024-03-21 13:38

本文主要是介绍机顶盒软件组成及启动流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.  软件结构组成


    uboot        : 一种boot loader,负责机顶盒嵌入式linux的系统引导工作,引导系统启动,已经系统维护(镜像烧写,软件更新)。
env            :uboot 的环境变量,存储着一些变量及其值,供uboot使用,比较重要的两个变量:bootcmd  bootargs。
logo          :开机图片。
loader       :升级程序。
loaderbak :升级程序备份。
kernel        :linux 内核。
rootfs         :linux 根文件系统。
app            :应用程序。
ui               :页面文件。
data           :应用程序数据。
stbenv       :机顶盒产品信息。

2. 启动流程
   总体流程:
上电  -->  运行uboot  --> 加载kernel,运行kernel  -->  挂载根文件系统  -->  运行init进程  -->  执行启动脚本  -->  运行app

1.  uboot存储在flash设备的0地址处,上电后,从uboot开始运行。
2.  uboot起来后会运行bootcmd变量中的指令,bootcmd会读取kernel镜像,然后用 bootm命令去解压kernel镜像并运行kernel,
        运行kernel时,bootargs变量值会传递给kernel。
   3.  kernel起来后根据 bootargs 中root描述挂载 rootfs 。
   4.  rootfs挂载成功后,会运行 init 进程。
   5.  init 进程起来后,会执行启动脚本。
   6.  启动脚本中运行app。

下面是一段盒子启动打印:
Board: STiH237-HDK (B2141)  [32-bit mode] 

U-Boot 2010.09 (Feb 12 2015 - 14:59:24) - stm24-2013-08-17    //uboot 运行

DRAM:  256 MiB
NAND:  ONFI flash detected
ONFI param page 0 valid
ONFI flash is MT29F4G08ABADAH4, 512 MiB, page size 2048+64, sector size 128 KiB
512 MiB
SPI:  info: found ST N25Q256 (32MiB) device (page=256,erase=65536)
info: BCH controller initializing with ECC of 18-bits per 1KiB sector
Bad block table found at page 262080, version 0x01
Bad block table found at page 262016, version 0x01
In:    serial
Out:   serial
Err:   serial
Net:   stmac-0
Uncompressing Linux 2.6 ...

### 1843224 ###

xxxxxxxx: enable clk
xxxxxxxx: display hd logo
xxxxxxxx: display sd logo
can not find this value
Hit any key to stop autoboot:  0

NAND read: device 0 offset 0x2200000, size 0x300000      //读取kernel镜像
3145728 bytes read: OK
## Booting kernel from Legacy Image at 80000000 ...          <--------
Image Name:   Linux 3.4
Image Type:   SuperH Linux Kernel Image (gzip compressed)
Data Size:    2080907 Bytes =   2 MiB
Load Address: 80800000
Entry Point:  80801000
Verifying Checksum ... OK
Uncompressing Kernel Image ... OK                                     解压kernel镜像的打印 ------>

Starting kernel:                              //运行kernel,bootargs传递给kernel
start    = 0x80801000
initrd   = 0x00000000 (0 bytes)
bootargs = console=ttyAS0,115200 ubi.mtd=5 root=ubi0:rootfs rootfstype=ubifs rw mtdparts=stm-nand-bch:1M(uboot),1M(logo),16M(loader),16M(loader_bak),3M(kernel),32M(rootfs),64M(app),32M(ui),345M(data),1M(stbenv) stmmaceth=msglvl:0,watchdog:5000 M129(000000):eth0:off bigphysarea=3000 elevator=cfq

Welcome to STLinux (busybox)!    //init 进程启动,执行启动脚本,脚本中打印的欢迎标语。
[system background process]

//下面是挂载app  ui  data 分区的打印
UBI device number 1, total 512 LEBs (65011712 bytes, 62.0 MiB), available 0 LEBs (0 bytes), LEB size 126976 bytes (124.0 KiB)
UBI device number 2, total 256 LEBs (32505856 bytes, 31.0 MiB), available 0 LEBs (0 bytes), LEB size 126976 bytes (124.0 KiB)
STxH205  detected (32BITS)
UBI device number 3, total 2760 LEBs (350453760 bytes, 334.2 MiB), available 0 LEBs (0 bytes), LEB size 126976 bytes (124.0 KiB)

Please press Enter to activate this console.

//应用程序开始运行
-----------------------------------------------------
Software  : iPanel 3.0 Advanced
Platform  : STiH273
Branch    : Debug Branch
[BuildTime]-[Sep  7 2015]-[17:59:41]
-----------------------------------------------------


uboot环境变量
uboot命令行,输入 print 即可打印 uboot 环境变量,环境变量可以配置ip serverip mac 地址等(tftp工具下载镜像需要配置ip)。注意以下两个变量:

bootcmd=nand read 80000000 2200000 300000; bootm 80000000
bootargs=console=ttyAS0,115200 ubi.mtd=5 root=ubi0:rootfs rootfstype=ubifs rw mtdparts=stm-nand-bch:1M(uboot),1M(logo),16M(loader),16M(loader_bak),3M(kernel),32M(rootfs),64M(app),32M(ui),345M(data),1M(stbenv) stmmaceth=msglvl:0,watchdog:5000 M129(000000):eth0:off bigphysarea=3000 elevator=cfq

bootcmd:启动命令,描述kernel启动的命令,从上面变量值可以看到是从nand flash中读取了kernel镜像,并交给bootm命令去解压执行。
bootargs:启动参数描述,这些参数会传递给kernel,kernel启动后需要用到这里的参数,例如 root 描述的根文件系统信息,console 描述的串口信息,以及分区划分信息。

init进程
kernel启动后,会挂载根文件系统,然后执行init进程,shell命令行模式下输入 top 命令查看,即可发现这个init进程,其pid是1,是系统启动后运行的第一个用户态进程。


启动脚本
ST平台启动脚本是 /etc/init.d/rcSBB, 不同平台略有区别,因为使用的不同的根文件系统,根文件系统中的 init 进程不同,init 读取启动脚本并执行的策略会有区别,但都是类似的模式。ST 平台启动脚本内容:

#!/bin/sh
echo "Welcome to STLinux (busybox)!"    //欢迎标语
# mount proc filesystem                            <-------
mount -t proc proc /proc
# mount devpts to allow logging in
mount -t devpts devpts /dev/pts -ogid=5,mode=620
# mount sysfs
mount -t sysfs sysfs /sys
#mount -t fusectl fusectl /sys/fs/fuse/connections      挂载一些文件系统 ------>
# start the telnet daemon to allow remote login
#busybox telnetd -l /bin/sh
/sbin/syscall &
/sbin/udevd.sh
/root/ipanel_start.sh          //执行启动app的脚本


这篇关于机顶盒软件组成及启动流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Qt 设置软件版本信息的实现

《Qt设置软件版本信息的实现》本文介绍了Qt项目中设置版本信息的三种常用方法,包括.pro文件和version.rc配置、CMakeLists.txt与version.h.in结合,具有一定的参考... 目录在运行程序期间设置版本信息可以参考VS在 QT 中设置软件版本信息的几种方法方法一:通过 .pro

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地