Skip to content

Latest commit

 

History

History
166 lines (133 loc) · 7.96 KB

CHANGELOG.md

File metadata and controls

166 lines (133 loc) · 7.96 KB

Unreleased Features

Please add a note of your changes below this heading if you make a Pull Request.

Releases

[0.4.0] - 2018-06-10

Added

  • Encoder can now go forever in velocity/torque mode due to using circular encoder space.
  • Protocol supports function return values
  • bake Git-derived firmware version into firmware binary. The firmware version is exposed through the fw_version_[...] properties.
  • make write_otp command to burn the board version onto the ODrive's one-time programmable memory. If you have an ODrive v3.4 or older, you should run this once for a better firmware update user experience in the future. Run the command without any options for more details. Once set, the board version is exposed through the hw_version_[...] properties.
  • infrastructure to publish the python tools to PyPi. See tools/setup.py for details.
  • Automated test script run_tests.py
  • System stats (e.g. stack usage) are exposed under <odrv>.system_stats

Changed

  • DFU script updates
    • Verify the flash after writing
    • Automatically download firmware from GitHub releases if no file is provided
    • Retain configuration during firmware updates
  • Refactor python tools
    • The scripts explore_odrive.py, liveplotter.py, drv_status.py and rate_test.py have been merged into one single odrivetool script. Running this script without any arguments provides the shell that explore_odrive.py used to provide.
    • The command line options of odrivetool have changed compared to the original explore_odrive.py. See odrivetool --help for more details.
    • odrivetool (previously explore_odrive.py) now supports controlling multiple ODrives concurrently (odrv0, odrv1, ...)
    • No need to restart the odrivetool shell when devices get disconnected and reconnected
    • ODrive accesses from within python tools are now thread-safe. That means you can read from the same remote property from multiple threads concurrently.
    • The liveplotter (odrivetool liveplotter, formerly liveplotter.py) does no longer steal focus and closes as expected
    • Add commands odrivetool backup-config and odrivetool restore-config
    • (experimental: start liveplotter from odrivetool shell by typing start_liveplotter(lambda: odrv0.motor0.encoder.encoder_state))
  • Set thread priority of USB pump thread above protocol thread
  • GPIO3 not sensitive to edges by default
  • The device now appears as a composite device on USB. One subdevice is still a CDC device (virtual COM port), the other subdevice is a vendor specific class. This should resolve several issues that were caused by conflicting kernel drivers or OS services.
  • Add WinUSB descriptors. This will tell Windows >= 8 to automatically load winusb.sys for the ODrive (only for the vendor specific subdevice). This makes it possible to use the ODrive from userspace via WinUSB with zero configuration. The Python tool currently still uses libusb so Zadig is still required.
  • Add a configuration to enable the ASCII protocol on USB at runtime. This will only enable the ASCII protocol on the USB CDC subdevice, not the vendor specific subdevice so the python tools will still be able to talk to the ODrive.

Fixed

  • Enums now transported with correct underlying type on native protocol
  • USB issue where the device would stop responding when the host script would quit abruptly or reset the device during operation

[0.3.6] - 2018-03-26

Added

  • Storing of configuration parameters to Non Volatile Memory
  • USB Bootloader
  • make erase_config to erase the configuration with an STLink (the configuration can also be erased from within explore_odrive.py, using odrv0.erase_configuration())
  • Travis-CI builds firmware for all board versions and deploys the binaries when a tag is pushed to master
  • General purpose ADC API. See function get_adc_voltage() in low_level.cpp for more detais.

Changed

  • Most of the code from lowlevel.c moved to axis.cpp, encoder.cpp, controller.cpp, sensorless_estimator.cpp, motor.cpp and the corresponding header files
  • Refactoring of the developer-facing communication protocol interface. See e.g. axis.hpp or controller.hpp for examples on how to add your own fields and functions
  • Change of the user-facing field paths. E.g. my_odrive.motor0.pos_setpoint is now at my_odrive.axis0.controller.pos_setpoint. Names are mostly unchanged.
  • Rewrite of the top-level per-axis state-machine
  • The build is now configured using the tup.config file instead of editing source files. Make sure you set your board version correctly. See here for details.
  • The toplevel directory for tup is now Firmware. If you used tup before, go to Firmware and run rm -rd ../.tup; rm -rd build/*; make.
  • Update CubeMX generated STM platform code to version 1.19.0
  • Remove UUID_0, UUID_1 and UUID_2 from USB protocol. Use serial_number instead.
  • Freertos memory pool (task stacks, etc) now uses Core Coupled Memory.

Fixed

  • malloc now fails if we run out of memory (before it would always succeed even if we are out of ram...)

[0.3.5] - 2018-03-04

Added

  • Reporting error if your encoder CPR is incorrect
  • Ability to start anticogging calibration over USB protocol
  • Reporting of DRV status/control registers and fault codes
  • DRV status read script
  • Microsecond delay function
  • Travis-CI
  • Firmware update over USB

Changed

  • Build system is now tup instead of make. Please check the Readme for installation instructions.

[0.3.4] - 2018-02-13

Fixed

  • Broken way to check for python 2. Python 2 not supported yet.

[0.3.3] - 2018-02-12

Added

  • Liveplotter script
  • Automatic recovery of USB halt/stall condition

Changed

  • Modified python code to be Python 2 compatible

Fixed

  • USB CSC (USB serial) now reports a sensible baud rate

[0.3.2] - 2018-02-02

Added

  • Gimbal motor mode
  • Encoder index pulse support
  • resistance_calib_max_voltage parameter

[0.3.1] - 2018-01-18

Added

  • UUID Endpoint
  • Reporting of correct ODrive version on USB descriptor
  • Getting started instructions for VSCode

Changed

  • USB Product ID to 0x0D32, as it is the only Pid we were allocated on pid.codes
  • Recommended method to debug firmware from VSCode now uses Cortex-Debug extension instead of native-debug.
  • Refactor IDE instructions into separate files

Fixed

  • Bug where the remote function calls from Python to the ODrive were not working properly.

[0.3] - 2017-12-18

Added

  • New binary communication protocol
    • This is a much richer and more efficient binary protocol than the old human-readable protocol.
    • The old protocol is still available (but will be depricated eventually). You must manually chose to fall back on this protocol if you wish to still use it.
  • Support for C++
  • Demo scripts for getting started with commanding ODrive from python
  • Protection from user setting current_lim higher than is measurable
  • Current sense shunt values for HW v3.4
  • Check DRV chip fault line

Changed

  • Shunt resistance values for v3.3 and earlier to include extra resistance of PCB
  • Default HW revision to v3.4
  • Refactoring of control code:
    • Lifted top layer of low_level.c into Axis.cpp

[0.2.2] - 2017-11-17

Fixed

  • Incorrect TIM14 interrupt mapping on board v3.2 caused hard-fault

Changed

  • GPIO communication mode now defaults to NONE

[0.2.1] - 2017-11-14

Fixed

  • USB communication deadlock
  • EXTI handler redefiniton in V3.2

Changed

  • Resistance/inductance measurement now saved dispite errors, to allow debugging

[0.2.0] - 2017-11-12

Added

  • UART communication
  • Setting to select UART or Step/dir on GIPIO 1,2
  • Basic Anti-cogging

[0.1.0] - 2017-08-26

Added

  • Step/Dir interface
  • this Changelog
  • motor control interrupt timing diagram
  • uint16 exposed variable type
  • null termination to USB string parsing

Changed

  • Fixed Resistance measurement bug
  • Simplified motor control adc triggers
  • Increased AUX bridge deadtime