2024-12-10 07:05 AM - last edited on 2024-12-10 07:10 AM by Andrew Neil
Does anyone have access to documentation with an actual list of registers with addresses and functionality and a full description of the register bits for the VL53L0X?
All I have been able to find is documentation that refers to the questionable API driver package and some doxygen-generated document based on the comments in the API.
Solved! Go to Solution.
2025-01-09 01:14 PM
After comparing the output of the Rasp Pi and the NUCLEO, we were able to determine that the problem was a byte ordering issue in the RdWord and WrWord functions in the early part of the initialization process. The sensor is taking measurements on the workbench. We will proceed to attempting to calibrate the unit and verifying the data.
2024-12-10 07:44 AM
This is the most asked question - and the answer is we don't give out the register map. And before you ask, there are a few reasons.
1) there are a LOT of registers. And while I'm sure you could write a driver eventually- you would end up hating ST forever.
2) support would be near impossible. You might not get the accuracy or distance you need and there would be no way for me to tell you what you needed to change.
3) Our first chip was duplicated by some company in China. Theirs didn't work very well, but it cost us some sales and we don't want to go through that again.
ST has a driver. It's been well tested over the last 8 years, and it works. There have been many, many designs and the L0 is still one of our best-selling ToF parts.
ST has a driver. It has more lines of code in it than most people want, and I think it should be a lot simpler. But one must argue that it works. And if you don't call a function, a reasonable linker will not include it.
Lots of people have re-engineered our driver, and most of them work. Try one, and if you have an issue, go back the to original and see what differences there are.
One guy used our driver to get the config he wanted, then monitored the I2C traffic, then just implemented functions to duplicate the I2C traffic. I'm not suggesting you do that, but if you were really tight one space, it would work.
- john
2024-12-18 07:14 AM
Comically, I just received an automated email from ST asking if your non-response solved my problem. Apparently, it has not...
First of all, let me explain that I have been a software engineer for about as long as ST has existed. I am currently working on a project for a company that has already given up on using your sensor in a previous project and this project is going about as well.
Before I came onboard, someone rigged up a demo using a Raspberry Pi and, what appears to be, your "Continuous Ranging example" from "en.STSW-IMG005.zip". Nobody has bothered to stress-test the thing, or verify the accuracy of the data it sends back, but at least it runs.
For development purposes, we are using a NUCLEO-G071RB and a TOF200C-VL53L0X.
The sensor is connected CN6-4 (3.3v) and CN6-6 (GND), CN5-10 and CN5-9 (I2C1).
Although I was originally cycling the power to the sensor by hand for each test, but it didn't seem to help and I got tired of it, so I also attached the SHUTDOWN pin to a GPIO so that I could cycle the power automatically at the beginning of the program.
I have created a clean project in STM32CubeIDE 1.16.1, downloaded this same sample code, and built the project.
I scraped out anything that has anything to do with Windows, Linux, etc.
I added the HAL I2C function calls.
I renamed your "main()" to "run_example()" so that I could call it from within the default "main()" after system initialization is complete.
Without exception, every time it runs, it times out in the exact same place-
A) I have seen no problems related to the I2C bus and have tried every reasonable combination of settings just to make sure that there was no change.
B) The function that it is getting stuck in is called in other places before getting stuck here and it always succeeds in those calls.
C) As a matter of due diligence, I increased the timeout loop count to 2000 and even added in 10ms delays for each loop. It made no difference.
D) I enclosed the call to "PerformSingleMeasurement()" in a loop that retries infinitely until it succeeds. It never escapes the loop.
E) I have also tried adding delays at various places before this function gets called in case the NUCLEO board is sending commands faster than the sensor can process them. It made no difference.
Since I have no insight into what your sensor is doing, here we are. This project is already on a tight schedule and this thing is taking up way too much of our time. I am hoping that you will be able to use your insider knowledge to provide a solution.
2025-01-02 08:58 AM
Are you checking the return status from all your I2C calls? It's easy to assume they all complete, when they do not.
When you issue the PerformSingleMeasurement, the VCSEL (laser) will start. One cannot see it, but a web-cam can. (Don't use an IPhone - the IR filter on that camera is too good. It filters out the 940nm light.) Is the VCSEL running? Do you see the glow of the sensor light?
If you've completed all those steps, one has to assume the I2C is functioning correctly. And if you are polling, you don't need the interrupt line.
So power, ground, both I2C lines, and Xshut are all you need. Sometimes the XShut is connected to power on the board - for simplicity.
But if XShut were low, your I2C would not be completing during the initialization phase.
I did a web-search for TOF200C-VL53L0X and I came up with two different parts. Not sure which one you have.
I have seen something like this before, and the device was being starved for voltage. But if you've hooked it up as you say, that is not the issue.
Another issue is I2C reliability. Are your wires exceptionally long? Over a foot, you can have issues unless you play with the pull-ups.
That is all I can think of.
2025-01-02 09:40 AM
The device we were using was (I believe) a custom-built module.
In order to verify that it is not the problem, I had the company purchase a X-NUCLEO-53L0A1 expansion board.
I removed one of the wing-board modules from the kit and attached it to the NUCLEO-G071RB dev board with approximately 3-inch jumpers. The problem persists.
The power comes directly from the 3.3v pin (CN7-16) on the dev board which is attached to a powered USB hub that supplies 1.5A. I have not noticed a voltage drop on the oscope, but I will check at the sensor. That being said, the expansion board regulates everything down to 2.8v when the sensor is attached, so I have to believe that I am good.
With I2C, you always need pull-ups. Since I wasn't sure about the sensor side, I enabled the pull-ups on the G071. As far as I can tell, every line of code in this example is error-checking to make sure the I2C comms are completing properly.
Our module has the XSHUT line exposed and I was using it to reset the chip before every run through the debugger. The 53L0A1 module does not, so I have switched to using the VL53L0X_ResetDevice() swr reset.
I am currently working on something else, but I will hook up the board again and verify the voltage and see if we can detect the IR lights.
2025-01-02 10:49 AM
As far as I can tell from the oscope, the voltage at the sensor never changes.
The IR emitters remain on even after the VL53L0X_measurement_poll_for_completion() function times out.
And just to be clear, the VL53L0X_PerformSingleMeasurement() function succeeds twice during calibration before failing on the third time it is called.
2025-01-03 07:29 AM
Interesting. If the sensor is flashing, it's running. So clearly the start, started the sensor. The sensor is working, gathering data, but it's the VL53L0X_measurement_poll_for_completion() that is hanging you up.
So let's try something. Just read the data in a loop with a delay more or less equal to the timing budget. You should get changing data.
call
2025-01-08 07:24 AM
I added the call to VL53L0X_ClearInterruptMask() to VL53L0X_PerformSingleMeasurement() right before the call to VL53L0X_StartMeasurement() and it made no difference.
I also set it to disregard the time out and continue. In the main measurement loop, all it prints is this:
API Status: 0 : No Error
Range Status: 4 : Phase Fail
RANGE IGNORE THRESHOLD: 511.992188
Measured distance: 8190
One time, I left it running and stepped away for 5 or 10 minutes. When I came back, it was actually taking readings, but the data was off by a factor of 25-50%, it was glitchy, and it eventually went back to the stream of error messages.
We have been told that we have until the end of the week to get this thing working or find a different solution.
I'm going to try to attach a zipped version of the demo project we are building. It is all ST code or code generated by the CUBE-MX, so there is nothing proprietary in it.
2025-01-08 09:09 AM
I put a printf() function in the I2C routines and this is the last bit of communications that the thing is doing. Maybe someone on your end can explain what this means.
Call of VL53L0X_PerformRefCalibration
> 01: 01
> 00: 41
Start polling
< 13: 40
< 13: 44
End polling
> 0B: 01
> 0B: 00
< 13: 40
> 00: 00
> FF: 01
> 00: 00
> FF: 00
< CB: 1B
> FF: 01
> 00: 01
> FF: 00
> 01: 02
> 00: 01
Start polling
< 13: 44
End polling
> 0B: 01
> 0B: 00
< 13: 40
> 00: 00
> FF: 01
> 00: 00
> FF: 00
< EE: 01
> FF: 01
> 00: 01
> FF: 00
> 01: E8
API Status: 0 : No Error
Call of VL53L0X_PerformRefSpadManagement
> FF: 01
> 4F: 00
> 4E: 2C
> FF: 00
> B6: B4
> 80: 00
> 01: 01
> 00: 41
Start polling
< 13: 40
< 13: 44
End polling
> 0B: 01
> 0B: 00
< 13: 40
> 00: 00
> 01: 02
> 00: 01
Start polling
< 13: 44
End polling
> 0B: 01
> 0B: 00
< 13: 40
> 00: 00
> 01: E8
> B0: 07 00 00 00 00 00
< B0: 07 00 00 00 00 00
> 01: C0
> 0B: 01
> 0B: 00
< 13: 40
> 80: 01
> FF: 01
> 00: 00
> 91: 3C
> 00: 01
> FF: 00
> 80: 00
> 00: 01
< 00: 00
Start polling
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
< 13: 40
End polling
refSpadCount = 536907168, isApertureSpads = 0
API Status: -7 : Time out error
API Status: -7 : Time out error
API Status: -7 : Time out error
2025-01-09 01:14 PM
After comparing the output of the Rasp Pi and the NUCLEO, we were able to determine that the problem was a byte ordering issue in the RdWord and WrWord functions in the early part of the initialization process. The sensor is taking measurements on the workbench. We will proceed to attempting to calibrate the unit and verifying the data.