mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-23 17:18:28 -04:00
HAL_PX4: fixed a race condition on i2c init
we could call init on two devices with the same name, which caused init_ok to be false. This could cause the SMBus battery to fail to initialise Thanks to Michael duBreuil for finding this!
This commit is contained in:
parent
b6404ff26b
commit
3402d07651
@ -155,6 +155,9 @@ static int main_loop(int argc, char **argv)
|
||||
hal.uartE->begin(57600);
|
||||
hal.scheduler->init();
|
||||
|
||||
// init the I2C wrapper class
|
||||
PX4_I2C::init_lock();
|
||||
|
||||
/*
|
||||
run setup() at low priority to ensure CLI doesn't hang the
|
||||
system, and to allow initial sensor read loops to run
|
||||
|
@ -22,6 +22,7 @@
|
||||
namespace PX4 {
|
||||
|
||||
uint8_t PX4::PX4_I2C::instance;
|
||||
pthread_mutex_t PX4::PX4_I2C::instance_lock;
|
||||
|
||||
DeviceBus I2CDevice::businfo[I2CDevice::num_buses];
|
||||
|
||||
@ -72,14 +73,19 @@ bool PX4_I2C::do_transfer(uint8_t address, const uint8_t *send, uint32_t send_le
|
||||
{
|
||||
set_address(address);
|
||||
if (!init_done) {
|
||||
if (pthread_mutex_lock(&instance_lock) != 0) {
|
||||
return false;
|
||||
}
|
||||
init_done = true;
|
||||
// we do late init() so we can setup the device paths
|
||||
|
||||
snprintf(devname, sizeof(devname), "AP_I2C_%u", instance);
|
||||
snprintf(devpath, sizeof(devpath), "/dev/api2c%u", instance);
|
||||
init_ok = (init() == OK);
|
||||
if (init_ok) {
|
||||
instance++;
|
||||
}
|
||||
pthread_mutex_unlock(&instance_lock);
|
||||
}
|
||||
if (!init_ok) {
|
||||
return false;
|
||||
|
@ -23,9 +23,15 @@ public:
|
||||
}
|
||||
|
||||
uint8_t map_bus_number(uint8_t bus) const;
|
||||
|
||||
// setup instance_lock
|
||||
static void init_lock(void) {
|
||||
pthread_mutex_init(&instance_lock, nullptr);
|
||||
}
|
||||
|
||||
private:
|
||||
static uint8_t instance;
|
||||
static pthread_mutex_t instance_lock;
|
||||
bool init_done;
|
||||
bool init_ok;
|
||||
char devname[10];
|
||||
|
Loading…
Reference in New Issue
Block a user