Contiki 3.x
temperature-sensor.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2012, STMicroelectronics.
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 /**
33  * \addtogroup stm32nucleo-spirit1-temperature-sensor
34  * @{
35  *
36  * \file
37  * Driver for the stm32nucleo-spirit1 Temperature sensor (on expansion board)
38  */
39 /*---------------------------------------------------------------------------*/
40 #ifdef X_NUCLEO_IKS01A1
41 /*---------------------------------------------------------------------------*/
42 #include "lib/sensors.h"
43 #include "temperature-sensor.h"
44 #include "st-lib.h"
45 /*---------------------------------------------------------------------------*/
46 static int _active = 0;
47 /*---------------------------------------------------------------------------*/
48 static void
49 init(void)
50 {
51  /*Temperature and Humity sensors share the same hw*/
52  if(!st_lib_bsp_hum_temp_is_initialized()) {
53  st_lib_bsp_hum_temp_init();
54  _active = 1;
55  }
56 }
57 /*---------------------------------------------------------------------------*/
58 static void
59 activate(void)
60 {
61  _active = 1;
62 }
63 /*---------------------------------------------------------------------------*/
64 static void
65 deactivate(void)
66 {
67  _active = 0;
68 }
69 /*---------------------------------------------------------------------------*/
70 static int
71 active(void)
72 {
73  return _active;
74 }
75 /*---------------------------------------------------------------------------*/
76 static int
77 value(int type)
78 {
79  int32_t temperature;
80  volatile float temperature_value;
81 
82  st_lib_bsp_hum_temp_get_temperature((float *)&temperature_value);
83  temperature = temperature_value * 10;
84  return temperature;
85 }
86 /*---------------------------------------------------------------------------*/
87 static int
88 configure(int type, int value)
89 {
90  switch(type) {
91  case SENSORS_HW_INIT:
92  init();
93  return 1;
94  case SENSORS_ACTIVE:
95  if(value) {
96  activate();
97  } else {
98  deactivate();
99  }
100  return 1;
101  }
102 
103  return 0;
104 }
105 /*---------------------------------------------------------------------------*/
106 static int
107 status(int type)
108 {
109  switch(type) {
110  case SENSORS_READY:
111  return active();
112  }
113 
114  return 0;
115 }
116 /*---------------------------------------------------------------------------*/
117 SENSORS_SENSOR(temperature_sensor, TEMPERATURE_SENSOR,
118  value, configure, status);
119 #endif /*X_NUCLEO_IKS01A1*/
120 /*---------------------------------------------------------------------------*/
121 /** @} */
static int value(int type)
Returns device temperature.
Header file for the STM32Cube HAL APIs.
const struct sensors_sensor temperature_sensor
NOTE: For the temperature measurement, the ADC extended range mode is needed; but this is inaccurate ...