nx6310 0 18 августа, 2010 Опубликовано 18 августа, 2010 · Жалоба Здраствуйте. Микроконтроллер 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 0 23 августа, 2012 Опубликовано 23 августа, 2012 · Жалоба Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке? Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
vlad_new 1 23 августа, 2012 Опубликовано 23 августа, 2012 · Жалоба Прошло два года с момента публикации. Удалось ли вам тогда пробуждать микроконтроллер из STOP режима, по внешнему сигналу на любой ножке? Я не Он, но режим STOP использовал. Все работает и от лапок и от RTC. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Basilij 0 23 августа, 2012 Опубликовано 23 августа, 2012 · Жалоба Я не Он, но режим STOP использовал. Все работает и от лапок и от RTC. Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0) Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
vlad_new 1 23 августа, 2012 Опубликовано 23 августа, 2012 · Жалоба Спасибо за ответ. Не подскажите а для чего тогда пин WKUP ?(PA0) А это еще для более глубокого сна, когда вырубается вообще все. Энергопотребление в Stop режиме коло 13 мкА, а когда все вырубается, то около <1 мкА. Но разбудить его можно только лапкой резет или wkup. По сути этот вывод служит для подключения (к примеру) кнопки включения/отключения устройства с батарейным питанием, ну что то типа кнопки Power. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Basilij 0 23 августа, 2012 Опубликовано 23 августа, 2012 · Жалоба Прояснили! :смайлик низкий поклон: Вот я этой разницы про Глубокий Стоп и не очень Глубокий, понять и не мог. Как понимаю при не глубоком Стопе состояние пинов сохраняються. При не глубоком не сохраняются и при переходе в активный режим происходит перенициализация всего. Верно резюмировал!? Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
vlad_new 1 24 августа, 2012 Опубликовано 24 августа, 2012 · Жалоба В режиме Ожидания (Standby) все I/O выводы находятся в высоко-импедансном состоянии, за исключением: • Вход Сброса (все еще доступен)) • Вывод TAMPER, если он сконфигурирован как вход сброса резервных данных или как выход калибровки. • Вход пробуждения WKUP, если разрешен Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
MiklPolikov 0 29 августа, 2012 Опубликовано 29 августа, 2012 · Жалоба А это еще для более глубокого сна, когда вырубается вообще все. Энергопотребление в Stop режиме коло 13 мкА, а когда все вырубается, то около <1 мкА. 13мка , это вы для какого процессора смотрите ? У моего STM32L151 вроде бы 1.6мка в режиме STOP with RTC Где почитать про использование этого режима ? После выхода из STOP выполнение команды начинается с того места где остановилось, или с начала ? Если с начала, то как понять что это не несет а выход из STOP ? и т.д. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
nx6310 0 19 октября, 2012 Опубликовано 19 октября, 2012 · Жалоба stop режим не сбрасывает микроконтроллер, т.е. после пробуждения программа продолжает работать. После STAND-BY программа перезапускается Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
MK2 0 18 января, 2013 Опубликовано 18 января, 2013 · Жалоба Столкнулся с проблемой точно наоборот... проц 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 0 19 января, 2013 Опубликовано 19 января, 2013 · Жалоба Столкнулся с проблемой точно наоборот... проц stm32f100c4t6 не хочет засыпать. Что значит "не хочеч засыпать?" Не хочет уменьшать энергопотребление, не хочет останавливать тактирование ядра,.... ? Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
vlad_new 1 19 января, 2013 Опубликовано 19 января, 2013 · Жалоба Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
MK2 0 22 января, 2013 Опубликовано 22 января, 2013 · Жалоба Если ADC включен, то не уснет. Для F4 может и ещё есть какието исключения. В рефернесе на F1 сказано что уснет все кроме АЦП поэтому его отдельно выключать надо. Выяснилось вот что усыпает но с выдернутым житагом! вот так вот Правда выяснилось другое... После просыпа не работает прерывания на прием уарта, причем не понятно то ли сам уарт глючит то ли это от того что я до этого все порты в Floating mode переводил. Передача по уарту тем не менее идет. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
MK2 0 22 января, 2013 Опубликовано 22 января, 2013 · Жалоба и еще вдогонку... с уартом дело похоже оказалось в портах... переводишь хотя бы один порт в float mode и все он накрывается даже если USART1 висит на А, а переводишь порт В и еще в STOPMODE нельзя переходить в прерывании! обратно он не возращается(( походу в этом и была бага топикстатера Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
MiklPolikov 0 8 февраля, 2013 Опубликовано 8 февраля, 2013 · Жалоба В режиме Ожидания (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(); //заснули Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться