TI中文支持网
TI专业的中文技术问题搜集分享网站

F2812的Mcbsp发送接收问题

您好!我现在使用F2812的Mcbsp串口通信,遇到问题是发送数据时,偶尔会出现数据重复发送现象。如:

 0x005A27F6 ,
 0x006E6B11 ,
 0x007B27D0 ,
 0x007F7FFF ,
 0x007F7FFF ,
 0x007B27D           第四个数据发送了两次,我用自发自接功能检查也是如此,请问一般出现这种问题,有什么建议方法吗?谢谢!

Jones Chen:

给您贴一个MCBSP初始化的代码供参考:

 

/*********************************MCBSP初始化******************************************//************************函数功能描述************************//*********每6个字产生一次Mcbsp接收中断,每个字为16位*********//******发送(接收)帧同步,发送(接收)时钟同步均由外部提供******/ void mcbsp_init(){

/*************** MCBSP 复位*********************/   McbspaRegs.SPCR2.bit.FRST=0; // 帧同步产生器复位   McbspaRegs.SPCR2.bit.GRST=0; // 采样速率生成器复位   McbspaRegs.SPCR2.bit.XRST=0; // 发送器复位   McbspaRegs.SPCR1.bit.RRST=0; // 接收器复位

/***************McBSP 寄存器 初始化************/   McbspaRegs.SPCR2.all=0x0100; // 串口控制寄存器2 //(9)FREE=0  自由运行模式是禁止的 //(8)SOFT=1  SOFT模式是使能的 //(7)FRST=0   //(6)GRST=0  采样速率生成器是复位的 //(5.4)XINTM=00 (X)INT由(X)RDY驱动 //(3)XSYNCERR=0 没有发送同步错误 //(2)XEMPTY=0 发送移位寄存器(XSR)为空 只读 //(1)XREDY=0 发送器没有准备好  只读 //(0)XRST=0  发送器是复位的   McbspaRegs.SPCR1.all=0x0000; // 串口控制寄存器1   //(15)DLB=0   数字回路自测试模式 禁用   //(1413)RJUST=00  DRR采用右对齐模式,用0填充MSB   //(1211)CLKSTP=00 禁止时钟停止模式,工作在非SPI模式   //(10~8)保留   //(7)DXENA=0   DX使能器关闭   //(6)ABIS=0   禁止A-bis模式   //(5.4)RINTM=0  (R)INT由(R)RDY驱动   //(3)RSYNCERR=0   没有接收同步错误   //(2)RFULL=0   接收移位寄存器(RSR) 不是满的 只读   //(1)RRDY=0   接收器没有准备好    只读   //(0)RRST=0   接收器是复位的 

   McbspaRegs.RCR2.all=0x0001;//接收控制寄存器2   //(15)RPHASE=0   接收相位    单项   //(4~3)RCOMPAND  接收压缩解压模式 不进行压缩解压 从MSB开始发送数据   //??(2)RFIG=0    接收帧忽略  第一个重新发送后的接受帧同步脉冲   //(1.0)RDATDLY=1 接收数据延迟     1位数据延迟      McbspaRegs.RCR1.all=0x0040;//接收控制寄存器1   //(14~8)RFRLEN1=0接收帧长1=0000000 每帧一个字   //(7~5)RWDLEN1=0接收字长1=010   每字16位

   McbspaRegs.XCR2.all=0x0001;//发送控制寄存器2   McbspaRegs.XCR1.all=0x0040;//发送控制寄存器1

   McbspaRegs.MCR2.all=0x0000;//多通道控制寄存器2   McbspaRegs.MCR1.all=0x0000;//多通道控制寄存器1/***************帧同步设置*************************/   McbspaRegs.SRGR2.all=0x8000;//采样速率生成器2    //(15)GSYNC=1 采样速率生成器时钟同步    //(13)CLKSM=0    外部CLKR引脚时钟           //(12)FSGM=0  只有当内部提供帧同步信号时有效   //(11~0)FPER=0   由于外部帧提供帧同步信号 FPER的设置对帧周期没有影响                          McbspaRegs.SRGR1.all=0x0000;//采样速率生成器1    //(15~8)FWID=0 帧宽度          //(7~0)CLKGDV=0 采样速率生成器时钟分频系数     McbspaRegs.PCR.all=0x0080;//引脚控制寄存器   ok   //(11)FSXM=0(发送帧同步) 外部提供发送帧同步       //(10)FSRM=0(接收帧同步) 外部提供接收帧同步   //(9)CLKXM=0(发送时钟)   外部引脚CLK(R/X)提供   //(8)CLKRM=0(接收时钟) 外部引脚CLK(R/X)提供   //(7)SCLKME=1   外部CLKR引脚时钟/************MCBSP FIFO 寄存器配置****************/    McbspaRegs.MFFTX.all= 0x4000;//FIFO 发送寄存器 ok   //MFFENA=1 MCBSP FIFO增强功能 使能    //发送FIFO处于复位状态   //TX FIFO中断 禁止

   McbspaRegs.MFFRX.all= 0x0026; //FIFO 接收寄存器 ok   //6个字产生一次接收中断 每个字16位   //基于RXFFIVL匹配的RX FIFO的中断使能   //当RXFFST>=RXFFIL=6个字时产生Mcbsp接收中断   //接收FIFO处于 复位状态

   McbspaRegs.MFFCT.all= 0x0000;//FIFO 控制寄存器 ok    //只有在SPI模式下才使用该寄存器,在Mcbsp模式下 这些位不起作用

   McbspaRegs.MFFINT.all=0x0000;//FIFO 中断寄存器 ok   //只有在非FIFO和A-bis FIFO模式下 才使用该寄存器

   McbspaRegs.MFFST.all=0x000;//FIFO 状态寄存器   ok   //FSR标志:检测到接收帧同步脉冲=1   //FSX标志:检测到发送帧同步脉冲=1

/************** Enable FIFO**********************/   McbspaRegs.MFFTX.bit.TXFIFO_RESET=1;//发送FIFO 脱离 复位状态 ok   McbspaRegs.MFFRX.bit.RXFIFO_RESET=1;//接收FIFO 脱离 复位状态 ok   /************* Enable Sample rate generator******/   McbspaRegs.SPCR2.bit.GRST=1;//   delay_loop(1000000);    DELAY_US(1000);

}      

赞(0)
未经允许不得转载:TI中文支持网 » F2812的Mcbsp发送接收问题
分享到: 更多 (0)