mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-08 17:08:28 -04:00
HAL_ChibiOS: check bus owner on all SPI transfers
This commit is contained in:
parent
6a12b612b1
commit
4118a3eb03
@ -229,7 +229,9 @@ bool SPIDevice::clock_pulse(uint32_t n)
|
||||
acquire_bus(false, true);
|
||||
bus.semaphore.give();
|
||||
} else {
|
||||
bus.semaphore.assert_owner();
|
||||
if (!bus.semaphore.check_owner()) {
|
||||
return false;
|
||||
}
|
||||
spiIgnore(spi_devices[device_desc.bus].driver, n);
|
||||
}
|
||||
return true;
|
||||
@ -269,7 +271,6 @@ bool SPIDevice::transfer(const uint8_t *send, uint32_t send_len,
|
||||
uint8_t *recv, uint32_t recv_len)
|
||||
{
|
||||
if (!bus.semaphore.check_owner()) {
|
||||
hal.console->printf("SPI: not owner of 0x%x\n", unsigned(get_bus_id()));
|
||||
return false;
|
||||
}
|
||||
if ((send_len == recv_len && send == recv) || !send || !recv) {
|
||||
@ -292,7 +293,9 @@ bool SPIDevice::transfer(const uint8_t *send, uint32_t send_len,
|
||||
|
||||
bool SPIDevice::transfer_fullduplex(const uint8_t *send, uint8_t *recv, uint32_t len)
|
||||
{
|
||||
bus.semaphore.assert_owner();
|
||||
if (!bus.semaphore.check_owner()) {
|
||||
return false;
|
||||
}
|
||||
uint8_t buf[len];
|
||||
memcpy(buf, send, len);
|
||||
bool ret = do_transfer(buf, buf, len);
|
||||
@ -323,7 +326,9 @@ bool SPIDevice::adjust_periodic_callback(AP_HAL::Device::PeriodicHandle h, uint3
|
||||
*/
|
||||
bool SPIDevice::acquire_bus(bool set, bool skip_cs)
|
||||
{
|
||||
bus.semaphore.assert_owner();
|
||||
if (!bus.semaphore.check_owner()) {
|
||||
return false;
|
||||
}
|
||||
if (set && cs_forced) {
|
||||
return true;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user