-
Notifications
You must be signed in to change notification settings - Fork 17.9k
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
AP_Scripting: add bindings for servo telemetry #28857
base: master
Are you sure you want to change the base?
Conversation
7cab0c2
to
ad05ddb
Compare
This now gets the structure and adds auto generation of a bitmask check and set. This means the script writer does not need to know there is a validity bitmask in the structure. This is currently read only, but it also adds auto setting of the mask when a value is set. The only slight problem is that once set there is no way to un-set the mask from lua. One disadvantage to this method is that were stuck with the types in the structure, previously I had returned the temp in degrees by applying the scale in the getter, now were stuck with centi degrees. |
Example of the new docs markup:
First bit is the same, the stuff added is:
"valid_mask" is the keyword to enable the bitmask validity check. |
I haven't looked in detail, but it seems this can't absolutely fix the race condition because there isn't a lock protecting the telemetry data. The race window is much shorter now however, so maybe it's fixed enough? It was said in the call that there's servos which output different data at different rates anyway, so maybe comparing commanded vs. achieved just isn't possible in general. Also still curious what the size impact would be if you had one mega function which returned eleven values. |
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.
Looks OK to me but @tpwrules will review more thoroughly
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.
A couple little things in the generator but should be ready to go after!
I tested in SITL using quadplane-can and the position from four servos comes through but it's the same for all four of them. I checked that the data I could get from Lua matched the data logged in CSRV, and it all did so this PR is good, but there's still probably something funky here.
cbed113
to
19b0ebb
Compare
19b0ebb
to
e72720f
Compare
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.
Tested and still works, thanks for the fixes.
I cleaned up the history slightly and folded in another really tiny fix to the generator. Figured it was easier to do it myself then to go through review again.
Concerned whether servo telemetry needs a fix similar to #28999 but that doesn't impact this PR at all. |
|
||
const volatile TelemetryData &telem_data = _telem_data[servo_index]; | ||
|
||
// Because the structure is volatile we have to copy element wise |
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.
we could just cast to override the volatile?
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.
or could memcpy and assert types equal?
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 couldn't get casting to work. The compiler was too smart. memcpy
may work....
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.
../../libraries/AP_Servo_Telem/AP_Servo_Telem.cpp:171:20: error: invalid conversion from ‘const volatile void*’ to ‘const void*’ [-fpermissive]
171 | memcpy(&telem, &telem_data, sizeof(telem));
| ^~~~~~~~~~~
| |
| const volatile void*
compilation terminated due to -Wfatal-errors.
No, not allowed to cast for the memcpy either.
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.
try this:
telem = *const_cast<TelemetryData*>(&telem_data);
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.
memcpy(&telem, (const void*)&telem_data, sizeof(telem));
will work too. But it's not exactly kosher as the read won't be performed volatile-wise. But we should be able to trust memcpy, we're not doing any funny memory mapped stuff here. Multi-core systems need not apply...
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.
try this:
telem = *const_cast<TelemetryData*>(&telem_data);
I have changed to this. Thanks.
Fix generator to skip generation of docs for generation methods that don't exist, and to avoid generating Lua creation methods that couldn't be called. Co-authored-by: Thomas Watson <[email protected]>
e72720f
to
5c0969a
Compare
AP_Servo_Telem works subtly differently and does not suffer the same issue. The getter functions return success if that telemetry field has ever been reported, and it is up to the caller to check whether that data is stale. AP_ESC_Telem's getters return failure if the data has timed out (or if a race condition leads it to falsely conclude there has been a timeout).
Perhaps that rename should be part of this PR though. |
Adds bindings for servo telem, this allows servo checks to be done in lua.