#!/usr/bin/env bash # Convenience script for loading firmware onto a dfu type device # By default, initiates dfu-util SERIAL_PORT="/dev/kiibohd" AUTO_SCREEN_SESSION="/dev/kiibohd" NOSCREEN=0 PROG_NAME=$(basename $0) # Parse all the command line arguments while (( "$#" >= "1" )); do # Scan each argument key="$1" case $key in -a|--autoscreen) AUTO_SCREEN_SESSION="$2" shift ;; -f|--fastload) SERIAL_PORT="$2" shift ;; -n|--noscreen) NOSCREEN=1 shift ;; -h|--help) echo "Usage: $PROG_NAME [options...]" echo "" echo "Loads the most recent built firmware (@TARGET_BIN@) to the device." echo " (load.dfu)" echo "" echo "Arguments:" echo " -a, --autoscreen SERIAL_PORT Use screen on the specified serial port after loading." echo " e.g. /dev/ttyACM0" echo " -f, --fastload SERIAL_PORT Send the reload command to the debug terminal." echo " e.g. /dev/ttyACM0" echo " NOTE: May not work due to non-functional terminal, or disable remote flashing" echo " -h, --help This message." exit 1 ;; *) echo "INVALID ARG: '$1'" exit 2 ;; esac # Shift to the next argument shift done # If a SERIAL_PORT was specified set the uC into reflash mode # XXX May not be successful if uC is not in a good state (or does not allow remote flashing) if [[ "$SERIAL_PORT" != "" ]] && [[ -e "$SERIAL_PORT" ]]; then echo "NOTE: This may fail if the uC is in a bad state or does not support remote flashing" printf "reload\r" > $SERIAL_PORT fi # Load via dfu-util # Used for McHCK based uCs if type dfu-util &>/dev/null; then # Wait for device to appear while true; do dfu-util -l | grep -q "Kiibohd DFU" if [ $? -eq 0 ]; then break fi sleep 0.1 done dfu-util -D @TARGET_BIN@ EXIT_STATUS=$? else echo "dfu-util is required to reprogram the device" exit 3 fi # Load Screen Session if specified if (( "$EXIT_STATUS" == "0" )) && [[ "$AUTO_SCREEN_SESSION" != "" ]] && [[ $NOSCREEN -ne 1 ]]; then if type screen &>/dev/null; then # Wait for interface while [ ! -e $AUTO_SCREEN_SESSION ]; do sleep 0.1 done screen $AUTO_SCREEN_SESSION else echo "screen is not installed" exit 3 fi fi exit $EXIT_STATUS