按G.723标准设计的数字录音系统
AX0=DM(0x3fe5); {For 2181-PF0 connect with AD73311-RESET}
AR=AX0 AND 0XFFFE; {PF0 pin reset}
DM(0x3fe5)=AR; {RESET AD73311 to program}
NOP; {Delay}
NOP;
NOP
AX0=DM(0x3fe5);
AR=AX0 OR 0X0001; {2181-PF0 SET}
DM(0x3fe5)=AR; {ready to program}
ax0=0x82f9; {写控制寄存器CRC,5V电源,使能ADC和DAC}
tx0=ax0;
IDLE;
ax0=0x811b; {写控制寄存器CRB,分频,设置8K采样率}
tx0=ax0;
IDLE;
ax0=0x8320; {写控制寄存器CRD,输出输入增益为0}
tx0=ax0;
IDLE;
ax0=0x8400; {写控制寄存器CRE,DAC延迟量为0}
ax0=ax0;
IDLE;
ax0=0x8001; {写控制寄存器CRA,进入数据传输模式}
tx0=ax0;
IDLE;
2.2 闪速存储器与ADSP-2181的接口电路
闪速存储器采用韩国三星公司生产的KM29 N32000,容量为4M×8=32Mbit,分成512块,每块有16页,每页528个字节。可进行100万次擦写,数据保存时间为10年,通过编程可自动进行擦写。这里用于保存录音数据,其数据保存不需要充电维持。
javascript:window.open(this.src);" style="cursor:pointer;"/>
KM29N32000与ADSP-2181的接口电路如图4所示,它的读写及擦除操作说明如下:
(1)读操作
首先让CLE置高,进入命令模式。此时ALE置低,从I/O口输入00H(表示读操作控制命令字),接下来CLE置低,ALE置高,进入地址加载模式,将要访问的24位地址(A0~A23)分三次由低到高从I/O口磅入。适当延迟后,将ALE置低,就可连续地进行读操作,每次读取一帧数据。得到的数据是加载地址开始的。整个过程CE必须保持低电平。
(2)写操作
写操作过程与读操作类似,开始控制命令字是80H,将加载地十分三次送入后,适当延迟,就可连续地向闪速存储器写入一帧数据。数据写完时,CLE置高,送入10H命令字,进行写操作。
(3)擦除操作
保存数据时,如果对应存储区已经有数据,就必须先擦除掉原来数据。每次擦除一次,每块8K字节。
首先输入控制命令字60H,接着把块地址分两次送出,再输入D0H命令字进行块擦除。擦除完后,输入命令字70H,可读取擦除状态。如果接下来读取的数据的LSB位为"0"则表示擦除成功,为"1"则表示产生了错误,可重新进行擦除操作。如果再次错误,可能是对应单元出错了。
在访问Flash RAM的内存操作中,最重要的是要注意各个信号的时序。必须严格按照说明书的时序图进行操作才能实现正常的功能。
2.3 LCD显示及接口电路
在本系统中用LCD显示当前系统处于的状态,如录放状态、进行的时间等。可由ADSP-2181进行控制,设定显示方式及内容。
所用的是点阵式液晶显示器,为日立公司的HD44780A00LCD。里面有专用集成电路作为点阵的控制驱动,只要直接送入数据和指令就可实现所需的显示。在本系统中,由于LCD使能信号脉宽较大,无法直接由DSP产生,因此通过触发单稳触发器74LS123来产生LCD使能信号。接口电路如图5所示。
通过调节连接74LS123的R和C值可控制输出Q的脉宽tW。当C≥1000pF时为:
tW=K·R·C
其中K为常数,与外界温度及外接电容C有关,在0.2~0.6间选择。
当C≤1000pF时,tW估计值如下:
tW=6+0.05C(pF)+0.45R(kΩ)C+11.6R
当74LS123引脚A出现一个下降脉冲时,输出Q产生一个高电平脉冲,脉宽由R和C决定,驱动LCD工作。
录音时LCD上面一行显示RECORD,下行则显示进行的时间;放音时上面一行显示PLAY,下行也显示进行的时间。时间的显示通过ADSP-2181里面定时器中断进行。
javascript:window.open(this.src);" style="cursor:pointer;"/>
3 系统控制软件设计
ADSP21XX系列提供了一整套软件开发工具及相应的仿真器开发平台,给系统的调试与仿真提供了极大的方便。软件开发系统包括系统建造器、带运行时时间库的C编译器、汇编器、连接器、PROM划分器等。通过编译连接汇编源程序,可以生成EXE文件。此文件是存储映像文件,可以加载到仿真器上进行仿真;调试成功后,通过PROM划分器和EPROM烧制设备可以写入EPROM,系统复位时DSP加载EPROM程序便可自动运行,控制整个系统的工作。
系统软件设计采用自举和中断控制两种方式。自举方式系统一上电,ADSP-2181读取EPROM中的程序,自动运行程序去控制整个系统工作。
中断控制利用了ADSP-2181的两个中断,即sport0接收中断和timer中断。ADSP-2181的sport与AD73311相连。当得到一个采样数据时,产生一个接收中断,ADSP-2181读取便得到采样数据。由于sport0是全双工的,当产生接收中断时,同时可以发送数据,一方面在录音时可以得到回放效果;另一方面则在播放时可直接发送数据,而对采样数据置之不理,这样便于解码数据以固定的码率回放。Timer中断定时检测 外部控制引脚状态,包括录音、放音、快放及码率转换4个引脚,每个引脚的0/1状态对应两种控制,即开始录音/停止录音、开始放音/停止放音、5.3kbps/6.3kbps码率转换及快放状态,共有七个状态。
DSP汇编语言的结构与ASM汇编语言类似,其开头部分对应中断向量表。工作在中断方式时,则向量表对应中断处一般为一条跳转语句;产生中断时,则跳到相应语句执行中断控制功能。
主程序的中断设置部分如下:
JUMP start;NOP;NOP;NOP; {reset start interrupt}
RTI;NOP;NOP;NOP; {IRQ2}
RTI;NOP;NOP;NOP; {IRQL1}
RTI;NOP;NOP;NOP; {sport0 transmit}
JUMP sportReceive;NOP;NOP;NOP; {sport0 receive}
RTI;NOP;NOP;NOP; {IRQE}
RTI;NOP;NOP;NOP; {BDMA}
RTI;NOP;NOP;NOP; {sport1 transmit}
RTI;NOP;NOP;NOP; {sport1 receive}
JUMP settimer;NOP;NOP;NOP; {timer interrupt}
RTI;NOP;NOP;NOP; {PowerDown}
sporto和timer中断控制说明如下:
(1)sporto接收数据中断
在程序中,数据处理集中在此进行。主要过程是:在录音时,每收到240个采样数据,就进行G.723编码,将编码结果保存到闪速存储器中;在播放时,每次读取24个数据,将读取的数据进行解码,再通过串行口发送出去,经扬声器还原成语音信号。其流程如图6所示。
(2)timer中断
timer中断用来检测用户的控制信息及显示运行时间信息。用户控制有4个,即码率选择、录音控制、放音控制及快退控制。对应这4个控制引脚,初始设定为输入态,然后通过检测各个引脚的电平设定工作态。其流程如图7所示。
4 系统调试
系统调试要使用AD公司提供的ADSP21XX系列的整套软件开发工具和仿真器。笔者使用ADSP-2181-EZ-ICE仿真器进行调试。仿真器上自带33MHz的2181,调试支持20个断点,可单步、设断点和全速运行,可随时观察和修改寄存器和存储单元的值。仿真器上提供了一个14针的仿真接口,仿真器通过此接口仿真控制目标系统。仿真器与计算机间有一个RS-232接口,通过数据进行连到计算机的串行口上,在仿真器开发平台上就可以进行软件调试。
系统调试时遇到的主要问题是存储器读写及LCD的显示问题。开始时发现写进闪速存储器的数据与读出的数据不符。经仔细分析,发现是由于没有严格按照闪速存储器的读写操作时序进行编程,或是延迟量不够,或是两个信号的先后次序弄反了,数据可能根本没有写进去,读出的数据当然是错的。在严格按照其说明书的时序进行编程控制后,数据的读写擦除操作完全正常。
在播放录音数据时,曾出现声音跳变不连续的问题,经分析发现原因在于地址定位时出错。因为对闪速存储器担任时每次读写都是一帧数据,而编解码时一次操作的数据为20/24个字节,两者长度不一样,需要进行转换操作。
LCD开始调试时没有信息显示。经分析发现原因在于工作周期。本系统中ADSP-2181处理器的机器周期为30ns,经设定最大的等待周期为7机器周期后也才有240ns,而LCD的工作使能脉宽至少要300ns。因此在硬件上增加了一单稳延迟电路,这样便解决了此问题。