blob: 7a9d2e1ab0bc056263f2e4bc82105beb27d0a681 [file] [log] [blame]
/*
* Copyright (c) 2022 Esco Medical ApS
*
* SPDX-License-Identifier: Apache-2.0
*/
#ifndef ZEPHYR_DRIVERS_SENSOR_ICM42670_TRIGGER_H_
#define ZEPHYR_DRIVERS_SENSOR_ICM42670_TRIGGER_H_
#include <zephyr/device.h>
/** implement the trigger_set sensor api function */
int icm42670_trigger_set(const struct device *dev, const struct sensor_trigger *trig,
sensor_trigger_handler_t handler);
/**
* @brief initialize the icm42670 trigger system
*
* @param dev icm42670 device pointer
* @return int 0 on success, negative error code otherwise
*/
int icm42670_trigger_init(const struct device *dev);
/**
* @brief enable the trigger gpio interrupt
*
* @param dev icm42670 device pointer
* @return int 0 on success, negative error code otherwise
*/
int icm42670_trigger_enable_interrupt(const struct device *dev);
/**
* @brief lock access to the icm42670 device driver
*
* @param dev icm42670 device pointer
*/
void icm42670_lock(const struct device *dev);
/**
* @brief lock access to the icm42670 device driver
*
* @param dev icm42670 device pointer
*/
void icm42670_unlock(const struct device *dev);
#endif /* ZEPHYR_DRIVERS_SENSOR_ICM42670_TRIGGER_H_ */