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>
|
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
|
|
|
|
|
|
|
#include "kernel_types.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
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 {
|
|
|
|
gpio_t gpio_dev; /**< GPIO device which is used */
|
|
|
|
kernel_pid_t msg_thread_pid; /**< thread to msg on irq */
|
|
|
|
} pir_t;
|
|
|
|
|
2017-03-06 17:43:56 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief value to configure sensitivity of sensore
|
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
|
|
|
|
|
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 {
|
|
|
|
PIR_STATUS_HI = PIR_MSG_T_STATUS_START, /**< motion was detected */
|
|
|
|
PIR_STATUS_LO, /**< no motion is detected */
|
|
|
|
} 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
|
|
|
|
* @param[in] gpio the GPIO device the sensor is connected to
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
|
|
|
int pir_init(pir_t *dev, gpio_t gpio);
|
|
|
|
|
|
|
|
/**
|
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
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Register a thread for notification whan state changes on the
|
|
|
|
* 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
|
|
|
/** @} */
|