mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #2954 from d00616/cpu_nrf51_lpm
cpu/nrf51822/lpm_arch: add __WFI
This commit is contained in:
commit
bac6b7fa97
@ -14,10 +14,12 @@
|
||||
* @brief Implementation of the kernels power management interface
|
||||
*
|
||||
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
||||
* @author Frank Holtz <frank-riot2015@holtznet.de>
|
||||
*
|
||||
* @}
|
||||
*/
|
||||
|
||||
#include "cpu.h"
|
||||
#include "arch/lpm_arch.h"
|
||||
|
||||
void lpm_arch_init(void)
|
||||
@ -27,8 +29,26 @@ void lpm_arch_init(void)
|
||||
|
||||
enum lpm_mode lpm_arch_set(enum lpm_mode target)
|
||||
{
|
||||
(void) target;
|
||||
/* TODO: needs to be implemented */
|
||||
switch (target) {
|
||||
/* wait for next interrupt */
|
||||
case LPM_IDLE:
|
||||
case LPM_SLEEP:
|
||||
case LPM_POWERDOWN:
|
||||
__DSB();
|
||||
__WFI();
|
||||
break;
|
||||
case LPM_OFF:
|
||||
/* Switch of RAM and power off */
|
||||
NRF_POWER->RAMON = 0;
|
||||
NRF_POWER->SYSTEMOFF = 1;
|
||||
break;
|
||||
|
||||
/* do nothing here */
|
||||
case LPM_UNKNOWN:
|
||||
case LPM_ON:
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user