2015-05-01 15:33:27 +02:00
|
|
|
/*
|
2015-09-27 18:58:30 +02:00
|
|
|
* Copyright 2015 Ludwig Knüpfer
|
2016-11-14 13:39:21 +01:00
|
|
|
* Copyright 2017 HAW Hamburg
|
2015-05-01 15:33:27 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-11-19 17:13:33 +01:00
|
|
|
* @defgroup drivers_isl29125 ISL29125 RGB light sensor
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_sensors
|
2015-05-01 15:33:27 +02:00
|
|
|
* @brief Device driver for the ISL29125 RGB light sensor
|
|
|
|
*
|
|
|
|
* ## Description
|
|
|
|
*
|
|
|
|
* The device supports level conversion in 12, and 16 bit depth per
|
|
|
|
* channel. Selecting a higher precision results in a longer
|
|
|
|
* conversion time.
|
|
|
|
*
|
|
|
|
* The driver uses the @ref color_rgb_t color definition from @ref
|
|
|
|
* color.h for value representation. It does not depend on the color
|
|
|
|
* module however.
|
|
|
|
*
|
|
|
|
* ## Usage
|
|
|
|
*
|
|
|
|
* Examine `tests/driver_isr29125` for an exemplary application using
|
|
|
|
* this driver.
|
|
|
|
*
|
|
|
|
* ## Caveats
|
|
|
|
*
|
|
|
|
* A GPIO pin definition has been included in the interface for future
|
|
|
|
* compatibility only.
|
|
|
|
* - The driver does not support SYNC mode at the moment.
|
|
|
|
* - The driver supports polling only, i.e. interrupt mode is
|
|
|
|
* currently not supported.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Device driver interface for the ISL29125 RGB light sensor
|
|
|
|
*
|
2015-09-27 18:58:30 +02:00
|
|
|
* @author Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de
|
2016-11-14 13:39:21 +01:00
|
|
|
* @author Martin Heusmann <martin.heusmann@haw-hamburg.de>
|
|
|
|
* @author Cenk Gündoğan <mail-github@cgundogan.de>
|
2015-05-01 15:33:27 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ISL29125_H
|
|
|
|
#define ISL29125_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
#include "color.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief data type for storing lux RGB sensor readings
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
float red; /**< red lux value */
|
|
|
|
float green; /**< green lux value */
|
|
|
|
float blue; /**< blue lux value */
|
|
|
|
} isl29125_rgb_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief supported operation modes of the ISL29125 sensor's AD
|
|
|
|
* conversion
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_MODE_DOWN = 0x00, /**< ADC powered down */
|
|
|
|
ISL29125_MODE_STANDBY = 0x04, /**< AD conversion not performed */
|
|
|
|
ISL29125_MODE_RGB = 0x05, /**< RGB conversion */
|
|
|
|
ISL29125_MODE_R = 0x02, /**< red conversion only */
|
|
|
|
ISL29125_MODE_G = 0x01, /**< green conversion only */
|
|
|
|
ISL29125_MODE_B = 0x03, /**< blue conversion only */
|
|
|
|
ISL29125_MODE_RG = 0x06, /**< red and green conversion only */
|
|
|
|
ISL29125_MODE_GB = 0x07 /**< green and blue conversion only */
|
|
|
|
} isl29125_mode_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief supported RGB sensing range values of the ISL29125 sensor
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_RANGE_375 = 0x00, /**< range: 5.7m - 375 lux */
|
|
|
|
ISL29125_RANGE_10K = 0x08 /**< range: 0.152 - 10,000 lux */
|
|
|
|
} isl29125_range_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief supported color resolutions of the ISL29125 sensor's AD
|
|
|
|
* conversion
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_RESOLUTION_12 = 0x10, /**< resolution: 12 bit */
|
|
|
|
ISL29125_RESOLUTION_16 = 0x00 /**< resolution: 16 bit */
|
|
|
|
} isl29125_resolution_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device descriptor for ISL29125 sensors
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
i2c_t i2c; /**< I2C device the sensor is connected to */
|
|
|
|
gpio_t gpio; /**< GPIO pin for interrupt/sync mode */
|
|
|
|
isl29125_range_t range; /**< sensor range */
|
|
|
|
isl29125_resolution_t res; /**< sensor resolution */
|
|
|
|
} isl29125_t;
|
|
|
|
|
2016-11-14 13:39:21 +01:00
|
|
|
/**
|
|
|
|
* @brief Configuration-3 Register 0x03 B1:0
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_INTERRUPT_STATUS_NONE = 0x00, /**< No interrupt */
|
|
|
|
ISL29125_INTERRUPT_STATUS_GREEN = 0x01, /**< GREEN interrupt */
|
|
|
|
ISL29125_INTERRUPT_STATUS_RED = 0x02, /**< RED interrupt */
|
|
|
|
ISL29125_INTERRUPT_STATUS_BLUE = 0x03 /**< BLUE interrupt */
|
|
|
|
} isl29125_interrupt_status_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Configuration-3 Register 0x03 B3:2
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_INTERRUPT_PERSIST_1 = (0x00 << 2), /**< Int. Persist: Number of integration cycle 1 */
|
|
|
|
ISL29125_INTERRUPT_PERSIST_2 = (0x01 << 2), /**< Int. Persist: Number of integration cycle 2 */
|
|
|
|
ISL29125_INTERRUPT_PERSIST_4 = (0x02 << 2), /**< Int. Persist: Number of integration cycle 4 */
|
|
|
|
ISL29125_INTERRUPT_PERSIST_8 = (0x03 << 2) /**< Int. Persist: Number of integration cycle 8 */
|
|
|
|
} isl29125_interrupt_persist_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Configuration-3 Register 0x03 B4
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
ISL29125_INTERRUPT_CONV_DIS = (0x0 << 4), /**< RGB Conversion done to ~INT Control disable */
|
|
|
|
ISL29125_INTERRUPT_CONV_EN = (0x1 << 4), /**< RGB Conversion done to ~INT Control enable */
|
|
|
|
} isl29125_interrupt_conven_t;
|
|
|
|
|
2015-05-01 15:33:27 +02:00
|
|
|
/**
|
|
|
|
* @brief initialize a new ISL29125 device
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
* @param[in] i2c I2C device the sensor is connected to
|
|
|
|
* @param[in] gpio GPIO pin for interrupt/sync mode (currently unused)
|
|
|
|
* @param[in] mode operation mode
|
|
|
|
* @param[in] range measurement range
|
|
|
|
* @param[in] resolution AD conversion resolution
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
|
|
|
int isl29125_init(isl29125_t *dev, i2c_t i2c, gpio_t gpio,
|
2015-05-12 07:25:54 +02:00
|
|
|
isl29125_mode_t mode, isl29125_range_t range,
|
|
|
|
isl29125_resolution_t resolution);
|
2015-05-01 15:33:27 +02:00
|
|
|
|
2016-11-14 13:39:21 +01:00
|
|
|
/**
|
|
|
|
* @brief initialize interrupts
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
* @param[in] interrupt_status Interrupt status
|
|
|
|
* @param[in] interrupt_persist Interrupt persistency
|
|
|
|
* @param[in] interrupt_conven RGB conversion done to interrupt control, enable
|
|
|
|
* @param[in] lower_threshold Lower interrupt threshold
|
|
|
|
* @param[in] higher_threshold Higher interrupt threshold
|
|
|
|
* @param[in] cb Callback function on interrupts
|
|
|
|
* @param[in] arg Argument passed to the callback function
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
|
|
|
int isl29125_init_int(isl29125_t *dev, isl29125_interrupt_status_t interrupt_status,
|
|
|
|
isl29125_interrupt_persist_t interrupt_persist,
|
|
|
|
isl29125_interrupt_conven_t interrupt_conven,
|
|
|
|
uint16_t lower_threshold, uint16_t higher_threshold,
|
|
|
|
gpio_cb_t cb, void *arg);
|
|
|
|
|
2015-05-01 15:33:27 +02:00
|
|
|
/**
|
|
|
|
* @brief read RGB values from device
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
* @param[in] dest pointer to lux RGB color object data is written to
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
void isl29125_read_rgb_lux(const isl29125_t *dev, isl29125_rgb_t *dest);
|
2015-05-01 15:33:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief read color values from device
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
* @param[in] dest pointer to RGB color object data is written to
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
void isl29125_read_rgb_color(const isl29125_t *dev, color_rgb_t *dest);
|
2015-05-01 15:33:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief set the device's operation mode
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
* @param[in] mode operation mode
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
void isl29125_set_mode(const isl29125_t *dev, isl29125_mode_t mode);
|
2015-05-01 15:33:27 +02:00
|
|
|
|
2016-11-14 13:39:21 +01:00
|
|
|
/**
|
|
|
|
* @brief read isl29125 interrupt status
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an ISL29125 device
|
|
|
|
*
|
|
|
|
* @return interrupt status
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int isl29125_read_irq_status(const isl29125_t *dev);
|
2016-11-14 13:39:21 +01:00
|
|
|
|
2015-05-01 15:33:27 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* ISL29125_H */
|
|
|
|
/** @} */
|