mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
208 lines
8.0 KiB
C
208 lines
8.0 KiB
C
|
/*
|
||
|
* Copyright (C) 2016-2018 Inria
|
||
|
*
|
||
|
* 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 drivers_si114x
|
||
|
* @brief Internal addresses, registers, constants for the Si114x sensors family.
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Internal addresses, registers, constants for the Si114x sensor.
|
||
|
*
|
||
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
||
|
*/
|
||
|
|
||
|
#ifndef SI114X_INTERNALS_H
|
||
|
#define SI114X_INTERNALS_H
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief Si114x I2C address
|
||
|
*/
|
||
|
#define SI114X_ADDR (0x60)
|
||
|
|
||
|
/**
|
||
|
* @name Si114x commands
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI114X_PARAM_QUERY (0x80)
|
||
|
#define SI114X_PARAM_SET (0xA0)
|
||
|
#define SI114X_NOP (0x00)
|
||
|
#define SI114X_RESET (0x01)
|
||
|
#define SI114X_BUSADDR (0x02)
|
||
|
#define SI114X_PS_FORCE (0x05)
|
||
|
#define SI114X_ALS_FORCE (0x06)
|
||
|
#define SI114X_PS_ALS_FORCE (0x07)
|
||
|
#define SI114X_PS_PAUSE (0x09)
|
||
|
#define SI114X_ALS_PAUSE (0x0A)
|
||
|
#define SI114X_PS_ALS_PAUSE (0x0B)
|
||
|
#define SI114X_PS_AUTO (0x0D)
|
||
|
#define SI114X_ALS_AUTO (0x0E)
|
||
|
#define SI114X_PS_ALS_AUTO (0x0F)
|
||
|
#define SI114X_GET_CAL (0x12)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Si114x registers
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI114X_REG_PART_ID (0x00)
|
||
|
#define SI114X_REG_REV_ID (0x01)
|
||
|
#define SI114X_REG_SEQ_ID (0x02)
|
||
|
#define SI114X_REG_INT_CFG (0x03)
|
||
|
#define SI114X_REG_IRQ_ENABLE (0x04)
|
||
|
#define SI114X_REG_IRQ_MODE1 (0x05)
|
||
|
#define SI114X_REG_IRQ_MODE2 (0x06)
|
||
|
#define SI114X_REG_HW_KEY (0x07)
|
||
|
#define SI114X_REG_MEAS_RATE0 (0x08)
|
||
|
#define SI114X_REG_MEAS_RATE1 (0x09)
|
||
|
#define SI114X_REG_PS_LED21 (0x0F)
|
||
|
#define SI114X_REG_PS_LED3 (0x10)
|
||
|
#define SI114X_REG_UCOEF0 (0x13)
|
||
|
#define SI114X_REG_UCOEF1 (0x14)
|
||
|
#define SI114X_REG_UCOEF2 (0x15)
|
||
|
#define SI114X_REG_UCOEF3 (0x16)
|
||
|
#define SI114X_REG_PARAM_WR (0x17)
|
||
|
#define SI114X_REG_COMMAND (0x18)
|
||
|
#define SI114X_REG_RESPONSE (0x20)
|
||
|
#define SI114X_REG_IRQ_STATUS (0x21)
|
||
|
#define SI114X_REG_ALS_VIS_DATA0 (0x22)
|
||
|
#define SI114X_REG_ALS_VIS_DATA1 (0x23)
|
||
|
#define SI114X_REG_ALS_IR_DATA0 (0x24)
|
||
|
#define SI114X_REG_ALS_IR_DATA1 (0x25)
|
||
|
#define SI114X_REG_PS1_DATA0 (0x26)
|
||
|
#define SI114X_REG_PS1_DATA1 (0x27)
|
||
|
#define SI114X_REG_PS2_DATA0 (0x28)
|
||
|
#define SI114X_REG_PS2_DATA1 (0x29)
|
||
|
#define SI114X_REG_PS3_DATA0 (0x2A)
|
||
|
#define SI114X_REG_PS3_DATA1 (0x2B)
|
||
|
#define SI114X_REG_UV_INDEX0 (0x2C)
|
||
|
#define SI114X_REG_UV_INDEX1 (0x2D)
|
||
|
#define SI114X_REG_PARAM_RD (0x2E)
|
||
|
#define SI114X_REG_CHIP_STAT (0x30)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Si114x response register error codes
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI114X_NO_ERROR (0x00)
|
||
|
#define SI114X_INVALID_SETTING (0x80)
|
||
|
#define SI114X_PS1_ADC_OVERFLOW (0x88)
|
||
|
#define SI114X_PS2_ADC_OVERFLOW (0x89)
|
||
|
#define SI114X_PS3_ADC_OVERFLOW (0x8A)
|
||
|
#define SI114X_ALS_VIS_ADC_OVERFLOW (0x8C)
|
||
|
#define SI114X_ALS_IR_ADC_OVERFLOW (0x8D)
|
||
|
#define SI114X_UV_ADC_OVERFLOW (0x8E)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Si114x parameters RAM
|
||
|
*
|
||
|
* @note These parameter can be accessed indirectly using PARAM_QUERY or
|
||
|
* PARAM_SET commands.
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI114X_I2C_ADDR (0x00)
|
||
|
#define SI114X_PARAM_CHLIST (0x01)
|
||
|
#define SI114X_PARAM_CHLIST_ENUV (0x80)
|
||
|
#define SI114X_PARAM_CHLIST_ENAUX (0x40)
|
||
|
#define SI114X_PARAM_CHLIST_ENALSIR (0x20)
|
||
|
#define SI114X_PARAM_CHLIST_ENALSVIS (0x10)
|
||
|
#define SI114X_PARAM_CHLIST_ENPS1 (0x01)
|
||
|
#define SI114X_PARAM_CHLIST_ENPS2 (0x02)
|
||
|
#define SI114X_PARAM_CHLIST_ENPS3 (0x04)
|
||
|
#define SI114X_PARAM_PSLED12SEL (0x02)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS2NONE (0x00)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS2LED1 (0x10)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS2LED2 (0x20)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS2LED3 (0x40)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS1NONE (0x00)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS1LED1 (0x01)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS1LED2 (0x02)
|
||
|
#define SI114X_PARAM_PSLED12SEL_PS1LED3 (0x04)
|
||
|
#define SI114X_PARAM_PSLED3SEL (0x03)
|
||
|
#define SI114X_PARAM_PSENCODE (0x05)
|
||
|
#define SI114X_PARAM_ALSENCODE (0x06)
|
||
|
#define SI114X_PARAM_PS1ADCMUX (0x07)
|
||
|
#define SI114X_PARAM_PS2ADCMUX (0x08)
|
||
|
#define SI114X_PARAM_PS3ADCMUX (0x09)
|
||
|
#define SI114X_PARAM_PSADCOUNTER (0x0A)
|
||
|
#define SI114X_PARAM_PSADCGAIN (0x0B)
|
||
|
#define SI114X_PARAM_PSADCMISC (0x0C)
|
||
|
#define SI114X_PARAM_PSADCMISC_RANGE (0x20)
|
||
|
#define SI114X_PARAM_PSADCMISC_PSMODE (0x04)
|
||
|
#define SI114X_PARAM_ALSIRADCMUX (0x0E)
|
||
|
#define SI114X_PARAM_AUXADCMUX (0x0F)
|
||
|
#define SI114X_PARAM_ALSVISADCOUNTER (0x10)
|
||
|
#define SI114X_PARAM_ALSVISADCGAIN (0x11)
|
||
|
#define SI114X_PARAM_ALSVISADCMISC (0x12)
|
||
|
#define SI114X_PARAM_ALSVISADCMISC_VISRANGE (0x20)
|
||
|
#define SI114X_PARAM_ALSIRADCOUNTER (0x1D)
|
||
|
#define SI114X_PARAM_ALSIRADCGAIN (0x1E)
|
||
|
#define SI114X_PARAM_ALSIRADCMISC (0x1F)
|
||
|
#define SI114X_PARAM_ALSIRADCMISC_RANGE (0x20)
|
||
|
#define SI114X_PARAM_ADCMUX_SMALLIR (0x00)
|
||
|
#define SI114X_PARAM_ADCMUX_LARGEIR (0x03)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Si114x constants
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI1145_ID (0x45)
|
||
|
#define SI1146_ID (0x46)
|
||
|
#define SI1147_ID (0x47)
|
||
|
#define SI114X_STARTUP_TIME (25000UL) /* 25ms */
|
||
|
#define SI114X_WAIT_10MS (10000UL) /* 10ms */
|
||
|
#define SI114X_INIT_VALUE (0x17)
|
||
|
#define SI114X_UCOEF0_DEFAULT (0x29)
|
||
|
#define SI114X_UCOEF1_DEFAULT (0x89)
|
||
|
#define SI114X_UCOEF2_DEFAULT (0x02)
|
||
|
#define SI114X_UCOEF3_DEFAULT (0x00)
|
||
|
#define SI114X_ADC_REC_CLK (0x70) /* 511 ADC Clock */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Si114x register bits
|
||
|
* @{
|
||
|
*/
|
||
|
#define SI114X_EN_UV (0x80)
|
||
|
#define SI114X_EN_AUX (0x40)
|
||
|
#define SI114X_EN_ALS_IR (0x20)
|
||
|
#define SI114X_EN_ALS_VIS (0x10)
|
||
|
|
||
|
#define SI114X_EN_PS3_IE (0x10)
|
||
|
#define SI114X_EN_PS2_IE (0x08)
|
||
|
#define SI114X_EN_PS1_IE (0x04)
|
||
|
#define SI114X_EN_ALS_IE (0x01)
|
||
|
|
||
|
#define SI114X_INTCFG_INTOE (0x01)
|
||
|
#define SI114X_INTCFG_INTMODE (0x02)
|
||
|
|
||
|
#define SI114X_PS3_ALIGN (0x40)
|
||
|
#define SI114X_PS2_ALIGN (0x20)
|
||
|
#define SI114X_PS1_ALIGN (0x10)
|
||
|
#define SI114X_ALS_IR_ALIGN (0x20)
|
||
|
#define SI114X_ALS_VIS_ALIGN (0x10)
|
||
|
#define SI114X_PS_RANGE (0x20)
|
||
|
#define SI114X_PS_ADC_MODE (0x04)
|
||
|
#define SI114X_VIS_RANGE (0x20)
|
||
|
#define SI114X_IR_RANGE (0x20)
|
||
|
/** @} */
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* SI114X_INTERNALS_H */
|
||
|
/** @} */
|