Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: stm32 stop mode
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
nx6310
Здраствуйте. Микроконтроллер 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
Basilij
Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке?
vlad_new
Цитата(Basilij @ Aug 23 2012, 08:13) *
Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке?

Я не Он, но режим STOP использовал. Все работает и от лапок и от RTC.
Basilij
Цитата(vlad_new @ Aug 23 2012, 17:30) *
Я не Он, но режим STOP использовал. Все работает и от лапок и от RTC.


Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0)
vlad_new
Цитата(Basilij @ Aug 23 2012, 16:43) *
Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0)

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

Basilij
Прояснили! :смайлик низкий поклон:
Вот я этой разницы про Глубокий Стоп и не очень Глубокий, понять и не мог. Как понимаю при не глубоком Стопе состояние пинов сохраняються. При не глубоком не сохраняются и при переходе в активный режим происходит перенициализация всего. Верно резюмировал!?
vlad_new
В режиме Ожидания (Standby) все I/O выводы находятся в высоко-импедансном состоянии, за
исключением:
• Вход Сброса (все еще доступен))
• Вывод TAMPER, если он сконфигурирован как вход сброса резервных данных или как
выход калибровки.
• Вход пробуждения WKUP, если разрешен
MiklPolikov
Цитата(vlad_new @ Aug 23 2012, 17:01) *
А это еще для более глубокого сна, когда вырубается вообще все. Энергопотребление в Stop режиме коло 13 мкА, а когда все вырубается, то около <1 мкА.

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

Где почитать про использование этого режима ?
После выхода из STOP выполнение команды начинается с того места где остановилось, или с начала ?
Если с начала, то как понять что это не несет а выход из STOP ? и т.д.
nx6310
stop режим не сбрасывает микроконтроллер, т.е. после пробуждения программа продолжает работать. После STAND-BY программа перезапускается
MK2
Столкнулся с проблемой точно наоборот... проц 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 сборшены перед входом
вообще не понимаю почему он не "устает"
MiklPolikov
Цитата(MK2 @ Jan 18 2013, 20:31) *
Столкнулся с проблемой точно наоборот... проц stm32f100c4t6 не хочет засыпать.


Что значит "не хочеч засыпать?" Не хочет уменьшать энергопотребление, не хочет останавливать тактирование ядра,.... ?
vlad_new
Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения.
MK2
Цитата(vlad_new @ Jan 19 2013, 10:39) *
Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения.


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

Выяснилось вот что усыпает но с выдернутым житагом! вот так вот
Правда выяснилось другое... После просыпа не работает прерывания на прием уарта, причем не понятно то ли сам уарт глючит то ли это от того что я до этого все порты в Floating mode переводил. Передача по уарту тем не менее идет.
MK2
и еще вдогонку...
с уартом дело похоже оказалось в портах... переводишь хотя бы один порт в float mode и все он накрывается даже если USART1 висит на А, а переводишь порт В
и еще в STOPMODE нельзя переходить в прерывании! обратно он не возращается((
походу в этом и была бага топикстатера
MiklPolikov
Цитата(vlad_new @ Aug 24 2012, 16:52) *
В режиме Ожидания (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();  //заснули
maksimp
Цитата(MiklPolikov @ Feb 8 2013, 18:48) *
Код
    __WFI();  //заснули

Вероятно нужно не __WFI(); а __WFE(); . WFI - это ожидание прерывания. WFE - ожидание события пробуждения.
MiklPolikov
Цитата(maksimp @ Feb 8 2013, 21:56) *
Вероятно нужно не __WFI(); а __WFE(); . WFI - это ожидание прерывания. WFE - ожидание события пробуждения.


Поменял __WFI(); на __WFE(); , как будто ничего не изменилось.

Да в общем-то у меня в режиме STANDBUY и STOP ток потребления одинаковый 19мкА .Но в STOP всё работает как надо.
Вот только я ток хочу меньше, в AN3193 STM32L15x ultralow power features overview говорится что в режиме STOP должно быть 1.6мкА.
digital
Цитата(MK2 @ Jan 22 2013, 12:40) *
Выяснилось вот что усыпает но с выдернутым житагом! вот так вот


Спасибо большое!!!!
bigal
Чтобы отладчик работал со спящими режимами нужно специальные биты выставить
Код
#if defined(DEBUG)
  DBGMCU_Config(DBGMCU_SLEEP, ENABLE);
  DBGMCU_Config(DBGMCU_STOP, ENABLE);
  DBGMCU_Config(DBGMCU_STANDBY, ENABLE);
#endif

Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.