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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Test application for the PIR motion sensor driver
|
|
|
|
*
|
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
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PIR_GPIO
|
|
|
|
#error "PIR_GPIO not defined"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "thread.h"
|
2015-09-03 21:36:13 +02:00
|
|
|
#include "xtimer.h"
|
2014-09-24 19:33:12 +02:00
|
|
|
#include "pir.h"
|
|
|
|
|
2015-04-28 20:02:05 +02:00
|
|
|
char pir_handler_stack[THREAD_STACKSIZE_MAIN];
|
2014-09-24 19:33:12 +02:00
|
|
|
pir_t dev;
|
|
|
|
|
|
|
|
void* pir_handler(void *arg)
|
|
|
|
{
|
|
|
|
msg_t msg_q[1];
|
|
|
|
msg_init_queue(msg_q, 1);
|
|
|
|
|
|
|
|
printf("Registering PIR handler thread... %s\n",
|
|
|
|
pir_register_thread(&dev) == 0 ? "[OK]" : "[Failed]");
|
|
|
|
|
|
|
|
msg_t m;
|
|
|
|
while (msg_receive(&m)) {
|
|
|
|
printf("PIR handler got a message: ");
|
|
|
|
switch (m.type) {
|
|
|
|
case PIR_STATUS_HI:
|
|
|
|
puts("something started moving.");
|
|
|
|
break;
|
|
|
|
case PIR_STATUS_LO:
|
|
|
|
puts("the movement has ceased.");
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
puts("stray message.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
puts("PIR handler: this should not have happened!");
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("PIR motion sensor test application\n");
|
2015-07-06 14:15:27 +02:00
|
|
|
printf("Initializing PIR sensor at GPIO_%ld... ", (long)PIR_GPIO);
|
2014-09-24 19:33:12 +02:00
|
|
|
if (pir_init(&dev, PIR_GPIO) == 0) {
|
|
|
|
puts("[OK]\n");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
puts("[Failed]");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if TEST_PIR_POLLING
|
|
|
|
puts("Printing sensor state every second.");
|
|
|
|
while (1) {
|
|
|
|
printf("Status: %s\n", pir_get_status(&dev) == PIR_STATUS_LO ? "lo" : "hi");
|
2015-09-03 21:36:13 +02:00
|
|
|
xtimer_usleep(1000 * 1000);
|
2014-09-24 19:33:12 +02:00
|
|
|
}
|
|
|
|
#else
|
|
|
|
thread_create(
|
2015-04-28 20:02:05 +02:00
|
|
|
pir_handler_stack, sizeof(pir_handler_stack), THREAD_PRIORITY_MAIN - 1,
|
2015-12-02 12:00:37 +01:00
|
|
|
THREAD_CREATE_WOUT_YIELD | THREAD_CREATE_STACKTEST,
|
2014-09-24 19:33:12 +02:00
|
|
|
pir_handler, NULL, "pir_handler");
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|