From eca634ec6278d30d3fa00b532def49336ddff5ce Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Tue, 29 May 2018 21:01:58 +1000 Subject: [PATCH] HAL_ChibiOS: support 6 SPI buses --- libraries/AP_HAL_ChibiOS/SPIDevice.cpp | 20 ++++++++++++++------ libraries/AP_HAL_ChibiOS/SPIDevice.h | 1 + 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/libraries/AP_HAL_ChibiOS/SPIDevice.cpp b/libraries/AP_HAL_ChibiOS/SPIDevice.cpp index decafc71e4..29a777f437 100644 --- a/libraries/AP_HAL_ChibiOS/SPIDevice.cpp +++ b/libraries/AP_HAL_ChibiOS/SPIDevice.cpp @@ -36,10 +36,12 @@ extern const AP_HAL::HAL& hal; #define SPI2_CLOCK STM32_PCLK1 #define SPI3_CLOCK STM32_PCLK1 #define SPI4_CLOCK STM32_PCLK2 +#define SPI5_CLOCK STM32_PCLK2 +#define SPI6_CLOCK STM32_PCLK2 // expected bus clock speeds -static const uint32_t bus_clocks[4] = { - SPI1_CLOCK, SPI2_CLOCK, SPI3_CLOCK, SPI4_CLOCK +static const uint32_t bus_clocks[6] = { + SPI1_CLOCK, SPI2_CLOCK, SPI3_CLOCK, SPI4_CLOCK, SPI5_CLOCK, SPI6_CLOCK }; static const struct SPIDriverInfo { @@ -177,10 +179,9 @@ bool SPIDevice::clock_pulse(uint32_t n) return true; } -uint16_t SPIDevice::derive_freq_flag(uint32_t _frequency) +uint16_t SPIDevice::derive_freq_flag_bus(uint8_t busid, uint32_t _frequency) { uint32_t spi_clock_freq = SPI1_CLOCK; - uint8_t busid = spi_devices[device_desc.bus].busid; if (busid > 0 && busid-1 < ARRAY_SIZE_SIMPLE(bus_clocks)) { spi_clock_freq = bus_clocks[busid-1] / 2; } @@ -198,6 +199,12 @@ uint16_t SPIDevice::derive_freq_flag(uint32_t _frequency) return i * SPI_CR1_BR_0; } +uint16_t SPIDevice::derive_freq_flag(uint32_t _frequency) +{ + uint8_t busid = spi_devices[device_desc.bus].busid; + return derive_freq_flag_bus(busid, _frequency); +} + bool SPIDevice::transfer(const uint8_t *send, uint32_t send_len, uint8_t *recv, uint32_t recv_len) { @@ -360,8 +367,9 @@ void SPIDevice::test_clock_freq(void) uint8_t *buf = (uint8_t *)hal.util->malloc_type(len, AP_HAL::Util::MEM_DMA_SAFE); for (uint8_t i=0; iprintf("SPI[%u] clock=%u\n", spi_devices[i].busid, unsigned(256ULL * 1000000ULL * len * 8ULL / uint64_t(t1 - t0))); + hal.console->printf("SPI[%u] clock=%u\n", spi_devices[i].busid, unsigned(1000000ULL * len * 8ULL / uint64_t(t1 - t0))); } hal.util->free_type(buf, len, AP_HAL::Util::MEM_DMA_SAFE); } diff --git a/libraries/AP_HAL_ChibiOS/SPIDevice.h b/libraries/AP_HAL_ChibiOS/SPIDevice.h index 9a9849e858..be94e204ad 100644 --- a/libraries/AP_HAL_ChibiOS/SPIDevice.h +++ b/libraries/AP_HAL_ChibiOS/SPIDevice.h @@ -113,6 +113,7 @@ private: char *pname; bool cs_forced; static void *spi_thread(void *arg); + static uint16_t derive_freq_flag_bus(uint8_t busid, uint32_t _frequency); uint16_t derive_freq_flag(uint32_t _frequency); };