首先看上图,usart模块的波特率值设定是通过以下三个寄存器决定的:UxBR0,UxBR1,UxMCTL ,其中UxBR1+UxBR0为整数部分,UxMCTL为设定小数部分,两者结合起来为一个16位的字
举例1:波特率=9600,时钟源=32768Hz,cpu为F5438;
N=32768/9600=3.4133333333 。很明显:UxBR1+UxBR0=3,即UxBR1=0,UxBR0=0x03,把小数部分0.4133333×8,即3.306666,取整后为3(0011),取UCOS16=0,那么UCBRSx=0x03,放入UACxMCTL寄存器就是0000 0110 = 0x06;
反推真实波特率:UxBR0=3,UCBRSx=3,真实波特率= 32768/(3+3/8)=32768/3.375=9709
举例2:波特率=9600,时钟源=32KHz,cpu为FR5994;
N=32000/9600=3.3333333333 。很明显:UxBR1+UxBR0=3,即UxBR1=0,UxBR0=0x03,小数0.3333用查表法得出UCBRSx的取值,若UCBRSx取值=0x25,那么对应的小数=0.3000,在FR5994中设置对应寄存器UCAxMCTLW=0x2500;
反推真实波特率:整数部分UxBR0=3,小数部分UCAxMCTLW=0x2500(对应小数=0.3000),因此真实波特率=32000/(3+0.3)=9697