mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 17:38:32 -04:00
AP_InertialSensor: refactor constructors to avoid leak
We were previously leaking the AP_MPU6000_BusDriver if the ~AP_InertialSensor_MPU6000::detect*() failed. In order to avoid the leak move the repeated code in a single private _detect() member that receives everything as argument. Then this method takes ownership of the objects. By a adding a destructor to AP_InertialSensor_MPU6000 it becomes easier to free the objects it takes ownership of.
This commit is contained in:
parent
c3063f0ab2
commit
cf1273668e
@ -394,35 +394,45 @@ AP_InertialSensor_MPU6000::AP_InertialSensor_MPU6000(AP_InertialSensor &imu, AP_
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
AP_InertialSensor_MPU6000::~AP_InertialSensor_MPU6000()
|
||||||
detect the sensor
|
|
||||||
*/
|
|
||||||
AP_InertialSensor_Backend *AP_InertialSensor_MPU6000::detect_spi(AP_InertialSensor &_imu)
|
|
||||||
{
|
{
|
||||||
AP_InertialSensor_MPU6000 *sensor = new AP_InertialSensor_MPU6000(_imu, new AP_MPU6000_BusDriver_SPI());
|
delete _bus;
|
||||||
if (sensor == NULL) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
if (!sensor->_init_sensor()) {
|
|
||||||
delete sensor;
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return sensor;
|
/* Detect the sensor on SPI bus. It must have a corresponding device on
|
||||||
|
* SPIDriver table */
|
||||||
|
AP_InertialSensor_Backend *AP_InertialSensor_MPU6000::detect_spi(AP_InertialSensor &imu)
|
||||||
|
{
|
||||||
|
AP_MPU6000_BusDriver *bus = new AP_MPU6000_BusDriver_SPI();
|
||||||
|
if (!bus)
|
||||||
|
return nullptr;
|
||||||
|
return _detect(imu, bus);
|
||||||
}
|
}
|
||||||
|
|
||||||
AP_InertialSensor_Backend *AP_InertialSensor_MPU6000::detect_i2c(AP_InertialSensor &_imu,
|
/* Detect the sensor on the specified I2C bus and address */
|
||||||
|
AP_InertialSensor_Backend *AP_InertialSensor_MPU6000::detect_i2c(AP_InertialSensor &imu,
|
||||||
AP_HAL::I2CDriver *i2c,
|
AP_HAL::I2CDriver *i2c,
|
||||||
uint8_t addr)
|
uint8_t addr)
|
||||||
{
|
{
|
||||||
AP_InertialSensor_MPU6000 *sensor = new AP_InertialSensor_MPU6000(_imu,
|
AP_MPU6000_BusDriver *bus = new AP_MPU6000_BusDriver_I2C(i2c, addr);
|
||||||
new AP_MPU6000_BusDriver_I2C(i2c, addr));
|
if (!bus)
|
||||||
|
return nullptr;
|
||||||
|
return _detect(imu, bus);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Common detection method - it takes ownership of the bus, freeing it if it's
|
||||||
|
* not possible to return an AP_InertialSensor_Backend */
|
||||||
|
AP_InertialSensor_Backend *AP_InertialSensor_MPU6000::_detect(AP_InertialSensor &_imu,
|
||||||
|
AP_MPU6000_BusDriver *bus)
|
||||||
|
{
|
||||||
|
AP_InertialSensor_MPU6000 *sensor = new AP_InertialSensor_MPU6000(_imu, bus);
|
||||||
if (sensor == NULL) {
|
if (sensor == NULL) {
|
||||||
return NULL;
|
delete bus;
|
||||||
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (!sensor->_init_sensor()) {
|
if (!sensor->_init_sensor()) {
|
||||||
delete sensor;
|
delete sensor;
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
return sensor;
|
return sensor;
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
class AP_MPU6000_BusDriver
|
class AP_MPU6000_BusDriver
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
virtual ~AP_MPU6000_BusDriver() { };
|
||||||
virtual void init(bool &fifo_mode, uint8_t &max_samples) = 0;
|
virtual void init(bool &fifo_mode, uint8_t &max_samples) = 0;
|
||||||
virtual void read8(uint8_t reg, uint8_t *val) = 0;
|
virtual void read8(uint8_t reg, uint8_t *val) = 0;
|
||||||
virtual void write8(uint8_t reg, uint8_t val) = 0;
|
virtual void write8(uint8_t reg, uint8_t val) = 0;
|
||||||
@ -45,6 +46,7 @@ class AP_InertialSensor_MPU6000 : public AP_InertialSensor_Backend
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
AP_InertialSensor_MPU6000(AP_InertialSensor &imu, AP_MPU6000_BusDriver *bus);
|
AP_InertialSensor_MPU6000(AP_InertialSensor &imu, AP_MPU6000_BusDriver *bus);
|
||||||
|
~AP_InertialSensor_MPU6000();
|
||||||
static AP_InertialSensor_Backend *detect_i2c(AP_InertialSensor &_imu,
|
static AP_InertialSensor_Backend *detect_i2c(AP_InertialSensor &_imu,
|
||||||
AP_HAL::I2CDriver *i2c,
|
AP_HAL::I2CDriver *i2c,
|
||||||
uint8_t addr);
|
uint8_t addr);
|
||||||
@ -57,6 +59,9 @@ public:
|
|||||||
bool accel_sample_available(void) { return _sum_count >= _sample_count; }
|
bool accel_sample_available(void) { return _sum_count >= _sample_count; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static AP_InertialSensor_Backend *_detect(AP_InertialSensor &_imu,
|
||||||
|
AP_MPU6000_BusDriver *bus);
|
||||||
|
|
||||||
#if MPU6000_DEBUG
|
#if MPU6000_DEBUG
|
||||||
void _dump_registers(void);
|
void _dump_registers(void);
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user