历史上的今天
今天是:2025年04月23日(星期三)
2020年04月23日 | MSP430F5438学习笔记 UART ACLK 9600-8-N-1
2020-04-23 来源:eefocus
1.初始化UART0之前需要先初始化ACLK、SMCLK和MCLK。示例代码中使用XT1,ACLK为32768,SMCLK和MCLK约为8MHZ。
2.UART的时钟可以参考ACLK或者SMCLK,本例参考ACLK。由于参考ACLK时钟,所以串口速率不能超过32768。选择9600较为合适。
3.MSP430波特率的产生有两种模式,低频波特率产生和过采样波特率产生。代码中使用低频波特率产生。
4.代码的开头调用了stdio,在函数中宏重写了putchar函数,定向到UART单字节输出。
5.代码初始化之后输出 Hello MSP430,随后直接反射串口接收到的数据,例如发送123456即返回123456。
// 时钟默认情况
// FLL时钟 FLL选择 XT1
// 辅助时钟 ACLK选择 XT1 32768Hz
// 主系统时钟 MCLK选择 DCOCLKDIV 8000000Hz
// 子系统时钟 SMCLK选择 DCOCLKDIV 8000000Hz
// UART时钟选择 ACLK
// 低频波特率产生 9600-8-N-1
#include #include 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!rn"); 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_1; // 选择ACLK时钟 UCA0BR0 = 3; // 查表获得 UCA0BR1 = 0; // UCA0BRX和UCA0MCTL数值 UCA0MCTL |= UCBRS_3 + 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; } }
史海拾趣
|
本帖最后由 paulhyde 于 2014-9-15 09:42 编辑 步进电机在控制类系统中使用非常广泛,我设计过步进电机在工业系统中的应用有三次,一次是关于线切割铣床上工件移动的设计,一次是关于超声波小径管无损探伤驱动小径管旋转和探头水平移动的设计,还 ...… 查看全部问答> |
|
大家好,本人新手,希望得到大家的帮助! 我想使用C51单片机连接一个74HC154译码器,进而实现对多个步进电机的控制,我想问的是这能否实现?如果不能实现,我该怎样才能做到用单片机控制多个电机呢? 非常感谢! 简单地说,怎样实现用单片机控制 ...… 查看全部问答> |
|
现在想用msp430的串口进行收发程序开发,但不知道对方一次发送过来多少数据?如何才能完整接收呢?我感觉使用中断的方式一次只能接收一个字节的数据,不能把对方发送的完整数据全部接收!请问有什么解决办法?谢谢! 另外,使用串口通信,一方是ms ...… 查看全部问答> |
|
有一套串口通信协议需要分析破解,寻求达人帮助! 谢谢! to:hawking20001981(东东VC++Primer) 请速和我联系! QQ:652650436… 查看全部问答> |
|
在VMware上运行VxWorks遭遇"Error loading file! 0xd0003",已经困扰几天了 【环境】PC、XP、Tornado2.2、VMWare、虚拟软驱RamDiskNT、虚拟网卡为AMD的PC-NET,按要求从AMD的网站上下载的最新驱程 【实施】严格按照网上的《嵌入式实时操作系统VxWorks入门》一文搭建; VMware Network Adapter VMnet1和VMwar ...… 查看全部问答> |
|
RealViewMDK一项功能,节约STM32芯片32%的CODE使用量 安装了MDK3.23版本之后,在keilarmoardsembeststm32v100开发板例程中,使用Blinky的例程,该例程含有LCD显示,ADC,USART,GPIO,NVIC等功能,在C/C++选项中使用三级优化-o3选项后编译结果:Code=7764,RO-data=468,RW-data ...… 查看全部问答> |
|
基于STM32和STM8的医疗电子方案,PPT格式,简单介绍了基于stm32的电图机(ECG) 、指甲式脉搏血氧仪、多参数监护仪、B超 、胎心仪、注射泵、输液泵、生化分析仪、麻醉呼吸机,基于stm8的血糖仪以及其它医疗产品的设计… 查看全部问答> |




