Paparazzi UAS  v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
vl53l1x_api.h File Reference

Functions definition. More...

#include "vl53l1_platform.h"
+ Include dependency graph for vl53l1x_api.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  VL53L1X_Version_t
 defines SW Version More...
 
struct  VL53L1X_Result_t
 defines packed reading results type More...
 

Macros

#define VL53L1X_IMPLEMENTATION_VER_MAJOR   3
 
#define VL53L1X_IMPLEMENTATION_VER_MINOR   3
 
#define VL53L1X_IMPLEMENTATION_VER_SUB   0
 
#define VL53L1X_IMPLEMENTATION_VER_REVISION   0000
 
#define SOFT_RESET   0x0000
 
#define VL53L1_I2C_SLAVE__DEVICE_ADDRESS   0x0001
 
#define VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND   0x0008
 
#define ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS   0x0016
 
#define ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS   0x0018
 
#define ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS   0x001A
 
#define ALGO__PART_TO_PART_RANGE_OFFSET_MM   0x001E
 
#define MM_CONFIG__INNER_OFFSET_MM   0x0020
 
#define MM_CONFIG__OUTER_OFFSET_MM   0x0022
 
#define GPIO_HV_MUX__CTRL   0x0030
 
#define GPIO__TIO_HV_STATUS   0x0031
 
#define SYSTEM__INTERRUPT_CONFIG_GPIO   0x0046
 
#define PHASECAL_CONFIG__TIMEOUT_MACROP   0x004B
 
#define RANGE_CONFIG__TIMEOUT_MACROP_A_HI   0x005E
 
#define RANGE_CONFIG__VCSEL_PERIOD_A   0x0060
 
#define RANGE_CONFIG__VCSEL_PERIOD_B   0x0063
 
#define RANGE_CONFIG__TIMEOUT_MACROP_B_HI   0x0061
 
#define RANGE_CONFIG__TIMEOUT_MACROP_B_LO   0x0062
 
#define RANGE_CONFIG__SIGMA_THRESH   0x0064
 
#define RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS   0x0066
 
#define RANGE_CONFIG__VALID_PHASE_HIGH   0x0069
 
#define VL53L1_SYSTEM__INTERMEASUREMENT_PERIOD   0x006C
 
#define SYSTEM__THRESH_HIGH   0x0072
 
#define SYSTEM__THRESH_LOW   0x0074
 
#define SD_CONFIG__WOI_SD0   0x0078
 
#define SD_CONFIG__INITIAL_PHASE_SD0   0x007A
 
#define ROI_CONFIG__USER_ROI_CENTRE_SPAD   0x007F
 
#define ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE   0x0080
 
#define SYSTEM__SEQUENCE_CONFIG   0x0081
 
#define VL53L1_SYSTEM__GROUPED_PARAMETER_HOLD   0x0082
 
#define SYSTEM__INTERRUPT_CLEAR   0x0086
 
#define SYSTEM__MODE_START   0x0087
 
#define VL53L1_RESULT__RANGE_STATUS   0x0089
 
#define VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0   0x008C
 
#define RESULT__AMBIENT_COUNT_RATE_MCPS_SD   0x0090
 
#define VL53L1_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0   0x0096
 
#define VL53L1_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0   0x0098
 
#define VL53L1_RESULT__OSC_CALIBRATE_VAL   0x00DE
 
#define VL53L1_FIRMWARE__SYSTEM_STATUS   0x00E5
 
#define VL53L1_IDENTIFICATION__MODEL_ID   0x010F
 
#define VL53L1_ROI_CONFIG__MODE_ROI_CENTRE_SPAD   0x013E
 

Typedefs

typedef int8_t VL53L1X_ERROR
 

Functions

VL53L1X_ERROR VL53L1X_GetSWVersion (VL53L1X_Version_t *pVersion)
 This function returns the SW driver version. More...
 
VL53L1X_ERROR VL53L1X_SetI2CAddress (VL53L1_DEV, uint8_t new_address)
 This function sets the sensor I2C address used in case multiple devices application, default address 0x52. More...
 
VL53L1X_ERROR VL53L1X_SensorInit (VL53L1_DEV dev)
 This function loads the 135 bytes default values to initialize the sensor. More...
 
void VL53L1X_BootDevice (VL53L1_DEV dev, uint16_t TimingBudgetInMs, uint16_t DistanceMode, uint32_t InterMeasurementInMs)
 Implement boot sequence of VL53L1 device as described in documentation See VL53L1X_SetTimingBudgetInMs, VL53L1X_SetDistanceMode and VL53L1X_SetInterMeasurementInMs for params details. More...
 
VL53L1X_ERROR VL53L1X_ClearInterrupt (VL53L1_DEV dev)
 This function clears the interrupt, to be called after a ranging data reading to arm the interrupt for the next data ready event. More...
 
VL53L1X_ERROR VL53L1X_SetInterruptPolarity (VL53L1_DEV dev, uint8_t IntPol)
 This function programs the interrupt polarity
1=active high (default), 0=active low. More...
 
VL53L1X_ERROR VL53L1X_GetInterruptPolarity (VL53L1_DEV dev, uint8_t *pIntPol)
 This function returns the current interrupt polarity
1=active high (default), 0=active low. More...
 
VL53L1X_ERROR VL53L1X_StartRanging (VL53L1_DEV dev)
 This function starts the ranging distance operation
The ranging operation is continuous. More...
 
VL53L1X_ERROR VL53L1X_StopRanging (VL53L1_DEV dev)
 This function stops the ranging. More...
 
VL53L1X_ERROR VL53L1X_CheckForDataReady (VL53L1_DEV dev, uint8_t *isDataReady)
 This function checks if the new ranging data is available by polling the dedicated register. More...
 
VL53L1X_ERROR VL53L1X_SetTimingBudgetInMs (VL53L1_DEV dev, uint16_t TimingBudgetInMs)
 This function programs the timing budget in ms. More...
 
VL53L1X_ERROR VL53L1X_GetTimingBudgetInMs (VL53L1_DEV dev, uint16_t *pTimingBudgetInMs)
 This function returns the current timing budget in ms. More...
 
VL53L1X_ERROR VL53L1X_SetDistanceMode (VL53L1_DEV dev, uint16_t DistanceMode)
 This function programs the distance mode (1=short, 2=long(default)). More...
 
VL53L1X_ERROR VL53L1X_GetDistanceMode (VL53L1_DEV dev, uint16_t *pDistanceMode)
 This function returns the current distance mode (1=short, 2=long). More...
 
VL53L1X_ERROR VL53L1X_SetInterMeasurementInMs (VL53L1_DEV dev, uint32_t InterMeasurementInMs)
 This function programs the Intermeasurement period in ms
Intermeasurement period must be >/= timing budget. More...
 
VL53L1X_ERROR VL53L1X_GetInterMeasurementInMs (VL53L1_DEV dev, uint16_t *pIM)
 This function returns the Intermeasurement period in ms. More...
 
VL53L1X_ERROR VL53L1X_BootState (VL53L1_DEV dev, uint8_t *state)
 This function returns the boot state of the device (1:booted, 0:not booted) More...
 
VL53L1X_ERROR VL53L1X_GetSensorId (VL53L1_DEV dev, uint16_t *id)
 This function returns the sensor id, sensor Id must be 0xEEAC. More...
 
VL53L1X_ERROR VL53L1X_GetDistance (VL53L1_DEV dev, uint16_t *distance)
 This function returns the distance measured by the sensor in mm. More...
 
VL53L1X_ERROR VL53L1X_GetSignalPerSpad (VL53L1_DEV dev, uint16_t *signalPerSp)
 This function returns the returned signal per SPAD in kcps/SPAD. More...
 
VL53L1X_ERROR VL53L1X_GetAmbientPerSpad (VL53L1_DEV dev, uint16_t *amb)
 This function returns the ambient per SPAD in kcps/SPAD. More...
 
VL53L1X_ERROR VL53L1X_GetSignalRate (VL53L1_DEV dev, uint16_t *signalRate)
 This function returns the returned signal in kcps. More...
 
VL53L1X_ERROR VL53L1X_GetSpadNb (VL53L1_DEV dev, uint16_t *spNb)
 This function returns the current number of enabled SPADs. More...
 
VL53L1X_ERROR VL53L1X_GetAmbientRate (VL53L1_DEV dev, uint16_t *ambRate)
 This function returns the ambient rate in kcps. More...
 
VL53L1X_ERROR VL53L1X_GetRangeStatus (VL53L1_DEV dev, uint8_t *rangeStatus)
 This function returns the ranging status error
(0:no error, 1:sigma failed, 2:signal failed, ..., 7:wrap-around) More...
 
VL53L1X_ERROR VL53L1X_GetResult (VL53L1_DEV dev, VL53L1X_Result_t *pResult)
 This function returns measurements and the range status in a single read access. More...
 
VL53L1X_ERROR VL53L1X_SetOffset (VL53L1_DEV dev, int16_t OffsetValue)
 This function programs the offset correction in mm. More...
 
VL53L1X_ERROR VL53L1X_GetOffset (VL53L1_DEV dev, int16_t *Offset)
 This function returns the programmed offset correction value in mm. More...
 
VL53L1X_ERROR VL53L1X_SetXtalk (VL53L1_DEV dev, uint16_t XtalkValue)
 This function programs the xtalk correction value in cps (Count Per Second). More...
 
VL53L1X_ERROR VL53L1X_GetXtalk (VL53L1_DEV dev, uint16_t *Xtalk)
 This function returns the current programmed xtalk correction value in cps. More...
 
VL53L1X_ERROR VL53L1X_SetDistanceThreshold (VL53L1_DEV dev, uint16_t ThreshLow, uint16_t ThreshHigh, uint8_t Window, uint8_t IntOnNoTarget)
 This function programs the threshold detection mode
Example:
VL53L1X_SetDistanceThreshold(dev,100,300,0,1): Below 100
VL53L1X_SetDistanceThreshold(dev,100,300,1,1): Above 300
VL53L1X_SetDistanceThreshold(dev,100,300,2,1): Out of window
VL53L1X_SetDistanceThreshold(dev,100,300,3,1): In window
. More...
 
VL53L1X_ERROR VL53L1X_GetDistanceThresholdWindow (VL53L1_DEV dev, uint16_t *window)
 This function returns the window detection mode (0=below; 1=above; 2=out; 3=in) More...
 
VL53L1X_ERROR VL53L1X_GetDistanceThresholdLow (VL53L1_DEV dev, uint16_t *low)
 This function returns the low threshold in mm. More...
 
VL53L1X_ERROR VL53L1X_GetDistanceThresholdHigh (VL53L1_DEV dev, uint16_t *high)
 This function returns the high threshold in mm. More...
 
VL53L1X_ERROR VL53L1X_SetROI (VL53L1_DEV dev, uint16_t X, uint16_t Y)
 This function programs the ROI (Region of Interest)
The ROI position is centered, only the ROI size can be reprogrammed. More...
 
VL53L1X_ERROR VL53L1X_GetROI_XY (VL53L1_DEV dev, uint16_t *ROI_X, uint16_t *ROI_Y)
 This function returns width X and height Y. More...
 
VL53L1X_ERROR VL53L1X_SetROICenter (VL53L1_DEV dev, uint8_t ROICenter)
 This function programs the new user ROI center, please to be aware that there is no check in this function. More...
 
VL53L1X_ERROR VL53L1X_GetROICenter (VL53L1_DEV dev, uint8_t *ROICenter)
 This function returns the current user ROI center. More...
 
VL53L1X_ERROR VL53L1X_SetSignalThreshold (VL53L1_DEV dev, uint16_t signal)
 This function programs a new signal threshold in kcps (default=1024 kcps
. More...
 
VL53L1X_ERROR VL53L1X_GetSignalThreshold (VL53L1_DEV dev, uint16_t *signal)
 This function returns the current signal threshold in kcps. More...
 
VL53L1X_ERROR VL53L1X_SetSigmaThreshold (VL53L1_DEV dev, uint16_t sigma)
 This function programs a new sigma threshold in mm (default=15 mm) More...
 
VL53L1X_ERROR VL53L1X_GetSigmaThreshold (VL53L1_DEV dev, uint16_t *signal)
 This function returns the current sigma threshold in mm. More...
 
VL53L1X_ERROR VL53L1X_StartTemperatureUpdate (VL53L1_DEV dev)
 This function performs the temperature calibration. More...
 

Detailed Description

Functions definition.

Definition in file vl53l1x_api.h.


Data Structure Documentation

◆ VL53L1X_Version_t

struct VL53L1X_Version_t

defines SW Version

Definition at line 129 of file vl53l1x_api.h.

Data Fields
uint8_t build

build number

uint8_t major

major number

uint8_t minor

minor number

uint32_t revision

revision number

◆ VL53L1X_Result_t

struct VL53L1X_Result_t

defines packed reading results type

Definition at line 139 of file vl53l1x_api.h.

Data Fields
uint16_t Ambient

ResultAmbient

uint16_t Distance

ResultDistance

uint16_t NumSPADs

ResultNumSPADs

uint16_t SigPerSPAD

ResultSignalPerSPAD

uint8_t Status

ResultStatus

Macro Definition Documentation

◆ ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS

#define ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS   0x0016

Definition at line 83 of file vl53l1x_api.h.

◆ ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS

#define ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS   0x0018

Definition at line 84 of file vl53l1x_api.h.

◆ ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS

#define ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS   0x001A

Definition at line 85 of file vl53l1x_api.h.

◆ ALGO__PART_TO_PART_RANGE_OFFSET_MM

#define ALGO__PART_TO_PART_RANGE_OFFSET_MM   0x001E

Definition at line 86 of file vl53l1x_api.h.

◆ GPIO__TIO_HV_STATUS

#define GPIO__TIO_HV_STATUS   0x0031

Definition at line 90 of file vl53l1x_api.h.

◆ GPIO_HV_MUX__CTRL

#define GPIO_HV_MUX__CTRL   0x0030

Definition at line 89 of file vl53l1x_api.h.

◆ MM_CONFIG__INNER_OFFSET_MM

#define MM_CONFIG__INNER_OFFSET_MM   0x0020

Definition at line 87 of file vl53l1x_api.h.

◆ MM_CONFIG__OUTER_OFFSET_MM

#define MM_CONFIG__OUTER_OFFSET_MM   0x0022

Definition at line 88 of file vl53l1x_api.h.

◆ PHASECAL_CONFIG__TIMEOUT_MACROP

#define PHASECAL_CONFIG__TIMEOUT_MACROP   0x004B

Definition at line 92 of file vl53l1x_api.h.

◆ RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS

#define RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS   0x0066

Definition at line 99 of file vl53l1x_api.h.

◆ RANGE_CONFIG__SIGMA_THRESH

#define RANGE_CONFIG__SIGMA_THRESH   0x0064

Definition at line 98 of file vl53l1x_api.h.

◆ RANGE_CONFIG__TIMEOUT_MACROP_A_HI

#define RANGE_CONFIG__TIMEOUT_MACROP_A_HI   0x005E

Definition at line 93 of file vl53l1x_api.h.

◆ RANGE_CONFIG__TIMEOUT_MACROP_B_HI

#define RANGE_CONFIG__TIMEOUT_MACROP_B_HI   0x0061

Definition at line 96 of file vl53l1x_api.h.

◆ RANGE_CONFIG__TIMEOUT_MACROP_B_LO

#define RANGE_CONFIG__TIMEOUT_MACROP_B_LO   0x0062

Definition at line 97 of file vl53l1x_api.h.

◆ RANGE_CONFIG__VALID_PHASE_HIGH

#define RANGE_CONFIG__VALID_PHASE_HIGH   0x0069

Definition at line 100 of file vl53l1x_api.h.

◆ RANGE_CONFIG__VCSEL_PERIOD_A

#define RANGE_CONFIG__VCSEL_PERIOD_A   0x0060

Definition at line 94 of file vl53l1x_api.h.

◆ RANGE_CONFIG__VCSEL_PERIOD_B

#define RANGE_CONFIG__VCSEL_PERIOD_B   0x0063

Definition at line 95 of file vl53l1x_api.h.

◆ RESULT__AMBIENT_COUNT_RATE_MCPS_SD

#define RESULT__AMBIENT_COUNT_RATE_MCPS_SD   0x0090

Definition at line 114 of file vl53l1x_api.h.

◆ ROI_CONFIG__USER_ROI_CENTRE_SPAD

#define ROI_CONFIG__USER_ROI_CENTRE_SPAD   0x007F

Definition at line 106 of file vl53l1x_api.h.

◆ ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE

#define ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE   0x0080

Definition at line 107 of file vl53l1x_api.h.

◆ SD_CONFIG__INITIAL_PHASE_SD0

#define SD_CONFIG__INITIAL_PHASE_SD0   0x007A

Definition at line 105 of file vl53l1x_api.h.

◆ SD_CONFIG__WOI_SD0

#define SD_CONFIG__WOI_SD0   0x0078

Definition at line 104 of file vl53l1x_api.h.

◆ SOFT_RESET

#define SOFT_RESET   0x0000

Definition at line 80 of file vl53l1x_api.h.

◆ SYSTEM__INTERRUPT_CLEAR

#define SYSTEM__INTERRUPT_CLEAR   0x0086

Definition at line 110 of file vl53l1x_api.h.

◆ SYSTEM__INTERRUPT_CONFIG_GPIO

#define SYSTEM__INTERRUPT_CONFIG_GPIO   0x0046

Definition at line 91 of file vl53l1x_api.h.

◆ SYSTEM__MODE_START

#define SYSTEM__MODE_START   0x0087

Definition at line 111 of file vl53l1x_api.h.

◆ SYSTEM__SEQUENCE_CONFIG

#define SYSTEM__SEQUENCE_CONFIG   0x0081

Definition at line 108 of file vl53l1x_api.h.

◆ SYSTEM__THRESH_HIGH

#define SYSTEM__THRESH_HIGH   0x0072

Definition at line 102 of file vl53l1x_api.h.

◆ SYSTEM__THRESH_LOW

#define SYSTEM__THRESH_LOW   0x0074

Definition at line 103 of file vl53l1x_api.h.

◆ VL53L1_FIRMWARE__SYSTEM_STATUS

#define VL53L1_FIRMWARE__SYSTEM_STATUS   0x00E5

Definition at line 118 of file vl53l1x_api.h.

◆ VL53L1_I2C_SLAVE__DEVICE_ADDRESS

#define VL53L1_I2C_SLAVE__DEVICE_ADDRESS   0x0001

Definition at line 81 of file vl53l1x_api.h.

◆ VL53L1_IDENTIFICATION__MODEL_ID

#define VL53L1_IDENTIFICATION__MODEL_ID   0x010F

Definition at line 119 of file vl53l1x_api.h.

◆ VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0

#define VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0   0x008C

Definition at line 113 of file vl53l1x_api.h.

◆ VL53L1_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0

#define VL53L1_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0   0x0096

Definition at line 115 of file vl53l1x_api.h.

◆ VL53L1_RESULT__OSC_CALIBRATE_VAL

#define VL53L1_RESULT__OSC_CALIBRATE_VAL   0x00DE

Definition at line 117 of file vl53l1x_api.h.

◆ VL53L1_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0

#define VL53L1_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0   0x0098

Definition at line 116 of file vl53l1x_api.h.

◆ VL53L1_RESULT__RANGE_STATUS

#define VL53L1_RESULT__RANGE_STATUS   0x0089

Definition at line 112 of file vl53l1x_api.h.

◆ VL53L1_ROI_CONFIG__MODE_ROI_CENTRE_SPAD

#define VL53L1_ROI_CONFIG__MODE_ROI_CENTRE_SPAD   0x013E

Definition at line 120 of file vl53l1x_api.h.

◆ VL53L1_SYSTEM__GROUPED_PARAMETER_HOLD

#define VL53L1_SYSTEM__GROUPED_PARAMETER_HOLD   0x0082

Definition at line 109 of file vl53l1x_api.h.

◆ VL53L1_SYSTEM__INTERMEASUREMENT_PERIOD

#define VL53L1_SYSTEM__INTERMEASUREMENT_PERIOD   0x006C

Definition at line 101 of file vl53l1x_api.h.

◆ VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND

#define VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND   0x0008

Definition at line 82 of file vl53l1x_api.h.

◆ VL53L1X_IMPLEMENTATION_VER_MAJOR

#define VL53L1X_IMPLEMENTATION_VER_MAJOR   3

Definition at line 73 of file vl53l1x_api.h.

◆ VL53L1X_IMPLEMENTATION_VER_MINOR

#define VL53L1X_IMPLEMENTATION_VER_MINOR   3

Definition at line 74 of file vl53l1x_api.h.

◆ VL53L1X_IMPLEMENTATION_VER_REVISION

#define VL53L1X_IMPLEMENTATION_VER_REVISION   0000

Definition at line 76 of file vl53l1x_api.h.

◆ VL53L1X_IMPLEMENTATION_VER_SUB

#define VL53L1X_IMPLEMENTATION_VER_SUB   0

Definition at line 75 of file vl53l1x_api.h.

Typedef Documentation

◆ VL53L1X_ERROR

Definition at line 78 of file vl53l1x_api.h.

Function Documentation

◆ VL53L1X_BootDevice()

void VL53L1X_BootDevice ( VL53L1_DEV  dev,
uint16_t  TimingBudgetInMs,
uint16_t  DistanceMode,
uint32_t  InterMeasurementInMs 
)

Implement boot sequence of VL53L1 device as described in documentation See VL53L1X_SetTimingBudgetInMs, VL53L1X_SetDistanceMode and VL53L1X_SetInterMeasurementInMs for params details.

Definition at line 262 of file vl53l1x_api.c.

References dev, state, VL53L1X_BootState(), VL53L1X_SensorInit(), VL53L1X_SetDistanceMode(), VL53L1X_SetInterMeasurementInMs(), VL53L1X_SetTimingBudgetInMs(), and VL53L1X_StartRanging().

Referenced by multi_ranger_boot_device(), and sonar_vl53l1x_init().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_BootState()

VL53L1X_ERROR VL53L1X_BootState ( VL53L1_DEV  dev,
uint8_t state 
)

This function returns the boot state of the device (1:booted, 0:not booted)

Definition at line 564 of file vl53l1x_api.c.

References dev, state, status, VL53L1_FIRMWARE__SYSTEM_STATUS, and VL53L1_RdByte().

Referenced by VL53L1X_BootDevice().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_CheckForDataReady()

VL53L1X_ERROR VL53L1X_CheckForDataReady ( VL53L1_DEV  dev,
uint8_t isDataReady 
)

This function checks if the new ranging data is available by polling the dedicated register.

Parameters
isDataReady==0 -> not ready; isDataReady==1 -> ready

Definition at line 324 of file vl53l1x_api.c.

References dev, GPIO__TIO_HV_STATUS, status, VL53L1_RdByte(), and VL53L1X_GetInterruptPolarity().

Referenced by VL53L1X_SensorInit(), and VL53L1X_StartTemperatureUpdate().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_ClearInterrupt()

VL53L1X_ERROR VL53L1X_ClearInterrupt ( VL53L1_DEV  dev)

This function clears the interrupt, to be called after a ranging data reading to arm the interrupt for the next data ready event.

Definition at line 278 of file vl53l1x_api.c.

References dev, status, SYSTEM__INTERRUPT_CLEAR, and VL53L1_WrByte().

Referenced by VL53L1X_SensorInit(), and VL53L1X_StartTemperatureUpdate().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_GetAmbientPerSpad()

VL53L1X_ERROR VL53L1X_GetAmbientPerSpad ( VL53L1_DEV  dev,
uint16_t amb 
)

This function returns the ambient per SPAD in kcps/SPAD.

Definition at line 608 of file vl53l1x_api.c.

References dev, RESULT__AMBIENT_COUNT_RATE_MCPS_SD, status, VL53L1_RdWord(), and VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0.

+ Here is the call graph for this function:

◆ VL53L1X_GetAmbientRate()

VL53L1X_ERROR VL53L1X_GetAmbientRate ( VL53L1_DEV  dev,
uint16_t ambRate 
)

This function returns the ambient rate in kcps.

Definition at line 641 of file vl53l1x_api.c.

References dev, RESULT__AMBIENT_COUNT_RATE_MCPS_SD, status, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetDistance()

VL53L1X_ERROR VL53L1X_GetDistance ( VL53L1_DEV  dev,
uint16_t distance 
)

This function returns the distance measured by the sensor in mm.

Definition at line 584 of file vl53l1x_api.c.

References dev, status, VL53L1_RdWord(), and VL53L1_RESULT__FINAL_CROSSTALK_CORRECTED_RANGE_MM_SD0.

+ Here is the call graph for this function:

◆ VL53L1X_GetDistanceMode()

VL53L1X_ERROR VL53L1X_GetDistanceMode ( VL53L1_DEV  dev,
uint16_t pDistanceMode 
)

This function returns the current distance mode (1=short, 2=long).

Definition at line 523 of file vl53l1x_api.c.

References dev, PHASECAL_CONFIG__TIMEOUT_MACROP, status, and VL53L1_RdByte().

Referenced by VL53L1X_SetTimingBudgetInMs().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_GetDistanceThresholdHigh()

VL53L1X_ERROR VL53L1X_GetDistanceThresholdHigh ( VL53L1_DEV  dev,
uint16_t high 
)

This function returns the high threshold in mm.

Definition at line 775 of file vl53l1x_api.c.

References dev, status, SYSTEM__THRESH_HIGH, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetDistanceThresholdLow()

VL53L1X_ERROR VL53L1X_GetDistanceThresholdLow ( VL53L1_DEV  dev,
uint16_t low 
)

This function returns the low threshold in mm.

Definition at line 765 of file vl53l1x_api.c.

References dev, status, SYSTEM__THRESH_LOW, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetDistanceThresholdWindow()

VL53L1X_ERROR VL53L1X_GetDistanceThresholdWindow ( VL53L1_DEV  dev,
uint16_t window 
)

This function returns the window detection mode (0=below; 1=above; 2=out; 3=in)

Definition at line 756 of file vl53l1x_api.c.

References dev, status, SYSTEM__INTERRUPT_CONFIG_GPIO, and VL53L1_RdByte().

+ Here is the call graph for this function:

◆ VL53L1X_GetInterMeasurementInMs()

VL53L1X_ERROR VL53L1X_GetInterMeasurementInMs ( VL53L1_DEV  dev,
uint16_t pIM 
)

This function returns the Intermeasurement period in ms.

Definition at line 550 of file vl53l1x_api.c.

References dev, status, VL53L1_RdDWord(), VL53L1_RdWord(), VL53L1_RESULT__OSC_CALIBRATE_VAL, and VL53L1_SYSTEM__INTERMEASUREMENT_PERIOD.

+ Here is the call graph for this function:

◆ VL53L1X_GetInterruptPolarity()

VL53L1X_ERROR VL53L1X_GetInterruptPolarity ( VL53L1_DEV  dev,
uint8_t pIntPol 
)

This function returns the current interrupt polarity
1=active high (default), 0=active low.

Definition at line 297 of file vl53l1x_api.c.

References dev, GPIO_HV_MUX__CTRL, status, and VL53L1_RdByte().

Referenced by VL53L1X_CheckForDataReady().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_GetOffset()

VL53L1X_ERROR VL53L1X_GetOffset ( VL53L1_DEV  dev,
int16_t Offset 
)

This function returns the programmed offset correction value in mm.

Definition at line 698 of file vl53l1x_api.c.

References ALGO__PART_TO_PART_RANGE_OFFSET_MM, dev, offset, status, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetRangeStatus()

VL53L1X_ERROR VL53L1X_GetRangeStatus ( VL53L1_DEV  dev,
uint8_t rangeStatus 
)

This function returns the ranging status error
(0:no error, 1:sigma failed, 2:signal failed, ..., 7:wrap-around)

Definition at line 651 of file vl53l1x_api.c.

References dev, status, status_rtn, VL53L1_RdByte(), and VL53L1_RESULT__RANGE_STATUS.

+ Here is the call graph for this function:

◆ VL53L1X_GetResult()

VL53L1X_ERROR VL53L1X_GetResult ( VL53L1_DEV  dev,
VL53L1X_Result_t pResult 
)

This function returns measurements and the range status in a single read access.

Definition at line 665 of file vl53l1x_api.c.

References VL53L1X_Result_t::Ambient, dev, VL53L1X_Result_t::Distance, VL53L1X_Result_t::NumSPADs, VL53L1X_Result_t::SigPerSPAD, VL53L1X_Result_t::Status, status, status_rtn, VL53L1_ReadMulti(), and VL53L1_RESULT__RANGE_STATUS.

+ Here is the call graph for this function:

◆ VL53L1X_GetROI_XY()

VL53L1X_ERROR VL53L1X_GetROI_XY ( VL53L1_DEV  dev,
uint16_t ROI_X,
uint16_t ROI_Y 
)

This function returns width X and height Y.

Definition at line 822 of file vl53l1x_api.c.

References dev, ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE, status, and VL53L1_RdByte().

+ Here is the call graph for this function:

◆ VL53L1X_GetROICenter()

VL53L1X_ERROR VL53L1X_GetROICenter ( VL53L1_DEV  dev,
uint8_t ROICenter 
)

This function returns the current user ROI center.

Definition at line 792 of file vl53l1x_api.c.

References dev, ROI_CONFIG__USER_ROI_CENTRE_SPAD, status, and VL53L1_RdByte().

+ Here is the call graph for this function:

◆ VL53L1X_GetSensorId()

VL53L1X_ERROR VL53L1X_GetSensorId ( VL53L1_DEV  dev,
uint16_t id 
)

This function returns the sensor id, sensor Id must be 0xEEAC.

Definition at line 574 of file vl53l1x_api.c.

References dev, status, VL53L1_IDENTIFICATION__MODEL_ID, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetSigmaThreshold()

VL53L1X_ERROR VL53L1X_GetSigmaThreshold ( VL53L1_DEV  dev,
uint16_t signal 
)

This function returns the current sigma threshold in mm.

Definition at line 864 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__SIGMA_THRESH, status, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetSignalPerSpad()

VL53L1X_ERROR VL53L1X_GetSignalPerSpad ( VL53L1_DEV  dev,
uint16_t signalPerSp 
)

This function returns the returned signal per SPAD in kcps/SPAD.

With kcps stands for Kilo Count Per Second

Definition at line 595 of file vl53l1x_api.c.

References dev, status, VL53L1_RdWord(), VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0, and VL53L1_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0.

+ Here is the call graph for this function:

◆ VL53L1X_GetSignalRate()

VL53L1X_ERROR VL53L1X_GetSignalRate ( VL53L1_DEV  dev,
uint16_t signalRate 
)

This function returns the returned signal in kcps.

Definition at line 619 of file vl53l1x_api.c.

References dev, status, VL53L1_RdWord(), and VL53L1_RESULT__PEAK_SIGNAL_COUNT_RATE_CROSSTALK_CORRECTED_MCPS_SD0.

+ Here is the call graph for this function:

◆ VL53L1X_GetSignalThreshold()

VL53L1X_ERROR VL53L1X_GetSignalThreshold ( VL53L1_DEV  dev,
uint16_t signal 
)

This function returns the current signal threshold in kcps.

Definition at line 841 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS, status, and VL53L1_RdWord().

+ Here is the call graph for this function:

◆ VL53L1X_GetSpadNb()

VL53L1X_ERROR VL53L1X_GetSpadNb ( VL53L1_DEV  dev,
uint16_t spNb 
)

This function returns the current number of enabled SPADs.

Definition at line 630 of file vl53l1x_api.c.

References dev, status, VL53L1_RdWord(), and VL53L1_RESULT__DSS_ACTUAL_EFFECTIVE_SPADS_SD0.

+ Here is the call graph for this function:

◆ VL53L1X_GetSWVersion()

◆ VL53L1X_GetTimingBudgetInMs()

VL53L1X_ERROR VL53L1X_GetTimingBudgetInMs ( VL53L1_DEV  dev,
uint16_t pTimingBudgetInMs 
)

This function returns the current timing budget in ms.

Definition at line 445 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__TIMEOUT_MACROP_A_HI, status, and VL53L1_RdWord().

Referenced by VL53L1X_SetDistanceMode().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_GetXtalk()

VL53L1X_ERROR VL53L1X_GetXtalk ( VL53L1_DEV  dev,
uint16_t Xtalk 
)

This function returns the current programmed xtalk correction value in cps.

Definition at line 725 of file vl53l1x_api.c.

References ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS, dev, status, and VL53L1_RdDWord().

+ Here is the call graph for this function:

◆ VL53L1X_SensorInit()

VL53L1X_ERROR VL53L1X_SensorInit ( VL53L1_DEV  dev)

This function loads the 135 bytes default values to initialize the sensor.

Parameters
devDevice address
Returns
0:success, != 0:failed

Definition at line 238 of file vl53l1x_api.c.

References dev, status, VL51L1X_DEFAULT_CONFIGURATION, VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND, VL53L1_WrByte(), VL53L1X_CheckForDataReady(), VL53L1X_ClearInterrupt(), VL53L1X_SetI2CAddress(), VL53L1X_StartRanging(), and VL53L1X_StopRanging().

Referenced by VL53L1X_BootDevice().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_SetDistanceMode()

VL53L1X_ERROR VL53L1X_SetDistanceMode ( VL53L1_DEV  dev,
uint16_t  DistanceMode 
)

This function programs the distance mode (1=short, 2=long(default)).

Short mode max distance is limited to 1.3 m but better ambient immunity.
Long mode can range up to 4 m in the dark with 200 ms timing budget.

Definition at line 486 of file vl53l1x_api.c.

References dev, PHASECAL_CONFIG__TIMEOUT_MACROP, RANGE_CONFIG__VALID_PHASE_HIGH, RANGE_CONFIG__VCSEL_PERIOD_A, RANGE_CONFIG__VCSEL_PERIOD_B, SD_CONFIG__INITIAL_PHASE_SD0, SD_CONFIG__WOI_SD0, status, VL53L1_WrByte(), VL53L1_WrWord(), VL53L1X_GetTimingBudgetInMs(), and VL53L1X_SetTimingBudgetInMs().

Referenced by VL53L1X_BootDevice().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_SetDistanceThreshold()

VL53L1X_ERROR VL53L1X_SetDistanceThreshold ( VL53L1_DEV  dev,
uint16_t  ThreshLow,
uint16_t  ThreshHigh,
uint8_t  Window,
uint8_t  IntOnNoTarget 
)

This function programs the threshold detection mode
Example:
VL53L1X_SetDistanceThreshold(dev,100,300,0,1): Below 100
VL53L1X_SetDistanceThreshold(dev,100,300,1,1): Above 300
VL53L1X_SetDistanceThreshold(dev,100,300,2,1): Out of window
VL53L1X_SetDistanceThreshold(dev,100,300,3,1): In window
.

Parameters
dev: device address
ThreshLow(inmm) : the threshold under which one the device raises an interrupt if Window = 0
ThreshHigh(inmm) : the threshold above which one the device raises an interrupt if Window = 1
Windowdetection mode : 0=below, 1=above, 2=out, 3=in
IntOnNoTarget= 1 (No longer used - just use 1)

Definition at line 735 of file vl53l1x_api.c.

References dev, status, SYSTEM__INTERRUPT_CONFIG_GPIO, SYSTEM__THRESH_HIGH, SYSTEM__THRESH_LOW, VL53L1_RdByte(), VL53L1_WrByte(), and VL53L1_WrWord().

+ Here is the call graph for this function:

◆ VL53L1X_SetI2CAddress()

VL53L1X_ERROR VL53L1X_SetI2CAddress ( VL53L1_DEV  dev,
uint8_t  new_address 
)

This function sets the sensor I2C address used in case multiple devices application, default address 0x52.

Definition at line 229 of file vl53l1x_api.c.

References dev, status, VL53L1_I2C_SLAVE__DEVICE_ADDRESS, and VL53L1_WrByte().

Referenced by VL53L1X_SensorInit().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_SetInterMeasurementInMs()

VL53L1X_ERROR VL53L1X_SetInterMeasurementInMs ( VL53L1_DEV  dev,
uint32_t  InterMeasurementInMs 
)

This function programs the Intermeasurement period in ms
Intermeasurement period must be >/= timing budget.

This condition is not checked by the API, the customer has the duty to check the condition. Default = 100 ms

Definition at line 537 of file vl53l1x_api.c.

References dev, status, VL53L1_RdWord(), VL53L1_RESULT__OSC_CALIBRATE_VAL, VL53L1_SYSTEM__INTERMEASUREMENT_PERIOD, and VL53L1_WrDWord().

Referenced by VL53L1X_BootDevice().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_SetInterruptPolarity()

VL53L1X_ERROR VL53L1X_SetInterruptPolarity ( VL53L1_DEV  dev,
uint8_t  IntPol 
)

This function programs the interrupt polarity
1=active high (default), 0=active low.

Definition at line 286 of file vl53l1x_api.c.

References dev, GPIO_HV_MUX__CTRL, status, VL53L1_RdByte(), and VL53L1_WrByte().

+ Here is the call graph for this function:

◆ VL53L1X_SetOffset()

VL53L1X_ERROR VL53L1X_SetOffset ( VL53L1_DEV  dev,
int16_t  OffsetValue 
)

This function programs the offset correction in mm.

Parameters
OffsetValue:theoffset correction value to program in mm

Definition at line 685 of file vl53l1x_api.c.

References ALGO__PART_TO_PART_RANGE_OFFSET_MM, dev, MM_CONFIG__INNER_OFFSET_MM, MM_CONFIG__OUTER_OFFSET_MM, status, and VL53L1_WrWord().

+ Here is the call graph for this function:

◆ VL53L1X_SetROI()

VL53L1X_ERROR VL53L1X_SetROI ( VL53L1_DEV  dev,
uint16_t  X,
uint16_t  Y 
)

This function programs the ROI (Region of Interest)
The ROI position is centered, only the ROI size can be reprogrammed.


The smallest acceptable ROI size = 4

Parameters
X:ROIWidth; Y=ROI Height

Definition at line 801 of file vl53l1x_api.c.

References dev, ROI_CONFIG__USER_ROI_CENTRE_SPAD, ROI_CONFIG__USER_ROI_REQUESTED_GLOBAL_XY_SIZE, status, VL53L1_RdByte(), VL53L1_ROI_CONFIG__MODE_ROI_CENTRE_SPAD, VL53L1_WrByte(), mesonh.mesonh_atmosphere::X, and mesonh.mesonh_atmosphere::Y.

+ Here is the call graph for this function:

◆ VL53L1X_SetROICenter()

VL53L1X_ERROR VL53L1X_SetROICenter ( VL53L1_DEV  dev,
uint8_t  ROICenter 
)

This function programs the new user ROI center, please to be aware that there is no check in this function.

if the ROI center vs ROI size is out of border the ranging function return error #13

Definition at line 785 of file vl53l1x_api.c.

References dev, ROI_CONFIG__USER_ROI_CENTRE_SPAD, status, and VL53L1_WrByte().

+ Here is the call graph for this function:

◆ VL53L1X_SetSigmaThreshold()

VL53L1X_ERROR VL53L1X_SetSigmaThreshold ( VL53L1_DEV  dev,
uint16_t  sigma 
)

This function programs a new sigma threshold in mm (default=15 mm)

Definition at line 852 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__SIGMA_THRESH, status, and VL53L1_WrWord().

+ Here is the call graph for this function:

◆ VL53L1X_SetSignalThreshold()

VL53L1X_ERROR VL53L1X_SetSignalThreshold ( VL53L1_DEV  dev,
uint16_t  signal 
)

This function programs a new signal threshold in kcps (default=1024 kcps
.

Definition at line 833 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__MIN_COUNT_RATE_RTN_LIMIT_MCPS, status, and VL53L1_WrWord().

+ Here is the call graph for this function:

◆ VL53L1X_SetTimingBudgetInMs()

VL53L1X_ERROR VL53L1X_SetTimingBudgetInMs ( VL53L1_DEV  dev,
uint16_t  TimingBudgetInMs 
)

This function programs the timing budget in ms.

Predefined values = 15, 20, 33, 50, 100(default), 200, 500.

Definition at line 343 of file vl53l1x_api.c.

References dev, RANGE_CONFIG__TIMEOUT_MACROP_A_HI, RANGE_CONFIG__TIMEOUT_MACROP_B_HI, status, VL53L1_WrWord(), and VL53L1X_GetDistanceMode().

Referenced by VL53L1X_BootDevice(), and VL53L1X_SetDistanceMode().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_SetXtalk()

VL53L1X_ERROR VL53L1X_SetXtalk ( VL53L1_DEV  dev,
uint16_t  XtalkValue 
)

This function programs the xtalk correction value in cps (Count Per Second).


This is the number of photons reflected back from the cover glass in cps.

Definition at line 710 of file vl53l1x_api.c.

References ALGO__CROSSTALK_COMPENSATION_PLANE_OFFSET_KCPS, ALGO__CROSSTALK_COMPENSATION_X_PLANE_GRADIENT_KCPS, ALGO__CROSSTALK_COMPENSATION_Y_PLANE_GRADIENT_KCPS, dev, status, and VL53L1_WrWord().

+ Here is the call graph for this function:

◆ VL53L1X_StartRanging()

VL53L1X_ERROR VL53L1X_StartRanging ( VL53L1_DEV  dev)

This function starts the ranging distance operation
The ranging operation is continuous.

The clear interrupt has to be done after each get data to allow the interrupt to raise when the next data is ready
1=active high (default), 0=active low, use SetInterruptPolarity() to change the interrupt polarity if required.

Definition at line 308 of file vl53l1x_api.c.

References dev, status, SYSTEM__MODE_START, and VL53L1_WrByte().

Referenced by VL53L1X_BootDevice(), VL53L1X_SensorInit(), and VL53L1X_StartTemperatureUpdate().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VL53L1X_StartTemperatureUpdate()

VL53L1X_ERROR VL53L1X_StartTemperatureUpdate ( VL53L1_DEV  dev)

This function performs the temperature calibration.

It is recommended to call this function any time the temperature might have changed by more than 8 deg C without sensor ranging activity for an extended period.

Definition at line 875 of file vl53l1x_api.c.

References dev, status, VL53L1_VHV_CONFIG__TIMEOUT_MACROP_LOOP_BOUND, VL53L1_WrByte(), VL53L1X_CheckForDataReady(), VL53L1X_ClearInterrupt(), VL53L1X_StartRanging(), and VL53L1X_StopRanging().

+ Here is the call graph for this function:

◆ VL53L1X_StopRanging()

VL53L1X_ERROR VL53L1X_StopRanging ( VL53L1_DEV  dev)

This function stops the ranging.

Definition at line 316 of file vl53l1x_api.c.

References dev, status, SYSTEM__MODE_START, and VL53L1_WrByte().

Referenced by VL53L1X_SensorInit(), and VL53L1X_StartTemperatureUpdate().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: