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

AP_Scripting: add bindings for servo telemetry #28857

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

IamPete1
Copy link
Member

Adds bindings for servo telem, this allows servo checks to be done in lua.

@IamPete1
Copy link
Member Author

For refence attempt 1 cost 1500 bytes or so.
image

@IamPete1
Copy link
Member Author

IamPete1 commented Dec 21, 2024

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.

@IamPete1
Copy link
Member Author

Example of the new docs markup:

userdata AP_Servo_Telem::TelemetryData field command_position float'skip_check read valid_mask valid_types AP_Servo_Telem::TelemetryData::Types::COMMANDED_POSITION

First bit is the same, the stuff added is:

valid_mask valid_types AP_Servo_Telem::TelemetryData::Types::COMMANDED_POSITION

"valid_mask" is the keyword to enable the bitmask validity check.
"valid_types" is the variable name on the "AP_Servo_Telem::TelemetryData" object.
"AP_Servo_Telem::TelemetryData::Types::COMMANDED_POSITION" is the bitmask value that the mask should be checked against.

@IamPete1 IamPete1 requested a review from tpwrules December 21, 2024 04:05
@IamPete1
Copy link
Member Author

Now only costs about 1K, so saves 400 bytes over the individual getters.

image

@tpwrules
Copy link
Contributor

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.

Copy link
Contributor

@rmackay9 rmackay9 left a 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

Copy link
Contributor

@tpwrules tpwrules left a 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.

libraries/AP_Scripting/generator/src/main.c Outdated Show resolved Hide resolved
libraries/AP_Scripting/generator/src/main.c Outdated Show resolved Hide resolved
libraries/AP_Scripting/generator/src/main.c Outdated Show resolved Hide resolved
libraries/AP_Scripting/generator/src/main.c Outdated Show resolved Hide resolved
libraries/AP_Scripting/generator/src/main.c Outdated Show resolved Hide resolved
@IamPete1 IamPete1 force-pushed the servo_telem_scr branch 2 times, most recently from cbed113 to 19b0ebb Compare January 1, 2025 16:03
@IamPete1 IamPete1 requested a review from tpwrules January 1, 2025 16:07
@tpwrules tpwrules dismissed tridge’s stale review January 5, 2025 04:37

race condition (mostly) fixed

Copy link
Contributor

@tpwrules tpwrules left a 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.

@tpwrules
Copy link
Contributor

tpwrules commented Jan 5, 2025

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
Copy link
Contributor

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?

Copy link
Contributor

@tridge tridge Jan 6, 2025

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?

Copy link
Member Author

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....

Copy link
Member Author

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.

Copy link
Contributor

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);

Copy link
Contributor

@tpwrules tpwrules Jan 7, 2025

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...

Copy link
Member Author

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.

IamPete1 and others added 4 commits January 7, 2025 01:18
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]>
@robertlong13
Copy link
Collaborator

robertlong13 commented Jan 8, 2025

Concerned whether servo telemetry needs a fix similar to #28999 but that doesn't impact this PR at all.

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).

AP_Servo_Telem::stale suffers the same potential race condition, but that function is only used by AP_Servo_Telem::valid and that function is unused. The lua bindings use the valid_mask instead of AP_Servo_Telem::valid, which should probably be named to present_mask since it's the mask checked by AP_Servo_Telem::present. AP_Servo_Telem::valid requires things to be both present and fresh.

Perhaps that rename should be part of this PR though.

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.

6 participants