vl6180x.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2021 Gunar Schorcht
3  *
4  * This file is subject to the terms and conditions of the GNU Lesser
5  * General Public License v2.1. See the file LICENSE in the top level
6  * directory for more details.
7  */
8 
9 #pragma once
10 
395 #ifdef __cplusplus
396 extern "C"
397 {
398 #endif
399 
400 #include <stdbool.h>
401 #include <stdint.h>
402 
403 #include "periph/gpio.h"
404 #include "periph/i2c.h"
405 
406 #include "vl6180x_regs.h"
407 
408 #define VL6180X_I2C_ADDR (0x29)
413 typedef enum {
423 
427 typedef enum {
437 
441 typedef enum {
457 
461 typedef enum {
466 
484 typedef enum {
487  VL6180X_INT_LOW = 1,
489  VL6180X_INT_HIGH = 2,
491  VL6180X_INT_OUT = 3,
494  VL6180X_INT_DRDY = 4,
497 
511 typedef struct {
512 #if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
514 #endif
515 #if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
517 #endif
519 
534 typedef struct {
535 #if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
536  uint8_t rng_high;
537  uint8_t rng_low;
538 #endif
539 #if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
540  uint16_t als_high;
541  uint16_t als_low;
542 #endif
544 
548 typedef struct {
553  unsigned i2c_dev;
554  uint8_t i2c_addr;
556 #if IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN
557  gpio_t shutdown_pin;
558 #endif /* IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN */
559 
560 #if IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN
561  gpio_t int_pin;
564 #endif /* IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN */
565 
587  uint8_t period;
588 
589 #if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
594  uint8_t rng_max_time;
598 #endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
599 
600 #if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
605  uint16_t als_int_time;
607  uint16_t als_lux_res;
613 #endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
614 
616 
620 typedef struct {
621 
623  bool cont_meas;
624 #if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
626 #endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
627 #if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
629 #endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
630 } vl6180x_t;
631 
652 int vl6180x_init(vl6180x_t *dev, const vl6180x_params_t *params);
653 
675 
695 
696 #if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
712 
734 int vl6180x_rng_read(vl6180x_t *dev, uint8_t *mm);
735 
745 
760 
761 #if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
792 int vl6180x_rng_config(vl6180x_t *dev, uint8_t period, uint8_t max_time);
793 
794 #endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
795 #endif /* IS_USED(MODULE_VL6180X_RNG) || DOXYGEN */
796 
797 #if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
811 
844 int vl6180x_als_read(vl6180x_t *dev, uint16_t *raw, uint16_t *lux);
845 
855 
870 
871 #if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
903 int vl6180x_als_config(vl6180x_t *dev, uint8_t period, uint8_t int_time,
904  vl6180x_als_gain_t gain);
905 
906 #endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
907 #endif /* IS_USED(MODULE_VL6180X_ALS) || DOXYGEN */
908 
909 #if IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN
926 
943 
944 #endif /* IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN */
945 
946 #if IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN
947 
979 
1004 
1005 #if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
1021 
1022 #endif /* IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN */
1023 #endif /* IS_USED(MODULE_VL6180X_IRQ) || DOXYGEN */
1024 
1048  uint16_t reg, const uint8_t *data, uint8_t len);
1049 
1068  uint16_t reg, uint8_t *data, uint8_t len);
1070 #ifdef __cplusplus
1071 }
1072 #endif
1073 
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:461
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:484
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:427
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:413
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:441
int vl6180x_power_down(const vl6180x_t *dev)
Power down the sensor.
@ VL6180X_ALS_OVERFLOW
ALS measurement overflow.
Definition: vl6180x.h:463
@ VL6180X_ALS_UNDERFLOW
ALS measurement underflow.
Definition: vl6180x.h:464
@ VL6180X_ALS_OK
No error.
Definition: vl6180x.h:462
@ VL6180X_INT_LOW
Interrupt is triggered when values are below the lower threshold.
Definition: vl6180x.h:487
@ VL6180X_INT_DRDY
Interrupt is triggered when new data are ready to be read.
Definition: vl6180x.h:494
@ VL6180X_INT_HIGH
Interrupt is triggered when values are above the upper threshold.
Definition: vl6180x.h:489
@ VL6180X_INT_NONE
Interrupt is disabled.
Definition: vl6180x.h:485
@ VL6180X_INT_OUT
Interrupt is triggered when values are below the lower threshold or above the upper threshold (value ...
Definition: vl6180x.h:491
@ VL6180X_ALS_GAIN_5
5 x gain (actual analogue gain of 5.21)
Definition: vl6180x.h:430
@ VL6180X_ALS_GAIN_2_5
2.5 x gain (actual analogue gain of 2.6)
Definition: vl6180x.h:431
@ VL6180X_ALS_GAIN_1
1 x gain (actual analogue gain of 1.01), default
Definition: vl6180x.h:434
@ VL6180X_ALS_GAIN_1_67
1.67 x gain (actual analogue gain of 1.72)
Definition: vl6180x.h:432
@ VL6180X_ALS_GAIN_40
40 x gain (actual analogue gain of 40)
Definition: vl6180x.h:435
@ VL6180X_ALS_GAIN_20
20 x gain (actual analogue gain of 20)
Definition: vl6180x.h:428
@ VL6180X_ALS_GAIN_10
10 x gain (actual analogue gain of 10.32)
Definition: vl6180x.h:429
@ VL6180X_ALS_GAIN_1_25
1.25 x gain (actual analogue gain of 1.28)
Definition: vl6180x.h:433
@ VL6180X_ERROR_NOT_READY
Device not ready.
Definition: vl6180x.h:421
@ VL6180X_ERROR_NO_DATA
No data available.
Definition: vl6180x.h:418
@ VL6180X_ERROR_WRONG_ID
Wrong id read.
Definition: vl6180x.h:416
@ VL6180X_ERROR_ALS
Ambient light sensing (ALS) error.
Definition: vl6180x.h:420
@ VL6180X_ERROR_RNG
Ranging error.
Definition: vl6180x.h:419
@ VL6180X_OK
Success.
Definition: vl6180x.h:414
@ VL6180X_ERROR_NO_PIN
Pin not defined.
Definition: vl6180x.h:417
@ VL6180X_ERROR_I2C
I2C communication error.
Definition: vl6180x.h:415
@ VL6180X_RNG_ALGO_UNDERFLOW
Ranging algorithm underflow.
Definition: vl6180x.h:454
@ VL6180X_RNG_EARLY_CONV_EST
Early convergence estimate.
Definition: vl6180x.h:448
@ VL6180X_RNG_ALGO_OVERFLOW
Ranging algorithm overflow.
Definition: vl6180x.h:455
@ VL6180X_RNG_NO_TARGET
No target, ignore.
Definition: vl6180x.h:450
@ VL6180X_RNG_RAW_ALGO_OVERFLOW
Raw ranging algorithn overflow.
Definition: vl6180x.h:453
@ VL6180X_RNG_VCSEL_WD_TEST
VCSEL watchdog test.
Definition: vl6180x.h:444
@ VL6180X_RNG_PLL1_LOCK
PLL1 lock.
Definition: vl6180x.h:446
@ VL6180X_RNG_MAX_CONV
Maximum convergence time reached.
Definition: vl6180x.h:449
@ VL6180X_RNG_MAX_SNR
Maximum SNR reached.
Definition: vl6180x.h:451
@ VL6180X_RNG_VCSEL_CONT_TEST
VCSEL continuity Test.
Definition: vl6180x.h:443
@ VL6180X_RNG_PLL2_LOCK
PLL2 lock.
Definition: vl6180x.h:447
@ VL6180X_RNG_VCSEL_WD
VCSEL watchdog.
Definition: vl6180x.h:445
@ VL6180X_RNG_OK
No error.
Definition: vl6180x.h:442
@ VL6180X_RNG_RAW_ALGO_UNDERFLOW
Raw ranging algorithm underflow.
Definition: vl6180x.h:452
Low-level I2C peripheral driver interface definition.
Interrupt config.
Definition: vl6180x.h:511
vl6180x_int_mode_t als_int
Interrupt mode for ALS measurements.
Definition: vl6180x.h:516
vl6180x_int_mode_t rng_int
Interrupt mode for range measurements.
Definition: vl6180x.h:513
Interrupt threshold configuration.
Definition: vl6180x.h:534
uint8_t rng_high
upper threshold for range values
Definition: vl6180x.h:536
uint8_t rng_low
lower threshold for range values
Definition: vl6180x.h:537
uint16_t als_high
upper threshold for ALS values
Definition: vl6180x.h:540
uint16_t als_low
lower threshold for ALS values
Definition: vl6180x.h:541
VL6180X device configuration.
Definition: vl6180x.h:548
uint16_t als_int_time
ALS integration time in ms [1...512] (default 100 = 100 ms, recommended)
Definition: vl6180x.h:605
gpio_t shutdown_pin
Shutdown pin, LOW active.
Definition: vl6180x.h:557
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:594
vl6180x_int_config_t int_cfg
Interrupt mode configuration.
Definition: vl6180x.h:562
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:607
uint8_t i2c_addr
I2C slave address.
Definition: vl6180x.h:554
uint8_t period
Measurement period in continuous mode in steps of 10 ms (default 20 = 200 ms).
Definition: vl6180x.h:587
vl6180x_als_gain_t als_gain
ALS analogue gain for light channel (default VL6180X_ALS_GAIN_1_0)
Definition: vl6180x.h:610
vl6180x_int_thresh_t int_thresh
Interrupt threshold configuration.
Definition: vl6180x.h:563
gpio_t int_pin
Interrupt pin, LOW active.
Definition: vl6180x.h:561
unsigned i2c_dev
I2C device, default I2C_DEV(0)
Definition: vl6180x.h:553
VL6180X sensor device data structure type.
Definition: vl6180x.h:620
vl6180x_als_status_t als_status
Status of last ALS measurement.
Definition: vl6180x.h:628
vl6180x_rng_status_t rng_status
Status of last range measurement.
Definition: vl6180x.h:625
vl6180x_params_t params
Device initialization parameters.
Definition: vl6180x.h:622
bool cont_meas
Continuous mode running.
Definition: vl6180x.h:623
Register definitions for ST VL6180X Ranging and Ambient Light Sensing (ALS) module.