SmartMX Camera - Firmware Update Bug

SmartMX Camera - Firmware Update Bug

After updating to firmware 1.2.0+, the SmartMX camera may turn on at boot and then minutes later power off for no apparent reason, this could be a symptom of a firmware update bug. 
If the Vehicle has been added to Black Moth Universe then a patch will be deployed shortly after boot to rectify this. 

This is a technical guide and not recommended without instruction.

First Check - Reset Network Switch

The vehicle must be turned on but the affected camera must now be offline to detect if this is the bug. 
Set the vehicle's IP Address:
  1. Tigerip={vehicleIpAddress}
Find the camera's IP address. This can be found in the API : $Tigerip:8080/config/camera/
or through command prompt: 
  1. curl -s http://$Tigerip:8080/config/camera/ | python -m json.tool
Set the camera's IP address and try to ping it.
  1. ssh root@$Tigerip
  2. cam_ip={cameraIpAddress}
  3. ping $cam_ip
Expect no response, if you do get a response this is not the firmware bug - contact support. 
If there's no response we can now reset the network switch and then ping again. 
Note: This will reboot all cameras at once. 
  1. mv88e6097 reset
  2. ping $cam_ip
You should shortly begin to see a network ping, it should be almost immediate, but it may take a minute or 2. If the camera does start to ping you've confirmed that it was the firmware bug. 

Update Firmware

Once it's online stop the rtsp-server and the camera will force itself to download the latest firmware from the TigerMX. 
Your SSH connection may get refused if the camera is still loading, just keep trying. 
  1. ssh root@$cam_ip
  2. systemctl stop rtsp-server
Now the system will try to update the camera uninterrupted:
  1. journalctl -lfu firmware-upgrade
Wait for this process to run it's course until you get the following output, it may take a few minutes:
  1. [Info ] image download OK
If the engine is not turned on you may to restart the poe via API to keep the camera online to complete the firmware update:
http://$Tigerip:8080/shutdown/powerup/poe/

Reboot and Test

Once the download is complete restart the rtsp-server go restart the video stream. 
  1. systemctl restart rtsp-server
It may be take 5 minutes of uptime to ensure if the camera is now stable and not rebooting.

Camera rebooting after the update

This can occur when the power state gets confused , the fix is to power cycle the POE via the API. 
Note: This turns off all cameras at once.
First, remove power from the POE.
  1. /shutdown/powerdown/poe/
followed by returning the power.
  1. /shutdown/powerup/poe/

    • Related Articles

    • Update TigerMX Firmware Manually via API

      Before anything please note: NO TAR XZ When updating from 1.0.1 to 1.2.0 do not upload a tar file, it cannot be read and will brick the system.  eg. uImage-jjr-dvr-atlas_v1.2.0-21-g1c1d693.tar.xz Only use this manual method if Universe is not able to ...
    • Update System Firmware

      Updating the firmware through Universe will not interfere with the usability of the system.  How do I know if I need to update?  In Universe, updates are controlled via the 'System' (TigerMX-5) rather than per the 'Installation' (vehicle) the system ...
    • How to Install / Remove SmartMX Camera

      Turn off TigerMX-5 System Follow this process to safely shutdown the system: How to Reboot / Shutdown / Hard Power Cycle Removing and Installing SmartMX-180 Camera 1. Disconnect Camera 1.1. While holding onto the knurled (textured ridge) grip of the ...
    • SmartMX Camera Troubleshooting

      Software Check Before continuing with this guide first confirm the following: The camera view is not loading on the display (see below) The other camera views are working (use the on-screen buttons to check) Support has confirmed there's no software ...
    • Camera serial / item number is empty or null

      Example: "ip": "10.0.0.128",         "item": null,         "mac": "14:1f:ba:91:02:a1",         "name": "left",         "online": true,         "orientation": "rotate-180",         "poe_port": 4,         "pose": {             "rotation": {             ...