diff options
author | Jesse Vincent <jesse@keyboard.io> | 2017-02-28 18:15:58 +0800 |
---|---|---|
committer | Jesse Vincent <jesse@keyboard.io> | 2017-02-28 18:15:58 +0800 |
commit | 54a812a725879539fa8c9c2383eb80c9ec6b1683 (patch) | |
tree | 8633c172bb92bf76184ad8a570c57442de779d27 | |
parent | First step of getting the makefile to use an external kaleidoscope builder (diff) | |
download | keyboardio-model01-54a812a725879539fa8c9c2383eb80c9ec6b1683.tar.gz keyboardio-model01-54a812a725879539fa8c9c2383eb80c9ec6b1683.tar.bz2 keyboardio-model01-54a812a725879539fa8c9c2383eb80c9ec6b1683.zip |
remove the builder, since we can now use the systemwide one in the hardware dir
-rwxr-xr-x | tools/kaleidoscope-builder | 313 | ||||
-rw-r--r-- | tools/settings.sh | 85 |
2 files changed, 0 insertions, 398 deletions
diff --git a/tools/kaleidoscope-builder b/tools/kaleidoscope-builder deleted file mode 100755 index 6c984e5..0000000 --- a/tools/kaleidoscope-builder +++ /dev/null @@ -1,313 +0,0 @@ -#! /bin/sh - -set -e - -firmware_size () { - ## This is a terrible hack, please don't hurt me. - algernon - - MAX_PROG_SIZE=28672 - - output="$($@ | grep "\\(Program\\|Data\\):" | sed -e 's,^, - ,' && echo)" - - PROGSIZE="$(echo "${output}" | grep Program: | cut -d: -f2 | awk '{print $1}')" - - PERCENT="$(echo ${PROGSIZE} ${MAX_PROG_SIZE} | awk "{ printf \"%02.01f\", \$1 / \$2 * 100 }")" - - echo "${output}" | sed -e "s,\(Program:.*\)(\([0-9\.]*%\) Full),\1(${PERCENT}% Full)," -} - -find_sketch () { - if [ -e "${SOURCEDIR}/.kaleidoscope-builder.conf" ]; then - . "${SOURCEDIR}/.kaleidoscope-builder.conf" - fi - - SKETCH="${SKETCH:-${DEFAULT_SKETCH}}" - LIBRARY="${LIBRARY:-${SKETCH}}" - - for path in "hardware/keyboardio/avr/libraries/Kaleidoscope-${LIBRARY}/examples/${SKETCH}" \ - "examples/${LIBRARY}" \ - "src" \ - "." ; do - if [ -f "${path}/${SKETCH}.ino" ]; then - echo "${path}" - return - fi - done - exit 1 -} - -prepare_to_flash () { - if [ ! -e "${HEX_FILE_PATH}" ]; then - compile - fi - - echo "Press ENTER when ready..." - read a -} - -flash () { - prepare_to_flash - reset_device - sleep 3s - flash_over_usb - -} - -flash_over_usb () { - avrdude -q -q -p${MCU} -cavr109 -D -P ${DEVICE_PORT_BOOTLOADER} -b57600 "-Uflash:w:${HEX_FILE_PATH}:i" - -} - -program() { - prepare_to_flash - flash_with_programmer -} - -flash_with_programmer() { - - avrdude -v \ - -p${MCU} \ - -cusbtiny \ - -D \ - -B 1 \ - "-Uflash:w:${HEX_FILE_PATH}:i" -} - -hex_with_bootloader () { - if [ ! -e "${HEX_FILE_PATH}" ]; then - compile - fi - - cat ${HEX_FILE_PATH} | awk '/^:00000001FF/ == 0' > ${HEX_FILE_WITH_BOOTLOADER_PATH} - echo "Using ${BOOTLOADER_PATH}" - ${MD5} ${BOOTLOADER_PATH} - cat ${BOOTLOADER_PATH} >> ${HEX_FILE_WITH_BOOTLOADER_PATH} - cat <<EOF - -Combined firmware and bootloader are now at ${HEX_FILE_WITH_BOOTLOADER_PATH} -Make sure you have the bootloader version you expect. - -And TEST THIS ON REAL HARDWARE BEFORE YOU GIVE IT TO ANYONE - -EOF -} - -build () { - compile $@ - size $@ -} - -compile () { - install -d "${OUTPUT_PATH}" - - echo "Building ${OUTPUT_DIR}/${SKETCH} (${LIB_VERSION}) ..." - - ${compile_HOOKS} - - if [ -d "${ARDUINO_LOCAL_LIB_PATH}/libraries" ]; then - local_LIBS="-libraries \"${ARDUINO_LOCAL_LIB_PATH}/libraries\"" - fi - - ${ARDUINO_BUILDER} \ - -compile \ - -hardware "${ARDUINO_PATH}/hardware" \ - -hardware "${BOARD_HARDWARE_PATH}" \ - ${ARDUINO_TOOLS_PARAM} \ - -tools "${ARDUINO_PATH}/tools-builder" \ - -fqbn "${FQBN}" \ - ${local_LIBS} \ - -libraries "${BOARD_HARDWARE_PATH}/.." \ - -libraries "${ROOT}" \ - ${EXTRA_BUILDER_ARGS} \ - -build-path "${BUILD_PATH}" \ - -ide-version "${ARDUINO_IDE_VERSION}" \ - -warnings all \ - ${ARDUINO_VERBOSE} \ - -prefs "compiler.cpp.extra_flags=-std=c++11 -Woverloaded-virtual -Wno-unused-parameter -Wno-unused-variable -Wno-ignored-qualifiers" \ - ${ARDUINO_AVR_GCC_PREFIX_PARAM} \ - "$(find_sketch)/${SKETCH}.ino" - - cp "${BUILD_PATH}/${SKETCH}.ino.hex" "${HEX_FILE_PATH}" - cp "${BUILD_PATH}/${SKETCH}.ino.elf" "${ELF_FILE_PATH}" - ln -sf "${OUTPUT_FILE_PREFIX}.hex" "${OUTPUT_PATH}/${SKETCH}-latest.hex" - ln -sf "${OUTPUT_FILE_PREFIX}.elf" "${OUTPUT_PATH}/${SKETCH}-latest.elf" - rm -rf "${BUILD_PATH}" -} - -_find_all () { - for plugin in hardware/keyboardio/avr/libraries/Kaleidoscope-*/examples/* \ - examples/* \ - src/*.ino; do - if [ -d "$(dirname ${plugin})" ] || [ -f "${plugin}" ]; then - p="$(basename "${plugin}" .ino)" - if [ "${p}" != '*' ]; then - echo "${p}" - fi - fi - done | sort -} - -build_all () { - plugins="$(_find_all)" - - for plugin in ${plugins}; do - export SKETCH="${plugin}" - export LIBRARY="${plugin}" - $0 ${plugin} build - done -} - -size () { - if [ ! -e "${HEX_FILE_PATH}" ]; then - compile - fi - - echo "- Size: firmware/${LIBRARY}/${OUTPUT_FILE_PREFIX}.elf" - firmware_size "${AVR_SIZE}" -C --mcu="${MCU}" "${ELF_FILE_PATH}" - echo -} - -size_map () { - if [ ! -e "${HEX_FILE_PATH}" ]; then - compile - fi - - "${AVR_NM}" --size-sort -C -r -l "${ELF_FILE_PATH}" -} - -decompile () { - - if [ ! -e "${HEX_FILE_PATH}" ]; then - compile - fi - - "${AVR_OBJDUMP}" -d "${ELF_FILE_PATH}" -} - -clean () { - rm -rf "${OUTPUT_PATH}" -} - -reset_device () { - ${RESET_DEVICE} -} - -usage () { - cat <<EOF -Usage: $0 SKETCH commands... - -Runs all of the commands in the context of the Sketch. - -Available commands: - - help - This help screen. - - compile - Compiles the sketch. - - size - Reports the size of the compiled sketch. - - build - Runs compile and report-size. - - clean - Cleans up the output directory. - - size-map - Displays the size map for the sketch. - - decomple - Decompile the sketch. - - reset-device - Reset the device. - - flash - Flashes the firmware using avrdude. - - build-all - Build all Sketches we can find. -EOF -} - -help () { - usage -} - -if [ $# -lt 1 ]; then - usage - exit 1 -fi - -## Parse the command-line -## - anything that has a =, is an env var -## - from the remaining stuff, the first one is the Library/Sketch -## - everything else are commands -## -## - if there is only one argument, that's a command - -ROOT="$(cd $(dirname $0)/..; pwd)" -export ROOT -export SOURCEDIR="$(pwd)" - -if [ -e "${HOME}/.kaleidoscope-builder.conf" ]; then - . "${HOME}/.kaleidoscope-builder.conf" -fi - -if [ -e "${SOURCEDIR}/.kaleidoscope-builder.conf" ]; then - . "${SOURCEDIR}/.kaleidoscope-builder.conf" -fi - - -. ${ROOT}/tools/settings.sh - - -cmds="" - -## Export vars -for i in $(seq 1 $#); do - v="$1" - shift - - case "${v}" in - *=*) - export ${v} - ;; - *) - cmds="${cmds} ${v}" - ;; - esac -done - -set -- ${cmds} - -if [ $# -eq 1 ]; then - cmd="$(echo $1 | tr '-' '_')" - ${cmd} - exit $? -fi - -SKETCH="$1" -shift - -if [ "${SKETCH}" = "default" ]; then - SKETCH="${DEFAULT_SKETCH}" -fi - -cmds="" - -for i in $(seq 1 $#); do - cmds="${cmds} $(echo $1 | tr '-' '_')" - shift -done - -LIBRARY="${SKETCH}" - -export SKETCH -export LIBRARY - -for cmd in ${cmds}; do - ${cmd} -done diff --git a/tools/settings.sh b/tools/settings.sh deleted file mode 100644 index d5b8fdf..0000000 --- a/tools/settings.sh +++ /dev/null @@ -1,85 +0,0 @@ -## NEEDS: LIBRARY, SKETCH, ROOT, SOURCEDIR -## Should be included when the current directory is the dir of the Sketch. - -case "$0" in - */settings.sh) - echo "This file must be included, never run directly!" >&2 - exit 1 - ;; -esac - -SKETCH="${SKETCH:-${DEFAULT_SKETCH}}" -LIBRARY="${LIBRARY:-${SKETCH}}" - -if [ -z "${SKETCH}" ] || [ -z "${LIBRARY}" ] || [ -z "${ROOT}" ] || [ -z "${SOURCEDIR}" ]; then - echo "SKETCH, LIBRARY, SOURCEDIR, and ROOT need to be set before including this file!" >&2 - exit 1 -fi - -BOARD="${BOARD:-model01}" -MCU="${MCU:-atmega32u4}" -FQBN="${FQBN:-keyboardio:avr:${BOARD}}" - -DEVICE_PORT="$(ls /dev/ttyACM* 2>/dev/null || echo '')" -DEVICE_PORT_BOOTLOADER="$(ls /dev/ttyACM* 2>/dev/null || echo '')" - -RESET_DEVICE="stty -F ${DEVICE_PORT} 1200 hupcl" - -ARDUINO_PATH="${ARDUINO_PATH:-/usr/local/arduino}" -ARDUINO_LOCAL_LIB_PATH="${ARDUINO_LOCAL_LIB_PATH:-${HOME}/Arduino}" -ARDUINO_TOOLS_PATH="${ARDUINO_TOOLS_PATH:-${ARDUINO_PATH}/hardware/tools}" -ARDUINO_BUILDER="${ARDUINO_BUILDER:-${ARDUINO_PATH}/arduino-builder}" -ARDUINO_IDE_VERSION="100607" - -BOARD_HARDWARE_PATH="${BOARD_HARDWARE_PATH:-${ARDUINO_LOCAL_LIB_PATH}/hardware}" -BOOTLOADER_PATH="${BOARD_HARDWARE_PATH}/keyboardio/avr/bootloaders/caterina/Caterina.hex" - -AVR_SIZE="${AVR_SIZE:-${ARDUINO_TOOLS_PATH}/avr/bin/avr-size}" -AVR_NM="${AVR_NM:-${ARDUINO_TOOLS_PATH}/avr/bin/avr-nm}" -AVR_OBJDUMP="${AVR_OBJDUMP:-${ARDUINO_TOOLS_PATH}/avr/bin/avr-objdump}" - -MD5="md5sum" - -BUILD_PATH="${BUILD_PATH:-$(mktemp -d 2>/dev/null || mktemp -d -t 'build')}" -OUTPUT_DIR="${OUTPUT_DIR:-output/${LIBRARY}}" -OUTPUT_PATH="${OUTPUT_PATH:-${SOURCEDIR}/${OUTPUT_DIR}}" - -GIT_VERSION="$(cd $(find_sketch); git describe --abbrev=4 --dirty --always)" -LIB_VERSION="$(cd $(find_sketch); (grep version= ../../library.properties 2>/dev/null || echo version=0.0.0) | cut -d= -f2)-g${GIT_VERSION}" - -OUTPUT_FILE_PREFIX="${SKETCH}-${LIB_VERSION}" - -HEX_FILE_PATH="${OUTPUT_PATH}/${OUTPUT_FILE_PREFIX}.hex" -HEX_FILE_WITH_BOOTLOADER_PATH="${OUTPUT_PATH}/${OUTPUT_FILE_PREFIX}-with-bootloader.hex" -ELF_FILE_PATH="${OUTPUT_PATH}/${OUTPUT_FILE_PREFIX}.elf" - -ARDUINO_TOOLS_PARAM="-tools ${ARDUINO_TOOLS_PATH}" -if [ -z "${ARDUINO_TOOLS_PATH}" ]; then - ARDUINO_TOOLS_PARAM="" -fi - -if [ ! -z "${AVR_GCC_PREFIX}" ]; then - ARDUINO_AVR_GCC_PREFIX_PARAM="-prefs \"runtime.tools.avr-gcc.path=${AVR_GCC_PREFIX}\"" -fi - -if [ ! -z "${VERBOSE}" ] && [ "${VERBOSE}" -gt 0 ]; then - ARDUINO_VERBOSE="-verbose" -else - ARDUINO_VERBOSE="-quiet" -fi - -## Platform-specific overrides -# Shamelessly stolen from git's Makefile -uname_S=$(uname -s 2>/dev/null || echo not) - -if [ "${uname_S}" = "Darwin" ]; then - DEVICE_PORT="$(ls /dev/cu.usbmodemHID?? /dev/cu.usbmodem14*)" - DEVICE_PORT_BOOTLOADER="$(ls /dev/cu.usbmodem14*)" - - ARDUINO_PATH="/Applications/Arduino.app/Contents/Java/" - ARDUINO_LOCAL_LIB_PATH="${HOME}/Documents/Arduino" - - MD5="md5" - - RESET_DEVICE="stty -f ${DEVICE_PORT} 1200" -fi |