Flash User Bootloader¶
This script will flash user bootloader to the connected OAK camera. Bootloader can only be flashed to devices that have on-board flash memory.
Note
We suggest using Device Manager, a GUI tool for interfacing with the bootloader and its configurations.
Demo¶
Example script output
~/depthai-python/examples/bootloader$ python3 flash_user_bootloader.py
[0] 1844301041C83D0E00 [X_LINK_USB_VSC] current bootloader: 0.0.26
Which DepthAI device to flash User Bootloader for (Note: Only NETWORK supported) [0..0]: 0
User Bootloader version to flash: 0.0.26
Flashing User Bootloader...
Flashing progress: 0.0%
Flashing progress: 18.8%
Flashing progress: 31.2%
Flashing progress: 48.2%
Flashing progress: 94.2%
Flashing progress: 100.0%
Flashing successful. Took 7.55600329185836 seconds
Setup¶
Please run the install script to download all required dependencies. Please note that this script must be ran from git context, so you have to download the depthai-python repository first and then run the script
git clone https://github.com/luxonis/depthai-python.git
cd depthai-python/examples
python3 install_requirements.py
For additional information, please follow installation guide
Source code¶
Also available on GitHub
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | #!/usr/bin/env python3
import depthai as dai
import sys
import time
deviceInfos = dai.DeviceBootloader.getAllAvailableDevices()
if len(deviceInfos) == 0:
print("No device found to flash. Exiting.")
exit(-1)
else:
for i, di in enumerate(deviceInfos):
print(f'[{i}] {di.getMxId()} [{di.protocol.name}]', end='')
if di.state == dai.XLinkDeviceState.X_LINK_BOOTLOADER:
with dai.DeviceBootloader(di) as bl:
print(f' current bootloader: {bl.getVersion()}', end='')
print()
selected = input(f'Which DepthAI device to flash User Bootloader for (Note: Only NETWORK supported) [0..{len(deviceInfos)-1}]: ')
info = deviceInfos[int(selected)]
# Open DeviceBootloader and allow flashing bootloader
with dai.DeviceBootloader(info) as bl:
print("User Bootloader version to flash:", bl.getVersion())
# Create a progress callback lambda
progress = lambda p : print(f'Flashing progress: {p*100:.1f}%')
print(f"Flashing User Bootloader...")
startTime = time.monotonic()
(res, message) = bl.flashUserBootloader(progress)
if res:
print("Flashing successful. Took", time.monotonic() - startTime, "seconds")
else:
print("Flashing failed:", message)
|
Also available on GitHub
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 | #include <chrono>
#include <string>
#include "XLink/XLink.h"
#include "depthai/depthai.hpp"
#include "depthai/xlink/XLinkConnection.hpp"
static const char* ProtocolToStr(XLinkProtocol_t val) {
switch(val) {
case X_LINK_USB_VSC:
return "X_LINK_USB_VSC";
case X_LINK_USB_CDC:
return "X_LINK_USB_CDC";
case X_LINK_PCIE:
return "X_LINK_PCIE";
case X_LINK_IPC:
return "X_LINK_IPC";
case X_LINK_TCP_IP:
return "X_LINK_TCP_IP";
case X_LINK_NMB_OF_PROTOCOLS:
return "X_LINK_NMB_OF_PROTOCOLS";
case X_LINK_ANY_PROTOCOL:
return "X_LINK_ANY_PROTOCOL";
default:
return "INVALID_ENUM_VALUE";
break;
}
}
int main(int argc, char** argv) try {
using namespace std::chrono;
dai::DeviceInfo info;
auto deviceInfos = dai::DeviceBootloader::getAllAvailableDevices();
if(deviceInfos.empty()) {
std::cout << "No device found to flash. Exiting." << std::endl;
return -1;
} else {
for(int i = 0; i < deviceInfos.size(); i++) {
const auto& devInfo = deviceInfos[i];
std::cout << "[" << i << "] " << devInfo.getMxId() << "[" << ProtocolToStr(devInfo.protocol) << "]";
if(devInfo.state == X_LINK_BOOTLOADER) {
dai::DeviceBootloader bl(devInfo);
std::cout << " current bootloader: " << bl.getVersion();
}
std::cout << std::endl;
}
int selected = 0;
std::cout << "Which DepthAI device to flash bootloader for (Note: Only NETWORK supported) [0.." << deviceInfos.size() - 1 << "]\n";
std::cin >> selected;
info = deviceInfos[selected];
}
dai::DeviceBootloader bl(info);
// Create a progress callback lambda
auto progress = [](float p) { std::cout << "Flashing Progress..." << p * 100 << "%" << std::endl; };
std::cout << "Flashing User Bootloader..." << std::endl;
auto t1 = steady_clock::now();
bool success = false;
std::string message;
std::tie(success, message) = bl.flashUserBootloader(progress);
if(success) {
std::cout << "Flashing successful. Took " << duration_cast<milliseconds>(steady_clock::now() - t1).count() << "ms" << std::endl;
} else {
std::cout << "Flashing failed: " << message << std::endl;
}
return 0;
} catch(const std::exception& ex) {
std::cout << "Exception: " << ex.what() << std::endl;
}
|