BitArt

Ideas Worth Spreading

导航

Blackfin DSP(六):BF533的SPORT接口

Posted on 2013-09-10 08:17  BitArt  阅读(4714)  评论(0编辑  收藏  举报

1.特性

  bf533有两个SPORT口(synchronous serial Port),即同步串行接口。完全独立的接收和发送通道,且每个通道都具有缓冲,最高速度可达SCLK/2。最大支持32bit字长,可进行硬件u-lawA-law压缩。结构框图如下:

        

 

2.接口信号说明

        

3.串行时钟T/RCLK

  由SPORTx_TCLKDIV和SPORTx_RCLKDIV两个16位寄存器决定分频的值,假设系统时钟为SCLK,则串行时钟的计算公式为:

  

例如,SCLK=133MHz,RCLKDIV = 4时,得到的RCLK freq = 133/(2*(4+1))=13.3MHz。

4.帧同步信号T/RFS

  帧同步信号的分频是由SPORTx_TFSDIV和SPORTx_RFSDIV寄存器的值决定的,计算公式如下:

  

  注意到,帧同步信号的频率是对串行时钟频率的分频,而不是对系统时钟SCLK的分频,因此,在相邻的两个帧同步信号之间,有(T/RFSDIV+1)个串行位时钟,看下图的说明:

        

                        图 1 : 

  因此,我通常并不计算T/RFS信号的频率,而是把它理解为Number of transmit clock cycles counted before generatingTFS pulse,该值就等于T/RFSDIV+1.图中所示TFSDIV = 8,8+1 = 9 > 8因此两个字节的数据之间有一个bit的无关位。

5. 工作模式

  1)提前帧同步和延迟帧同步

    提前同步模式,帧同步信号比数据早一个串行时钟周期。

    

  2)有帧模式和无帧模式

    有帧模式:对于每一个字,都需要一个帧信号;

    无帧模式:在第一个字传送后,忽视帧信号,但是帧信号是一直按照我们的设置继续产生的,只不过被忽视了;

    

5.程序实例与讲解:

1)发送端设置:

void Init_Sport1_TX(int TCLKDIV)
{

    //SPORTx_TCLK frequency = (SCLK frequency)/(2 x (SPORTx_TCLKDIV + 1))
    *pSPORT1_TCLKDIV    =    TCLKDIV;
    //the number of cycles between frame sync pulses
    *pSPORT1_TFSDIV        =    8;
    // driving data with rising edge,late frame sync,active low
    //sync require, inter FS used, internal tclk used
    *pSPORT1_TCR1        =   LATFS|LTFS|TFSR|ITFS| ITCLK;
    // 8 bit word length
    *pSPORT1_TCR2        =    7;
    // 发送使能
     *pSPORT1_TCR1       = (*pSPORT1_TCR1 | TSPEN);
}

按照该程序设置,可以得到图1所示的波形。

2)接收端设置:

一般情况下,接收端的设置和发送端一致,只不过接收端一般使用发送端的帧同步信号FS和位时钟SCLK所以配置为external FS和external SCLK

void Init_Sport1_RX(int RCLKDIV)
{
    //SPORTx_RCLK frequency = (SCLK frequency)/(2 x (SPORTx_RCLKDIV + 1))
    *pSPORT1_RCLKDIV    =    RCLKDIV;
    //the number of cycles between frame sync pulses
    *pSPORT1_RFSDIV        =  8;
    // sync require, external FS used, external rclk used
    *pSPORT1_RCR1        =    LARFS|LRFS|RFSR;
    // 8 bit word length
    *pSPORT1_RCR2        =    7;
    *pSPORT1_RCR1       = (*pSPORT1_RCR1 | RSPEN);//使能SPORT1接收
}

3)发送数据:

 *pSPORT1_TX16 =d;  
while((*pSPORT1_STAT&0x0040)!=0x0040);     /*等待上一次发送完成 */

4)接收数据:

while(!(*pSPORT1_STAT & RXNE));//查看SPI传输状态是否有数据需要接收
i = *pSPORT1_RX16; //读取数据