-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add clear errors #27
Add clear errors #27
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I tested it on S1. I called /request_axis_state with wrong state, called /clear_errors and then called /request_axis_state with correct state. I confirmed that procedure_result is changed to 0.
To be clear, an explicit clear_errors call should not be considered a requirement for entering CLOSED_LOOP_CONTROL. On a high level, an explicit call to clear_errors should only be used to make the LED not be red. See explanation here. If entering CLOSED_LOOP_CONTROL is the goal, clearing errors should be handled transparently by (future) ODrive firmware, or, for compatibiliy with older firmware, transparently in request_state_callback()
.
If clearing the LED color is the goal of this PR, then the approach looks mostly good. The git history is still a bit convoluted and the PR contains unrelated formatting changes. Please use git rebase / cherry-pick / amend so that the PR consists of a single commit and doesn't contain unrelated formatting changes. Please also add a note in README about the new service call.
ef806a9
to
5baa614
Compare
I think S1 needs to call clear_errors() to re-enable the brake resistor, but under what circumstances is the brake resistor disarmed? Since I use S1, I would like to enable and use the brake resistor if it is disabled. I made the following edits:
I was concerned that the contribution of liborw in #14 might disappear, so I decided not to consolidate the commits to preserve the commit history. Should we consolidate all changes, including the additions to the README, into a single commit (add service to clear errors)? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes that's true, if you need the brake resistor in your system to be running even if the motor is off (e.g. to sink power from another ODrive), then that's another reason to call clear_errors(). The brake resistor disarms on conditions that specifically restrict the brake resistor's ability to run safely: overvoltage, undervoltage, configuration error and low level system error. We're considering to change this in future firmware versions to re-enable it automatically when the conditions allow it.
Formatting looks good now.
If you wish to preserve authorship, there are multiple ways to do it. E.g. you can still squash the original commits into one, and put additional changes in a separate one, or mention co-authorship in the commit message.
Co-authored-by: Libor Wagner (wagnelib) <libor.wagner@cvut.cz>
5baa614
to
e497e18
Compare
@samuelsadok
|
looks good, thanks! |
Taking over #14
The former PR broke file structure and I made a brand new PR.
I tested it on S1. I called
/request_axis_state
with wrong state, called/clear_errors
and then called/request_axis_state
with correct state. I confirmed thatprocedure_result
is changed to 0.