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

Crash after dynamically adding plugin DiffDrive to non-existing entity #2512

Closed
gzfuzz opened this issue Aug 5, 2024 · 1 comment
Closed
Labels
bug Something isn't working

Comments

@gzfuzz
Copy link

gzfuzz commented Aug 5, 2024

Environment

  • OS Version: Ubuntu 22.04
  • Source or binary build?
    source build
    gz-sim version: 907efc3
    built with
    gcc version: 11.4.0 (Ubuntu 11.4.0-1ubuntu1~22.04)
    build options: -DCMAKE_BUILD_TYPE=Coverage

Description

  • Expected behavior: Gazebo doesn't crash
  • Actual behavior: Gazebo crashes

Steps to reproduce

  1. gz sim a.txt -r
  2. add plugin DiffDrive with gz service command, to a non-existing entity id
gz service --timeout 10000 -s /world/world_0/entity/system/add --reptype gz.msgs.Boolean --reqtype gz.msgs.EntityPlugin_V --req 'entity {
  id: 100
}
plugins {
  name: "gz::sim::systems::DiffDrive"
  filename: "gz-sim-diff-drive-system"
  innerxml: "<left_joint>front_left_wheel_joint</left_joint>\n        \n<left_joint>rear_left_wheel_joint</left_joint>\n        \n<right_joint>front_right_wheel_joint</right_joint>\n        \n<right_joint>rear_right_wheel_joint</right_joint>\n        \n<wheel_separation>1.25</wheel_separation>\n        \n<wheel_radius>0.3</wheel_radius>\n        \n<max_linear_acceleration>1</max_linear_acceleration>\n        \n<min_linear_acceleration>-1</min_linear_acceleration>\n        \n<max_angular_acceleration>2</max_angular_acceleration>\n        \n<min_angular_acceleration>-2</min_angular_acceleration>\n        \n<max_linear_velocity>0.5</max_linear_velocity>\n        \n<min_linear_velocity>-0.5</min_linear_velocity>\n        \n<max_angular_velocity>1</max_angular_velocity>\n        \n<min_angular_velocity>-1</min_angular_velocity>\n      "}'

Also similar to #2508. Cause seems to be here?

void DiffDrivePrivate::UpdateVelocity(const UpdateInfo &_info,

Output

[Err] [EntityComponentManager.cc:1083] Trying to create a component of type [9904571861011273795] attached to entity [100], but this entity does not exist. This create component request will be ignored.
[Err] [DiffDrive.cc:185] DiffDrive plugin should be attached to a model entity. Failed to initialize.
Stack trace (most recent call last) in thread 237459:
#16   Object "[0xffffffffffffffff]", at 0xffffffffffffffff, in
#15   Object "/lib/x86_64-linux-gnu/libc.so.6", at 0x7ff6cad4084f, in
#14   Object "/lib/x86_64-linux-gnu/libc.so.6", at 0x7ff6cacaeac2, in
#13   Object "/lib/x86_64-linux-gnu/libstdc++.so.6", at 0x7ff6c69eb252, in
#12   Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c468ac8f, in
#11   Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c468accf, in
#10   Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c468ad43, in
#9    Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c468ae15, in
#8    Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c468aead, in
#7    Object "/home/ren/play/robot/workspace/install/lib/libgz-sim8.so.8", at 0x7ff6c467afb1, in
#6    Object "/data/play/robot/workspace/install/lib/gz-sim-8/plugins/libgz-sim-diff-drive-system.so", at 0x7ff685da7326, in gz::sim::v8::systems::DiffDrive::PostUpdate(gz::sim::v8::UpdateInfo const&, gz::sim::v8::EntityComponentManager const&)
#5    Object "/data/play/robot/workspace/install/lib/gz-sim-8/plugins/libgz-sim-diff-drive-system.so", at 0x7ff685da8e22, in gz::sim::v8::systems::DiffDrivePrivate::UpdateVelocity(gz::sim::v8::UpdateInfo const&, gz::sim::v8::EntityComponentManager const&)
#4    Object "/home/ren/play/robot/workspace/install/lib/libgz-math7.so.7", at 0x7ff6bf4a48e9, in gz::math::v7::SpeedLimiter::Limit(double&, double, double, std::chrono::duration<long, std::ratio<1l, 1000000000l> >) const
#3    Object "/home/ren/play/robot/workspace/install/lib/libgz-math7.so.7", at 0x7ff6bf4a4e0e, in gz::math::v7::SpeedLimiter::LimitJerk(double&, double, double, std::chrono::duration<long, std::ratio<1l, 1000000000l> >) const
#2    Object "/home/ren/play/robot/workspace/install/lib/libgz-math7.so.7", at 0x7ff6bf4a5341, in std::unique_ptr<gz::math::v7::SpeedLimiterPrivate, std::default_delete<gz::math::v7::SpeedLimiterPrivate> >::operator->() const
#1    Object "/home/ren/play/robot/workspace/install/lib/libgz-math7.so.7", at 0x7ff6bf4a5531, in std::unique_ptr<gz::math::v7::SpeedLimiterPrivate, std::default_delete<gz::math::v7::SpeedLimiterPrivate> >::get() const
#0    Object "/home/ren/play/robot/workspace/install/lib/libgz-math7.so.7", at 0x7ff6bf4a5680, in std::__uniq_ptr_impl<gz::math::v7::SpeedLimiterPrivate, std::default_delete<gz::math::v7::SpeedLimiterPrivate> >::_M_ptr() const
Segmentation fault (Address not mapped to object [(nil)])
@gzfuzz gzfuzz added the bug Something isn't working label Aug 5, 2024
@iche033
Copy link
Contributor

iche033 commented Aug 7, 2024

#2516

@iche033 iche033 closed this as completed Aug 7, 2024
@github-project-automation github-project-automation bot moved this from In progress to Done in Core development Aug 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
Archived in project
Development

No branches or pull requests

2 participants