基于TMS320LF2407 DSP控制器语音模块的设计与实现
扫描二维码
随时随地手机看文章
何苏勤 靳丽 摘要:本文着重介绍了dsp芯片的spi同步串行接口及spi与语音转换芯片ad50的通信方式,给出了硬件电路设计。针对ad50的特点,软件设计时通过dsp的spi口对其进行初始化配置,使其正常工作。dsp在内部对语音信号予以处理并通过ad50输出。
关键字:数字信号处理器dsp同步串行接口spi语音模块 ad50的初始化 1 引言
随着信息技术和计算机技术的飞速发展,dsp技术也正以日新月异的速度应用到国民经济的各个领域。
tms320lf240x系列dsp是美国德州仪器(ti)公司推出的一款16位定点数字信号处理器,它采用程序总线、数据总线分别独立并具有多条总线的哈佛结构体系,其数据和程序有各自独立的存储空间,这样的结构使数据吞吐率有很大提高;芯片内部包含多个处理单元;16×16位硬件乘法器;广泛采用深度流水线技术,以及特有的dsp指令,使得取址、译码和处理可同时进行,从而减少了指令执行时间,增强了dsp的处理能力;具有强大的内部事件管理器、10位a/d采样功能、i/o端口等丰富的外设接口。因此 dsp适用于高速、实时性的数据处理应用系统。 对于某一控制任务可能需要多个dsp相互合作完成或dsp作为主控制器来控制其他外围器件,这样dsp就需要和其他控制器频繁交换数据,此时,我们可以通过spi口进行器件之间的高速数据交换,这种通信方式比起通过串行通讯接口(sci)速度提高了近一倍。2. spi串行外设接口 dsp的串行外设接口(spi)是一个高速同步串行输入/输出(i/o)口,它能使可编程长度(1~16位)的串行位流以可编程的位传输速率输入或输出器件。spi口主要 通过4根线来完成通信[1],即:时钟线(spiclk),主机输出/从机输入线(spisimo),主机输入/从机输出线(spisomi),spi从发送使能 。它主要用于主从式系统中,一个主控制器可以带动几个从器件,或者一个主控制器可以和几个其他控制器构成多机系统,从器件的时钟是由主机给出,主机通过从发送使能信号来使同一时刻只有一个从器件和主机交换数据。从器件只有在主机发送命令时才向主机传送数据。 由于spi接口是串行传输数据,所以要求通信两端的时序必须匹配。tms320lf2407的spi接口有4种时序,由芯片的spiclk寄存器的4种时钟模式确定。这4种模式规定同步移出和移入数据位与时钟上/下触发沿及相位是否延迟的关系。 模式0――上升沿触发无延时:上升沿发送数据,紧接的下降沿接收数据。 模式1――上升沿触发有延时:上升沿前半个周期和紧接的下降沿之间发送数据,上升沿接收数据。 模式2――下降沿触发无延时:下降沿发送数据,紧接的上升沿接收数据。 模式3――下降沿触发有延时:下降沿前半个周期和紧接的上升沿之间发送数据,下降沿接收数据。 dsp可以根据系统中与之通信的芯片的具体特点来选择一个工作模式。3. 硬件电路设计 语音模块的硬件电路设计必须保证语音信号输出的实时性,这里我们采用ti dsp系列的tms320lf2407(以下简称2407),它高达30mips的处理能力足以满足语音的实时要求。语音采集和输出芯片采用的是tlc320ad50c[2] (以下简称ad50),它是一款单5v电源供电、16位a/d和d/a高分辨率的可编程信号转换器。语音信号实时处理系统的主要功能是将话音通过mic输入,然后经过差分放大、模拟带通滤波后,输入ad50,经采样,将数据再送入dsp中进行处理,最后再将处理完的语音数据经dac,放大输出,最后驱动喇叭发声。 ad50是差分器件,从mic输入的信号vaudio经集成运放后变为差分输入2n*vaudio,在对模拟信号进行数据采集以前,需要经过带通滤波器滤除带外杂波。由于话音的频率一般在3400hz以下,而工频干扰一般为50hz左右。所以设计了通带范围为300hz~3400hz的带通滤波器。该滤波器由两级二阶低通、两级二阶高通级联组成,采用多级反馈形式,具有巴特沃斯(butterworth)带内平坦的特性,这样可保证300~3400hz的语音信号不失真地通过滤波器,不仅滤除带外的低频信号,以减少带外工频等分量的干扰,还将滤除带外的高次谐波,减少由于采样引起的混叠失真。 设计中ad50的功能实现是通过对其内部的4个寄存器进行编程来完成的,对这4个寄存器的访问与其他一些接口电路有所不同,它不是通过地址线选通寄存器,而是通过串行输入口(din)在二次通信的时刻将控制字输入到ad50中,对4个寄存器进行初始化。通过这种串行接口的初始化,可以达到对ad50进行编程的目的,可编程的功能还包括:复位、掉电、通信协议、信号采样率、增益控制等。 ad50和dsp交换数据时,数据流和控制流在串行线上一位一位的传输,我们通过分时复用传输线即一次串行通信和请求二次串行通信的方法来分辨是数据流还是控制流。使一次通信