Skip to content
Snippets Groups Projects
Unverified Commit c5b954da authored by Beat Küng's avatar Beat Küng
Browse files

heater: fix resource leak

parent 61534818
No related branches found
No related tags found
No related merge requests found
......@@ -73,7 +73,10 @@ Heater::~Heater()
// Unsubscribe from uORB topics.
orb_unsubscribe(_params_sub);
orb_unsubscribe(_sensor_accel_sub);
if (_sensor_accel_sub >= 0) {
orb_unsubscribe(_sensor_accel_sub);
}
}
int Heater::controller_period(char *argv[])
......@@ -238,6 +241,10 @@ void Heater::initialize_topics()
for (size_t x = 0; x < number_of_imus; x++) {
_sensor_accel_sub = orb_subscribe_multi(ORB_ID(sensor_accel), (int)x);
if (_sensor_accel_sub < 0) {
continue;
}
while (orb_update(ORB_ID(sensor_accel), _sensor_accel_sub, &_sensor_accel) != PX4_OK) {
usleep(200000);
}
......@@ -247,6 +254,8 @@ void Heater::initialize_topics()
PX4_INFO("IMU sensor identified.");
break;
}
orb_unsubscribe(_sensor_accel_sub);
}
PX4_INFO("Device ID: %d", _sensor_accel.device_id);
......@@ -430,4 +439,4 @@ void Heater::update_params(const bool force)
int heater_main(int argc, char *argv[])
{
return Heater::main(argc, argv);
}
\ No newline at end of file
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment