Loading...
Searching...
No Matches
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
394
395#ifdef __cplusplus
396extern "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)
409
423
437
457
466
497
511typedef struct {
512#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
514#endif
515#if IS_USED(MODULE_VL6180X_ALS) || DOXYGEN
517#endif
519
534typedef 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
548typedef struct {
553 unsigned i2c_dev;
554 uint8_t i2c_addr;
555
556#if IS_USED(MODULE_VL6180X_SHUTDOWN) || DOXYGEN
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
567
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
620typedef struct {
621
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
652int vl6180x_init(vl6180x_t *dev, const vl6180x_params_t *params);
653
675
695
696#if IS_USED(MODULE_VL6180X_RNG) || DOXYGEN
712
734int vl6180x_rng_read(vl6180x_t *dev, uint8_t *mm);
735
745
760
761#if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
792int 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
844int vl6180x_als_read(vl6180x_t *dev, uint16_t *raw, uint16_t *lux);
845
855
870
871#if IS_USED(MODULE_VL6180X_CONFIG) || DOXYGEN
903int 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
1029
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.