Skip to content
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

🐛 Fix bool evalution of XYval and similar types #26936

Conversation

sjasonsmith
Copy link
Contributor

@sjasonsmith sjasonsmith commented Apr 4, 2024

Description

XYval and similar types has an operator bool() which should allow them to be easily tested for zero values in conditional expressions. This was not working, because operator T*() was being implicitly used instead, which then always evaluated to true.

By making the pointer conversion explicit, it is still accessible for use, but will not be automatically used in a boolean expression.

This was found while debugging problems in BACKLASH_COMPENSATION, where the following statement evaluated to false, even though all referenced variables contained zeroed-out data.

if (!correction && !residual_error) return;

Requirements

N/A

Benefits

Remove unintuitive behavior

Configurations

N/A

Related Issues

N/A

@sjasonsmith
Copy link
Contributor Author

@tombrazier, with this change the backlash compensation behavior is going to change. Previously this bypass would never execute, but now it can:

if (!correction && !residual_error) return;

Do you think that is going to break anything in backlash compensation? I think it will most likely just reduce overhead when this branch is taken, but I haven't examined everything closely.

@tombrazier
Copy link
Contributor

@tombrazier, with this change the backlash compensation behavior is going to change. Previously this bypass would never execute, but now it can:

if (!correction && !residual_error) return;

Do you think that is going to break anything in backlash compensation? I think it will most likely just reduce overhead when this branch is taken, but I haven't examined everything closely.

Short answer: no I don't think it will break anything.

Long answer: The check is for the case where backlash is disabled by setting the amount of correction to zero. In that situation any previously unapplied correction that is recorded in Backlash::residual_error must still get applied. However once that has happened there is no need to do the rest of the backlash logic as it will always just result in zero steps being applied. i.e. the backlash calculations are redundant. The bug that is fixed here resulted in this redundant calculation happening anyway. That is both inefficient and also not what a user would expect if they have disabled backlash compensation. I think the fix will restore the more efficient and expected behaviour.

@sjasonsmith sjasonsmith changed the title 🐛 Require explicit casts to pointer for types in types.h 🐛 Fix evaluating XYval and similar types as bool Apr 6, 2024
@sjasonsmith sjasonsmith changed the title 🐛 Fix evaluating XYval and similar types as bool 🐛 Fix bool evalution of XYval and similar types Apr 6, 2024
@sjasonsmith sjasonsmith merged commit d30fcb8 into MarlinFirmware:bugfix-2.1.x Apr 6, 2024
61 checks passed
@tombrazier
Copy link
Contributor

@thinkyhead After a long conversation on Discord there are several things I want to draw to your attention about this PR.

  • It fixes a bunch of problems, including the input shaping infinite loop in 2.1.2.2.
  • Consequently releasing a 2.1.2.3 with this PR included sounds like a good idea.
  • The reason the cast to pointer operator masked the cast to bool operator is that the cast to bool operator recently became const. When used with a non-const variable the compiler chooses to implicitly cast to pointer and then cast that to bool rather than do a const cast and then use the bool cast operator.
  • The ambiguity suggests that we might have gone overboard with cast operators.
  • Consequently, the explicit fix here might not be the best. It is possible that the cast to pointer operator is never actually used for XYval and related types. Maybe it should be removed completely.
  • And maybe the cast to bool operator should be made an explicit member function named something like all().
  • Finally, if we keep the cast operators, some kind of test code would be ideal to prevent this happening again in the future. We thought about using static_assert but I am not sure that will work.

sjasonsmith added a commit to sjasonsmith/Marlin that referenced this pull request Apr 9, 2024
@sjasonsmith sjasonsmith deleted the users/jassmith/PR/bool_failure branch April 21, 2024 16:44
thisiskeithb added a commit to thisiskeithb/Marlin that referenced this pull request Apr 28, 2024
Fixes Input Shaping bootloop among other issues. See MarlinFirmware#26936 for more information.

Co-authored-by: sjasonsmith <[email protected]>
@thisiskeithb
Copy link
Member

RPGFabi pushed a commit to RPGFabi/Marlin that referenced this pull request Jun 15, 2024
Require explicit cast to get T* pointers from XYval and similar types. This prevents the pointer from being implicitly returned and checked for nullptr when trying to evaluate these structs in boolean expressions.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants