[mw_shl_code=c,true]void uart_init(u32 pclk2,u32 bound)
{
float temp;
u16 mantissa;
u16 fraction;
temp=(float)(pclk2*1000000)/(bound*16);//得到USARTDIV
mantissa=temp; //得到整数部分
fraction=(temp-mantissa)*16; //得到小数部分
mantissa<<=4;
mantissa+=fraction;
RCC->APB2ENR|=1<<2; //使能PORTA口时钟
RCC->APB2ENR|=1<<14; //使能串口时钟
GPIOA->CRH&=0XFFFFF00F;//IO状态设置
GPIOA->CRH|=0X000008B0;//IO状态设置
RCC->APB2RSTR|=1<<14; //复位串口1
RCC->APB2RSTR&=~(1<<14);//停止复位
//波特率设置
USART1->BRR=mantissa; // 波特率设置
USART1->CR1|=0X200C; //1位停止,无校验位.
#if EN_USART1_RX //如果使能了接收
//使能接收中断
USART1->CR1|=1<<8; //PE中断使能
USART1->CR1|=1<<5; //接收缓冲区非空中断使能
MY_NVIC_Init(3,3,USART1_IRQChannel,2);//组2,最低优先级
#endif
}
[/mw_shl_code]
个人认为,在计算波特率的时候,没必要去计算中间变量,开始看计算波特率的部分一时还没弄明白是为什么,理解了之后发现太复杂了。
[mw_shl_code=c,true]
[mw_shl_code=c,true]
[mw_shl_code=c,true] temp=(float)(pclk2*1000000)/(bound*16);//得到USARTDIV
mantissa=temp; //得到整数部分
fraction=(temp-mantissa)*16; //得到小数部分
mantissa<<=4;
mantissa+=fraction; [/mw_shl_code]
[/mw_shl_code]
[/mw_shl_code]
[mw_shl_code=c,true][/mw_shl_code]
和下面的式子相比较,首先计算 temp的时候除以 16是没必要的,因为在下面小数部分和整数部分都乘了 16再作和运算
其次也没必要将整数部分和小数部分分开来运算了,所以上面的式子还是等价于 mantissa = (pclk2*1000000)/bound; //得到USARTDIV
纯属个人见解,如有错误之处,烦请更正,谢谢。
|