这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » msp430F5438串口波特率的设置

共2条 1/1 1 跳转至

msp430F5438串口波特率的设置

助工
2014-10-14 20:37:13     打赏
个人英文水平有限,翻译会有错误。
 15.3.1 USCI Initialization and Reset
USCI通过PUC(上电清除)或置位UCSWRST复位。在PUCUCSWRST位自动置位,保持USCI在复位情况。UCSWRST置位时复位UCRXIE, UCTXIE, UCRXIFG, UCRXERR, UCBRK, UCPE, UCOE, UCFE,UCSTOEUCBTOE位,并置位UCTXIFG位。清零UCSWRSTUSCI工作。
---------------------------------------------------------
Note:Initializing or ReConfiguring the USCI Module 
推荐USCI初始化/重置过程:
1.设置 UCSWRST
2.UCSWRST = 1初始化所有USCI 寄存器(including UCAxCTL1) 
3.设置端口。
4.由软件清除UCSWRST  (BIC.B  #UCSWRST,&UCAxCTL1) 
5.由 UCRXIE /或 UCTXIE 使能中断(可选)。
------------------------------------------------------

15.3.9     UART Baud Rate Generation 
 
USCI波特率发生器可以用非标准源频率产生标准波特率。通过选择UCOS16位,提供两种模式。
Low-Frequency Baud Rate Generation 
UCOS16=0时为low-frequency mode。此模式允许从低频时钟源产生波特率。(例:32768Hz产生9600波特率)。通过应用更低的输入频率,模块的电源消耗减少。在更高频率和更高的预分频设置下应用此模式,将导致 the majority votes to be taken in an increasingly smaller window and thus decrease the benefit of the majority vote. (不会翻译了)
在低频模式,波特率产生器用一个预分频器和一个调制器产生位时钟。这种组合支持分数因子产生波特率。在这种模式下,最大的USCI波特率是串口时钟源频率BRCLK1/3
Oversampling Baud Rate Generation
  UCOS16=1时为Oversampling mode。这种模式支持用较高的时钟频率采样UART位流。这导致多数表决总是以位时钟周期的1/16分离。当IrDA编码器和解码器使能,此模式也以3/16位时间简单的支持IrDA脉冲。
此模式用预分频器和调制器产生一个比BITCLK16倍的BITCLK16时钟。一个附加的分频和调制阶段从BITCLK16产生BITCLK。这种组合为产生波特率,支持BITCLK16BITCLK细微的划分。此模式的最大USCI波特率是串口时钟源频率BRCLK1/16。当UCBRx设置为01时,第一个预分频和调制阶段被跳过BRCLK=BITCLK16,在这种情况下没有为BITCLK16调制的可能,因此UCBRFx位被忽视。
15.3.10 Setting a Baud Rate 
   给定一个BRCLK时钟源,波特率用来决定需要分频的因子N
              N = fBRCLK/Baudrate
分频因子N通常是非整数值,因此至少一个分频器和一个调制阶段用来尽可能的接近N
如果N等于或大于16,可以设置UCOS16选择oversampling baud Rate模式
注:Round():指四舍五入。
Low-Frequency Baud Rate Mode Setting
 在low-frequency mode,整数部分的因子可以由预分频实现:
                 UCBRx = INT(N) 
 小数部分的因子可以用下列标称公式通过调制器实现:
       UCBRSx = round( ( N – INT(N) ) × 8 )
 增加或减少UCBRSx一个计数设置,对于任何给定的位可能得到一个较低的最高比特误码率如果确定是这样的情况UCBRSx设置的每一位必须执行一个精确的错误计算

例1:1048576Hz频率下驱动以115200波特率异步通讯
ACLK = REFO = ~32768Hz, MCLK = SMCLK = default DCO = 32 x ACLK = 1048576Hz。
N = fBRCLK/Baudrate  = 1048576/115200 = ~9.10 
UCBRx = INT(N) = INT(9.10) = 9
UCBRSx = round( ( N – INT(N) )×8 ) 
        = round( ( 9.10 – 9) × 8 )=round(0.8 )=1
UCA0CTL1 |= UCSSEL_2;// SMCLK为时钟
UCAxBR0 = 9;
UCAxBR1 = 0; 
UCAxMCTL = 0x02;//7-4:UCBRFx,3-1:UCBRSx,0:UCOS16
UCBRSx 为寄存器UCAxMCTL1-3位,所以写入0x02(00000010)
 
例2:32768Hz频率下驱动以2400波特率异步通ACLK = REFO = ~32768Hz, MCLK = SMCLK = DCO ~1.045MHz
N = fBRCLK/Baudrate  = 32768/2400 = ~13.65 
UCBRx = INT(N) = INT(13.65) = 13
UCBRSx = round( ( N – INT(N) )×8 ) 
        = round( ( 13.65 – 13) × 8 )=round(5.2)=5
UCA0CTL1 |= UCSSEL_1;                   // ACLK为时钟
UCAxBR0 = 13;UCAxBR1 = 0 ;
UCAxMCTL = 0x0A;//7-4:UCBRFx,3-1:UCBRSx,0:UCOS16
UCBRSx为寄存器UCAxMCTL1-3位,所以写入0x0A(00001010)

Oversampling Baud Rate Mode Setting 
在oversampling mode 与分频器设置如下: 
            UCBRx = INT(N/16) 
第一个调制阶段设置如下:
    UCBRFx = round( ( (N/16) – INT(N/16) ) × 16 ) 
当要求更精确时,UCBRSx也可以被设置成0-7。

例1:1048576Hz频率下驱动以9600波特率异步通讯
      UCBRx = INT(N/16)=INT(fBRCLK/Baudrate/16) 
   UCBRx = INT(1048576Hz/(16*9600)) = INT(~6.8)
   UCBRFx = round( ( (N/16) – INT(N/16) ) × 16 )
          = round( (   6.8 – 6 ) × 16 )=13
  UCAxCTL1 |= UCSSEL_2; // SMCLK为时钟
  UCAxBR0 = 6;          // 1MHz 9600 
  UCAxBR1 = 0;          // 1MHz 9600
  UCAxMCTL = 0xD1;      //7-4:UCBRFx,3-1:UCBRSx,0:UCOS16
  UCBRFx 为寄存器UCAxMCTL4-7位,UCOS16为0位,所以写入0xD1(11010001)
     具体的寄存器值设置在MSP430F5438 User's Guide的15.3.13Typical Baud Rates and Errors中有列表。具体程序参考TI的例程

专家
2014-10-14 21:34:13     打赏
2楼
谢谢楼主的翻译!

共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]