/* * Copyright (c) 2015, Zolertia - http://www.zolertia.com * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the Institute nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * */ /*---------------------------------------------------------------------------*/ /** * \addtogroup zoul-examples * @{ * * \defgroup zoul-tsl2563-test TSL2563 light sensor test * * Demonstrates the use of the TSL2563 digital ambient light sensor * @{ * * \file * Driver for the external TSL2563 light sensor * * \author * Antonio Lignan * Toni Lozano */ /*---------------------------------------------------------------------------*/ #include #include "contiki.h" #include "dev/i2c.h" #include "dev/leds.h" #include "dev/tsl2563.h" /*---------------------------------------------------------------------------*/ /* Default sensor's integration cycle is 402ms */ #define SENSOR_READ_INTERVAL (CLOCK_SECOND) /*---------------------------------------------------------------------------*/ PROCESS(remote_tsl2563_process, "TSL2563 test process"); AUTOSTART_PROCESSES(&remote_tsl2563_process); /*---------------------------------------------------------------------------*/ static struct etimer et; /*---------------------------------------------------------------------------*/ void light_interrupt_callback(uint8_t value) { printf("* Light sensor interrupt!\n"); leds_toggle(LEDS_PURPLE); } /*---------------------------------------------------------------------------*/ PROCESS_THREAD(remote_tsl2563_process, ev, data) { PROCESS_BEGIN(); static uint16_t light; /* Use Contiki's sensor macro to enable the sensor */ SENSORS_ACTIVATE(tsl2563); /* Default integration time is 402ms with 1x gain, use the below call to * change the gain and timming, see tsl2563.h for more options */ /* tsl2563.configure(TSL2563_TIMMING_CFG, TSL2563_G16X_402MS); */ /* Register the interrupt handler */ TSL2563_REGISTER_INT(light_interrupt_callback); /* Enable the interrupt source for values over the threshold. The sensor * compares against the value of CH0, one way to find out the required * threshold for a given lux quantity is to enable the DEBUG flag and see * the CH0 value for a given measurement. The other is to reverse the * calculations done in the calculate_lux() function. The below value roughly * represents a 2500 lux threshold, same as pointing a flashlight directly */ tsl2563.configure(TSL2563_INT_OVER, 0x15B8); /* And periodically poll the sensor */ while(1) { etimer_set(&et, SENSOR_READ_INTERVAL); PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et)); light = tsl2563.value(TSL2563_VAL_READ); if(light != TSL2563_ERROR) { printf("Light = %u\n", (uint16_t)light); } else { printf("Error, enable the DEBUG flag in the tsl2563 driver for info, "); printf("or check if the sensor is properly connected\n"); } } PROCESS_END(); } /*---------------------------------------------------------------------------*/ /** * @} * @} */