From c328d9a5317bfb78730a8c9336274aec821ef56f Mon Sep 17 00:00:00 2001 From: Andy Piper Date: Sat, 4 Jun 2022 12:56:10 +0100 Subject: [PATCH] AP_InertialSensor: don't print error when probing non-existant BMI270 fix device locking at startup on BMI270 --- .../AP_InertialSensor_BMI270.cpp | 27 ++++++++++--------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/libraries/AP_InertialSensor/AP_InertialSensor_BMI270.cpp b/libraries/AP_InertialSensor/AP_InertialSensor_BMI270.cpp index 9800db8a26..ed1dc70758 100644 --- a/libraries/AP_InertialSensor/AP_InertialSensor_BMI270.cpp +++ b/libraries/AP_InertialSensor/AP_InertialSensor_BMI270.cpp @@ -482,11 +482,12 @@ void AP_InertialSensor_BMI270::poll_data() bool AP_InertialSensor_BMI270::hardware_init() { - bool ret = false; + bool init = false; + bool read_chip_id = false; hal.scheduler->delay(BMI270_POWERUP_DELAY_MSEC); - _dev->get_semaphore()->take_blocking(); + WITH_SEMAPHORE(_dev->get_semaphore()); _dev->set_speed(AP_HAL::Device::SPEED_LOW); @@ -512,6 +513,9 @@ bool AP_InertialSensor_BMI270::hardware_init() continue; } + // successfully identified the chip, proceed with initialisation + read_chip_id = true; + // disable power save write_register(BMI270_REG_PWR_CONF, 0x00); hal.scheduler->delay(1); // needs to be at least 450us @@ -532,7 +536,7 @@ bool AP_InertialSensor_BMI270::hardware_init() read_registers(BMI270_REG_INTERNAL_STATUS, &status, 1); if ((status & 1) == 1) { - ret = true; + init = true; hal.console->printf("BMI270 initialized after %d retries\n", i+1); break; } @@ -540,19 +544,16 @@ bool AP_InertialSensor_BMI270::hardware_init() _dev->set_speed(AP_HAL::Device::SPEED_HIGH); - _dev->get_semaphore()->give(); - return ret; + if (read_chip_id && !init) { + hal.console->printf("BMI270: failed to init\n"); + } + + return init; } bool AP_InertialSensor_BMI270::init() { - bool ret = false; _dev->set_read_flag(0x80); - ret = hardware_init(); - if (!ret) { - hal.console->printf("BMI270: failed to init\n"); - } - - return ret; -} \ No newline at end of file + return hardware_init(); +}