Contiki-NG
temperature-sensor.c
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 /**
32  * \addtogroup nrf52dk-devices Device drivers
33  * @{
34  *
35  * \addtogroup nrf52dk-devices-temp Temperature sensor driver
36  * This is a driver for nRF52832 hardware sensor.
37  *
38  * @{
39  *
40  * \file
41  * Temperature sensor implementation.
42  * \author
43  * Wojciech Bober <wojciech.bober@nordicsemi.no>
44  *
45  */
46 #ifndef SOFTDEVICE_PRESENT
47 #include "nrf_temp.h"
48 #else
49 #include "nrf_soc.h"
50 #endif
51 #include "contiki.h"
52 #include "dev/temperature-sensor.h"
53 
54 
55 const struct sensors_sensor temperature_sensor;
56 
57 /*---------------------------------------------------------------------------*/
58 /**
59  * \brief Returns device temperature
60  * \param type ignored
61  * \return Device temperature in degrees Celsius
62  */
63 static int
64 value(int type)
65 {
66 #ifndef SOFTDEVICE_PRESENT
67  int32_t volatile temp;
68 
69  NRF_TEMP->TASKS_START = 1;
70  /* nRF52832 datasheet: one temperature measurement takes typically 36 us */
71  RTIMER_BUSYWAIT_UNTIL(NRF_TEMP->EVENTS_DATARDY, RTIMER_SECOND * 72 / 1000000);
72  NRF_TEMP->EVENTS_DATARDY = 0;
73  temp = nrf_temp_read();
74  NRF_TEMP->TASKS_STOP = 1;
75 
76  return temp;
77 #else
78  int32_t temp;
79  sd_temp_get(&temp);
80  return temp >> 2;
81 #endif
82 }
83 /*---------------------------------------------------------------------------*/
84 /**
85  * \brief Configures temperature sensor
86  * \param type initializes the hardware sensor when \a type is set to
87  * \a SENSORS_HW_INIT
88  * \param c ignored
89  * \return 1
90  * \note This function does nothing when SoftDevice is present
91  */
92 static int
93 configure(int type, int c)
94 {
95 #ifndef SOFTDEVICE_PRESENT
96  if (type == SENSORS_HW_INIT) {
97  nrf_temp_init();
98  }
99 #endif
100  return 1;
101 }
102 /**
103  * \brief Return temperature sensor status
104  * \param type ignored
105  * \return 1
106  */
107 /*---------------------------------------------------------------------------*/
108 static int
109 status(int type)
110 {
111  return 1;
112 }
113 /*---------------------------------------------------------------------------*/
114 SENSORS_SENSOR(temperature_sensor, TEMPERATURE_SENSOR, value, configure, status);
115 /**
116  * @}
117  * @}
118  */
static int status(int type)
Return temperature sensor status.
#define RTIMER_BUSYWAIT_UNTIL(cond, max_time)
Busy-wait until a condition for at most max_time.
Definition: rtimer.h:211
#define RTIMER_SECOND
Number of rtimer ticks for 1 second.
Definition: rtimer.h:112
static int value(int type)
Returns device temperature.
static int configure(int type, int c)
Configures temperature sensor.