Jump to content

    
Sign in to follow this  
nx6310

stm32 stop mode

Recommended Posts

Здраствуйте. Микроконтроллер stm32 перевожу в энергосберегающий режим STOP. А выйти из него в нормальный режим по внешнему прерыванию не получается. В нормальном режиме внешнее прерывание работает. В стоп-режиме не работает. Кто нибудь сталкивался с такой проблемой?. Код программы ниже:

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO, ENABLE);   //тактирование периферийных устройств
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);

     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_3|GPIO_Pin_10;
     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;           // конифгурация вывода РА1 как вход
     GPIO_Init(GPIOA, &GPIO_InitStructure);                                        //

GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource1);    //РА1 источник прерывания линии 1

    EXTI_InitStructure.EXTI_Line = EXTI_Line1;                         // настрока 
    EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;         // внешнего 
    EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;        //прерывания
    EXTI_InitStructure.EXTI_LineCmd = ENABLE;                       //  - прерывание по пер.фронту
    EXTI_Init(&EXTI_InitStructure);

PWR_PVDLevelConfig(PWR_PVDLevel_2V2);  // включение детектора
PWR_PVDCmd(ENABLE);        // напряжения питания

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);                    //настойка приоритета
   NVIC_InitStructure.NVIC_IRQChannel = EXTI1_IRQn;             // и разрешение 
    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; // канала прерывания EXTI1
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;           // в контроллере прерываний
    NVIC_Init(&NVIC_InitStructure);

...
...
PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI); // переход в режим стоп

 

Подпрограмма обработки прерывания

void EXTI1_IRQHandler(void){
if(EXTI_GetITStatus(EXTI_Line1) != RESET)
      {GPIO_WriteBit(GPIOB, GPIO_Pin_9, Bit_SET);
        if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET)
        {
          /* Clear Wake Up flag */
          PWR_ClearFlag(PWR_FLAG_WU);
        }
      print("PRERIVANIE 1");
        /* Clear the Key Button EXTI line pending bit */
        EXTI_ClearITPendingBit(EXTI_Line1);
      }
}

 

Тут на руском языке инфа есть немного http://www.gaw.ru/html.cgi/txt/doc/micros/...x_arh/index.htm

Share this post


Link to post
Share on other sites

Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке?

Share this post


Link to post
Share on other sites
Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке?

Я не Он, но режим STOP использовал. Все работает и от лапок и от RTC.

Share this post


Link to post
Share on other sites
Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0)

А это еще для более глубокого сна, когда вырубается вообще все. Энергопотребление в Stop режиме коло 13 мкА, а когда все вырубается, то около <1 мкА.

Но разбудить его можно только лапкой резет или wkup. По сути этот вывод служит для подключения (к примеру) кнопки включения/отключения устройства с батарейным питанием, ну что то типа кнопки Power.

 

 

Share this post


Link to post
Share on other sites

Прояснили! :смайлик низкий поклон:

Вот я этой разницы про Глубокий Стоп и не очень Глубокий, понять и не мог. Как понимаю при не глубоком Стопе состояние пинов сохраняються. При не глубоком не сохраняются и при переходе в активный режим происходит перенициализация всего. Верно резюмировал!?

Share this post


Link to post
Share on other sites

В режиме Ожидания (Standby) все I/O выводы находятся в высоко-импедансном состоянии, за

исключением:

• Вход Сброса (все еще доступен))

• Вывод TAMPER, если он сконфигурирован как вход сброса резервных данных или как

выход калибровки.

• Вход пробуждения WKUP, если разрешен

 

Share this post


Link to post
Share on other sites
А это еще для более глубокого сна, когда вырубается вообще все. Энергопотребление в Stop режиме коло 13 мкА, а когда все вырубается, то около <1 мкА.

13мка , это вы для какого процессора смотрите ? У моего STM32L151 вроде бы 1.6мка в режиме STOP with RTC

 

Где почитать про использование этого режима ?

После выхода из STOP выполнение команды начинается с того места где остановилось, или с начала ?

Если с начала, то как понять что это не несет а выход из STOP ? и т.д.

 

Share this post


Link to post
Share on other sites

Столкнулся с проблемой точно наоборот... проц stm32f100c4t6 не хочет засыпать.

конфиг EXTI

   /* Configure EXTI0 line */
   EXTI_InitStructure.EXTI_Line = EXTI_Line10 |  EXTI_Line11 | EXTI_Line12 | EXTI_Line13 | EXTI_Line14 | EXTI_Line15;
   EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
   EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;  
   EXTI_InitStructure.EXTI_LineCmd = ENABLE;
   EXTI_Init(&EXTI_InitStructure);

cами ножки

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
  
    /* Configure PB.10 -15 pin as input floating */
   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;
   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
   GPIO_Init(GPIOB, &GPIO_InitStructure);
   
   /* Enable AFIO clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
  
   /* Connect EXTI0 Line to PA.00 pin */
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource10);
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource11);
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource12);
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource13);
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource14);
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource15);

код такой

/****.....................***/
   RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);
    DMA1->IFCR = 0;
      ADC1->CR2 &= ~1;
      DMA1_Channel1->CCR &= ~1;
      DMA1_Channel4->CCR &= ~1;
      DMA1_Channel6->CCR &= ~1;
  /* Request to enter STOP mode with regulator in low power mode*/
     PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI);
     SYSCLKConfig_STOP();
           ADC1->CR2 |= 1;
      DMA1_Channel1->CCR |= 1;
      DMA1_Channel4->CCR |= 1;
      DMA1_Channel6->CCR |= 1;
.....................................................

дма запрещаю так как в доке написано если идет обмен по шине или пишется флеш то он игнорит вход в STOP MODE

If Flash memory programming is ongoing, the Stop mode entry is delayed until the memory

access is finished.

If an access to the APB domain is ongoing, The Stop mode entry is delayed until the APB

access is finished.

все pending flag сборшены перед входом

вообще не понимаю почему он не "устает"

Share this post


Link to post
Share on other sites
Столкнулся с проблемой точно наоборот... проц stm32f100c4t6 не хочет засыпать.

 

Что значит "не хочеч засыпать?" Не хочет уменьшать энергопотребление, не хочет останавливать тактирование ядра,.... ?

Share this post


Link to post
Share on other sites
Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения.

 

В рефернесе на F1 сказано что уснет все кроме АЦП поэтому его отдельно выключать надо.

 

Выяснилось вот что усыпает но с выдернутым житагом! вот так вот

Правда выяснилось другое... После просыпа не работает прерывания на прием уарта, причем не понятно то ли сам уарт глючит то ли это от того что я до этого все порты в Floating mode переводил. Передача по уарту тем не менее идет.

Share this post


Link to post
Share on other sites

и еще вдогонку...

с уартом дело похоже оказалось в портах... переводишь хотя бы один порт в float mode и все он накрывается даже если USART1 висит на А, а переводишь порт В

и еще в STOPMODE нельзя переходить в прерывании! обратно он не возращается((

походу в этом и была бага топикстатера

Share this post


Link to post
Share on other sites
В режиме Ожидания (Standby) все I/O выводы находятся в высоко-импедансном состоянии, за

исключением:

• Вход Сброса (все еще доступен))

• Вывод TAMPER, если он сконфигурирован как вход сброса резервных данных или как

выход калибровки.

• Вход пробуждения WKUP, если разрешен

 

Почему-то у меня не выходит из STANDBY по ноге WKUP2. По RTC выходит.

Достаточно ли только разрешить Вэйкап в регистре PWR->CSR ? Может надо ещё где-то что-то включить, ногу как-то настроить ?

 

Наблюдаю вот что :

-Вхожу в STANDBY

-Пытаюсь выйти по WKUP2 - не получается.

-Выхожу по RTC

-Снова вхожу в STANDBY

И вот после второго входа в STANDBY проц висит и не реагирует ни на что даже на ногу RESET. Помогает только сброс питания.

Если не входить в STANDBY то разумеется прерывания от RTC не вызывают зависания т.е. дело не в кривом обработчике.

 

 

 

     PWR->CSR |=PWR_CSR_EWUP2; // разрешили Вэйкап2 


        SCB->SCR |=SCB_SCR_SLEEPDEEP; //
    PWR->CR |= PWR_CR_PDDS; //Set PDDS bit in Power Control register (PWR_CR)   //выбрали  способ сна  STANDBY
    __WFI();  //заснули

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Sign in to follow this