-
Notifications
You must be signed in to change notification settings - Fork 276
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 segfault in the Breadcrumbs system #180
Conversation
Signed-off-by: Addisu Z. Taddese <addisu@openrobotics.org>
This feels like an issue we should resolve in ECS, correct? I could image this biting us and others in the future. If this is the case, could you create an issue for it? |
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.
+1 to @nkoenig 's suggestion to ticket an issue.
And a mental note to always get Data()
asap.
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.
confirmed that this fixes the crash.
I think this exposed a bigger issue with components that needs to be fixed? I imagine there are other places in the code base that do something similar with these pointers.
Edit Just refreshed my page and saw the previous comments. Yes we should ticket an issue for this.
I can create an issue, but I'm not sure what can be done because this is inherent to using a contiguous data container for the components. We can move to using something like |
Signed-off-by: Addisu Z. Taddese <addisu@openrobotics.org>
Signed-off-by: Addisu Z. Taddese <addisu@openrobotics.org>
The segfault occurred because a pointer to a component is invalidated by the creation of new components. This doesn't always happen, but if a component type had 99 items, and we take get a pointer to a component, as soon as new components of the same type are created, the underlying
std::vector
containing the component gets expanded invalidating our pointer. The underlyingstd::vector
gets expanded every 100 components.To test, run the attached world (extension is .txt because github doesn't allow .sdf files). It should crash after 2 sim seconds.
debug_breadcrumbs_crash.txt