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

gps(septentrio): add resilience information reporting #23096

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

flyingthingsintothings
Copy link
Contributor

@flyingthingsintothings flyingthingsintothings commented May 6, 2024

Solved Problem

When errors occur in attached GNSS receivers, there is no way to report them to the user so they know what is going wrong.

Solution

  • Add automatic configuration for Septentrio receivers to report resilience information every second
  • Add to Septentrio parser so it can parse the new message types
  • Change the uORB message for GNSS information to support this new information
  • Report the changes through MAVLink (submodule still needs to be updated)

Changelog Entry

For release notes:

Feature: Report resilience information from GNSS receivers
Documentation: Need to clarify page ...

Alternatives

/

Test coverage

/

Context

Another part has been implemented for QGroundControl to display this new information to users. This feature was proposed during the 2022 Developer Summit and received positive feedback. Messages to report jamming and spoofing state were already in the uORB protocol, but weren't used by any modules.

I would love to discuss this during the next Community Q&A call on Wednesday 🙂

@AlexKlimaj
Copy link
Member

One note that jamming and spoofing state is used currently by the ublox driver. I did the implementation last year.

https://github.com/PX4/PX4-GPSDrivers/blob/main/src/ubx.cpp#L2361-L2362

https://github.com/PX4/PX4-GPSDrivers/blob/main/src/ubx.cpp#L2120

@flyingthingsintothings
Copy link
Contributor Author

I did indeed notice that the u-blox driver already provides this information to the rest of the system, but it isn't really used anywhere as far as I can tell. This PR would aim to send this information to ground control stations so they can display it to the user. I used the existing uORB topics from the u-blox implementation you mentioned, but added some things to send extra information like GNSS signal authentication state.

@github-actions github-actions bot added the stale label Jun 13, 2024
@flyingthingsintothings flyingthingsintothings force-pushed the pr-resilience branch 3 times, most recently from 68cdd4e to 952b82f Compare June 21, 2024 14:30
@flyingthingsintothings
Copy link
Contributor Author

flyingthingsintothings commented Jun 21, 2024

This implementation should be ready, although there is one problem I don't know how to solve. The Septentrio driver uses get_device_id() to get the unique identifier for the GNSS receiver, but that one is the same for both instances of the module. I've looked how this function gets its id, but I don't really understand where in the code it gets generated. I can see that there are some files in NuttX that may generate this value, but I don't know specifically where. If anybody knows how to have two different ids for the two GNSS receivers, that would be a big help. Currently the code functions but QGroundControl can't differentiate between values from the main and secondary receiver because of this bug.

This is also meant as a basic implementation of the new protocol that can be further implemented in the future. For example the RAIM fields in the new MAVLink message aren't used yet. This is also only implemented for the Septentrio driver for now.

@flyingthingsintothings flyingthingsintothings marked this pull request as ready for review June 21, 2024 14:33
@flyingthingsintothings
Copy link
Contributor Author

I just noticed that most boards use the common.xml dialect from the MAVLink protocol. That one doesn't include the new message yet. Some boards like the 6X I was using for testing are already using the development.xml dialect. What is the best approach to solve this problem? Move the other boards to that dialect as well? Conditional compilation based on the dialect (if such a thing is possible)? Other options to make this PR compile?

@chiara-septentrio
Copy link

I've added a conditional include in mavlink_message.cpp as I've seen done with other types of messages using development.xml. I didn't have an issue with building when not using development.xml with this change.

@chiara-septentrio chiara-septentrio force-pushed the pr-resilience branch 2 times, most recently from 12f5219 to 09eb816 Compare August 14, 2024 12:33

_message_gps_state.system_error = sensor_gps_s::SYSTEM_ERROR_OK;

if (receiver_status.rx_error_cpu_overload)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is minor, but can you make sure that even one line if statements have braces to prevent any accidents?

Suggested change
if (receiver_status.rx_error_cpu_overload)
if (receiver_status.rx_error_cpu_overload) {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've added all the missing braces

@dagar dagar removed the stale label Aug 14, 2024
@DronecodeBot
Copy link

This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there:

https://discuss.px4.io/t/px4-sync-q-a-aug-14-2024/40168/1

@chiara-septentrio
Copy link

@dagar I've also double checked, the resilience values were already at 0 by default. It was probably already done when they were first created for Ublox.

@DronecodeBot
Copy link

This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there:

https://discuss.px4.io/t/px4-sync-q-a-aug-21-2024/40268/1

Implement support for the new MAVLink `GNSS_INTEGRITY` message and add
support to the Septentrio driver.
@chiara-septentrio
Copy link

@dagar I added comments to make more clear which value were the default ones for the new fields but I'm not sure where you would expect them to be initialized to default other than the files where it's already the case in the modules and drivers folder.

@chiara-septentrio
Copy link

Would it be possible to have an update quickly on this PR, I'm coming at the end of my internship and any hardware testing won't be possible afterward on my part.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants