学海荡舟手机网

主页 > 实用文摘 > 教育文摘_15 > > 详细内容

软件无线电的开放式软件通信体系结构_无线通信论文

摘要:介绍了软件无线电系统的开放式软件通信体系结构,提出在可重新配置的硬件平台上建主一种分布式处理环境,运行不同供应商提供的软件组件以支持各种服务,从而达到系统软件的可移植性、重用性和伸缩性。

    关键词:软件无线电 软件通信结构 corba idl 域描述体

伴随蜂窝无线个人通信系统服务的快速发展,产生了很多无线通信标准,如gsm、is95、is54/136、pdc等。这些空中接口对不同的应用和服务都有各自约定的波段、调制解调机制、编解码方式、复合接人技术和协议。可以预见,在不久的将来,无线电通信系统必将把各种无线接入网集成到一个通用系统结构中,通过一个硬件平台实现多种标准和服务。二十世纪90年代初开始,无线电的服务正从长期依赖的硬导线连接向软件无线电演进。

1 基本思想

软件无线电sdr(software defined radio)为以软件方式实现各种空中接口,提供灵活的无线通信方式以便于实现灵活的传输机制、协议和应用。图1所示为多模式(多个性)的sdr系统的功能模块及标准接口点约定,其中无线电节点指基站或移动终端。多模式技术要求可在一个以上的信道rf频带上接人,在图1中为信道集。

图1

    一个软件定义的个性包括rf频带、信道集、空中接口波形及相关功能。rf/信道接人模块提供多个信号通道及跨越多个rf频段的rf频率变换。if处理模块包括滤波、进一步频率变换、空/时分集处理、波束成形及相关功能。多模式无线电产生多个空中接口波形,波形在调制解调器模块确定。安全(infosec)功能在无线应用中越来越重要,该模块主要实现传输安全、身份认证及保护隐私等功能。调制解调器输出的编码信道比特流在infosec被称为黑色(密文)比特流,经由infosec变换为红色(明文)比特流。然后通过协议栈加以处理,产生网络比特或源比特。网络比特依从网络协议通过网络接口接人到远程源;源比特则通过源解码器接到本地源。图1中发展支持部分的功能是支持软件目标的下载及新技术插入。

sdr的基本宗旨是利用数字信号处理技术代替现在主要的模拟信号处理。通过智能天线、宽带rf器件、宽带模数转换器(adc)及数模转换器(dac),利用通用可编程处理器实现if、基带及比特流处理。因为用可重新编程的软件代替了硬件模拟电路,通过动态分配射频、中频、adc、dps硬件和算法,并将软件对象分配到硬件组件中,使得软件无线电可以在线改变自己的特性。支持软件无线电可重新配置的技术有:

(1)可通过重载微程序进行重新配置的可编程门阵列(fpga);

(2)可通过重载代码在指令存储区进行重新配置的通用处理器。

图2

    这些软硬相关的微程序和代码的仓库运行在系统某处的通用处理器,它包含带有文件系统访问fpga和处理器的操作系统。这个通用处理器通常也包含与外部信号处理子系统进行通信的接口,例如用户接口或者临近的监控站。

2 sdr的软件通信体系结构

军用联合策略无线电系统(jtrs)定义的软件通信体系结构sca (software communication architecture)规范经历了steps 2a和steps2b两期的修正改进。当前版本version 2.2是今年11月30日在jtrs网站上发布的,被软件无线电论坛(sdr forum)作为sdr的标准。

sca不是一个实现方面的结构,而是要建立一种为jtps软件无线电开发而与实现无关的框架。sca规范包括一篇阐述软件通信体系结构的主要文档和相关附录文档。附录文档有jtrs定义的应用环境描述体(aep)以及域描述体(domain profile),描述体包含协议。sca规范的附录文档还包括波形配置的应用程序接口(api)、服务定义api、安全性说明、rational uml文档,以及配置管理文档。

2.1 系统结构

图2为sdr系统软件结构和模块接口示意图,其中corba orb & services模块和operating system模块使用现有商用产品。该软件结构的特点是:最大程度地利用了商用产品和协议;通过开放式分层结构将核心应用程序和非核心应用程序从底层硬件独立出来;通过通用对象请求代理结构(corba)提供了一种分布式处理环境,从而达到软件应用程序的可移植性、重用性和伸缩性。按比特流分段,系统分为黑色总线(密文传输)、安全(infosec)和红色总线(明文传输)三个子段。这些子段在物理上是相互隔开的,从而保证黑/红之间的隔离和infosec的完整性。参照osi的七层模型,系统主要实现层、mac层和部分逻辑链路层的任务,然后通过i/o模块与外界进行数据交互。

系统由操作环境(operating environment)、应用程序、逻辑设备和通用软件规则构成。oe包括核心框架(cf)、中间件(如corba的对象请求代理orb)和操作系统,其中orb必须支持minimumcorba(最小corba)规范。corba的扩展服务,如命名服务、日志服务、事件服务和标准事件等也作为中间件的一部分。

2.2 核心框架idl与应用程序接口(apl)

核心框架cf(core framework)由一组开放式软件接口和描述体构成,定义了嵌入式通信系统中的应用程序组件的配置、管理机制及相互通信方式。cf接口通过idl进行定义,分为下面几类:

(1)基本应用程序接口,包括端口(port)、生命周期、属性集、资源工厂和资源等;

(2)框架控制接口,包括应用程序、应用程序工厂、域管理器;设备和设备管理器;

(3)框架服务接口,包括文件、文件系统、文件管理器。

    sca规范的附录c以rational uml的表达方式详细描述了各类接口之间的关系。这些以idl定义的接口以及这些接口的继承类也就形成了应用程序的接口(api),被波形应用程序引用。cf利用corba结构进行消息传递。标准的api对于应用程序的灵活使用和设备的替换使用都很重要,同时也可以保证服务提供者和用户无需考虑开发和使用时操作环境(oe)和编程语言的不同。

2.3 应用程序环境描述体 (application environmentprofile)

sca应用程序环境描述体(aep)基于posix实时应用程序支持标准(ieee std 1003.13—1998),支持波形的可移植性、结构的伸缩性以及商用服务期限。图2中的operating system要求posix兼容的实时操作系统(os)应提供aep指定的功能和选项。corba对象请求代理orb、cf框架控制接口、框架服务接口和硬件设备驱动在访问os提供的aep服务时不受限制,而应用程序访问os的这些服务时受限制,需要通过cf访问文件系统。sca规范附录b详细说明了与aep相关的标准。

2.4 域描述体(domain profile)

sdr设备的目的是建立一个可重新配置的平台,这个平台可运行不同供应商提供的软件组件支持用户需要的服务,硬件设备和软件组件构成了一个sca的系统域。sca规范要求可移植的软件组件提供通用信息,清楚地定义硬件设备和软件组件的信息和交付格式,包括组件的位置、标识、属性、性能及相互间的关系,这些信息称为域描述体。域管理器就是利用域描述体的组件配置来启动、初始化和维护sca兼容的系统中安装的应用程序。

对象管理组织omg(object management group)制定的corba组件规范定义了面向对象的框架中软件组件的交付配置过程,交付格式采用扩展标记语言xml。sca规范关于域描述体的约定遵循corba组件模型原理,域描述体使用文档类型定义(dtd)格式,文档后缀为“.dtd”。sca规范定义的dtd文档有以下几类,开发过程中还可以增加自己的dtd文档。

(1) profile descriptor:为sad、spd或dcd实例提供完整的文档名,通过cf接口的“profile”属性进行访问。

(2)software assembly descriptor(sad):描述应用程序/波形的软件配置特性和组件的连接特性。

(3)software package descriptor(spd):确定一个软件组件的实现情况,如处理器类型、操作系统、执行代码类型和文件名等。

(4)software component descriptor(scd):描述corba软件组件及其接口。

(5)device package descriptor(dpd):用于确定制造商的。

(6)device configuration descriptor(dcd):指明组件如何在最初时启动一个设备并找到域管理器。

(7)properties descriptor file(prf):描述软件包或设备包的属性。

sca规范附录d详细说明了有关的dtd文档。下面以dcd类型文档为例说明这类文档的用途和使用方法。dcd类型文档引用的dtd文件名为“deviceconfiguration.+sca版本号+.dtd”,如deviceconfiguration.2.1.dtd。根据它产生的xml文档实例通常以“_dcd.xml”为扩展名,如nodei_dcd.xml。xml文档在第二个有效行指出引用的dtd文档,xml解析器根据指定的dtd文档来验证xml文档的有效性。

2.5 安全结构(seeurity architecture)

在军用系统中,有专门的组织定义、维护和研究安全措施方面的问题。随着工商部门对保守企业秘密要求的不断提高,安全性功能不再只是针对jtrs的需求,信息安全(infosec)处理器的重要性也在不断提高。利用可编程的infosec器件,可实现软件定义的infosec。sca的体系结构也采用了可编程的安全模块。

3 参考案例

3.1典型的sdr收发器子系统

典型的sdr收发器应包括以下三个组成部分:

(1)rf接口模块:信号下行传输时,rf模拟信号需要经过频率变换和a/d转换,形成宽带中频数字信号;信号上行传输时反之。本模块负责实现变频、模数、数模转换,这里不采用可运行os和orb的嵌入式处理器。

(2)通道化和预处理模块:本模块由多个fpga和一个控制这些fpga的处理器构成。信号下行传输时,将中频数字信号经过数字下变频(ddc)得到窄带基带信号,上行传输时反之,数字下变频和上变频(duc)均通过fpga实现。每个fpga必须有它自己的逻辑设备,代表传输模块的逻辑设备必须放在本模块的嵌入式处理器上,以便其它sca设备和应用程序访问本模块。设备管理器和设备驱动以及支持软件也必须运行在这个嵌入式处理器上。需要注意的是,通过corba总线,处理器可以运行任何cf组件,不论这些组件在系统何处实例化。

(3)基带处理模块:该模块对基带数据进行调制/解调和位流处理得到用户数据。负载数据(payload)通过ethernet送出收发器子系统。

所有的处理器都必须运行一个操作系统(os)和对象请求代理(orb)。波形应用程序运行在通用处理器上。

3.2 sdr-3000软件无线电收发器

经过step2a和step2b两期的研发,boeing、harris、motorola等公司各自开发出了自己的sdr产品。sdr-3000是加拿大spectrum signal processing公司flexcomm平台的最新产品。该产品支持上百个同步收发的信道,每个信道包含一个独立的空中接口协议。flexcommsdr-3000平台几乎支持所有天线接口标准,适合于联合战术无线业务(jtrs)、机载通信站点(can),以及各种蜂窝标准的软件无线电系统开发与使用。其优越性在于:在已有硬件的基础上,可通过无线或网络安装新的升级版本、新的应用程序和波形,支持现场更换;已配置系统不需要进行额外的硬件投资即可提供新的业务和能力,可节省很大的成本。

    flexcomm sdr-3000是一种模块化的软件无线电收发器结构,由三块板组成,系统模块接口如图3所示。从天线获得的射频信号经转换模块得到中频数字信号,并通过基于rapidio的高速串行总线被送到软件i/o模块;在这里执行通道化功能、数字下变频ddc和其它预处理,然后经过串行总线传送到基带处理模块;数据收发器子系统得到的负载数据最后经嵌入式compactpci分组交换背板的ethernet总线送到外部子系统。

图4为sdr-3000的软件结构示意图。其中vsi/pro是mpi软件公司提供的矢量信号图像处理标准库。该车兼容vsipl嵌入式api标准,包括各种通用处理函牧,如fiy、fir滤波器。quicwave是基于vsi/pro开发的车,用于开发波形组件。quiccomm库用于支持板级功能函数,如处理器间的通信、可编程的fpga和powerpc的启动及某些i/o操作等。

sdr-3000的硬件和软件都支持sca,实际应用中可以选择是否采用这种系统架构。 目前,flexcomm sdr—3000系列产品并没有包含sca核心框架(cf)的服务功能,但收发器子系统可以通过corba总线(通过ethernet总线传输)访问运行在系统中其它子系统的cf服务。

3.3 pc上的参考实现模型

加拿大通信研究中心(communications research centre canada)在sdr论坛的支持下开发出了兼容sca的软件无线电系统参考实现模型。该系统基于linux操作系统,使用java语言进行开发。详细资料可从其网站http://www.crc.ca获得。

可编程的fpga和dsp等硬件技术与面向对象的分布式处理技术使软件无线电技术的实现成为可能,但其发展还要面对很多挑战,需要硬件开发商、核心框架开发者、波形应用程序开发人员和系统集成开发商的共同努力。