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
55const 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 */
63static int
64value(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 */
92static int
93configure(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/*---------------------------------------------------------------------------*/
108static int
109status(int type)
110{
111 return 1;
112}
113/*---------------------------------------------------------------------------*/
114SENSORS_SENSOR(temperature_sensor, TEMPERATURE_SENSOR, value, configure, status);
115/**
116 * @}
117 * @}
118 */
static int configure(int type, int c)
Configures temperature sensor.
static int value(int type)
Returns device temperature.
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