summaryrefslogtreecommitdiff
path: root/hidflash.py
diff options
context:
space:
mode:
authorVegard Storheil Eriksen <zyp@jvnv.net>2013-10-26 14:43:35 +0200
committerVegard Storheil Eriksen <zyp@jvnv.net>2013-10-26 14:43:48 +0200
commit5126039a1ca9a7715a06761a714d3e4e9d158e11 (patch)
treedbc33f12d8f00478766cda782f9d78956e99d03b /hidflash.py
parent9a09653330f2af11149b83e1df42a05a6cb018dc (diff)
Changed bootloader to use HID instead of DFU.
Diffstat (limited to 'hidflash.py')
-rwxr-xr-xhidflash.py61
1 files changed, 61 insertions, 0 deletions
diff --git a/hidflash.py b/hidflash.py
new file mode 100755
index 0000000..a7042ca
--- /dev/null
+++ b/hidflash.py
@@ -0,0 +1,61 @@
+#!/usr/bin/env python
+
+from hidapi import hidapi
+from elftools.elf.elffile import ELFFile
+
+import ctypes, time, sys
+
+e = ELFFile(open(sys.argv[1]))
+
+buf = ''
+
+for segment in sorted(e.iter_segments(), key = lambda x: x.header.p_paddr):
+ if segment.header.p_type != 'PT_LOAD':
+ continue
+
+ data = segment.data()
+ lma = segment.header.p_paddr
+
+ # Workaround for LD aligning segments to a larger boundary than 8k.
+ if lma == 0x8000000:
+ lma += 0x2000
+ data = data[0x2000:]
+
+ # Add padding if necessary.
+ buf += '\0' * (lma - 0x8002000 - len(buf))
+
+ buf += data
+
+# Align to 64B
+if len(buf) & (64 - 1):
+ buf += '\0' * (64 - (len(buf) & (64 - 1)))
+
+# Open device
+dev = hidapi.hid_open(0x1d50, 0x6084, None)
+
+if not dev:
+ raise RuntimeError('Device not found.')
+
+print 'Found device, starting flashing.'
+
+# Prepare
+if hidapi.hid_send_feature_report(dev, ctypes.c_char_p('\x00\x20'), 2) != 2:
+ raise RuntimeError('Prepare failed.')
+
+# Flash
+while buf:
+ if hidapi.hid_write(dev, ctypes.c_char_p('\x00' + buf[:64]), 65) != 65:
+ raise RuntimeError('Writing failed.')
+ buf = buf[64:]
+
+# Finish
+if hidapi.hid_send_feature_report(dev, ctypes.c_char_p('\x00\x21'), 2) != 2:
+ raise RuntimeError('Finish failed.')
+
+print 'Flashing finished, resetting.'
+
+# Reset
+if hidapi.hid_send_feature_report(dev, ctypes.c_char_p('\x00\x11'), 2) != 2:
+ raise RuntimeError('Reset failed.')
+
+print 'Done, everything ok.'