您现在的位置:机电论文网>> 单片机技术>> 正文内容

基于 EPM7128 设计的数据合并转换器

作者: 来源: 发布时间:2006/7/14 8:17:39  点击数:4400
摘要:介绍了基于CPLD芯片EPM7128设计的数据合并转换器。其中,控制串行口数据合并时间的计数器电路和并行数据转换成串行数据的移位电路都是在CPLD中完成的,数据块合并由相应的软件实现,最终形成CPM流输出。
    关键词:CPLD数据合并转换器串行口PCM流
    数据交换机的传送速率很高,当其和串行口通信时,在发送前把数据分为两部分分别发送到串行口,然后经过数据合并转换器把各个串行口的数据合并在一起并转换成PCM流。本文介绍了基于CPLD芯片EPM7128设计的数据合并转换器。
    1数据合并转换器硬件电路
    EPM7128是可编程的大规模逻辑器件,为ALTERA公司的MAX7000系列产品,具有高阻抗、电可擦等特点,可用门单元为2500个,管脚间最大延迟为5ns,工作电压为+5V。
    IDT7205为FIFO型异步读写的存储器芯片,容量为8192×9比特,存取时间为12ns,有空、半满、满三个标志位,最大功耗为660mW,工作电压为+5V。
    MSM4860DX属于PC104嵌入式系统的5X86系旬,为AMD-133MHzCPU,具有COM1、COM2两个串口,一个LPT并口,一个ELOPPY接口,一个IDE接口,一个VGA/LCD接口,一个AT-KEYBOARD接口,16个中断,额定功率为8W,工作电压为+5V。
    1.2数据合并转换器电路框图
    可编程的数据合并转换器电路框图如图1所示。图中,DB为数据总线,AB为地址总线,R和W分别为读写信号线,INT5、INT7、INT10INT11为四个中断,CS1、CS2和CS3是在CPLD内部生成的地址译码器Addr-encoder分别送给分频器、两个串行口的片选信号,ORG是晶振送给分频器的振荡脉冲,CLK是分频器输出的脉冲FRAMECLK和PCMCLK,WFIFO、RFIFO是由CPLD生成的包含地址信息的访问FIFO的读写脉冲,DATA_IN1和DATA_IN2为串行口输入数据,PCM_DATA是数据合并转换器输出的PCM流,PCMCLKA为输出的码同步时钟,WORLDCLKA为输出的字同步时钟。
    1.3电路工作分析
    晶振把时钟脉冲送给分频器,分频器含有两个可编程的定时器。分频器把可控的FRAMECLK和PCMCLK送给CPLD,在CPLD内部经过逻辑组合形成三路脉冲信号,一路控制计数器形成INT5、INT7两个帧频中断触发脉冲,CPU接到中断后立即写FIFO;另一路控制移位寄存器把并行数据转换成串行数据PCM流;第三路形成RFIFO去连续读FIFO。两个串行口通过中断方式(INT10、INT11)接收到外部数据后,暂存缓冲区内,按一定格式由中断INT5控制写给FIFO。
    2CPLD内部逻辑电路
    CPLD内部逻辑电路如图2所示。图中,虚线框内为CPLD内部电路,虚线框外为CPLD的I/O口。
    2.1地址译码器
    地址译码器Addr-encoder用VHDL语言生成。Addr-encoder的输出有总线驱动器芯片74245的使能脉冲ENB,总线传输方向的使能脉冲DIR,写FIFO操作脉冲WFIFO,分频器和串行口的片选CS1、CS2和CS3,FIFO数据空满标志脉冲RFIFOFLAG,FIFO复位时钟脉冲WCTRL。
    2.2数据移位部分
    FRAMECLK周期是PCMCLK的8位,它们都是分频送来的脉冲。FRAMECLK反相后作为FIFO的读信号,两次反相后作为字同步时钟。PCMCLK直接作为移位寄存器74165的时钟触发脉冲,两者与非后的输出低电平作为74165重数据的触发电平。它们的信号时序如图3所示。
    从三者的时序图可知,每当一个字节的最后一位完成移位后,在FRAMECLK脉冲反相的下降沿触发下读取FIFO数据,这时74165的装载使能74165STD恰好为低电平(与非结果),完成部数据装载,然后在PCMCLK脉冲的上升沿作用下开始新一软次的数据移位。
    2.3帧长计数器的部分
    两个74161设计长1/64的分频器,也叫帧长计数器,此计数器的时钟为FRAMECLK,计数器的输出最高两位逻辑与为中断INT7,把与门输出与次高位逻辑异或为中断INT5。这样,INT7比INT5在时序上早半个周期。开始复位后,INT7脉冲首先产生,触发中断,COU中断后在服务程序中把64个字节数据写到FIFO,然后屏蔽中断INT7,半个周期后,FIFO中还剩32个字节数据(因此FIFO的读脉冲和FRAMECLK反相同频)。然后中断INT5到来,CPU响应后,再写64个字节数据给FIFO,使FIFO中一直保持有数据的状态(可避免读FIFO正好落在两个写FIFO之间,FIFO因无数据而读死)。这样,每当中断INT5到来,都写64字节给FIFO,周而复始,所以把64字节定为帧长。
    设PCMCLK的频率为f(MHz),则FRAMECLK的频率为f/8,由于帧长为64,所以有:帧频=f/(8×64),PCM流速率=f(bit/s)。分频器的分频比是通过软件设定的,所以PCM流的速率可编程。
    3软件设计
    outp(0x303,0x36);//方式3,方波。//
    outp(0x300,0x50);//timer0,分频比为80。//
    outp(0x300,0x00);
    outp(0x303,0x74);//方式2,脉冲。//
    outp(0x301,0x08);//timer1,分频比为8。//
    outp(0x301,0x00);
    数据合并:
    if((com1_count%24)==0);//串行口1的24字节数据放在数组Frame的4~27的位置。//
    {
    com_buf1[com1_count++]=db1;//串行口1接收数据//
    intOriginal_Counter;
    Original_Counter=com1_count/24;
    memcpy(Frame[Original_Counter-1]+4,&com_buf1[com1_count-24],24);
    }
    if((com2_count%24)==0);//串行口2的24字节数据放在数组Frame的28~51的位置。//
    {
    com_buf2[com2_count++]=db2;//串行口2接收数据//
    intOriginal_Counter;
    Original_Counter=com2_count/24;
    Memcpy(Frame[Original_Counter-1]+28,&com_buf2[com2_count-24],24);//合并后的数据放在Frame数组中。//
    写FIFO:
    voidSend_To_Fifo(intnumber);//Send_To_Fifo函数为中断服务程序的一部分。//
    {
    for(inti=0;i<64;i++)
    outp(WFIFO,Frame[number][i]);//数组送给FIFO,实现数据合并//

更多
字体:【】-【】-【】【关闭此页

上一篇:基于Verilog-HDL的轴承振动'   下一篇:基于单片机的 复杂可编程逻辑器件快速'


特别声明:机电之家(http://www.jdzj.com )所共享的机电类资料,机电论文、机电类文章、机电企业类管理制度、机电类软件都来自网上收集,其版权归作者本人所有,如果有任何侵犯您权益的地方,请联系我们,我们将马上进行处理。购买的论文都出自原创,保证作者的原创的版权的转让,任何纠纷由法律解决。