嵌入式语音通信系统中VxWorks BSP的设计实现
时间:09-18
来源:
点击:
2.1.7 数据接收和发送
多通道语音通信系统中MPC860T SCC串口时分复用即工作在QMC模式,逻辑通道的通信协议为Trasparent mode,该协议仅传输二进制数据,不对数据流进行位级操作,不区分数据帧中的格式位、起止位和数据位等,不对接收的数据做检错处理,因而具有较高的数据传输速率。
接收函数由中断服务例程调用。由于是每接收一帧产生一次中断,故接收函数也每次处理一帧的数据。数据的接收由接收描述符RxBD控制。当要接收数据时,接收函数首先需要确定RxBD有效;确定没有问题后,才将数据从接收缓冲区拷贝到接收Ring buffer,并复位RxBD;否则在进行相应错误处理后复位RxBD。接收函数流程如图3所示。
数据发送不调用中断处理函数,发送函数检测到发送缓冲区可用(即TxBD中R位为1)后,调用回调函数将数据从发送Ring buffer拷贝到串口发送缓冲区(Txbuffer)。这里为发送功能开辟足够大的环形缓冲区(足以容纳应用程序每一帧的数据)。发送函数流程如图4所示。
2.2 BSP调试方法和遇到的问题
2.2.1 调试方法
开发调试有两种方法,一种是使用仿真器通过BDM(后端调试模式)一步步地跟踪调试,另一种是通过点灯的方式进行所谓的"黑"调。"黑"调的方法是通过"灯"闪、用示波器测片选等,根据外部现象和所编的测试代码进行比较分析来调试程序。进行"黑"调的目的是调通信串口部分代码,宿主机可以通过串口与目标机的通信,然后再调试其他部分。调试流程分成两部分。首先是预内核启动代码(Pre-Kernel Initializa-tion),待最小内核启动正常后再添加I/O系统、文件系统、网络系统等组件和调试应用程序。使用仿真器Vi-sion Probe通过BDM方式调试BSP并将BootRom映像烧入FLASH。
2.2.2 调试中遇到的问题
(1)系统无法正常复位
在调试过程中,发现MPC860T的CLKOUT引脚无输出信号,系统上电复位过程没有完成,系统无法正常工作。初步判断是硬件问题。用万用表和示波器逐步检查上电复位、硬件复位、软件复位、时钟输入和BDM调试等模块电路,发现正常。判断是BGA焊接出现问题,将芯片取下,重新焊接,系统复位正常,时钟信号输出稳定正常。
(2)网络无法与外界通信
100 Mb/s快速以太网驱动加载中,网络层协议无法运行,目标板无法与外界网络建立联系。目标板网络启动时发出的MAC地址信息帧外界无法收到。通过仿真器发现程序单步运行正常。经过反复试验和测试,最终发现因SDRAM初始化程序没有运行导致程序运行(需要SDRAM支持突发模式)出错。更改调试方式,将BootRom开始的所有程序烧入FLASH,上电启动,网络正常,目标板与外界建立良好的网络通信。
3 结 语
该系统在实际测试中话音质量稳定,测试时声音清晰,没有串扰和杂音,没有较大延迟,说明硬件设计正确完备,QMC驱动程序和语音编解码和IP封装与解封装应用程序性能优良。
如果板卡上语音通道更多,则每帧的时隙增多、长度增大,因为FPGA内部电路所提供的的帧同步信号周期并不改变,所以只是实际数据传输速率提高,可以保证各路语音的同步和实时性。系统中QMC工作在Transparent Mode限制了它的应用范围,如何改进使系统支持多种通信协议是需要进一步研究的问题。
多通道语音通信系统中MPC860T SCC串口时分复用即工作在QMC模式,逻辑通道的通信协议为Trasparent mode,该协议仅传输二进制数据,不对数据流进行位级操作,不区分数据帧中的格式位、起止位和数据位等,不对接收的数据做检错处理,因而具有较高的数据传输速率。
接收函数由中断服务例程调用。由于是每接收一帧产生一次中断,故接收函数也每次处理一帧的数据。数据的接收由接收描述符RxBD控制。当要接收数据时,接收函数首先需要确定RxBD有效;确定没有问题后,才将数据从接收缓冲区拷贝到接收Ring buffer,并复位RxBD;否则在进行相应错误处理后复位RxBD。接收函数流程如图3所示。
数据发送不调用中断处理函数,发送函数检测到发送缓冲区可用(即TxBD中R位为1)后,调用回调函数将数据从发送Ring buffer拷贝到串口发送缓冲区(Txbuffer)。这里为发送功能开辟足够大的环形缓冲区(足以容纳应用程序每一帧的数据)。发送函数流程如图4所示。
2.2 BSP调试方法和遇到的问题
2.2.1 调试方法
开发调试有两种方法,一种是使用仿真器通过BDM(后端调试模式)一步步地跟踪调试,另一种是通过点灯的方式进行所谓的"黑"调。"黑"调的方法是通过"灯"闪、用示波器测片选等,根据外部现象和所编的测试代码进行比较分析来调试程序。进行"黑"调的目的是调通信串口部分代码,宿主机可以通过串口与目标机的通信,然后再调试其他部分。调试流程分成两部分。首先是预内核启动代码(Pre-Kernel Initializa-tion),待最小内核启动正常后再添加I/O系统、文件系统、网络系统等组件和调试应用程序。使用仿真器Vi-sion Probe通过BDM方式调试BSP并将BootRom映像烧入FLASH。
2.2.2 调试中遇到的问题
(1)系统无法正常复位
在调试过程中,发现MPC860T的CLKOUT引脚无输出信号,系统上电复位过程没有完成,系统无法正常工作。初步判断是硬件问题。用万用表和示波器逐步检查上电复位、硬件复位、软件复位、时钟输入和BDM调试等模块电路,发现正常。判断是BGA焊接出现问题,将芯片取下,重新焊接,系统复位正常,时钟信号输出稳定正常。
(2)网络无法与外界通信
100 Mb/s快速以太网驱动加载中,网络层协议无法运行,目标板无法与外界网络建立联系。目标板网络启动时发出的MAC地址信息帧外界无法收到。通过仿真器发现程序单步运行正常。经过反复试验和测试,最终发现因SDRAM初始化程序没有运行导致程序运行(需要SDRAM支持突发模式)出错。更改调试方式,将BootRom开始的所有程序烧入FLASH,上电启动,网络正常,目标板与外界建立良好的网络通信。
3 结 语
该系统在实际测试中话音质量稳定,测试时声音清晰,没有串扰和杂音,没有较大延迟,说明硬件设计正确完备,QMC驱动程序和语音编解码和IP封装与解封装应用程序性能优良。
如果板卡上语音通道更多,则每帧的时隙增多、长度增大,因为FPGA内部电路所提供的的帧同步信号周期并不改变,所以只是实际数据传输速率提高,可以保证各路语音的同步和实时性。系统中QMC工作在Transparent Mode限制了它的应用范围,如何改进使系统支持多种通信协议是需要进一步研究的问题。
嵌入式 MPC860 语音通信系统 VxWorks BSP 相关文章:
- Linux嵌入式系统开发平台选型探讨(11-09)
- 基于Winodws CE的嵌入式网络监控系统的设计与实现(03-05)
- 嵌入式系统实时性的问题(06-21)
- 嵌入式实时系统中的优先级反转问题(06-10)
- 嵌入式Linux系统中MMC卡驱动管理技术研究(06-10)
- FPGA的DSP性能揭秘(06-16)