MSP430F5438学习笔记 UART SMCLK 115200-8-N-1
2013-06-06 12:47
141 查看
MSP430中 UCBR0、UCBR1和UCBRF的设置值可以通过计算,也通过通过查表获得。我个人倾向于查表法。具体可以参考以下两张图表。默认情况,ACLK为32768MHZ,而SMCLK为1048576。选择ACLK时波特率最大为9600,大于9600的情况只能使用SMCLK,波特率的设置和SMCLK的时钟频率有关,我个人更倾向于设置SMCLK和MCLK为8MHz。
// 时钟默认情况 // FLL时钟 FLL选择 XT1 // 辅助时钟 ACLK选择 XT1 32768Hz // 主系统时钟 MCLK选择 DCOCLKDIV 8000000Hz // 子系统时钟 SMCLK选择 DCOCLKDIV 8000000Hz // UART时钟选择 SMCLK // 低频波特率产生 115200-8-N-1 #include <msp430.h> #include <stdio.h> void clock_config(void); void select_xt1(void); void dco_config(void); void uart_config(void); int main(void) { clock_config(); // 初始化时钟 uart_config(); _EINT(); P4DIR |= BIT0; // P4.0输出 printf("Hello MSP430!\r\n"); while(1) { P4OUT ^= BIT0; __delay_cycles(1000000); } } void clock_config(void) { WDTCTL = WDTPW + WDTHOLD; // 停止看门狗 select_xt1(); // 选择XT1 dco_config(); // ACLK = XT1 = 32.768K // MCLK = SMCLK = 8000K } void select_xt1(void) { // 启动XT1 P7SEL |= 0x03; // P7.0 P7.1 外设功能 UCSCTL6 &= ~(XT1OFF); // XT1打开 UCSCTL6 |= XCAP_3; // 内部电容 do { UCSCTL7 &= ~XT1LFOFFG; // 清楚XT1错误标记 }while (UCSCTL7&XT1LFOFFG); // 检测XT1错误标记 } void dco_config(void) { __bis_SR_register(SCG0); // 禁止FLL功能 UCSCTL0 = 0x0000; // Set lowest possible DCOx, MODx UCSCTL1 = DCORSEL_5; // DCO最大频率为16MHz UCSCTL2 = FLLD_1 + 243; // 设置DCO频率为8MHz // MCLK = SMCLK= Fdcoclkdiv = (N+1)X(Ffllrefclk/n) // N为唯一需要计算的值 // Ffllrefclk FLL参考时钟,默认为XT1 // n取默认值,此时为1 // (243 + 1) * 32768 = 8MHz __bic_SR_register(SCG0); // 使能FLL功能 // 必要延时 __delay_cycles(250000); // 清楚错误标志位 do { UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + XT1HFOFFG + DCOFFG); // 清除所有振荡器错误标志位 SFRIFG1 &= ~OFIFG; // 清除振荡器错误 }while (SFRIFG1&OFIFG); // 等待清楚完成 } void uart_config(void) { P3SEL = 0x30; // 选择P3.4和P3.5的复用功能 UCA0CTL1 |= UCSWRST; // 软件复位 UCA0CTL1 |= UCSSEL_2; // 选择SMCLK时钟 UCA0BR0 = 69; // 查表获得 UCA0BR1 = 0; // UCA0BRX和UCA0MCTL数值 UCA0MCTL |= UCBRS_4 + UCBRF_0; // UCA0CTL1 &= ~UCSWRST; // UCA0IE |= UCRXIE; // 使能接收中断 } int putchar(int ch) { UCA0TXBUF = ch; while(!(UCA0IFG & UCTXIFG)); return ch; } #pragma vector=USCI_A0_VECTOR __interrupt void USCI_A0_ISR(void) { switch(__even_in_range(UCA0IV,4)) { case 0:break; case 2: // 接收中断 while (!(UCA0IFG&UCTXIFG)); // 等待发送完成 UCA0TXBUF = UCA0RXBUF; // 接收缓冲区 break; case 4:break; // 发送中断 default: break; } }
相关文章推荐
- MSP430Ware学习笔记 UART SMCLK 115200-8-N-1
- 关于串口的初始化Uart_Init(0, 115200)
- S3C44B0的UART波特率计算公式---分频设置
- Application of UART in GPS navigation system
- USB转UART桥接芯片CP2101及其应用
- (原创)uart传输发送模块联合在一起进行测试
- ARM9硬件接口学习之 UART
- 《嵌入式linux应用程序开发完全手册》通用异步收发器UART学习笔记
- Uart串口实验--TQ2440
- I2C-SPI-UART
- at91sam7x256之gpio与串口 uart0
- SPI、I2C、UART三种串行总线的区别
- 示波器 && USBee Suite抓I2C && USBee 示波器 && USBee Suite抓上电时序 && USBee Suite抓取UART && 数据记录仪
- [转]linux设备模型之uart驱动架构分析(开始做驱动!!)
- UART 2440
- I2C,SPI,UART和CAN的区别(转载)
- 自己动手写的UART2驱动
- UART初始化时可以使用的参数
- 使用单片机的UART(COM口)进行传输 (单片机 LM3S811)
- 如何通过 tty_struct 得到 uart_port 结构体