ltr329/ltr329.h
2024-10-11 17:47:40 +02:00

116 lines
4.0 KiB
C

/*
* File: ltr329.h
* Description: Library for the Lite-On Optical Sensor LTR-329ALS-01
* Author: David Zaitlik
* Date: 2022-05-22
*
*
* Copyright (c) 2024 Veles Labs s.r.o.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
#ifndef INC_LTR329_H_
#define INC_LTR329_H_
#include "stdint.h"
#include "stm32l0xx_ll_i2c.h"
#include "stm32l0xx_ll_utils.h"
#include "i2c.h"
#define LTR329_I2C_ADDRESS 0x29
/*
* Return values
*/
#define LTR329_OK 0
#define LTR329_ERROR -1 // generic error
/* LTR-329ALS-01 Registers */
/* Datasheet: https://optoelectronics.liteon.com/upload/download/DS86-2014-0006/LTR-329ALS-01_DS_V1.pdf */
typedef enum
{
LTR329_ALS_CONTR = 0x80, /* RW */
LTR329_ALS_MEAS_RATE = 0x85, /* RW */
LTR329_PART_ID = 0x86, /* R */
LTR329_MANUFAC_ID = 0x87, /* R */
LTR329_ALS_DATA_CH1_0 = 0x88, /* R */
LTR329_ALS_DATA_CH1_1 = 0x89, /* R */
LTR329_ALS_DATA_CH0_0 = 0x8A, /* R */
LTR329_ALS_DATA_CH0_1 = 0x8B, /* R */
LTR329_ALS_STATUS = 0x8C /* R */
} ltr329_cmd_t;
/* Bit masks for ALS Mode */
typedef enum
{
LTR329_MODE_STAND_BY = 0b00000000, /* DEFAULT */
LTR329_MODE_ACTIVE = 0b00000001
} ltr329_als_mode_t;
/* Bit masks for Gain settings */
typedef enum
{
LTR329_GAIN_1X = 0b00000000, /* DEFAULT */
LTR329_GAIN_2X = 0b00000100,
LTR329_GAIN_4X = 0b00001000,
LTR329_GAIN_8X = 0b00001100,
LTR329_GAIN_48X = 0b00011000,
LTR329_GAIN_96X = 0b00011100,
LTR329_GAIN_RESERVED1 = 0b00010000,
LTR329_GAIN_RESERVED2 = 0b00010100
} ltr329_gain_t;
/* Bit masks for Integration Time settings */
typedef enum
{
LTR329_INTEGRATION_50MS = 0b00001000,
LTR329_INTEGRATION_100MS = 0b00000000, /* DEFAULT */
LTR329_INTEGRATION_150MS = 0b00100000,
LTR329_INTEGRATION_200MS = 0b00010000,
LTR329_INTEGRATION_250MS = 0b00101000,
LTR329_INTEGRATION_300MS = 0b00110000,
LTR329_INTEGRATION_350MS = 0b00111000,
LTR329_INTEGRATION_400MS = 0b00011000
} ltr329_integration_time_t;
/* Bit masks for Measurement Rate settings */
typedef enum
{
LTR329_MEAS_RATE_50MS = 0b00000000,
LTR329_MEAS_RATE_100MS = 0b00000001,
LTR329_MEAS_RATE_200MS = 0b00000010,
LTR329_MEAS_RATE_500MS = 0b00000011, /* DEFAULT */
LTR329_MEAS_RATE_1000MS = 0b00000100,
LTR329_MEAS_RATE_2000MS = 0b00000111
} ltr329_measurement_rate_t;
/*int8_t ltr329_read_register (ltr329_cmd_t register_addr, uint8_t *register_data );
int8_t ltr329_write_register (ltr329_cmd_t register_addr, uint8_t register_data);*/
int8_t ltr329_write_settings (ltr329_gain_t gain, ltr329_als_mode_t mode, ltr329_integration_time_t integ_time, ltr329_measurement_rate_t meas_rate);
int8_t ltr329_read_settings (ltr329_gain_t *gain, ltr329_als_mode_t *mode, ltr329_integration_time_t *integ_time, ltr329_measurement_rate_t *meas_rate);
int8_t ltr329_sw_reset( void );
int8_t ltr329_measure (uint16_t *data_ch0, uint16_t *data_ch1);
int8_t ltr329_read_status_register(uint8_t *data_valid, uint8_t *new_data, ltr329_gain_t *gain);
int8_t ltr329_read_device_info (uint8_t *manufacturer_id, uint8_t *part_id);
#endif /* INC_LTR329_H_ */