Перейти к содержанию
    

Здраствуйте. Микроконтроллер 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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

 

Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0)

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

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

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

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

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

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

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

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

 

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

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

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

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

stop режим не сбрасывает микроконтроллер, т.е. после пробуждения программа продолжает работать. После STAND-BY программа перезапускается

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Столкнулся с проблемой точно наоборот... проц 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 сборшены перед входом

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

 

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения.

 

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

 

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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

В режиме Ожидания (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();  //заснули

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...