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  return nrf_temp_read();
68 #else
69  int32_t temp;
70  sd_temp_get(&temp);
71  return temp >> 2;
72 #endif
73 }
74 /*---------------------------------------------------------------------------*/
75 /**
76  * \brief Configures temperature sensor
77  * \param type initializes the hardware sensor when \a type is set to
78  * \a SENSORS_HW_INIT
79  * \param c ignored
80  * \return 1
81  * \note This function does nothing when SoftDevice is present
82  */
83 static int
84 configure(int type, int c)
85 {
86 #ifndef SOFTDEVICE_PRESENT
87  if (type == SENSORS_HW_INIT) {
88  nrf_temp_init();
89  }
90 #endif
91  return 1;
92 }
93 /**
94  * \brief Return temperature sensor status
95  * \param type ignored
96  * \return 1
97  */
98 /*---------------------------------------------------------------------------*/
99 static int
100 status(int type)
101 {
102  return 1;
103 }
104 /*---------------------------------------------------------------------------*/
105 SENSORS_SENSOR(temperature_sensor, TEMPERATURE_SENSOR, value, configure, status);
106 /**
107  * @}
108  * @}
109  */
static int status(int type)
Return temperature sensor status.
static int value(int type)
Returns device temperature.
static int configure(int type, int c)
Configures temperature sensor.