0

I am using MC9S08DZ96 microcontroller with 8MHz external clock. I have read Freescale AN3387 (HCS08 Automotive Low-Power Modes) and I have tried to change some of registers.
When the timer value reaches a certain value, the stop mode is executed and I expect the microcontroller to go to stop3.
These are my registers:

void _EntryPoint(void)
{
  /* ### MC9S08DZ128_64 "Cpu" init code ... */
  /*  PE initialization code after reset */
  /* Common initialization of the write once registers */
  /* SOPT1: COPT=0,STOPE=1,SCI2PS=0,IIC1PS=0,??=0,??=0,??=0 */
  setReg8(SOPT1, 0x20U);        
        
  /* SOPT2: COPCLKS=0,COPW=0,??=0,ADHTS=0,??=0,MCSEL=0 */
  setReg8(SOPT2, 0x00U); 
               
  /* SPMSC1: LVWF=0,LVWACK=0,LVWIE=0,LVDRE=1,LVDSE=1,LVDE=1,??=0,BGBE=0 */
  setReg8(SPMSC1, 0x1CU);  
             
  /* SPMSC2: ??=0,??=0,LVDV=0,LVWV=0,PPDF=0,PPDACK=0,??=0,PPDC=0 */
  setReg8(SPMSC2, 0x00U);  
             
  /*  System clock initialization */
  /*lint -save  -e923 Disable MISRA rule (11.3) checking. */
  if (*(uint8_t*)0xFFAFU != 0xFFU) {   /* Test if the device trim value is stored on the specified address */

    MCGTRM = *(uint8_t*)0xFFAFU;       /* Initialize MCGTRM register from a non volatile memory */
    enter code here
    MCGSC = *(uint8_t*)0xFFAEU;        /* Initialize MCGSC register from a non volatile memory */
  }

  /*lint -restore Enable MISRA rule (11.3) checking. */
  /* MCGC2: BDIV=0,RANGE=1,HGO=0,LP=0,EREFS=0,ERCLKEN=1,EREFSTEN=1 */

  setReg8(MCGC2, 0x23U);               /* Set MCGC2 register */ 
  /* MCGC3: DIV32=1 */

  setReg8Bits(MCGC3, 0x10U);            
  /* MCGC1: CLKS=2,RDIV=3,IREFS=0,IRCLKEN=1,IREFSTEN=1 */

  setReg8(MCGC1, 0x9BU);               /* Set MCGC1 register */ 
  /* MCGC3: LOLIE=0,PLLS=0,CME=0,DIV32=1,VDIV=4 */

  setReg8(MCGC3, 0x14U);               /* Set MCGC3 register */ 
  /* MCGT: ??=0,??=0,DMX32=0,??=0,??=0,??=0,??=0,DRST_DRS=0 */

  setReg8(MCGT, 0x00U);                /* Set MCGT register */ 

  while(MCGSC_IREFST != 0U) {          /* Wait until external reference is selected */
  }

  while((MCGSC & 0x0CU) != 0x08U) {    /* Wait until external clock is selected as a bus clock reference */
  }

  /* MCGC2: BDIV=0,RANGE=1,HGO=0,LP=1,EREFS=0,ERCLKEN=1,EREFSTEN=1 */

  setReg8(MCGC2, 0x2BU);               /* Set MCGC2 register */ 
  /* MCGC1: CLKS=2,RDIV=2,IREFS=0,IRCLKEN=1,IREFSTEN=1 */
  setReg8(MCGC1, 0x93U);               /* Set MCGC1 register */ 

  /* MCGC3: DIV32=0 */
  clrReg8Bits(MCGC3, 0x10U); 
           
  /* MCGC3: LOLIE=0,PLLS=1,CME=0,DIV32=0,VDIV=4 */
  setReg8(MCGC3, 0x44U);               /* Set MCGC3 register */ 

  while(MCGSC_PLLST == 0U) {           /* Wait until PLL is selected */
  }

  /* MCGC2: LP=0 */
  clrReg8Bits(MCGC2, 0x08U);    
        
  while(MCGSC_LOCK == 0U) {            /* Wait until PLL is locked */
  }

  /* MCGC1: CLKS=0,RDIV=2,IREFS=0,IRCLKEN=1,IREFSTEN=1 */
  setReg8(MCGC1, 0x13U);               /* Set MCGC1 register */ 

  while((MCGSC & 0x0CU) != 0x0CU) {    /* Wait until PLL clock is selected as a bus clock reference */
  }
  

  /*** End of PE initialization code after reset ***/
  /*lint -save  -e950 Disable MISRA rule (1.1) checking. */
  __asm   jmp _Startup ;               /* Jump to C startup code */
  /*lint -restore Enable MISRA rule (1.1) checking. */
}

When the timer value reaches a certain value, I wrote asm stop; command, but I don't see any change that the power consumption has decreased. In fact, I expect the device's consumption to reach microamps after the stop command, instead of the usual 30mA. Does anyone have experience doing this?

brhans
  • 14,373
  • 3
  • 34
  • 49

0 Answers0