blob: 3aef5fe6a367f0f0236f2aee1cc2c8c5da951c33 [file] [log] [blame]
/*
* Copyright (c) 2018 Intel Corporation
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/kernel.h>
#include <zephyr/drivers/gpio.h>
#include <zephyr/drivers/sensor.h>
#include "board.h"
#include "mesh.h"
#include <zephyr/bluetooth/mesh.h>
static const struct device *const dev_info[] = {
DEVICE_DT_GET_ONE(ti_hdc1010),
DEVICE_DT_GET_ONE(nxp_mma8652fc),
DEVICE_DT_GET_ONE(avago_apds9960),
DEVICE_DT_GET_ONE(solomon_ssd16xxfb),
};
int get_hdc1010_val(struct sensor_value *val)
{
if (sensor_sample_fetch(dev_info[DEV_IDX_HDC1010])) {
printk("Failed to fetch sample for device %s\n",
dev_info[DEV_IDX_HDC1010]->name);
return -1;
}
if (sensor_channel_get(dev_info[DEV_IDX_HDC1010],
SENSOR_CHAN_AMBIENT_TEMP, &val[0])) {
return -1;
}
if (sensor_channel_get(dev_info[DEV_IDX_HDC1010],
SENSOR_CHAN_HUMIDITY, &val[1])) {
return -1;
}
return 0;
}
int get_mma8652_val(struct sensor_value *val)
{
if (sensor_sample_fetch(dev_info[DEV_IDX_MMA8652])) {
printk("Failed to fetch sample for device %s\n",
dev_info[DEV_IDX_MMA8652]->name);
return -1;
}
if (sensor_channel_get(dev_info[DEV_IDX_MMA8652],
SENSOR_CHAN_ACCEL_XYZ, &val[0])) {
return -1;
}
return 0;
}
int get_apds9960_val(struct sensor_value *val)
{
if (sensor_sample_fetch(dev_info[DEV_IDX_APDS9960])) {
printk("Failed to fetch sample for device %s\n",
dev_info[DEV_IDX_APDS9960]->name);
return -1;
}
if (sensor_channel_get(dev_info[DEV_IDX_APDS9960],
SENSOR_CHAN_LIGHT, &val[0])) {
return -1;
}
if (sensor_channel_get(dev_info[DEV_IDX_APDS9960],
SENSOR_CHAN_PROX, &val[1])) {
return -1;
}
return 0;
}
#define MOTION_TIMEOUT K_MINUTES(30)
static struct k_work_delayable motion_work;
static void motion_timeout(struct k_work *work)
{
int err;
printk("power save\n");
if (!mesh_is_initialized()) {
k_work_schedule(&motion_work, MOTION_TIMEOUT);
return;
}
err = bt_mesh_suspend();
if (err && err != -EALREADY) {
printk("failed to suspend mesh (err %d)\n", err);
}
}
static void motion_handler(const struct device *dev,
const struct sensor_trigger *trig)
{
int err;
printk("motion!\n");
if (!mesh_is_initialized()) {
return;
}
err = bt_mesh_resume();
if (err && err != -EALREADY) {
printk("failed to resume mesh (err %d)\n", err);
}
k_work_reschedule(&motion_work, MOTION_TIMEOUT);
}
static void configure_accel(void)
{
const struct device *accel = dev_info[DEV_IDX_MMA8652];
struct sensor_trigger trig_motion = {
.type = SENSOR_TRIG_DELTA,
.chan = SENSOR_CHAN_ACCEL_XYZ,
};
int err;
err = sensor_trigger_set(accel, &trig_motion, motion_handler);
if (err) {
printk("setting motion trigger failed, err %d\n", err);
return;
}
k_work_init_delayable(&motion_work, motion_timeout);
k_work_schedule(&motion_work, MOTION_TIMEOUT);
}
int periphs_init(void)
{
unsigned int i;
/* Bind sensors */
for (i = 0U; i < ARRAY_SIZE(dev_info); i++) {
if (!device_is_ready(dev_info[i])) {
printk("%s: device not ready.\n", dev_info[i]->name);
return -ENODEV;
}
}
configure_accel();
return 0;
}