免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1014 | 回复: 0

STB 上 Linux 软件系统解决方案 [复制链接]

论坛徽章:
0
发表于 2010-01-14 09:21 |显示全部楼层
近年来,国内巨大的STB潜在市场,吸引了包括芯片厂商、CA厂商、中间件供应商、机顶盒生产厂商等厂家的热情,围绕STB的竞争全面展开。
  机顶盒是一种专用设备,包括软件模块和硬件模块。软件模块包括系统引导程序、嵌入式操作系统和应用软件。硬件模块根据CPU的不同,分为
ASIC专用芯片
组、多媒体DSP、X86三种。低档机顶盒一般采用专用芯片组或多媒体DSP,只支持较少的几种媒体编解码标准,业务扩展能力较弱,价格比较低。高档机顶
盒大多基于X86硬件,使用WinCE或Linux操作系统,甚至配有硬盘,与PC机非常相似,业务功能丰富,当然,价格也不菲。
  事实上,随着IPTV的兴起,对机顶盒的性能要求也越来越高,采用X86硬件提升机顶盒的性能已是大势所趋。但是,在提供更丰富业务功能的同
时,大幅降低
机顶盒成本,也是机顶盒技术发展的一个必然方向。本文将讲述基于兼容X86的STB上Linux软件系统解决方案,不涉及技术开发细节。主要将从以下方面
进行介绍:
一、硬件环境介绍
  本机顶盒核心部件包括:STPC CPU,2M FLASH,64M DOM和32M RAM。
  其中FLASH中存放Bootloader代码,DOM中存放嵌入式Linux操作系统。当然,机顶盒需要一些外围硬件电路,比如网络接口、遥控器接口等等。
二、Bootloader开发
  Bootloader是跟底层硬件关联性非常强的一层软件,也称为BSP。开发人员需要相当熟悉硬件结构,一般来说,可以由硬件人员完成,也可
以由软硬件
人员共同协助完成。Bootloader除了初始化CPU,RAM和基本的串口输出等功能外,还需要一些扩展功能,比如实现通过网络接口或者串口烧录操作
系统等。u-boot是一个开源的面向多个目标平台(ppc, mips, arm,
x86)的bootloader,并且功能强大,目前广泛应用在嵌入式系统开发中,只要根据硬件平台做有限的修改,就可以顺利实现。本篇不讲述u-
boot的具体移植过程,移植细节可参见《u-boot在PowerPC 860上的移植》一文。
三、嵌入式Linux裁减与移植
  嵌入式Linux我们选用Peewee Linux进行裁减,Peewee Linux的介绍和基本配置可参考《Embedded
Linux 嵌入式系统原理与实务》一书。Peewee
Linux的裁减仅仅是通过配置界面选择某些组件,但需要注意的是要保留X窗口,浏览器需要X窗口支持才能启动图形化浏览器。但是,通过Peewee
Linux裁减的Linux系统通常比较大,还需要做更进一步的裁减。一般来说一个不带X窗口的嵌入式Linux可以小到4M,带有X窗口的Linux也
可以在30M以下构建出来。总之,裁减后的Linux系统不能过于庞大,否则加上浏览器程序极有可能超出DOM的64M空间,需要另加存储空间,增加成
本。
  另一方面,在移植Linux到STB上后,由于STB上很多硬件在Linux下缺少驱动程序支持,不能工作。为此,开发必要的驱
动程序是必不可少的一步。
在Linux下开发一个驱动是相当容易的,一是因为Linux驱动程序的架构相对固定,二是有很多的源码可供参考。难点往往是调试过程,也更花时间,并且
经常需要改动某些代码,同时,驱动开发过程中也经常需要示波器、逻辑分析仪等设备的帮助。
四、浏览器程序选择 (Embedded Mozilla)
  在Linux环境下有很多开源的浏览器,但综合比较来说,Mozilla功能强大,支持的协议也相对比较多,图形界面丰富。其
次,Mozilla专门为嵌 入式系统开发了一个Embedded
Mozilla项目,不加裁减的话,编译结果大概20M多,用户可以对其进行裁减,一般来说,裁减到14M左右是很轻而易举的事。并且该项目是提供源码
的,用户可以根据需要定制一些功能,比如用户界面等等。
  具体可以参考主页:http://www.mozilla.org
五、JVM移植
  针对目前很多网页是Java severlet的特点,使得浏览器能支持Java语言是一大趋势,Embedded
Mozilla很容易实现对Java的支持,这也是为什么选择Embedded
Mozilla的原因之一。只要以动态库的形式注册sun公司提供的JVM到该STB的系统库路径下,并在Embedded
Mozilla中设置一下浏览器针对Java severlet的plug in功能,即可实现Embedded Mozilla对Java
severlet的支持。
  JVM下载参考:http://www.sun.com
六、其它应用开发扩展(EPG实现及EasySoap使用)
  该部分功能主要是为解决STB向PVR/DVR的扩展,当然如此扩展后需要添加大容量存储设备,以存储数据。EPG是PVR/DVR上不可或缺
的软件之
一,预先提供节目给用户,用户通过预定的方式下“订单”,PVR/DVR根据用户的预定情况实现节目的自动录制功能。目前EPG功能比较流行的做法是:在
PC机上用Web Service实现服务端,在PVR/DVR上实现客户端,由于Web
Service利用SOAP协议交互。为此,EasySoap浮出水面,利用该开源项目,可以很方便开发出Linux上的EPG客户端,实现与Web
Service的交互。
七、媒体播放软件实现
  该功能也可认为是STB的扩展,是PVR/DVR功能的一部分。媒体播放器我们选用功能强大的mplayer,这是Linux下又一个出色的开
源软件,支 持格式众多,包括很多流媒体在内,移植mplayer也比较简单。参见网站:http://www.mplayerhq.hu/
八、VOD实现
  VOD是STB交互功能的增强,因为我们已经移植了Embedded
Mozilla以及mplayer,VOD功能可以利用这两个软件顺利实现,需要做的工作只是在Embedded
Mozilla中如何判断当前的连接是一个媒体文件,以判断是否需要打开mplayer进行播放。
九、软件远程更新问题
  虽然目前用户要在STB设备上实现软件远程更新的需求并不突出,但软件远程更新问题是降低维护费用一个强有力的手段。STB的远程软件更新可以
采用主动或
被动的方式,主动的方式就是由用户手动去下载最新软件,实现升级;被动方式就是由STB开发商根据STB的信息主动提示用户更新,类似于window
2000/XP的升级程序。考虑到STB的特殊性,比如升级过程中可能发生意外,掉线等情况,建议采用由用户手动去下载软件进行升级的方式。
  具体实现方法是:在STB上开发专门用于软件升级的程序,该程序通过HTTP/FTP下载最新应用程序到本地,然后实现STB上软件的升级。由
于系统上空
间通常比较紧张,一旦升级失败,极有可能造成系统不能启动的情况,解决办法往往是增加内存空间,先备份先前的系统,如果升级成功,再删除,如果失败,则恢
复先前系统。
十、小结
  Linux由于其开源特性、出色的网络功能和众多的开源项目支持,正越来越成为嵌入式系统开发者关注的目标之一。相信越来越多的嵌入式开发者将加入到Linux这个行列中来。
  本文提出的仅仅是解决方案,实际开发中,从硬件设计到软件开发是一个相当漫长的过程,软硬件的协同设计、硬件的调试、软件的开发、软件的测试、系统的集成测试等过程都会遇到拦路虎,很多意想不到的问题会时不时地忽然冒出来。
  为此,在STB项目开发中,硬件的设计过程需要具有丰富经验的硬件工程师,以尽量缩短硬件设计与调试的时间。软件系统中上层应用的开发过程建议
开发者采用
OO的思想,同时在开发中运用设计模式,以防开发过程各种意想不到的变化。另外,值得一提的是,很多项目中,开发人员认为只有硬件开发完成后才能进行软件
的开发,这是一种误解。事实上,软硬件开发的过程可以同步进行,在硬件开发阶段可以同时进行上层软件的开发,这样可以尽可能加快产品走向市场的步伐。
文章出处:  http://www.linux.cn/home/space-2-do-blog-id-197.html
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/88379/showart_2148495.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP