From 05a08252ff3f29b5ac684e97531a26a09e1310a9 Mon Sep 17 00:00:00 2001 From: David Sidrane Date: Wed, 23 Sep 2015 06:17:14 -1000 Subject: [PATCH] Bugfix:pthread_create retuns 0 on success and positive error on error without errono set --- src/modules/uavcan/uavcan_servers.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/modules/uavcan/uavcan_servers.cpp b/src/modules/uavcan/uavcan_servers.cpp index 52f0ce9697..824b5182e2 100644 --- a/src/modules/uavcan/uavcan_servers.cpp +++ b/src/modules/uavcan/uavcan_servers.cpp @@ -98,6 +98,7 @@ UavcanServers::~UavcanServers() if (_mutex_inited) { (void)Lock::deinit(_subnode_mutex); } + _main_node.getDispatcher().removeRxFrameListener(); } @@ -164,9 +165,9 @@ int UavcanServers::start(uavcan::INode &main_node) rv = pthread_create(&_instance->_subnode_thread, &tattr, static_cast(run_trampoline), NULL); - if (rv < 0) { - warnx("pthread_create() failed: %d", errno); - rv = -errno; + if (rv != 0) { + rv = -rv; + warnx("pthread_create() failed: %d", rv); delete _instance; _instance = nullptr; }