• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2016 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef _CHRE_SENSOR_H_
18 #define _CHRE_SENSOR_H_
19 
20 /**
21  * API dealing with sensor interaction in the Context Hub Runtime
22  * Environment.
23  *
24  * This includes the definition of our sensor types and the ability to
25  * configure them for receiving events.
26  */
27 
28 #include <stdbool.h>
29 #include <stdint.h>
30 
31 // For CHRE_EVENT_SENSOR_FIRST_EVENT and CHRE_EVENT_SENSOR_LAST_EVENT
32 #include "chre_event.h"
33 
34 #ifdef __cplusplus
35 extern "C" {
36 #endif
37 
38 /**
39  * The CHRE_SENSOR_TYPE_* defines are the sensor types supported.
40  *
41  * Unless otherwise noted, each of these sensor types is based off of a
42  * corresponding sensor type in the Android API's sensors.h interface.
43  * For a given CHRE_SENSOR_TYPE_FOO, it corresponds to the SENSOR_TYPE_FOO in
44  * hardware/libhardware/include/hardware/sensors.h of the Android code base.
45  *
46  * Unless otherwise noted below, a CHRE_SENSOR_TYPE_FOO should be assumed
47  * to work the same as the Android SENSOR_TYPE_FOO, as documented in the
48  * sensors.h documentation and as detailed within the Android Compatibility
49  * Definition Document.
50  *
51  * Note that every sensor will generate CHRE_EVENT_SENSOR_SAMPLING_CHANGE
52  * events, so it is not listed with each individual sensor.
53  */
54 
55 /**
56  * Accelerometer.
57  *
58  * Generates: CHRE_EVENT_SENSOR_ACCELEROMETER_DATA
59  *
60  * @see CHRE_EVENT_SENSOR_ACCELEROMETER_DATA
61  */
62 #define CHRE_SENSOR_TYPE_ACCELEROMETER  UINT8_C(1)
63 
64 /**
65  * Instantaneous motion detection.
66  *
67  * Generates: CHRE_EVENT_SENSOR_INSTANT_MOTION_DETECT_DATA
68  *
69  * This is a one-shot sensor.
70  *
71  * This does not have a direct analogy within sensors.h.  This is similar
72  * to SENSOR_TYPE_MOTION_DETECT, but this triggers instantly upon any
73  * motion, instead of waiting for a period of continuous motion.
74  */
75 #define CHRE_SENSOR_TYPE_INSTANT_MOTION_DETECT  UINT8_C(2)
76 
77 /**
78  * Stationary detection.
79  *
80  * Generates: CHRE_EVENT_SENSOR_STATIONARY_DETECT_DATA
81  *
82  * This is a one-shot sensor.
83  */
84 #define CHRE_SENSOR_TYPE_STATIONARY_DETECT  UINT8_C(3)
85 
86 /**
87  * Gyroscope.
88  *
89  * Generates: CHRE_EVENT_SENSOR_GYROSCOPE_DATA and
90  *     CHRE_EVENT_SENSOR_GYROSCOPE_BIAS_INFO
91  *
92  * Note that the GYROSCOPE_DATA is always the calibrated data, and not
93  * raw data.
94  */
95 #define CHRE_SENSOR_TYPE_GYROSCOPE  UINT8_C(6)
96 
97 /**
98  * Magnetometer.
99  *
100  * Generates: CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_DATA and
101  *     CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_BIAS_INFO
102  *
103  * Note that the GEOMAGNETIC_FIELD_DATA is always the calibrated data, and not
104  * raw data.
105  */
106 #define CHRE_SENSOR_TYPE_GEOMAGNETIC_FIELD  UINT8_C(8)
107 
108 /**
109  * Barometric pressure sensor.
110  *
111  * Generates: CHRE_EVENT_SENSOR_PRESSURE_DATA
112  */
113 #define CHRE_SENSOR_TYPE_PRESSURE  UINT8_C(10)
114 
115 /**
116  * Ambient light sensor.
117  *
118  * Generates: CHRE_EVENT_SENSOR_LIGHT_DATA
119  */
120 #define CHRE_SENSOR_TYPE_LIGHT  UINT8_C(12)
121 
122 /**
123  * Proximity detection.
124  *
125  * Generates: CHRE_EVENT_SENSOR_PROXIMITY_DATA
126  *
127  * This is an on-change sensor.
128  */
129 #define CHRE_SENSOR_TYPE_PROXIMITY  UINT8_C(13)
130 
131 /**
132  * Base value for all of the data events for sensors.
133  *
134  * The value for a data event FOO is
135  * CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_FOO
136  *
137  * This allows for easy mapping, and also explains why there are gaps
138  * in our values since we don't have all possible sensor types assigned.
139  */
140 #define CHRE_EVENT_SENSOR_DATA_EVENT_BASE  CHRE_EVENT_SENSOR_FIRST_EVENT
141 
142 /**
143  * nanoappHandleEvent argument: struct chreSensorThreeAxisData
144  *
145  * The data can be interpreted using the 'x', 'y', and 'z' fields within
146  * 'readings', or by the 3D array 'v' (v[0] == x; v[1] == y; v[2] == z).
147  *
148  * All values are in SI units (m/s^2) and measure the acceleration of the
149  * device minus the force of gravity.
150  */
151 #define CHRE_EVENT_SENSOR_ACCELEROMETER_DATA \
152     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_ACCELEROMETER)
153 
154 /**
155  * nanoappHandleEvent argument: struct chreSensorOccurrenceData
156  *
157  * Since this is a one-shot sensor, after this event is delivered to the
158  * nanoapp, the sensor automatically goes into DONE mode.  Sensors of this
159  * type must be configured with a ONE_SHOT mode.
160  */
161 #define CHRE_EVENT_SENSOR_INSTANT_MOTION_DETECT_DATA \
162     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_INSTANT_MOTION_DETECT)
163 
164 /**
165  * nanoappHandleEvent argument: struct chreSensorOccurrenceData
166  *
167  * Since this is a one-shot sensor, after this event is delivered to the
168  * nanoapp, the sensor automatically goes into DONE mode.  Sensors of this
169  * type must be configured with a ONE_SHOT mode.
170  */
171 #define CHRE_EVENT_SENSOR_STATIONARY_DETECT_DATA \
172     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_STATIONARY_DETECT)
173 
174 /**
175  * nanoappHandleEvent argument: struct chreSensorThreeAxisData
176  *
177  * The data can be interpreted using the 'x', 'y', and 'z' fields within
178  * 'readings', or by the 3D array 'v' (v[0] == x; v[1] == y; v[2] == z).
179  *
180  * All values are in radians/second and measure the rate of rotation
181  * around the X, Y and Z axis.
182  */
183 #define CHRE_EVENT_SENSOR_GYROSCOPE_DATA \
184     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_GYROSCOPE)
185 
186 /**
187  * nanoappHandleEvent argument: struct chreSensorThreeAxisData
188  *
189  * The data can be interpreted using the 'x', 'y', and 'z' fields within
190  * 'readings', or by the 3D array 'v' (v[0] == x; v[1] == y; v[2] == z).
191  *
192  * All values are in micro-Tesla (uT) and measure the geomagnetic
193  * field in the X, Y and Z axis.
194  */
195 #define CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_DATA \
196     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_GEOMAGNETIC_FIELD)
197 
198 /**
199  * nanoappHandleEvent argument: struct chreSensorFloatData
200  *
201  * The data can be interpreted using the 'pressure' field within 'readings'.
202  * This value is in hectopascals (hPa).
203  */
204 #define CHRE_EVENT_SENSOR_PRESSURE_DATA \
205     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_PRESSURE)
206 
207 /**
208  * nanoappHandleEvent argument: struct chreSensorFloatData
209  *
210  * The data can be interpreted using the 'light' field within 'readings'.
211  * This value is in SI lux units.
212  */
213 #define CHRE_EVENT_SENSOR_LIGHT_DATA \
214     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_LIGHT)
215 
216 /**
217  * nanoappHandleEvent argument: struct chreSensorByteData
218  *
219  * The data is interpreted from the following fields in 'readings':
220  * o 'isNear': If set to 1, we are nearby (on the order of centimeters);
221  *       if set to 0, we are far.
222  * o 'invalid': If set to 1, this is not a valid reading of this data.
223  *
224  * As an on-change sensor, there is an event generated upon configuring
225  * this sensor.  This is when we might get an 'invalid' reading.  Thus,
226  * this field must be checked on the first event before interpreting 'isNear'.
227  */
228 #define CHRE_EVENT_SENSOR_PROXIMITY_DATA \
229     (CHRE_EVENT_SENSOR_DATA_EVENT_BASE + CHRE_SENSOR_TYPE_PROXIMITY)
230 
231 
232 /**
233  * First value for sensor events which are not data from the sensor.
234  *
235  * Unlike the data event values, these other event values don't have any
236  * mapping to sensor types.
237  */
238 #define CHRE_EVENT_SENSOR_OTHER_EVENTS_BASE \
239     (CHRE_EVENT_SENSOR_FIRST_EVENT + 0x0100)
240 
241 /**
242  * nanoappHandleEvent argument: struct chreSensorSamplingChangeEvent
243  *
244  * Indicates that the interval and/or the latency which this sensor is
245  * sampling at has changed.
246  */
247 #define CHRE_EVENT_SENSOR_SAMPLING_CHANGE \
248     (CHRE_EVENT_SENSOR_OTHER_EVENTS_BASE + 0)
249 
250 /**
251  * nanoappHandleEvent argument: struct chreSensorThreeAxisData
252  *
253  * The data can be interpreted using the 'x_bias', 'y_bias', and 'z_bias'
254  * field within 'readings', or by the 3D array 'bias' (bias[0] == x_bias;
255  * bias[1] == y_bias; bias[2] == z_bias).
256  *
257  * All values are in radians/second and measure the rate of rotation
258  * around the X, Y and Z axis.
259  */
260 #define CHRE_EVENT_SENSOR_GYROSCOPE_BIAS_INFO \
261     (CHRE_EVENT_SENSOR_OTHER_EVENTS_BASE + 1)
262 
263 /**
264  * nanoappHandleEvent argument: struct chreSensorThreeAxisData
265  *
266  * The data can be interpreted using the 'x_bias', 'y_bias', and 'z_bias'
267  * field within 'readings', or by the 3D array 'bias' (bias[0] == x_bias;
268  * bias[1] == y_bias; bias[2] == z_bias).
269  *
270  * All values are in micro-Tesla (uT) and measure the geomagnetic
271  * field in the X, Y and Z axis.
272  */
273 #define CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_BIAS_INFO \
274     (CHRE_EVENT_SENSOR_OTHER_EVENTS_BASE + 2)
275 
276 
277 #if CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_BIAS_INFO > CHRE_EVENT_SENSOR_LAST_EVENT
278 #error Too many sensor events.
279 #endif
280 
281 
282 /**
283  * Value indicating we want the smallest possible latency for a sensor.
284  *
285  * This literally translates to 0 nanoseconds for the chreSensorConfigure()
286  * argument.  While we won't get exactly 0 nanoseconds, the CHRE will
287  * queue up this event As Soon As Possible.
288  */
289 #define CHRE_SENSOR_LATENCY_ASAP  UINT64_C(0)
290 
291 /**
292  * Special value indicating non-importance of the interval.
293  *
294  * @see chreSensorConfigure
295  * @see chreSensorSamplingStatus
296  */
297 #define CHRE_SENSOR_INTERVAL_DEFAULT  UINT64_C(-1)
298 
299 /**
300  * Special value indicating non-importance of the latency.
301  *
302  * @see chreSensorConfigure
303  * @see chreSensorSamplingStatus
304  */
305 #define CHRE_SENSOR_LATENCY_DEFAULT  UINT64_C(-1)
306 
307 
308 // This is used to define elements of enum chreSensorConfigureMode.
309 #define CHRE_SENSOR_CONFIGURE_RAW_POWER_ON           (1 << 0)
310 
311 // This is used to define elements of enum chreSensorConfigureMode.
312 #define CHRE_SENSOR_CONFIGURE_RAW_REPORT_CONTINUOUS  (1 << 1)
313 
314 // This is used to define elements of enum chreSensorConfigureMode.
315 #define CHRE_SENSOR_CONFIGURE_RAW_REPORT_ONE_SHOT    (2 << 1)
316 
317 
318 
319 /**
320  * Modes we can configure a sensor to use.
321  *
322  * Our mode will affect not only how/if we receive events, but
323  * also whether or not the sensor will be powered on our behalf.
324  *
325  * @see chreSensorConfigure
326  */
327 enum chreSensorConfigureMode {
328     /**
329      * Get events from the sensor.
330      *
331      * Power: Turn on if not already on.
332      * Reporting: Continuous.  Send each new event as it comes (subject to
333      *     batching and latency).
334      */
335     CHRE_SENSOR_CONFIGURE_MODE_CONTINUOUS =
336         (CHRE_SENSOR_CONFIGURE_RAW_POWER_ON |
337          CHRE_SENSOR_CONFIGURE_RAW_REPORT_CONTINUOUS),
338 
339     /**
340      * Get a single event from the sensor and then become DONE.
341      *
342      * Once the event is sent, the sensor automatically
343      * changes to CHRE_SENSOR_CONFIGURE_MODE_DONE mode.
344      *
345      * Power: Turn on if not already on.
346      * Reporting: One shot.  Send the next event and then be DONE.
347      */
348     CHRE_SENSOR_CONFIGURE_MODE_ONE_SHOT =
349         (CHRE_SENSOR_CONFIGURE_RAW_POWER_ON |
350          CHRE_SENSOR_CONFIGURE_RAW_REPORT_ONE_SHOT),
351 
352     /**
353      * Get events from a sensor that are generated for other apps.
354      *
355      * This is considered passive because the sensor will not be powered
356      * on for the sake of our nanoapp.  If and only if another app in
357      * the system has requested this sensor power on will we get events.
358      *
359      * This can be useful for something which is interested in seeing data,
360      * but not interested enough to be responsible for powering on the sensor.
361      *
362      * Power: Do not power the sensor on our behalf.
363      * Reporting: Continuous.  Send each event as it comes.
364      */
365     CHRE_SENSOR_CONFIGURE_MODE_PASSIVE_CONTINUOUS =
366         CHRE_SENSOR_CONFIGURE_RAW_REPORT_CONTINUOUS,
367 
368     /**
369      * Get a single event from a sensor that is generated for other apps.
370      *
371      * See CHRE_SENSOR_CONFIGURE_MODE_PASSIVE_CONTINUOUS for more details
372      * on what be "passive" means.
373      *
374      * Power: Do not power the sensor on our behalf.
375      * Reporting: One shot.  Send only the next event and then be DONE.
376      */
377     CHRE_SENSOR_CONFIGURE_MODE_PASSIVE_ONE_SHOT =
378         CHRE_SENSOR_CONFIGURE_RAW_REPORT_ONE_SHOT,
379 
380     /**
381      * Indicate we are done using this sensor and no longer interested in it.
382      *
383      * See chreSensorConfigure for more details on expressing interest or
384      * lack of interest in a sensor.
385      *
386      * Power: Do not power the sensor on our behalf.
387      * Reporting: None.
388      */
389     CHRE_SENSOR_CONFIGURE_MODE_DONE = 0,
390 };
391 
392 /**
393  * A structure containing information about a Sensor.
394  *
395  * See documentation of individual fields below.
396  */
397 struct chreSensorInfo {
398     /**
399      * The name of the sensor.
400      *
401      * A text name, useful for logging/debugging, describing the Sensor.  This
402      * is not assured to be unique (i.e. there could be multiple sensors with
403      * the name "Temperature").
404      *
405      * CHRE implementations may not set this as NULL.  An empty
406      * string, while discouraged, is legal.
407      */
408     const char *sensorName;
409 
410     /**
411      * One of the CHRE_SENSOR_TYPE_* defines above.
412      */
413     uint8_t sensorType;
414 
415     /**
416      * Flag indicating if this sensor is on-change.
417      *
418      * An on-change sensor only generates events when underlying state
419      * changes.  This has the same meaning as on-change does in the Android
420      * Sensors HAL.  See sensors.h for much more details.
421      *
422      * A value of 1 indicates this is on-change.  0 indicates this is not
423      * on-change.
424      */
425     uint8_t isOnChange  : 1;
426 
427     /**
428      * Flag indicating if this sensor is one-shot.
429      *
430      * A one-shot sensor only triggers a single event, and then automatically
431      * disables itself.
432      *
433      * A value of 1 indicates this is on-change.  0 indicates this is not
434      * on-change.
435      */
436     uint8_t isOneShot   : 1;
437     uint8_t unusedFlags : 6;
438 };
439 
440 /**
441  * Header used in every structure containing batchable data from a sensor.
442  *
443  * The typical structure for sensor data looks like:
444  *
445  *   struct chreSensorTypeData {
446  *       struct chreSensorDataHeader header;
447  *       struct {
448  *           uint32_t timestampDelta;
449  *           union {
450  *               <type> value;
451  *               <type> interpretation0;
452  *               <type> interpretation1;
453  *           };
454  *       } readings[1];
455  *   };
456  *
457  * Despite 'readings' being declared as an array of 1 element,
458  * an instance of the struct will actually have 'readings' as
459  * an array of header.readingCount elements (which may be 1).
460  * The 'timestampDelta' is in relation to the previous 'readings' (or
461  * the baseTimestamp for readings[0].  So,
462  * Timestamp for readings[0] == header.baseTimestamp +
463  *     readings[0].timestampDelta.
464  * Timestamp for readings[1] == timestamp for readings[0] +
465  *     readings[1].timestampDelta.
466  * And thus, in order to determine the timestamp for readings[N], it's
467  * necessary to process through all of the N-1 readings.  The advantage,
468  * though, is that our entire readings can span an arbitrary length of time,
469  * just as long as any two consecutive readings differ by no more than
470  * 4.295 seconds (timestampDelta, like all time in the CHRE, is in
471  * nanoseconds).
472  *
473  * If a sensor has batched readings where two consecutive readings differ by
474  * more than 4.295 seconds, the CHRE will split them across multiple
475  * instances of the struct, and send multiple events.
476  *
477  * The value from the sensor is typically expressed in a union,
478  * allowing a generic access to the data ('value'), along with
479  * differently named access giving a more natural interpretation
480  * of the data for the specific sensor types which use this
481  * structure.  This allows, for example, barometer code to
482  * reference readings[N].pressure, and an ambient light sensor
483  * to reference readings[N].light, while both use the same
484  * structure.
485  */
486 struct chreSensorDataHeader {
487     /**
488      * The base timestamp, in nanoseconds.
489      */
490     uint64_t baseTimestamp;
491 
492     /**
493      * The handle of the sensor producing this event.
494      */
495     uint32_t sensorHandle;
496 
497     /**
498      * The number elements in the 'readings' array.
499      *
500      * This must be at least 1.
501      */
502     uint16_t readingCount;
503 
504     /**
505      * Reserved bytes.
506      *
507      * These must be 0.
508      */
509     uint8_t reserved[2];
510 };
511 
512 /**
513  * Data for a sensor which reports on three axes.
514  *
515  * This is used by CHRE_EVENT_SENSOR_DATA, CHRE_EVENT_SENSOR_GYROSCOPE_DATA,
516  * CHRE_EVENT_SENSOR_GYROSCOPE_BIAS_INFO,
517  * CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_DATA, and
518  * CHRE_EVENT_SENSOR_GEOMAGNETIC_FIELD_BIAS_INFO.
519  */
520 struct chreSensorThreeAxisData {
521     /**
522      * @see chreSensorDataHeader
523      */
524     struct chreSensorDataHeader header;
525     struct {
526         /**
527          * @see chreSensorDataHeader
528          */
529         uint32_t timestampDelta;
530         union {
531             float values[3];
532             float v[3];
533             struct {
534                 float x;
535                 float y;
536                 float z;
537             };
538             float bias[3];
539             struct {
540                 float x_bias;
541                 float y_bias;
542                 float z_bias;
543             };
544         };
545     } readings[1];
546 };
547 
548 /**
549  * Data from a sensor where we only care about a event occurring.
550  *
551  * This is a bit unusual in that our readings have no data in addition
552  * to the timestamp.  But since we only care about the occurrence, we
553  * don't need to know anything else.
554  *
555  * Used by: CHRE_EVENT_SENSOR_INSTANT_MOTION_DETECT_DATA and
556  *     CHRE_EVENT_SENSOR_STATIONARY_DETECT_DATA.
557  */
558 struct chreSensorOccurrenceData {
559     struct chreSensorDataHeader header;
560     struct {
561         uint32_t timestampDelta;
562         // This space intentionally left blank.
563         // Only the timestamp is meaningful here, there
564         // is no additional data.
565     } readings[1];
566 };
567 
568 /**
569  * CHRE_EVENT_SENSOR_LIGHT_DATA and CHRE_EVENT_SENSOR_PRESSURE_DATA.
570  */
571 struct chreSensorFloatData {
572     struct chreSensorDataHeader header;
573     struct {
574         uint32_t timestampDelta;
575         union {
576             float value;
577             float light;  // lux
578             float pressure;  // hectopascals (hPa)
579         };
580     } readings[1];
581 };
582 
583 /**
584  * CHRE_EVENT_SENSOR_PROXIMITY_DATA.
585  */
586 struct chreSensorByteData {
587     struct chreSensorDataHeader header;
588     struct {
589         uint32_t timestampDelta;
590         union {
591             uint8_t value;
592             struct {
593                 uint8_t isNear : 1;
594                 uint8_t invalid : 1;
595                 uint8_t padding0 : 6;
596             };
597         };
598     } readings[1];
599 };
600 
601 /**
602  * The status of a sensor's sampling configuration.
603  */
604 struct chreSensorSamplingStatus {
605     /**
606      * The interval, in nanoseconds, at which the sensor is now sampling.
607      *
608      * If this is CHRE_SENSOR_INTERVAL_DEFAULT, then a sampling interval
609      * isn't meaningful for this sensor.
610      *
611      * Note that if 'enabled' is false, this value is not meaningful.
612      */
613     uint64_t interval;
614 
615     /**
616      * The latency, in nanoseconds, at which the senor is now reporting.
617      *
618      * If this is CHRE_SENSOR_LATENCY_DEFAULT, then a latency
619      * isn't meaningful for this sensor.
620      *
621      * Note that if 'enabled' is false, this value is not meaningful.
622      */
623     uint64_t latency;
624 
625     /**
626      * True if the sensor is actively powered and sampling; false otherwise.
627      */
628     bool enabled;
629 };
630 
631 /**
632  * The nanoappHandleEvent argument for CHRE_EVENT_SENSOR_SAMPLING_CHANGE.
633  *
634  * Note that only at least one of 'interval' or 'latency' must be
635  * different than it was prior to this event.  Thus, one of these
636  * fields may be (but doesn't need to be) the same as before.
637  */
638 struct chreSensorSamplingStatusEvent {
639     /**
640      * The handle of the sensor which has experienced a change in sampling.
641      */
642     uint32_t sensorHandle;
643 
644     /**
645      * The new sampling status.
646      *
647      * At least one of the field in this struct will be different from
648      * the previous sampling status event.
649      */
650     struct chreSensorSamplingStatus status;
651 };
652 
653 
654 
655 /**
656  * Find the default sensor for a given sensor type.
657  *
658  * @param sensorType One of the CHRE_SENSOR_TYPE_* constants.
659  * @param handle  If a sensor is found, then the memory will be filled with
660  *     the value for the sensor's handle.  This argument must be non-NULL.
661  * @returns true if a sensor was found, false otherwise.
662  */
663 bool chreSensorFindDefault(uint8_t sensorType, uint32_t *handle);
664 
665 /**
666  * Get the chreSensorInfo struct for a given sensor.
667  *
668  * @param sensorHandle  The sensor handle, as obtained from
669  *     chreSensorFindDefault() or passed to nanoappHandleEvent().
670  * @param info  If the sensor is valid, then this memory will be filled with
671  *     the SensorInfo contents for this sensor.  This argument must be
672  *     non-NULL.
673  * @returns true if the senor handle is valid and 'info' was filled in;
674  *     false otherwise.
675  */
676 bool chreGetSensorInfo(uint32_t sensorHandle, struct chreSensorInfo *info);
677 
678 /**
679  * Get the chreSensorSamplingStatus struct for a given sensor.
680  *
681  * Note that this may be different from what was requested in
682  * chreSensorConfigure(), for multiple reasons.  It's possible that the sensor
683  * does not exactly support the interval requested in chreSensorConfigure(), so
684  * a faster one was chosen.
685  *
686  * It's also possible that there is another user of this sensor who has
687  * requested a faster interval and/or lower latency.  This latter scenario
688  * should be noted, because it means the sensor rate can change due to no
689  * interaction from this nanoapp.  Note that the
690  * CHRE_EVENT_SENSOR_SAMPLING_CHANGE event will trigger in this case, so it's
691  * not necessary to poll for such a change.
692  *
693  * @param sensorHandle  The sensor handle, as obtained from
694  *     chreSensorFindDefault() or passed to nanoappHandleEvent().
695  * @param status  If the sensor is valid, then this memory will be filled with
696  *     the sampling status contents for this sensor.  This argument must be
697  *     non-NULL.
698  * @returns true if the senor handle is valid and 'status' was filled in;
699  *     false otherwise.
700  */
701 bool chreGetSensorSamplingStatus(uint32_t sensorHandle,
702                                  struct chreSensorSamplingStatus *status);
703 
704 /**
705  * Configures a given sensor at a specific interval and latency and mode.
706  *
707  * If this sensor's chreSensorInfo has isOneShot set to 1,
708  * then the mode must be one of the ONE_SHOT modes, or this method will fail.
709  *
710  * The CHRE wants to power as few sensors as possible, in keeping with its
711  * low power design.  As such, it only turns on sensors when there are clients
712  * actively interested in that sensor data, and turns off sensors as soon as
713  * there are no clients interested in them.  Calling this method generally
714  * indicates an interest, and using CHRE_SENSOR_CONFIGURE_MODE_DONE shows
715  * when we are no longer interested.
716  *
717  * Thus, each initial Configure of a sensor (per nanoapp) needs to eventually
718  * have a DONE call made, either directly or on its behalf.  Subsequent calls
719  * to a Configure method within the same nanoapp, when there has been no DONE
720  * in between, still only require a single DONE call.
721  *
722  * For example, the following is valid usage:
723  * <code>
724  *   chreSensorConfigure(myHandle, interval0, latency0, mode);
725  *   [...]
726  *   chreSensorConfigure(myHandle, interval1, latency0, mode);
727  *   [...]
728  *   chreSensorConfigure(myHandle, interval1, latency1, mode);
729  *   [...]
730  *   chreSensorConfigureModeOnly(myHandle, CHRE_SENSOR_CONFIGURE_MODE_DONE);
731  * </code>
732  *
733  * The first call to Configure is the one which creates the requirement
734  * to eventually call with DONE.  The subsequent calls are just changing the
735  * interval/latency.  They have not changed the fact that this nanoapp is
736  * still interested in output from the sensor 'myHandle'.  Thus, only one
737  * single call for DONE is needed.
738  *
739  * There is a special case.  One-shot sensors, sensors which
740  * just trigger a single event and never trigger again, implicitly go into
741  * DONE mode after that single event triggers.  Thus, the
742  * following are legitimate usages:
743  * <code>
744  *   chreSensorConfigure(myHandle, rate, latency, MODE_ONE_SHOT);
745  *   [...]
746  *   [myHandle triggers an event]
747  *   [no need to configure to DONE].
748  * </code>
749  *
750  * And:
751  * <code>
752  *   chreSensorConfigure(myHandle, rate, latency, MODE_ONE_SHOT);
753  *   [...]
754  *   chreSensorConfigureModeOnly(myHandle, MODE_DONE);
755  *   [we cancelled myHandle before it ever triggered an event]
756  * </code>
757  *
758  * Note that while PASSIVE modes, by definition, don't express
759  * an interest in powering the sensor, DONE is still necessary
760  * to silence the event reporting.
761  *
762  * @param sensorHandle  The handle to the sensor, as obtained from
763  *     chreSensorFindDefault().
764  * @param mode  The mode to use.  See descriptions within the
765  *     chreSensorConfigureMode enum.
766  * @param interval  The interval, in nanoseconds, at which we want events from
767  *     the sensor.  On success, the sensor will be set to 'interval', or a value
768  *     less than 'interval'.  There is a special value
769  *     CHRE_SENSOR_INTERVAL_DEFAULT, in which we don't express a preference for
770  *     the interval, and allow the sensor to chose what it wants.  Note that
771  *     due to batching, we may receive events less frequently than
772  *     'interval'.
773  * @param latency  The maximum latency, in nanoseconds, allowed before the
774  *     CHRE begins delivery of an event.  This will control how many events
775  *     can be queued by the sensor before requiring a delivery event.
776  *     Latency is defined as the "timestamp when event is queued by the CHRE"
777  *     minus "timestamp of oldest unsent data reading".
778  *     There is a special value CHRE_SENSOR_LATENCY_DEFAULT, in which we don't
779  *     express a preference for the latency, and allow the sensor to chose what
780  *     it wants.
781  *     Note that there is no assurance of how long it will take an event to
782  *     get through a CHRE's queueing system, and thus there is no ability to
783  *     request a minimum time from the occurrence of a phenomenon to when the
784  *     nanoapp receives the information.  The current CHRE API has no
785  *     real-time elements, although future versions may introduce some to
786  *     help with this issue.
787  * @returns true if the configuration succeeded, false otherwise.
788  *
789  * @see chreSensorConfigureMode
790  * @see chreSensorFindDefault
791  * @see chreSensorInfo
792  */
793 bool chreSensorConfigure(uint32_t sensorHandle,
794                          enum chreSensorConfigureMode mode,
795                          uint64_t interval, uint64_t latency);
796 
797 /**
798  * Short cut for chreSensorConfigure where we only want to change the mode.
799  *
800  * @see chreSensorConfigure
801  */
chreSensorConfigureModeOnly(uint32_t sensorHandle,enum chreSensorConfigureMode mode)802 inline bool chreSensorConfigureModeOnly(uint32_t sensorHandle,
803                                         enum chreSensorConfigureMode mode) {
804     return chreSensorConfigure(sensorHandle,
805                                mode,
806                                CHRE_SENSOR_INTERVAL_DEFAULT,
807                                CHRE_SENSOR_LATENCY_DEFAULT);
808 }
809 
810 
811 #ifdef __cplusplus
812 }
813 #endif
814 
815 #endif  /* _CHRE_SENSOR_H_ */
816 
817