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