




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于uC/OS-II的低速率语音编码器系统设计摘要:实现了一种全集成可变带宽中频宽带低通滤波器,讨论分析了跨导放大器-电容(OTAC)连续时间型滤波器的结构、设计和具体实现,使用外部可编程电路对所设计滤波器带宽进行控制,并利用ADS软件进行电路设计和仿真验证。仿真结果表明,该滤波器带宽的可调范围为126 MHz,阻带抑制率大于35 dB,带内波纹小于05 dB,采用18 V电源,TSMC 018m CMOS工艺库仿真,功耗小于21 mW,频响曲线接近理想状态。关键词:Butte摘要:uC/OS-II是一种免费且源代码公开的实时内核,经过多年的实际应用,显示出强大的功能和巨大的商业价值。本文实现
2、了uC/OS-II在TMS320C54X上的移植,并设计了基于uC/OS-II的低速率语音编码器。关键字: uC/OS-II; TMS320C54X;低速率语音编码器引言随着数字信号处理技术的发展,越来越多的数字信号处理芯片应用于各行各业。但是,以往多数的DSP 系统是基于流程图的设计方法,该方法设计的程序稳定性不高,流程中任意一个环节出错都将导致系统崩溃甚至死机。使用RTOS将对系统的稳定性有很大的改善。使应用模块化,可极大提高程序的可读性、可扩展性和可移植性。TI公司的定点DSP处理芯片TMS320C54X是目前应用比较广泛的一种DSP芯片,具有功耗低、运行速度快等优点,适合低速率语音编码
3、的应用。uC/OS-II是一种免费应且源代码公开的实时内核,经过多年的实际应用,显示出强大的功能和巨大的商业价值。本文实现了uC/OS-II在TMS320C54X上的移植,并提出了在uC/OS-II的平台上的低速率语音编码器的系统设计方案。图1 系统结构图图2 任务状态转移图uC/OS-II在TMS320C54X上的移植要实现uC/OS-II的移植,主要改写以下三个文件OS_CPU.H文件包括定义数据类型、代码值界区的中断控制、堆栈增长方向变量、任务切换函数定义和变量声明。TMS320C54X中的堆栈数据类型为16位,定义为:typedef unsigned int OS_STK在TMS320
4、C54X中所有的堆栈都必须用OS_STK声明。RTOS在进入系统临界区之前必须关闭中断,退出临界区后再打开中断。uC/OS-II定义了两个宏来关闭/打开中断:OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()。用OS_STK_GROWTH来设置,OS_STK_GROWTH为0表示堆栈从低地址向高地址递增;OS_STK_GROWTH为1表示堆栈从高向低地址递减,TMS320C54X中,堆栈地址是由高向低递减的。在uC/OS-II中,OS_TASK_SW()用来实现任务切换。OS_TASK_SW()函数模拟一次中断过程,在中断返回时进行任务切换。另外,还声明了一个8位变量
5、,用来调用DOS的时钟节拍函数,在TMS320C54X中应该屏蔽掉。OS_CPU_A.ASM文件在此文件中,需改写函数:OSStartHighRdy()、OSCtxSw()、OSIntCtxSw()。OSStartHighRdy (0)函数由Sstart()函数调用,功能是运行优先级最高的就绪任务。其过程为:获得优先级最高任务的TCB地址设置堆栈指针恢复任务环境中断返回运行新任务。在TMS320C54X中实现如程序列表1,其中,CONTEXT_RESTORE是将C54X中的寄存器出栈的宏定义,在此不再详述。OSCtxSw()函数是一个任务级的任务切换函数。软中断向量指向此函数。在uC/OS-I
6、I中,如果任务调用了某个函数,而该函数的执行结果可能造成系统任务的重新调度,则在函数的末尾会调用OSSched()。OSSched()查找当前就绪最高优先级任务,如果不是当前任务,则找到该任务TCB的地址,并拷贝到变量OSTCBHighRdy中,然后通过宏OS_TASK_SW()执行软中断调用OSCtxSw()进行任务切换。变量 OSTCBCur始终包含指向当前运行任务TCB的指针。在TMS320C54X中实现如程序列表2。OSIntCtxSw()函数与 OSCtxSw()函数类似,不同的是,OSIntCtxSw()函数进行中断级任务切换。中断可能引起任务切换,在中断服务程序的最后会调用 OS
7、IntExit()函数检查任务就绪状态,如果需要进行任务切换,则调用OSIntCtxSw()。值得注意的是,产生中断后,CPU寄存器会自动被保存,所以,在此函数中不再进行环境保存。在TMS320C54X中实现如程序列表3。OS_CPU_C.C文件在此文件中,只需修改 OSTaskStkInit()函数。OSTaskStkInit()由任务创建函数OSTaskCreate()或OSTaskCreateExt() 调用,用来初始化任务的堆栈。OSTaskStkInit()与调用它的函数有三个参数进行传递:任务代码起始地址(task),参数指针 (pdata),任务堆栈顶地址(ptos)。为提高代码
8、效率,此函数用汇编语言改写,在TMS320C54X中实现如程序列表4。(程序列表14,均见本刊网站 )基于uC/OS-II的低速率语音编码器系统设计本系统中,低速率语音编码器的功能有语音编码、语音解码、回波抵消、模拟接口、数字接口等。另外,为提高系统的稳定性,增加了空闲任务和监视任务。系统结构如图1所示。系统由里向外分为三层:操作系统层、任务层、硬件层。硬件层设计硬件层设计主要包括串口和HPI口,用于接收(发送)语音信号和信道上的数据。任务层设计本系统中共有七个任务,其优先级从高到低依次为:监控任务、模拟接口任务、数字接口任务、回波抵消任务、编码任务、解码任务、Idle任务。各任务的状态有4种
9、,即等待态和挂起态、就绪态、运行态以及中断态,状态的转换关系如图2所示。监视任务设计思路为:被监视任务正常运行时其执行时间是可预估的,被监视任务在其即将运行完毕时向监视任务发送消息说明自身运行正常。被监视任务运行时,监视任务处于等待态,等待被监视任务给它发送消息,等待时间被设定为预计的任务正常运行所需的最大时间。若等待时间内监视任务收到消息,则认为发送消息的任务运行正常,依照各任务执行顺序的先后下一任务开始运行,监视任务等待下一任务发送的消息。若等待时间已过,监视任务仍未收到消息,则系统的时间管理函数将强行把监视任务视为就绪态。因监视任务的优先权是最高的,它将抢占对CPU的控制权并采取相应的纠
10、错方案。操作系统层设计在应用中,各个任务之间都有数据要交换,本设计中采用消息机制实现任务间通信。编码任务需要模拟接口任务发送的消息,以接收用于编码的语音数据;数字接口任务需要编码任务发送的消息,以接收用于发往信道的编码数据;解码任务需要数字接口任务发来的消息,以接收来自信道的用于解码的解码字;模拟接口任务需要解码任务发来的消息,以接收用于D/A转换的数字语音信号。回波抵消任务需要等待的消息来自模拟接口任务和解码任务。监控任务接收所有其任务发来的消息,确认系统是否正常运行。在运行过程中,操作系统对各任务进行调度。其动作为:系统启动时,建立所有的任务,除回波抵消任务外,都处于就绪态;此时,监控任务
11、优先级最高,查询消息队列,没有消息的到来,转为等待态;模拟接口任务运行,接收/发送数据,发数据给回波抵消任务,并使回波抵消任务处于就绪态;如条件达到(如帧数已够),向编码任务发消息,传送数据,运行完毕,自行进入挂起态,等待下一次串口中断将其转为就绪态;数字接口任务运行,接收/发送数据,如条件达到(如编码字数够),向解码任务发消息,传送数据,运行完毕,自行进入挂起态,等待下一次串口中断(或HPI中断)将其转为就绪态;如消息足够,回波抵消任务运行,运行完毕,自行处于挂起态;编码任务运行,如有模拟接口任务发来的消息,则运行,编码完毕,向数字接口发消息;否则,处于等待态;解码任务运行,如有数字接口任务
12、发来的消息,则运行,解码完毕,向模拟接口任务和回波抵消任务发消息;否则,处于等待态;在所有任务都执行完毕后,Idle任务运行。由于所有的任务都有严格的执行时间限制,因此,上述的任务流程在正常情况下可以顺利进行。否则,监控任务会重启系统。结语本文在TMS320C54X的硬件平台上实现uC/OS-II,并针对传统的系统设计方法设计的低速率语音编码器稳定性不佳的问题,提出了基于uC/OS-II的低速率语音编码器系统设计的方案。由于低速率语音编码器通常是单片的,内部任务相对较少。使用实时内核来管理这些任务,会增加系统的内存和CPU时间的消耗,而任务调度的优势不能很好地显示出来,该设计有一定局限性。但是,在系统的内存足够大、CPU运行速度足够快的情况下,使用实时内核设计低速率语音编码器,有利于系统的后继开发。参考文献1 Jean J
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030年专家点评:中国可变电阻器行业发展环境及投资策略报告
- 2025至2031年中国箱型交流金属封闭开关设备行业投资前景及策略咨询研究报告
- 甘肃省陇南市某中学2024年中考数学模拟试卷含解析
- 2025-2030年中国RTB广告行业走势预测及未来趋势发展研究报告
- 2025年一般生产经营单位安全培训考试试题1套
- 2025厂级安全培训考试试题(研优卷)
- 2025新职工入场安全培训考试试题附参考答案【模拟题】
- 2024-2025承包商入厂安全培训考试试题答案打印
- 2025年新入职工安全培训考试试题答案打印
- 2024-2025岗前安全培训考试试题带答案(预热题)
- 陕西、山西省天一大联考2024-2025学年高中毕业班阶段性测试(七)语文试题及答案
- 大学生就业去向论文
- 实验室设备维护与保养试题及答案
- 2024年铁总服务有限公司招聘笔试真题
- 职业技术学院2024级安全技术与管理专业人才培养方案
- 广东省清远市2025届普通高中毕业年级高三教学质量检测物理试卷及答案(二)清远二模
- 2025届“皖南八校”高三第三次大联考物理试卷(含答案解析)
- 2025年4月广西壮族自治区贺州市中考二模语文试题(含答案)
- 教师资格笔试教育数字化转型的挑战与对策分析试题及答案
- 2025年保温杯抛光机项目可行性研究报告
- 2024年河北省中等职业教育对口高考畜牧兽医类真题试卷及参考答案-
评论
0/150
提交评论