VOXL 2 M0135 Dual Camera Connections with M0107 and M0149 Cameras
-
@Alex-Kushleyev Ahh, yeah. My board is upside down, so I got turned around.
I'm now detecting one camera, but both are plugged in. I'm not sure which one this is?
voxl2-mini:/$ voxl-camera-server -l DEBUG: Attempting to open the hal module DEBUG: SUCCESS: Camera module opened on attempt 0 DEBUG: ----------- Number of cameras: 1 DEBUG: Cam idx: 0, Cam slot: 2, Slave Address: 0x0030, Sensor Id: 0x0356 DEBUG: Note: This list comes from the HAL module and may not be indicative DEBUG: of configurations that have full pipelines DEBUG: Number of cameras: 1
Also, in terms of updating the config - is it a push command, like the ar0144 driver? Not sure what command to use in ADB.
-
@WineVirus please double check that you have
com.qti.sensormodule.imx412_3.bin
in/usr/lib/camera/
and also double check the orientation of the flex cable coming out of IMX412 camera inside your 3D printed enclosure. It should come straight away from the camera not towards to center of the camera PCB.for the configuration file, you could edit it right on VOXL (using a command line text editor, like
vi
), or you can make a new filevoxl-camera-server.conf
on your PC with the exact contents that i posted and push it to/etc/modalai/
Alex
-
@Alex-Kushleyev Is there somewhere I can download the imx412_3.bin file? It's not in the output of
./adb shell ls -la /usr/lib/camera
The flex connector comes straight away from the camera.
I've pushed the server config file.
-
copy the IMX412 driver
cp /usr/share/modalai/chi-cdk/imx412/com.qti.sensormodule.imx412_3.bin /usr/lib/camera/
-
@Alex-Kushleyev ok, the imx412_3 bin file is in /usr/lib/camera/, but I'm still only sensing 1 camera.
Also, I'll be on spring break, so I apologize for a potential lack of response.
-
@WineVirus Hmm. please double check to make sure all the connectors are seated properly. They should "snap in" as you insert them.
If that does not work, it could be a bad cable for IMX412 camera, or something else. we can try putting IMX412 on JL, so it would e imx412_2, which you could also copy and try. Then AR0144 could be on JU, so you could download it from here : https://gitlab.com/voxl-public/voxl-sdk/services/voxl-camera-server/-/blob/master/misc_files/usr/share/modalai/voxl-camera-server/drivers/ar0144/com.qti.sensormodule.ar0144_3.bin
Swapping the cameras can help figure out where the issue is. You can leave the existing sensormodules in there (no need to delete them), just add ar0144_3 and imx412_2
-
If you switch the two cameras around, make sure double check pin 1 on the connector. JL and JU are rotated 180 degrees with respect to each other. You can also just test IMX412 and not connect AR0144 at all, if that is simpler, so that you could test IMX412 only.
-
@Alex-Kushleyev Ran through the troubleshooting steps (swapping both connections), still only getting one camera (same ID, just on the other slot). I think I'll just replace the cable.
Can I work on the setup on only one sensor, with a simple way to add another one? Or will I have to redo the whole setup when I have both?
voxl2-mini:/$ voxl-camera-server -l existing instance of voxl-camera-server found, attempting to stop it DEBUG: Attempting to open the hal module DEBUG: SUCCESS: Camera module opened on attempt 0 DEBUG: ----------- Number of cameras: 1 DEBUG: Cam idx: 0, Cam slot: 3, Slave Address: 0x0030, Sensor Id: 0x0356 DEBUG: Note: This list comes from the HAL module and may not be indicative DEBUG: of configurations that have full pipelines DEBUG: Number of cameras: 1
-
Hi @WineVirus
I think you are also using M0135 wrong.
You can only use 1 of them on each J6 or J7, they cannot be cascaded.
The way I see this here is not the correct usage:
So the hires camera will never work like this.
The one camera you do see is the tracking cam... this one:
You must connect the module into M0135 directly only when plugged into the Voxl 2 Mini.
It is not designed to use the extension flex to mate to another image sensor via M0135.
In summary, remove this second M0135 and the M0036 extension flex:
And plug the M0149 directly into M0135 here to mimic what Alex has demonstrated:
Hope this helps.If I am mistaken, please let us know but this is what I gather from your photos.
-
@Vinny , i was able to use both cameras in this configuration (see above in this thread).
It seems the imx412 camera is not detected, potentially bad extension flex cable or (less likely) bad camera. Has this hires camera worked before at some point?
-
@Alex-Kushleyev OK, I am just making sure the M0135 is not used in a cascaded mode (a M0135 plugged into another M0135). That is what the first pictures look like to me since the M0135 is just sitting open on a bench.
As far as the image sensor, all modules are tested at ModalAI HQ before shipping in a known good working configuration of hardware (i.e.: a golden setup). So, yes, all image sensors are working when shipped. Same for the extension flexes. Every one is tested before shipping.
I do see a bend in the flex right here, so hopefully that is not a firm crease since creases will damage flexes:
Hope this helps! -
@Vinny I think you may be mistaken... One end of the M0036 is connected to the M0135, and the other end is connected to the M0107 Camera (that's inside the purple case). We're only using one M0135.
I'm receiving a new M0036 cable tomorrow. I'll test that.
-
@WineVirus Thanks for confirming!
Just trying to help and that picture struck me as odd.Glad you have it covered with Alex, he'll guide you correctly!!!
-
@Alex-Kushleyev I'm trying to run
voxl-camera-server
and I'm getting error messages for both cameras; The hires camera makes sense, but I'm not sure about the tracking cam...I've swapped the M0149 back to the JL port where it was originally. Also, I personally haven't gotten the hires camera working, but I agree that it's more likely the cable.
Starting Camera: tracking Using gain limits min: 54 max: 863 ERROR: Camera 0 failed to find supported preview config: 640x480 ERROR: Failed to start camera: tracking Starting Camera: hires ERROR: failed to call HAL3 get_camera_info for cam 1 ERROR: Failed to start camera: hires ------ voxl-camera-server: Camera server is now running
I'm not getting any output. Also,
voxl-inspect-services
listsvoxl-camera-server | Enabled | Not Running |
(I'm assuming it's because it has no cameras to run). Voxl Portal andvoxl-inspect-cam
show no camera streams. -
@WineVirus , i would suggest retracing the steps you took to get the tracking camera to work (from the beginning, after i posted the directions and pictures).
Once you get the tracking camera working, you can try to test the flex by connecting the tracking camera using the flex cable (please wat ch carefully the pin1 orientations). If the flex cable works for tracking camera, it is possible that imx412 has an issue.
I will be back in office tomorrow and can provide more guidance for testing.
-
Actually, i believe in your test, the tracking camera was detected, but you requested unsupported resolution of 640x480. AR0144 only supports raw resolution of 1280x800.
You can see that the error for tracking camera is
ERROR: Camera 0 failed to find supported preview config: 640x480
as opposed to hires cameraERROR: failed to call HAL3 get_camera_info for cam 1
So, you should check your
voxl-camera-server.conf
to make sure that the preview resolution is set to1280x800
for the AR0144 tracking camera, then it should work.After that, in order to check if the Flex cable is OK, you can insert the flex cable into the connection between M0135 and AR0144 camera, double check the pin1 orientations.
-
@Alex-Kushleyev I changed the resolution to be correct, and we finally have feed! Live output in voxl portal and
voxl-inspect-cam
.I've confirmed that M0036 cable is bad, the tracking camera isn't able to connect when routed through the cable.
However, we have a major issue with the feed we are receiving. We think it's a combination of bad focus + a possibly scratched lens... maybe you can help us diagnose. This the tracking output in Voxl Portal using the 9x6 checkerboard. We're using other forum threads to try and test out focus but I'd love to hear your preliminary thoughts.
-
Yes it appears the the camera lens is scratched but separately from that, it is out of focus because the image is blurry and you can actually see the scratch on the lens (if camera was focused properly, you would not see the scratch, maybe some blurriness instead). Was the lens turned from its original focus position or is it damaged such that lens holder is separated from the back of the camera?
Regarding the flex, if you believe that it came in non-working condition, please submit an RMA for a replacement. Just to be 100% sure, i will run a test with AR0144 and extension flex and send you results tonight or tomorrow (with picture of connection)
-
I tested AR0144 with M0036 flex in the configuration shown in picture below and it works. I also have the IMX412 camera attached with its own flex. The dual flex configuration is not ideal for plugging into M0135 due to flexes pointing towards each other after being connected to M0135, but for testing purposes it is OK.
If you have AR0144 camera connected in the same way with the flex cable and the camera is not detected, then it seems like the flex cable is the issue.