From 66fdfbb85094b2d1e399aadae2d40bd237b96d83 Mon Sep 17 00:00:00 2001 From: Murilo Belluzzo Date: Mon, 11 Jul 2016 20:03:44 -0300 Subject: [PATCH] AP_RangeFinder_LightWareI2C: Fix driver after I2CDevice conversion * Fix semaphore not being released in ::get_reading * Simplify semaphore releasing logic * Fix typo --- .../AP_RangeFinder_LightWareI2C.cpp | 27 +++++++++---------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/libraries/AP_RangeFinder/AP_RangeFinder_LightWareI2C.cpp b/libraries/AP_RangeFinder/AP_RangeFinder_LightWareI2C.cpp index abb43dcce3..330975fa0d 100644 --- a/libraries/AP_RangeFinder/AP_RangeFinder_LightWareI2C.cpp +++ b/libraries/AP_RangeFinder/AP_RangeFinder_LightWareI2C.cpp @@ -21,7 +21,7 @@ extern const AP_HAL::HAL& hal; /* - The constructor also initialises the rangefinder. Note that this + The constructor also initializes the rangefinder. Note that this constructor is not called until detect() returns true, so we already know that we should setup the rangefinder */ @@ -54,29 +54,26 @@ AP_RangeFinder_Backend *AP_RangeFinder_LightWareI2C::detect(RangeFinder &_ranger // read - return last value measured by sensor bool AP_RangeFinder_LightWareI2C::get_reading(uint16_t &reading_cm) { + uint8_t buff[2]; + + if (ranger._address[state.instance] == 0) { + return false; + } + // exit immediately if we can't take the semaphore if (!_dev->get_semaphore()->take(1)) { return false; } - if (ranger._address[state.instance] == 0) { - return false; - } - - uint8_t buff[2]; // read the high and low byte distance registers - if (!_dev->read(buff, sizeof(buff))) { - _dev->get_semaphore()->give(); - return false; + bool ret = _dev->read(buff, sizeof(buff)); + if (ret) { + // combine results into distance + reading_cm = ((uint16_t)buff[0]) << 8 | buff[1]; } - // combine results into distance - reading_cm = ((uint16_t)buff[0]) << 8 | buff[1]; - - // return semaphore _dev->get_semaphore()->give(); - - return true; + return ret; } /*