MSP430 - G2553之串口操作

2020-01-16来源: eefocus关键字:MSP430  G2553  串口操作

#include

 

void delay1s(void) 

{

  int t = 1000;

  while (t--)

    __delay_cycles(1000);    

}

 

#define UART_TXD 0x02                                  // TXD on P1.1 (Timer0_A.OUT0)

                                              

#define UART_TBIT (1000000 / 9600)                     // 9600 Baud, SMCLK = 1MHz

                                                       // Globals for transmit UART communication

unsigned int txData;                                   // UART internal variable for TX

 

void TimerA_UART_tx(unsigned char byte);               // Function prototypes

void TimerA_UART_print(char *string);

 

void main(void)

{

  WDTCTL = WDTPW + WDTHOLD;                            // Stop watchdog timer

  DCOCTL = 0x00;                                       // Set DCOCLK to 1MHz

  BCSCTL1 = CALBC1_1MHZ;

  DCOCTL = CALDCO_1MHZ;

 

  P1OUT = UART_TXD;                                    // Initialize P1.1

  P1SEL = UART_TXD;                                    // Timer function for TXD pin

  P1DIR = UART_TXD;                                    // Set TXD pin to output

                                                       // Timer_A for transmit UART operation

  TA0CCTL0 = OUT;                                      // Set TXD Idle as Mark = '1'

  TA0CCTL1 = SCS + CM1 + CAP;                          // Sync, Neg Edge, Capture

  TA0CTL = TASSEL_2 + MC_2;                            // SMCLK, start in continuous mode

 

  P2DIR |= (BIT3 | BIT4); //Set P1.0 and P1.6 to outputs

  

  _BIS_SR(GIE);                                        // Enable CPU interrupts

 

  while (1) {

    TimerA_UART_print("G2553 TimerA UARTrn");          // Send test message 

    TimerA_UART_print("READY.rn");

    P2OUT ^= 0x18;

    delay1s();

  }

}

 

void TimerA_UART_tx(unsigned char byte)              // Outputs one byte using the Timer_A UART

{              

  while (TACCTL0 & CCIE);                              // Ensure last char got TX'd

 

  TA0CCR0 = TAR;                                       // Current state of TA counter

  TA0CCR0 += UART_TBIT;                                // One bit time till first bit

  txData = byte;                                       // Load transmit data, e.g. 'A'=01000001

  txData |= 0x100;                                     // Add mark stop bit, e.g. 101000001

  txData <<= 1;                                        // Add space start bit, e.g. 1010000010

  TA0CCTL0 = OUTMOD0 + CCIE;                           // Set TXD on, enable counter interrupt

}

 

void TimerA_UART_print(char *string) {                 // Prints a string using the Timer_A UART

  while (*string)

    TimerA_UART_tx(*string++);

}

 

#pragma vector = TIMER0_A0_VECTOR                      // Timer_A UART - Transmit ISR

 

__interrupt void Timer_A0_ISR(void) {

  static unsigned char txBitCnt = 10;

  TA0CCR0 += UART_TBIT;                                // Add Offset to CCRx

 

  if (txBitCnt == 0) {                                 // All bits TXed?

    TA0CCTL0 &= ~CCIE;                                 // All bits TXed, disable interrupt

    txBitCnt = 10;                                     // Re-load bit counter

  }

  else {

    if (txData & 0x01)

      TA0CCTL0 &= ~OUTMOD2;                            // TX Mark '1'

    else

      TA0CCTL0 |= OUTMOD2;                             // TX Space '0'

  }

  txData >>= 1;                                        // Shift right 1 bit (low bits TX'ed first)

  txBitCnt--;

}

关键字:MSP430  G2553  串口操作 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic485833.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:MSP430系列单片机-Timer_A实现PWM
下一篇:TI - MCU - MSP430使用指南13 -> Timer定时器模块

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

如何提高MSP430 C语言代码的执行效率
关于代码效率———————MSP430系列的程序设计准则,有利于提高代码效率。应该指出,这些准则基本上是基于MSP430系列的硬件结构特点而提出的。1.位域类型的执行时很慢的,所以应当在仅仅为了节省数据存储空间时才使用位域方式。如果用户必须使用位域存储,可以用char或unsigned int的位屏蔽操作来代替位域操作。2.在模块之外不使用的变量应当声明为static,这样在编译时有可能使这些变量分配在寄存器中暂存,从而提高了代码效率。3.尽可能使用unsigned数据类型。许多情况下,对unsigned数据类型的操作,比对signed数据类型的操作效率更高,尤其对于除法和求模运算更是如此。4.程序设计中应该使用ANSI-C原型
发表于 2020-01-19
MSP430 Flash信息区
430单片机,一般具有内部的信息区,以便保存一些需要EEPROM才可保存的数据。 在论坛没有收到相关信息,就借用网上的,抛砖引玉,如果有什么问题,多多指正,一起掌握! MSP430 FLASH型单片机的FLASH存储器模块根据不同的容量分为若干段,其中信息存储器SegmengA及SegmentB各有128字节,其他段有512字节。SegmentB的地址是:0x1000到0x107F,SegmentA的地址是:0x1080到0x10FF。其他段的地址根据容量不同,从0xFFFF开始,每512字节为一段进行分配。 FLASH存储器写入数据时,每一位只能由“1”变成“0”,不能由“0”变成“1“,因此,当我
发表于 2020-01-19
关于MSP430-Flash超过64K的读写操作方法
下面例子是Qiaohaikun先生几年前一直用在MSP430FG4618...使用过的,一直都挺好使。希望在此分享出来能帮助到有需要的网友们。同样,希望各网友们如有精品程序例子的话同样可以发贴到微控论坛来。人人为我,我为人人! 运行代码  #include "msp430xG46x.h"  void WriteFlashErrorNum(void);  //----------------------------------------------------------------------  //功能:从flash中
发表于 2020-01-19
MSP430 开发注意事项要求
以下是在使用MSP430中的一些总结: 1.系统时钟问题: 系统默认使用DCO,使用外部高速晶振XT2时必须自己开启XT2,并延时50us等待XT2起振,然后手工清除IFG1中的OFIFG位 !!!!一定要注意操作顺序:打开XT2->等待XT2稳定->切换系统时钟为XT2 若后面两步操作反了,在通常情况下不会出现问题,但是在电压不稳MCU频繁复位的情况下,非常容易造成MCU死掉,只能掉电后重新上电才能可靠复位。2.早期版本的IAR开发环境 必须在Project->Option->C-Spy中选择对应器件的DDF文件,否则调试时无SFR窗口。3.在写Flash
发表于 2020-01-19
MSP430实现简单的对临界资源的冲突访问
实现对临界资源的冲突访问__monitor int get_lock(void){if (the_lock == 0) {  /* Success, we managed to lock the lock. */  the_lock = 1;  return 1; }else {  /* Failure, someone else has locked the lock. */  return 0;  } }/* release_lock -- Unlock the lock. */ __monitor void relea
发表于 2020-01-19
msp430硬件II2C
msp430系列硬件I2C操作24LC128程序说明:24lc128为美信公司EEPROM存储器,存取空间为128kbit。具体的通信规则可以看其器件手册。 ***************************************************************************************/ 运行代码 /*******************************************************************************  包含头文件  
发表于 2020-01-19
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved