Contiki-NG
lpm.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015, Nordic Semiconductor
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the Institute nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  */
30 /**
31  * \addtogroup nrf52840-dev Device drivers
32  * @{
33  *
34  * \addtogroup nrf52840-lpm Low power mode functions
35  * @{
36  *
37  * \file
38  * A header file for low power mode functions.
39  * \author
40  * Wojciech Bober <wojciech.bober@nordicsemi.no>
41  */
42 #ifndef LPM_H
43 #define LPM_H
44 
45 #include "sys/int-master.h"
46 #include "sys/critical.h"
47 #include "sys/process.h"
48 #include "sys/energest.h"
49 
50 /**
51  * \brief Stop and wait for an event
52  *
53  */
54 static inline void
55 lpm_drop(void)
56 {
57  int_master_status_t status;
58  int abort;
59  status = critical_enter();
60  abort = process_nevents();
61  if(!abort) {
62  ENERGEST_SWITCH(ENERGEST_TYPE_CPU, ENERGEST_TYPE_LPM);
63  __WFI();
64  ENERGEST_SWITCH(ENERGEST_TYPE_LPM, ENERGEST_TYPE_CPU);
65  }
66  critical_exit(status);
67 }
68 #endif /* LPM_H_ */
69 /**
70  * @}
71  * @}
72  */
Header file for the energy estimation mechanism
static void critical_exit(int_master_status_t status)
Exit a critical section and restore the master interrupt.
Definition: critical.h:81
__STATIC_INLINE void __WFI(void)
Wait For Interrupt.
Definition: cmsis_gcc.h:383
static int_master_status_t critical_enter()
Enter a critical section.
Definition: critical.h:65
INT_MASTER_STATUS_DATATYPE int_master_status_t
Master interrupt state representation data type.
Definition: int-master.h:62
Header file for the Contiki process interface.
static void lpm_drop(void)
Stop and wait for an event.
Definition: lpm.h:55
int process_nevents(void)
Number of events waiting to be processed.
Definition: process.c:316