Sensor Manager API¶
The sensor manager API manages the sensors that are enabled in an
application. The API allows a sensor device to register itself with the
sensor manager and an application to look up the sensors that are
enabled. The sensor manager maintains a list of sensors, each
represented by a struct sensor
object defined in the the Sensor
API.
Registering Sensors¶
When the BSP or the sensor creator package creates a sensor device in
the kernel, via the os_dev_create()
function, the sensor device init
function must initialize a struct sensor
object and call the
sensor_mgr_register()
function to register itself with the sensor
manager.
Looking Up Sensors¶
An application uses the sensor manager API to look up the
struct sensor
object for a sensor. The sensor
API and the sensor
listener API
perform operations on a sensor object. The sensor manager API provides
the following sensor lookup functions:
sensor_mgr_find_next_bytype()
: This function returns the next sensor, on the sensors list, whose configured sensor types match one of the specified sensor types to search for. The sensor types to search are specified as a bit mask. You can use the function to search for the first sensor that matches or to iterate through the list and search for all sensors that match. If you are iterating through the list to find the next match, you must call thesensor_mgr_lock()
function to lock the sensors list before you start the iteration and call thesensor_mgr_unlock()
unlock the list when you are done. You do not need to lock the sensor list if you use the function to find the first match because thesensor_mgr_find_next_bytype()
locks the sensors list before the search.sensor_mgr_find_next_bydevname()
: This function returns the sensor that matches the specified device name.Note: There should only be one sensor that matches a specified device name even though the function name suggests that there can be multiple sensors with the same device name.
Checking Configured Sensor Types¶
An application may configure a sensor device to only support a subset of
supported sensor types. The sensor_mgr_match_bytype()
function
allows an application to check whether a sensor is configured for one of
the specified sensor types. The type to check is a bit mask and can
include multiple types. The function returns a match when there is a
match for one, not all, of the specified types in the bit mask.
Polling Sensors¶
The sensor manager implements a poller that reads sensor data from
sensors at specified poll rates. If an application configures a sensor
to be polled, using the sensor_set_poll_rate_ms()
function defined
in the sensor API, the
sensor manager poller will poll and read the configured sensor data from
the sensor at the specified interval.
The sensor manager poller uses an OS callout to set up a timer event to
poll the sensors, and uses the default OS event queue and the OS main
task to process timer events. The SENSOR_MGR_WAKEUP_RATE
syscfg
setting specifies the default wakeup rate the sensor manager poller
wakes up to poll sensors. The sensor manager poller uses the poll rate
for a sensor if the sensor is configured for a higher poll rate than the
SENSOR_MGR_WAKEUP_RATE
setting value.
Note: An application needs to register a sensor listener to receive the sensor data that the sensor manager poller reads from a sensor.
Data Structures¶
The sensor manager API uses the struct sensor
and sensor_type_t
types.
API¶
-
int
sensor_mgr_lock
(void)¶ Lock sensor manager to access the list of sensors.
-
void
sensor_mgr_unlock
(void)¶ Unlock sensor manager once the list of sensors has been accessed.
-
int
sensor_mgr_register
(struct sensor *sensor)¶ Register the sensor with the global sensor list.
This makes the sensor searchable by other packages, who may want to look it up by type.
- Return
0 on success, non-zero error code on failure.
- Parameters
sensor
: The sensor to register
-
struct os_eventq *
sensor_mgr_evq_get
(void)¶ Get the current eventq, the system is misconfigured if there is still no parent eventq.
- Return
Ptr OS eventq that the sensor mgr is set to
-
struct sensor *
sensor_mgr_find_next
(sensor_mgr_compare_func_t, void*, struct sensor*)¶ The sensor manager contains a list of sensors, this function returns the next sensor in that list, for which compare_func() returns successful (one).
If prev_cursor is provided, the function starts at that point in the sensor list.
@warn This function MUST be locked by sensor_mgr_lock/unlock() if the goal is to iterate through sensors (as opposed to just finding one.) As the “prev_cursor” may be resorted in the sensor list, in between calls.
- Return
A pointer to the first sensor found from prev_cursor, or NULL, if none found.
- Parameters
compare_func
: The comparison function to use against sensors in the list.arg
: The argument to provide to that comparison functionprev_cursor
: The previous sensor in the sensor manager list, in case of iteration. If desire is to find first matching sensor, provide a NULL value.
-
struct sensor *
sensor_mgr_find_next_bytype
(sensor_type_t type, struct sensor *sensor)¶ Find the “next” sensor available for a given sensor type.
If the sensor parameter, is present find the next entry from that parameter. Otherwise, find the first matching sensor.
- Return
A pointer to the sensor object matching that sensor type, or NULL if none found.
- Parameters
type
: The type of sensor to search forsensor
: The cursor to search from, or NULL to start from the beginning.
-
struct sensor *
sensor_mgr_find_next_bydevname
(char *devname, struct sensor *prev_cursor)¶ Search the sensor list and find the next sensor that corresponds to a given device name.
- Return
0 on success, non-zero error code on failure
- Parameters
devname
: The device name to search forsensor
: The previous sensor found with this device name
-
int
sensor_mgr_match_bytype
(struct sensor *sensor, void*)¶ Check if sensor type matches.
- Return
1 if matches, 0 if it doesn’t match.
- Parameters
sensor
: The sensor objectarg
: type to check
-
int
sensor_set_poll_rate_ms
(char *devname, uint32_t poll_rate)¶ Set the sensor poll rate.
- Parameters
devname
: Name of the sensorpoll_rate
: The poll rate in milli seconds
-
int
sensor_set_n_poll_rate
(char *devname, struct sensor_type_traits *stt)¶ Set the sensor poll rate multiple based on the device name, sensor type.
- Parameters
devname
: Name of the sensorstt
: The sensor type trait
-
int
sensor_oic_tx_trigger
(struct sensor *sensor, void *arg, sensor_type_t type)¶ Transmit OIC trigger.
- Return
0 on sucess, non-zero on failure
- Parameters
sensor
: Ptr to the sensorarg
: Ptr to sensor datatype
: The sensor type
-
void
sensor_trigger_init
(struct sensor *sensor, sensor_type_t type, sensor_trigger_notify_func_t notify)¶ Sensor trigger initialization.
- Parameters
sensor
: Ptr to the sensortype
: Sensor type to enable trigger fornotify
: the function to call if the trigger condition is satisfied
-
struct sensor_type_traits *
sensor_get_type_traits_bytype
(sensor_type_t type, struct sensor *sensor)¶ Search the sensor type traits list for specific type of sensor.
- Return
NULL when no sensor type is found, ptr to sensor_type_traits structure when found
- Parameters
type
: The sensor type to search forsensor
: Ptr to a sensor
-
struct sensor *
sensor_get_type_traits_byname
(char*, struct sensor_type_traits**, sensor_type_t)¶ Get the type traits for a sensor.
- Return
NULL on failure, sensor struct on success
- Parameters
devname
: Name of the sensorstt
: Ptr to sensor types trait structtype
: The sensor type
-
int
sensor_set_thresh
(char *devname, struct sensor_type_traits *stt)¶ Set the thresholds along with the comparison algo for a sensor.
- Return
0 on success, non-zero on failure
- Parameters
devname
: Name of the sensorstt
: Ptr to sensor type traits containing thresholds
-
int
sensor_clear_low_thresh
(char *devname, sensor_type_t type)¶ Clears the low threshold for a sensor.
- Return
0 on success, non-zero on failure
- Parameters
devname
: Name of the sensortype
: The sensor type
-
int
sensor_clear_high_thresh
(char *devname, sensor_type_t type)¶ Clears the high threshold for a sensor.
- Return
0 on success, non-zero on failure
- Parameters
devname
: Name of the sensortype
: The sensor type
-
void
sensor_mgr_put_notify_evt
(struct sensor_notify_ev_ctx *ctx, sensor_event_type_t evtype)¶ Puts a notification event on the sensor manager evq.
- Parameters
ctx
: Notification event contextevtype
: The notification event type
-
void
sensor_mgr_put_interrupt_evt
(struct sensor *sensor)¶ Puts a interrupt event on the sensor manager evq.
- Parameters
sensor
: Sensor Ptr as interrupt event context
-
void
sensor_mgr_put_read_evt
(void *arg)¶ Puts read event on the sensor manager evq.
- Parameters
arg
: Argument
-
char *
sensor_ftostr
(float, char*, int)¶ Convinience API to convert floats to strings, might loose some precision due to rounding.
- Parameters
num
: Floating point number to printfltstr
: Output float stringlen
: Length of the string to print
-
int
sensor_shell_register
(void)¶ API to register sensor shell.
-
void
sensor_oic_init
(void)¶ Iterates through the sensor list and initializes OIC resources based on each sensor type.