реклама на сайте
подробности

 
 
> lpc1765 не хочет бай-бай
InsolentS
сообщение Jan 31 2014, 18:49
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 414
Регистрация: 8-06-06
Пользователь №: 17 897



Всем привет!
lpc1765 потребялет чрезмерно много тока в режиме PowerDown (около 1мА). Потребляет именно сам процессор - всё остальное с платы уже отпаяли. Не могу понять, что же мы забыли отключить. Если переключится в Deep PowerDown, потребление снижается до 240мкА. Но такой режим нам не подходит, потому что нужно просыпаться по прерыванию на ноге.
Вот код:
Код
  __disable_irq();
  
  systick_ctrl_temp = SysTick->CTRL; // Remember the SysTick timer state
  SysTick->CTRL = 0;    // Turn off the SysTick timer
  
  pconp_temp = LPC_SC->PCONP; // Remember the PCONP state  
  
  LPC_SC->PCONP = 0x00;
  
  SCB->SCR |= 0x04;     // SLEEPDEEP bit = 1
  LPC_SC->PCON = (1 << 3) | (1 << 0); // POWER DOWN mode, BOD disabled  
  
  __WFI();
  __nop();
  __nop();
  __nop();
  __nop();  
  
  SystemInit();
  
  LPC_SC->PCONP = pconp_temp; // Restore the PCONP state  
  SysTick->CTRL = systick_ctrl_temp; // Restore the SysTick state
  
  __enable_irq();

Все пины перед сном находятся в корректных состояниях (input floating, либо input pull-down либо output low). Если бы утечка шла через пины, думаю, не было бы такой разницы между PowerDown и Deep PowerDown.
В проекте используются SSP, I2C, CAN, USB - но всё это хозяйство мы перед сном отключаем, к тому же
Код
LPC_SC->PCONP = 0x00;

не оставляет периферии шансов, как я понимаю.
Что же ещё мы забыли отключить? wacko.gif


--------------------
Курильщик даташитов со стажем
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
ecomp42
сообщение Feb 2 2014, 15:27
Сообщение #2





Группа: Новичок
Сообщений: 9
Регистрация: 6-04-13
Пользователь №: 76 376



1. Никакие пины не сконфигурированы как функциональные? Перед powerdown их надо переводить обратно в I/O.

2. Про PLL есть errata 3.9:
Цитата
Problem: If the main PLL (PLL0) is enabled and connected before entering Deep Sleep or
Power-down modes, it will remain enabled and connected after the chip enters Deep
Sleep mode or Power-down mode causing the power consumption to be higher.

Принудительно отключается следующим образом
Код
LPC_SC->PLL0CON &= ~(1<<1);  /* Disconnect the main PLL (PLL0) */        
LPC_SC->PLL0FEED = 0xAA;        /* Feed */                                  
LPC_SC->PLL0FEED = 0x55;        /* Feed */                                  
while ((LPC_SC->PLL0STAT & (1<<25)) != 0x00);  /* Wait for main PLL (PLL0) to disconnect */
LPC_SC->PLL0CON &= ~(1<<0);  /* Turn off the main PLL (PLL0) */          
LPC_SC->PLL0FEED = 0xAA;        /* Feed */                                  
LPC_SC->PLL0FEED = 0x55;        /* Feed */                                  
while ((LPC_SC->PLL0STAT & (1<<24)) != 0x00); /* Wait for main PLL (PLL0) to shut down */


У меня всё устройство на LPC1768 в powerdown потребляет 60 мкА.

Сообщение отредактировал ecomp42 - Feb 2 2014, 15:31
Go to the top of the page
 
+Quote Post
Golikov A.
сообщение Feb 2 2014, 19:32
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 4 256
Регистрация: 17-02-06
Пользователь №: 14 454



Цитата(ecomp42 @ Feb 2 2014, 19:27) *
2. Про PLL есть errata 3.9:


вот оно почему у меня ПЛЛ перед сном выключалсяsm.gif А я вот после прочтения доки думал, зачем это было сделано, если все само должно было быть).... давно было дело, нюансов и не помнил, может вообще сделал так потому что в других процах так надо было...%)
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 19th July 2025 - 23:42
Рейтинг@Mail.ru


Страница сгенерированна за 0.01366 секунд с 7
ELECTRONIX ©2004-2016