P2SEL = BIT4+BIT5; // P2.4,5 = USART0 TXD/RXD
P5DIR |= BIT1; // Set P5.1 to output direction
// SetupUSCI0:
UCA0CTL1 = UCSWRST; // To set hold the module in reset
UCA0CTL1 = UCSSEL0; // ACLK
UCA0BR0 = 13; // 32k - 2400 baudrate control setting
UCA0BR1 = 0;
UCA0MCTL = UCBRS2+UCBRS1; // Second modulation stage values
UCA0STAT = UCFE+UCOE+UCPE+UCBRK+UCRXERR;
// RTC
RTCCTL = RTCBCD+RTCHOLD+RTCMODE_3+RTCTEV_0+RTCIE;
// RTC enable, BCD mode,
// alarm every Minute,
// enable RTC interrupt
// Init time
RTCSEC = 0x00; // Set Seconds
RTCMIN = 0x58; // Set Minutes
RTCHOUR = 0x08; // Set Hours
// Init date
RTCDOW = 0x02; // Set DOW
RTCDAY = 0x23; // Set Day
RTCMON = 0x08; // Set Month
RTCYEAR = 0x2005; // Set Year
RTCCTL &= ~RTCHOLD; // Enable RTC
while (1)
{
//__bis_SR_register(LPM3_bits + GIE); // Enter LPM3 w/ interrupt
__no_operation(); // Required for debugger
tx_char((RTCHOUR>>4)+0x30); // Send high nibble of hour
tx_char((RTCHOUR&0x0F)+0x30); // Send low nibble of hour
tx_char(':'); // Send ':'
tx_char((RTCMIN>>4)+0x30); // Send high nibble of minute
tx_char((RTCMIN&0x0F)+0x30); // Send low nibble of minute
tx_char('\n'); // Send new line
}
}
void tx_char(char c)
{
while ((IFG2 & UCA0TXIFG)==0){} // wait till TXbuf empty
UCA0TXBUF = c; // TX char
}
// Basic Timer interrupt service routine
#pragma vector=BASICTIMER_VECTOR
__interrupt void basic_timer(void)
{
P5OUT ^= BIT1; // Toggle P5.1 using exclusive-OR
LPM3_EXIT; // Exit LPM after interrupt
}
作者: 飛機翻筋斗 時間: 2020-3-16 14:25
你這程序rtc初始化是沒問題的,USCI串口我記得配置完要將UCSWRST復位的。
總中斷也沒開....
最后如果兩個模塊都不熟悉先一個個來 作者: f556 時間: 2020-3-30 16:43
RTCYEAR = 0x2005; // Set Year
0x2005不是2005年,是8197年,不知道萬年歷算法能支持到8000年不作者: f556 時間: 2020-3-31 10:39
RTCHOLD是這樣說的:The counter can be stopped by setting the RTCHOLD bit.帶有HOLD的說法一般是保持、停止。
RTCCTL = RTCBCD+RTCHOLD+RTCMODE_3+RTCTEV_0+RTCIE;這句中不對,RTCHOLD默認rw(1)了。
改成這樣試試:
RTCCTL = RTCBCD+RTCMODE_3+RTCTEV_0+RTCIE;
RTCCTL &= ~RTCHOLD;