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

 
 
> 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
InsolentS
сообщение Feb 3 2014, 18:58
Сообщение #3


Местный
***

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



Цитата(ecomp42 @ Feb 2 2014, 21:27) *
1. Никакие пины не сконфигурированы как функциональные? Перед powerdown их надо переводить обратно в I/O.

Все пины перед входом в спящий режим сконфигурированы как GPIO
Цитата(ecomp42 @ Feb 2 2014, 21:27) *
2. Про PLL есть errata 3.9:

Спасибо за наводку! Не поверите, перед тем как открывать эту тему, я пролистал errat'у 3 раза, и не заметил этого вопиющего бага. Видимо, нужно было ещё и читать sm.gif
К сожалению, не помогло. Код:
Код
__disable_irq();
  
  systick_ctrl_temp = SysTick->CTRL; // Remember the SysTick timer state
  SysTick->CTRL = 0;    // Turn off the SysTick timer

  // В этом месте потребление = 41мА
  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 */

  // 8.5мА
  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 */
  
  // 6.5мА  
  pconp_temp = LPC_SC->PCONP; // Remember the PCONP state    
  LPC_SC->PCONP = 0x00;
  
  // 6.25мА
  SCB->SCR |= 0x04; // ( 1 << 2 );    // SLEEPDEEP bit = 1
  LPC_SC->PCON = (1 << 3) | (1 << 0); // POWER DOWN mode  
  
  __WFI();   // 1мА :(
  __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();

По потребляемому току видно, что PLL отключается. Окончательно ничего не понимаю. Я искренне верю, что не бывает глючных процессоров, бывают только невыкуренные до конца даташиты и ерраты. Что же я ещё упустил? wacko.gif
Цитата(ecomp42 @ Feb 2 2014, 21:27) *
У меня всё устройство на LPC1768 в powerdown потребляет 60 мкА.

Если это не представляет большую коммерческую тайну, не могли бы Вы поделиться участком кода, который отвечает за перевод в спящий режим?


--------------------
Курильщик даташитов со стажем
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 07:48
Рейтинг@Mail.ru


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