您的位置:首页 > 其它

Blackfin DSP(六):BF533的SPORT接口

2013-09-10 08:17 639 查看
1.特性

  bf533有两个SPORT口(synchronous serial Port),即同步串行接口。完全独立的接收和发送通道,且每个通道都具有缓冲,最高速度可达SCLK/2。最大支持32bit字长,可进行硬件u-law和A-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; //读取数据



                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: