Hi all
我在做一个项目,需要用到RTC的低功耗模式 ,但我实测发现上电后的功耗是0.4uA,但执行完第一次中断程序后,之后不管进入多少次中断,进入RTC低功耗模式都是12.6uA。我试过和定时时间没关系,第一次中断前都是0.4uA。请问是我需要在每次再次进入低功耗时都需要重新配置下RTC吗?
//MSP430FR413x Demo - RTC, device enter LPM3.5 and toggle P1.0 in RTC interrupt handling every 1s
//
//
//Description: Device enter LPM3.5 after configuring the RTC. The RTC wakes
//the device up from LPM3.5 every second and toggles P1.0.
//It also stores the state of P0OUT in the Backup RAM Registers.
//
//ACLK = XT1 = 32kHz, MCLK = SMCLK = default DCODIV = ~1MHz.
//
//MSP430FR4133
//-----------------
///|\||
//| ||
//| |XIN(P4.1)|--
//--|RST| ~32768Hz
//|XOUT(P4.2)|--
//||
//|P4.5|-->LED
//
// Wei Zhao
// Texas Instruments Inc.
// March 2015
// Built with IAR Embedded Workbench v6.20 & Code Composer Studio v6.1
//******************************************************************************
#include <msp430.h>
void initGpio(void);
int main(void)
{WDTCTL = WDTPW | WDTHOLD;// Stop WDTinitGpio();// Configure GPIO// Initialize XT1 32kHz crystalP4SEL0 |= BIT1 | BIT2;// set XT1 pin as second functiondo{CSCTL7 &= ~(XT1OFFG | DCOFFG);// Clear XT1 and DCO fault flagSFRIFG1 &= ~OFIFG;} while (SFRIFG1 & OFIFG);// Test oscillator fault flag// First determine whether we are coming out of an LPMx.5 or a regular RESET.if (SYSRSTIV == SYSRSTIV_LPM5WU)// When woken up from LPM3.5, reinit{// If MCU wakes up from LPM3.5, re-init and then return to LPM3.5 again.// Restore P1OUT value from backup RAM memory, keep P1OUT after LPMx.5 resetP4OUT = *(unsigned int *)BKMEM_BASE;__enable_interrupt();// The RTC interrupt should trigger now...}else{// Device powered up from a cold start.// It configures the device and puts the device into LPM3.5// Configure backup memory*(unsigned int *)BKMEM_BASE = 0;// Initialize RTC// Interrupt and reset happen every 1024/32768 * 32 = 1 sec.RTCMOD = 960-1;RTCCTL = RTCSS__XT1CLK | RTCSR | RTCPS__1024 | RTCIE;// Store P1OUT value in backup memory register before enter LPM3.5*(unsigned int *)BKMEM_BASE = P4OUT;}// Enter LPM3.5 mode with interrupts enabled. Note that this operation does// not return. The LPM3.5 will exit through a RESET event, resulting in a// re-start of the code.PMMCTL0_H = PMMPW_H;// Open PMM Registers for writePMMCTL0_L |= PMMREGOFF;// and set PMMREGOFF__bis_SR_register(LPM3_bits | GIE);__no_operation();return 0;
}
void initGpio(void)
{
P1DIR |= 0x1F;
P2DIR |= 0xFF;
P3DIR |= 0xFF;
P4DIR |= 0xFF;
P5DIR |= 0xFF;
P6DIR |= 0xFF;
P7DIR |= 0xFF;
P8DIR |= 0xFD;
P1OUT |= 0x1F;
P2OUT |= 0xFF;
P3OUT |= 0xFF;
P3OUT &= ~0x87;
P4OUT |= 0xFF;
P5OUT |= 0xFF;
P6OUT |= 0xFF;
P7OUT |= 0xFF;
P8OUT |= 0xFD;
P8DIR &= ~0x02;
P8REN &= ~0x02;
//Motor P1.6 1.7 1.5
P1DIR &= ~0xE0;
P1REN &= ~0xE0;
P2DIR &= ~0xF3;
P2REN &= ~0xF3;// Disable the GPIO power-on default high-impedance mode// to activate previously configured port settingsPM5CTL0 &= ~LOCKLPM5;
}
#if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__)
#pragma vector = RTC_VECTOR
__interrupt void RTC_ISR(void)
#elif defined(__GNUC__)
void __attribute__ ((interrupt(RTC_VECTOR))) RTC_ISR (void)
#else
#error Compiler not supported!
#endif
{switch(__even_in_range(RTCIV, RTCIV_RTCIF)){case RTCIV_NONE : break;// No interrupt pendingcase RTCIV_RTCIF:// RTC Overflow// Toggle LED on P1.0P4OUT ^= BIT5;// Store P1OUT value in backup memory register*(unsigned int *)BKMEM_BASE = P4OUT;__bis_SR_register(LPM3_bits | GIE);break;default:break;}
}
灰小子:
看那个中断函数里有对io的操作,io也是要消耗电流的
Ling Zhu2:
yanqing zhou
Hi all
我在做一个项目,需要用到RTC的低功耗模式 ,但我实测发现上电后的功耗是0.4uA,但执行完第一次中断程序后,之后不管进入多少次中断,进入RTC低功耗模式都是12.6uA。我试过和定时时间没关系,第一次中断前都是0.4uA。请问是我需要在每次再次进入低功耗时都需要重新配置下RTC吗?
//MSP430FR413x Demo - RTC, device enter LPM3.5 and toggle P1.0 in RTC interrupt handling every 1s // // //Description: Device enter LPM3.5 after configuring the RTC. The RTC wakes //the device up from LPM3.5 every second and toggles P1.0. //It also stores the state of P0OUT in the Backup RAM Registers. // //ACLK = XT1 = 32kHz, MCLK = SMCLK = default DCODIV = ~1MHz. // //MSP430FR4133 //----------------- ///|\|| //| || //| |XIN(P4.1)|-- //--|RST|~32768Hz //|XOUT(P4.2)|-- //|| //|P4.5|-->LED // //Wei Zhao //Texas Instruments Inc. //March 2015 //Built with IAR Embedded Workbench v6.20 & Code Composer Studio v6.1 //****************************************************************************** #include <msp430.h>void initGpio(void);int main(void) {WDTCTL = WDTPW | WDTHOLD;// Stop WDTinitGpio();// Configure GPIO// Initialize XT1 32kHz crystalP4SEL0 |= BIT1 | BIT2;// set XT1 pin as second functiondo{CSCTL7 &= ~(XT1OFFG | DCOFFG);// Clear XT1 and DCO fault flagSFRIFG1 &= ~OFIFG;} while (SFRIFG1 & OFIFG);// Test oscillator fault flag// First determine whether we are coming out of an LPMx.5 or a regular RESET.if (SYSRSTIV == SYSRSTIV_LPM5WU)// When woken up from LPM3.5, reinit{// If MCU wakes up from LPM3.5, re-init and then return to LPM3.5 again.// Restore P1OUT value from backup RAM memory, keep P1OUT after LPMx.5 resetP4OUT = *(unsigned int *)BKMEM_BASE;__enable_interrupt();// The RTC interrupt should trigger now...}else{// Device powered up from a cold start.// It configures the device and puts the device into LPM3.5// Configure backup memory*(unsigned int *)BKMEM_BASE = 0;// Initialize RTC// Interrupt and reset happen every 1024/32768 * 32 = 1 sec.RTCMOD = 960-1;RTCCTL = RTCSS__XT1CLK | RTCSR | RTCPS__1024 | RTCIE;// Store P1OUT value in backup memory register before enter LPM3.5*(unsigned int *)BKMEM_BASE = P4OUT;}// Enter LPM3.5 mode with interrupts enabled. Note that this operation does// not return. The LPM3.5 will exit through a RESET event, resulting in a// re-start of the code.PMMCTL0_H = PMMPW_H;// Open PMM Registers for writePMMCTL0_L |= PMMREGOFF;// and set PMMREGOFF__bis_SR_register(LPM3_bits | GIE);__no_operation();return 0; }void initGpio(void) {P1DIR |= 0x1F;P2DIR |= 0xFF;P3DIR |= 0xFF;P4DIR |= 0xFF;P5DIR |= 0xFF;P6DIR |= 0xFF;P7DIR |= 0xFF;P8DIR |= 0xFD;P1OUT |= 0x1F;P2OUT |= 0xFF;P3OUT |= 0xFF;P3OUT &= ~0x87;P4OUT |= 0xFF;P5OUT |= 0xFF;P6OUT |= 0xFF;P7OUT |= 0xFF;P8OUT |= 0xFD;P8DIR &= ~0x02;P8REN &= ~0x02;//Motor P1.6 1.7 1.5P1DIR &= ~0xE0;P1REN &= ~0xE0;P2DIR &= ~0xF3;P2REN &= ~0xF3;// Disable the GPIO power-on default high-impedance mode// to activate previously configured port settingsPM5CTL0 &= ~LOCKLPM5; }#if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__) #pragma vector = RTC_VECTOR __interrupt void RTC_ISR(void) #elif defined(__GNUC__) void __attribute__ ((interrupt(RTC_VECTOR))) RTC_ISR (void) #else #error Compiler not supported! #endif {switch(__even_in_range(RTCIV, RTCIV_RTCIF)){case RTCIV_NONE : break;// No interrupt pendingcase RTCIV_RTCIF:// RTC Overflow// Toggle LED on P1.0P4OUT ^= BIT5;// Store P1OUT value in backup memory register*(unsigned int *)BKMEM_BASE = P4OUT;__bis_SR_register(LPM3_bits | GIE);break;default:break;} }
TI中文支持网



