I am trying to put the K20 in low-leakage stop mode and then wake it with the LLWU. This code works fine when I am using the debugger but without the debugger I get stuck somewhere between LED1_ON and LED0_ON. Any ideas?
#include <common.h>
// Include the cpu / board header file 
#include <cpu/MK20D10.h>
#include <board/escort_zr5.h>
#include <string.h>
#include "i2c.h"
void enter_lls(void);
void deepsleep(void);
void sleep(void);
int main(void)
{    
    volatile unsigned int dummyread;
    i2c_init(0, ACCEL_SLAVE_ADDRESS, 400000);
    I2CAccelInit();
DBG_LED1_ON;
    // Enable PC3 as falling edge wakeup to LLWU 
    LLWU_PE2 |= LLWU_PE2_WUPE7(2);
    // Disable the clock monitor
    MCG_C6 &= ~MCG_C6_CME0_MASK;
    
    // Put the processor in low-leakage stop mode
    enter_lls();
    //
    // Waiting for a motion interrupt from the accelerometer
    //
DBG_LED0_ON; // Tell the world we're awake
while(1);
    return 0;
}
/***************************************************************/
/*
 * Configures the ARM system control register for WAIT(sleep)mode
 * and then executes the WFI instruction to enter the mode.
 *
 * Parameters:
 * none
 *
 */
void sleep (void)
{
    /* Clear the SLEEPDEEP bit to make sure we go into WAIT (sleep) 
     * mode instead of deep sleep.
     */
    SCB_SCR &=  ~SCB_SCR_SLEEPDEEP_MASK;
#ifdef CMSIS        
    __wfi();
#else
    /* WFI instruction will start entry into WAIT mode */
    asm("WFI");
#endif
}
/***************************************************************/
/*
 * Configures the ARM system control register for STOP  
 * (deepsleep) mode and then executes the WFI instruction 
 * to enter the mode.
 *
 * Parameters:
 * none
 *
 */
void deepsleep (void)
{
  /* Set the SLEEPDEEP bit to enable deep sleep mode (STOP) */
  SCB_SCR |= SCB_SCR_SLEEPDEEP_MASK;
#ifdef CMSIS
  __wfi();
#else
  /* WFI instruction will start entry into STOP mode */
  asm("WFI");
#endif
}
/***************************************************************/
/* LLS mode entry routine. Puts the processor into LLS mode from
 * normal Run mode or VLPR. 
 *
 * Mode transitions:
 * RUN to LLS
 * VLPR to LLS
 *
 * Wake-up from LLS mode is controlled by the LLWU module. Most
 * modules cannot issue a wake-up interrupt in LLS mode, so make
 * sure to set up the desired wake-up sources in the LLWU before 
 * calling this function.
 *
 * Parameters:
 * none
 */
void enter_lls(void)
{
   volatile unsigned int dummyread;
   /* Write to PMPROT to allow LLS power modes this write-once 
      bit allows the MCU to enter the LLS low power mode*/
   SMC_PMPROT = SMC_PMPROT_ALLS_MASK;      
   /* Set the (for MC1) LPLLSM or 
     (for MC2)STOPM field to 0b011 for LLS mode  
      Retains LPWUI and RUNM values */
   SMC_PMCTRL &= ~SMC_PMCTRL_STOPM_MASK ;
   SMC_PMCTRL |= SMC_PMCTRL_STOPM(0x3) ;
   /*wait for write to complete to SMC before stopping core */  
   dummyread = SMC_PMCTRL;
   /* Now execute the stop instruction to go into LLS */
   deepsleep();
}
已解决! 转到解答。
 
					
				
		
 dereksnell
		
			dereksnell
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Hi ryanlush,
From the reference manual: "NOTE The LLWU interrupt must not be masked by the interrupt controller to avoid a scenario where the system does not fully exit stop mode on an LLS recovery."
The LLWU ISR is required when waking from LLS or VLLSx low-power modes.
We're glad to hear you have the wake-up working now. Best regards
Maybe I'm missing something but the datasheet doesn't explicitly say that you need to use the LLWU interrupt to wake the processor. When using the debugger it wakes up but without the debugger it seems you need to enable and handle the interrupt. That was all I did to get things working.
 
					
				
		
 dereksnell
		
			dereksnell
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Hi ryanlush,
From the reference manual: "NOTE The LLWU interrupt must not be masked by the interrupt controller to avoid a scenario where the system does not fully exit stop mode on an LLS recovery."
The LLWU ISR is required when waking from LLS or VLLSx low-power modes.
We're glad to hear you have the wake-up working now. Best regards
 
					
				
		
 Robin_Shen
		
			Robin_Shen
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Hi Ryan,
The PTC3/LLWU_P7 pin is default as CMP1_IN1 function.
Have you try to configure PORTx_PCRn[MUX] before using LLWU?
Best Regards,
Robin
-----------------------------------------------------------------------------------------------------------------------
Note: If this post answers your question, please click the Correct Answer button. Thank you!
-----------------------------------------------------------------------------------------------------------------------
