2014-09-24 19:33:12 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @defgroup drivers_pir PIR Motion Sensor
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_sensors
|
2014-09-24 19:33:12 +02:00
|
|
|
* @brief Device driver interface for the PIR motion sensor
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Device driver interface for the PIR motion sensor
|
|
|
|
*
|
2015-09-27 18:58:30 +02:00
|
|
|
* @author Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
2018-06-26 22:46:37 +02:00
|
|
|
* @author Hyung-Sin Kim <hs.kim@cs.berkeley.edu>
|
2014-09-24 19:33:12 +02:00
|
|
|
*/
|
|
|
|
|
2015-03-23 21:08:12 +01:00
|
|
|
#ifndef PIR_H
|
|
|
|
#define PIR_H
|
2014-09-24 19:33:12 +02:00
|
|
|
|
2020-11-20 13:56:48 +01:00
|
|
|
#include "sched.h"
|
2014-09-24 19:33:12 +02:00
|
|
|
#include "periph/gpio.h"
|
2018-06-26 22:46:37 +02:00
|
|
|
#include "stdbool.h"
|
2014-09-24 19:33:12 +02:00
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2018-06-26 22:46:37 +02:00
|
|
|
/**
|
|
|
|
* @brief PIR specific return values
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
PIR_OK = 0, /**< everything went as expected */
|
|
|
|
PIR_NOGPIO = -1, /**< errors while initializing the GPIO */
|
|
|
|
PIR_NOTHREAD = -2, /**< errors while registering the thread */
|
|
|
|
PIR_TIMEERR = -3, /**< errors while getting the time information */
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Parameters needed for device initialization
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
gpio_t gpio; /**< GPIO device which is used */
|
|
|
|
bool active_high; /**< Active when GPIO pin is high or not */
|
|
|
|
} pir_params_t;
|
|
|
|
|
|
|
|
|
2014-09-24 19:33:12 +02:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief device descriptor for a PIR sensor
|
2014-09-24 19:33:12 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2018-06-26 22:46:37 +02:00
|
|
|
uint64_t start_active_time; /**< Time when PIR starts to be active */
|
|
|
|
uint64_t accum_active_time; /**< Accumulated active time */
|
|
|
|
uint64_t last_read_time; /**< Last time when PIR status is read */
|
|
|
|
kernel_pid_t msg_thread_pid; /**< thread to msg on irq */
|
|
|
|
bool active; /**< Indicate PIR is active or not */
|
|
|
|
pir_params_t p; /**< Configuration parameters */
|
2014-09-24 19:33:12 +02:00
|
|
|
} pir_t;
|
|
|
|
|
2017-03-06 17:43:56 +01:00
|
|
|
/**
|
2020-04-06 08:51:47 +02:00
|
|
|
* @defgroup drivers_pir_config PIR Motion Sensor driver compile configuration
|
|
|
|
* @ingroup config_drivers_sensors
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief Sensitivity of sensor
|
2017-03-06 17:43:56 +01:00
|
|
|
*/
|
2014-09-24 19:33:12 +02:00
|
|
|
#ifndef PIR_MSG_T_STATUS_START
|
|
|
|
#define PIR_MSG_T_STATUS_START 150
|
|
|
|
#endif
|
2020-04-06 08:51:47 +02:00
|
|
|
/** @} */
|
2014-09-24 19:33:12 +02:00
|
|
|
|
2017-03-06 17:43:56 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief event type for a PIR sensor
|
2017-03-06 17:43:56 +01:00
|
|
|
*/
|
2014-09-24 19:33:12 +02:00
|
|
|
typedef enum {
|
2018-06-26 22:46:37 +02:00
|
|
|
PIR_STATUS_ACTIVE = PIR_MSG_T_STATUS_START, /**< motion was detected */
|
|
|
|
PIR_STATUS_INACTIVE, /**< no motion is detected */
|
2014-09-24 19:33:12 +02:00
|
|
|
} pir_event_t;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Initialize a PIR motion sensor
|
2014-09-24 19:33:12 +02:00
|
|
|
*
|
|
|
|
* The PIR motion sensor is interfaced by a single GPIO pin, specified by
|
|
|
|
* `gpio`.
|
|
|
|
*
|
|
|
|
* @note
|
|
|
|
* The sensor needs up to a minute to settle down before meaningful
|
|
|
|
* measurements can be made.
|
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor of an PIR sensor
|
2018-06-26 22:46:37 +02:00
|
|
|
* @param[in] params parameters of the PIR sensor
|
2014-09-24 19:33:12 +02:00
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2018-06-26 22:46:37 +02:00
|
|
|
int pir_init(pir_t *dev, const pir_params_t* params);
|
2014-09-24 19:33:12 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Read the current status of the motion sensor
|
2014-09-24 19:33:12 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of the PIR motion sensor to read from
|
|
|
|
*
|
|
|
|
* @return 1 if motion is detected, 0 otherwise
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
pir_event_t pir_get_status(const pir_t *dev);
|
2014-09-24 19:33:12 +02:00
|
|
|
|
2018-06-26 22:46:37 +02:00
|
|
|
/**
|
|
|
|
* @brief Read OCCUPANCY value
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of the PIR motion sensor to read from
|
|
|
|
* @param[out] occup occupancy ratio [in 100 * percentage]
|
|
|
|
* The value is renewed when it is read. So it is percentage
|
|
|
|
* of occupancy since the last read.
|
|
|
|
*
|
|
|
|
* @return 0 on success,
|
|
|
|
* @return -1 on errors,
|
|
|
|
*/
|
|
|
|
int pir_get_occupancy(pir_t *dev, int16_t *occup);
|
|
|
|
|
2014-09-24 19:33:12 +02:00
|
|
|
/**
|
2020-10-02 08:06:16 +02:00
|
|
|
* @brief Register a thread for notification when state changes on the
|
2014-09-24 19:33:12 +02:00
|
|
|
* motion sensor.
|
|
|
|
*
|
|
|
|
* @note
|
|
|
|
* This configures the gpio device for interrupt driven operation.
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of the PIR motion sensor to
|
|
|
|
* register for
|
|
|
|
*
|
|
|
|
* @return 0 on succuess,
|
|
|
|
* @return -1 on internal errors,
|
|
|
|
* @return -2 if another thread is registered already
|
|
|
|
*/
|
|
|
|
int pir_register_thread(pir_t *dev);
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-03-23 21:08:12 +01:00
|
|
|
#endif /* PIR_H */
|
2014-09-24 19:33:12 +02:00
|
|
|
/** @} */
|