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

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

相关文章

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud