Loading...
Searching...
No Matches
vl6180x.h
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2021 Gunar Schorcht
3 * SPDX-License-Identifier: LGPL-2.1-only
4 */
5
6#pragma once
7
391
392#ifdef __cplusplus
393extern "C"
394{
395#endif
396
397#include <stdbool.h>
398#include <stdint.h>
399
400#include "modules.h"
401#include "periph/gpio.h"
402#include "periph/i2c.h"
403
404#include "vl6180x_regs.h"
405
406#define VL6180X_I2C_ADDR (0x29)
407
421
435
455
464
495
509typedef struct {
510#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
512#endif
513#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
515#endif
517
532typedef struct {
533#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
534 uint8_t rng_high;
535 uint8_t rng_low;
536#endif
537#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
538 uint16_t als_high;
539 uint16_t als_low;
540#endif
542
546typedef struct {
551 unsigned i2c_dev;
552 uint8_t i2c_addr;
553
554#if IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN
556#endif /* IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN */
557
558#if IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN
559 gpio_t int_pin;
562#endif /* IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN */
563
565
585 uint8_t period;
586
587#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
592 uint8_t rng_max_time;
596#endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
597
598#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
603 uint16_t als_int_time;
605 uint16_t als_lux_res;
611#endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
612
614
618typedef struct {
619
622#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
624#endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
625#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
627#endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
628} vl6180x_t;
629
650int vl6180x_init(vl6180x_t *dev, const vl6180x_params_t *params);
651
673
693
694#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
710
732int vl6180x_rng_read(vl6180x_t *dev, uint8_t *mm);
733
743
758
759#if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
790int vl6180x_rng_config(vl6180x_t *dev, uint8_t period, uint8_t max_time);
791
792#endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
793#endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
794
795#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
809
842int vl6180x_als_read(vl6180x_t *dev, uint16_t *raw, uint16_t *lux);
843
853
868
869#if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
901int vl6180x_als_config(vl6180x_t *dev, uint8_t period, uint8_t int_time,
902 vl6180x_als_gain_t gain);
903
904#endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
905#endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
906
907#if IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN
924
941
942#endif /* IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN */
943
944#if IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN
945
977
1002
1003#if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
1019
1020#endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
1021#endif /* IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN */
1022
1027
1046 uint16_t reg, const uint8_t *data, uint8_t len);
1047
1066 uint16_t reg, uint8_t *data, uint8_t len);
1068#ifdef __cplusplus
1069}
1070#endif
1071
Low-level GPIO peripheral driver interface definitions.
int vl6180x_rng_read(vl6180x_t *dev, uint8_t *mm)
Read one ranging data sample in mm.
vl6180x_rng_status_t vl6180x_rng_status(const vl6180x_t *dev)
Get status of last range measurement.
int vl6180x_int_enable(vl6180x_t *dev, vl6180x_int_config_t mode)
Enable and disable interrupts.
int vl6180x_reg_read(const vl6180x_t *dev, uint16_t reg, uint8_t *data, uint8_t len)
Direct read from register.
vl6180x_als_status_t
Ambient light sensing (ALS) status.
Definition vl6180x.h:459
int vl6180x_int_config(vl6180x_t *dev, vl6180x_int_thresh_t thresh)
Configure thresholds for event interrupts at runtime.
int vl6180x_start_cont(vl6180x_t *dev)
Start measurements in continuous mode.
int vl6180x_als_data_ready(const vl6180x_t *dev)
ALS data ready status function.
vl6180x_als_status_t vl6180x_als_status(const vl6180x_t *dev)
Get status of last ALS measurement.
int vl6180x_stop_cont(vl6180x_t *dev)
Stop measurements in continuous mode.
int vl6180x_als_read(vl6180x_t *dev, uint16_t *raw, uint16_t *lux)
Read one ambient light sensing (ALS) data sample.
int vl6180x_int_wait(const vl6180x_t *dev, vl6180x_int_config_t *src)
Wait for configured interrupts and return the interrupt sources.
int vl6180x_power_up(vl6180x_t *dev)
Power down the sensor.
int vl6180x_als_start_single(const vl6180x_t *dev)
Start a single-shot ALS measurement.
vl6180x_int_mode_t
Interrupt mode.
Definition vl6180x.h:482
int vl6180x_rng_config(vl6180x_t *dev, uint8_t period, uint8_t max_time)
Reconfigure range measurements at runtime.
int vl6180x_rng_start_single(const vl6180x_t *dev)
Start a single-shot range measurement.
vl6180x_als_gain_t
Analogue gain for ALS measurements.
Definition vl6180x.h:425
int vl6180x_reg_write(const vl6180x_t *dev, uint16_t reg, const uint8_t *data, uint8_t len)
Direct write to register.
int vl6180x_rng_data_ready(const vl6180x_t *dev)
Range data ready status function.
int vl6180x_init(vl6180x_t *dev, const vl6180x_params_t *params)
Initialize the VL6180X sensor device.
vl6180x_error_t
Error codes.
Definition vl6180x.h:411
int vl6180x_als_config(vl6180x_t *dev, uint8_t period, uint8_t int_time, vl6180x_als_gain_t gain)
Reconfigure ambient light sensing (ALS) during runtime.
vl6180x_rng_status_t
Range measurement status.
Definition vl6180x.h:439
int vl6180x_power_down(const vl6180x_t *dev)
Power down the sensor.
@ VL6180X_ALS_OVERFLOW
ALS measurement overflow.
Definition vl6180x.h:461
@ VL6180X_ALS_UNDERFLOW
ALS measurement underflow.
Definition vl6180x.h:462
@ VL6180X_ALS_OK
No error.
Definition vl6180x.h:460
@ VL6180X_INT_LOW
Interrupt is triggered when values are below the lower threshold.
Definition vl6180x.h:485
@ VL6180X_INT_DRDY
Interrupt is triggered when new data are ready to be read.
Definition vl6180x.h:492
@ VL6180X_INT_HIGH
Interrupt is triggered when values are above the upper threshold.
Definition vl6180x.h:487
@ VL6180X_INT_NONE
Interrupt is disabled.
Definition vl6180x.h:483
@ VL6180X_INT_OUT
Interrupt is triggered when values are below the lower threshold or above the upper threshold (value ...
Definition vl6180x.h:489
@ VL6180X_ALS_GAIN_5
5 x gain (actual analogue gain of 5.21)
Definition vl6180x.h:428
@ VL6180X_ALS_GAIN_2_5
2.5 x gain (actual analogue gain of 2.6)
Definition vl6180x.h:429
@ VL6180X_ALS_GAIN_1
1 x gain (actual analogue gain of 1.01), default
Definition vl6180x.h:432
@ VL6180X_ALS_GAIN_1_67
1.67 x gain (actual analogue gain of 1.72)
Definition vl6180x.h:430
@ VL6180X_ALS_GAIN_40
40 x gain (actual analogue gain of 40)
Definition vl6180x.h:433
@ VL6180X_ALS_GAIN_20
20 x gain (actual analogue gain of 20)
Definition vl6180x.h:426
@ VL6180X_ALS_GAIN_10
10 x gain (actual analogue gain of 10.32)
Definition vl6180x.h:427
@ VL6180X_ALS_GAIN_1_25
1.25 x gain (actual analogue gain of 1.28)
Definition vl6180x.h:431
@ VL6180X_ERROR_NOT_READY
Device not ready.
Definition vl6180x.h:419
@ VL6180X_ERROR_NO_DATA
No data available.
Definition vl6180x.h:416
@ VL6180X_ERROR_WRONG_ID
Wrong id read.
Definition vl6180x.h:414
@ VL6180X_ERROR_ALS
Ambient light sensing (ALS) error.
Definition vl6180x.h:418
@ VL6180X_ERROR_RNG
Ranging error.
Definition vl6180x.h:417
@ VL6180X_OK
Success.
Definition vl6180x.h:412
@ VL6180X_ERROR_NO_PIN
Pin not defined.
Definition vl6180x.h:415
@ VL6180X_ERROR_I2C
I2C communication error.
Definition vl6180x.h:413
@ VL6180X_RNG_ALGO_UNDERFLOW
Ranging algorithm underflow.
Definition vl6180x.h:452
@ VL6180X_RNG_EARLY_CONV_EST
Early convergence estimate.
Definition vl6180x.h:446
@ VL6180X_RNG_ALGO_OVERFLOW
Ranging algorithm overflow.
Definition vl6180x.h:453
@ VL6180X_RNG_NO_TARGET
No target, ignore.
Definition vl6180x.h:448
@ VL6180X_RNG_RAW_ALGO_OVERFLOW
Raw ranging algorithn overflow.
Definition vl6180x.h:451
@ VL6180X_RNG_VCSEL_WD_TEST
VCSEL watchdog test.
Definition vl6180x.h:442
@ VL6180X_RNG_PLL1_LOCK
PLL1 lock.
Definition vl6180x.h:444
@ VL6180X_RNG_MAX_CONV
Maximum convergence time reached.
Definition vl6180x.h:447
@ VL6180X_RNG_MAX_SNR
Maximum SNR reached.
Definition vl6180x.h:449
@ VL6180X_RNG_VCSEL_CONT_TEST
VCSEL continuity Test.
Definition vl6180x.h:441
@ VL6180X_RNG_PLL2_LOCK
PLL2 lock.
Definition vl6180x.h:445
@ VL6180X_RNG_VCSEL_WD
VCSEL watchdog.
Definition vl6180x.h:443
@ VL6180X_RNG_OK
No error.
Definition vl6180x.h:440
@ VL6180X_RNG_RAW_ALGO_UNDERFLOW
Raw ranging algorithm underflow.
Definition vl6180x.h:450
Low-level I2C peripheral driver interface definition.
Common macros and compiler attributes/pragmas configuration.
Interrupt config.
Definition vl6180x.h:509
vl6180x_int_mode_t als_int
Interrupt mode for ALS measurements.
Definition vl6180x.h:514
vl6180x_int_mode_t rng_int
Interrupt mode for range measurements.
Definition vl6180x.h:511
Interrupt threshold configuration.
Definition vl6180x.h:532
uint8_t rng_high
upper threshold for range values
Definition vl6180x.h:534
uint8_t rng_low
lower threshold for range values
Definition vl6180x.h:535
uint16_t als_high
upper threshold for ALS values
Definition vl6180x.h:538
uint16_t als_low
lower threshold for ALS values
Definition vl6180x.h:539
VL6180X device configuration.
Definition vl6180x.h:546
uint16_t als_int_time
ALS integration time in ms [1...512] (default 100 = 100 ms, recommended)
Definition vl6180x.h:603
gpio_t shutdown_pin
Shutdown pin, LOW active.
Definition vl6180x.h:555
uint8_t rng_max_time
Maximum convergence time in ms [1...63] given to the sensor to perform a range measurement (default 5...
Definition vl6180x.h:592
vl6180x_int_config_t int_cfg
Interrupt mode configuration.
Definition vl6180x.h:560
uint16_t als_lux_res
ALS lux resolution multiplied by factor 1000 (default 0.32 lux/count is the factory calibrated lux re...
Definition vl6180x.h:605
uint8_t i2c_addr
I2C slave address.
Definition vl6180x.h:552
uint8_t period
Measurement period in continuous mode in steps of 10 ms (default 20 = 200 ms).
Definition vl6180x.h:585
vl6180x_als_gain_t als_gain
ALS analogue gain for light channel (default VL6180X_ALS_GAIN_1_0)
Definition vl6180x.h:608
vl6180x_int_thresh_t int_thresh
Interrupt threshold configuration.
Definition vl6180x.h:561
gpio_t int_pin
Interrupt pin, LOW active.
Definition vl6180x.h:559
unsigned i2c_dev
I2C device, default I2C_DEV(0)
Definition vl6180x.h:551
VL6180X sensor device data structure type.
Definition vl6180x.h:618
vl6180x_als_status_t als_status
Status of last ALS measurement.
Definition vl6180x.h:626
vl6180x_rng_status_t rng_status
Status of last range measurement.
Definition vl6180x.h:623
vl6180x_params_t params
Device initialization parameters.
Definition vl6180x.h:620
bool cont_meas
Continuous mode running.
Definition vl6180x.h:621
Register definitions for ST VL6180X Ranging and Ambient Light Sensing (ALS) module.