fsfw/src/fsfw_hal/stm32h7/spi/spiDefinitions.cpp

47 lines
1.3 KiB
C++
Raw Normal View History

2021-08-02 20:58:56 +02:00
#include "fsfw_hal/stm32h7/spi/spiDefinitions.h"
2021-07-13 19:19:25 +02:00
void spi::assignSpiMode(SpiModes spiMode, SPI_HandleTypeDef& spiHandle) {
2022-02-02 10:29:30 +01:00
switch (spiMode) {
case (SpiModes::MODE_0): {
spiHandle.Init.CLKPolarity = SPI_POLARITY_LOW;
spiHandle.Init.CLKPhase = SPI_PHASE_1EDGE;
break;
2021-07-13 19:19:25 +02:00
}
2022-02-02 10:29:30 +01:00
case (SpiModes::MODE_1): {
spiHandle.Init.CLKPolarity = SPI_POLARITY_LOW;
spiHandle.Init.CLKPhase = SPI_PHASE_2EDGE;
break;
2021-07-13 19:19:25 +02:00
}
2022-02-02 10:29:30 +01:00
case (SpiModes::MODE_2): {
spiHandle.Init.CLKPolarity = SPI_POLARITY_HIGH;
spiHandle.Init.CLKPhase = SPI_PHASE_1EDGE;
break;
2021-07-13 19:19:25 +02:00
}
2022-02-02 10:29:30 +01:00
case (SpiModes::MODE_3): {
spiHandle.Init.CLKPolarity = SPI_POLARITY_HIGH;
spiHandle.Init.CLKPhase = SPI_PHASE_2EDGE;
break;
2021-07-13 19:19:25 +02:00
}
2022-02-02 10:29:30 +01:00
}
2021-07-13 19:19:25 +02:00
}
uint32_t spi::getPrescaler(uint32_t clock_src_freq, uint32_t baudrate_mbps) {
2022-02-02 10:29:30 +01:00
uint32_t divisor = 0;
uint32_t spi_clk = clock_src_freq;
uint32_t presc = 0;
static const uint32_t baudrate[] = {
SPI_BAUDRATEPRESCALER_2, SPI_BAUDRATEPRESCALER_4, SPI_BAUDRATEPRESCALER_8,
SPI_BAUDRATEPRESCALER_16, SPI_BAUDRATEPRESCALER_32, SPI_BAUDRATEPRESCALER_64,
SPI_BAUDRATEPRESCALER_128, SPI_BAUDRATEPRESCALER_256,
};
2021-07-13 19:19:25 +02:00
2022-02-02 10:29:30 +01:00
while (spi_clk > baudrate_mbps) {
presc = baudrate[divisor];
if (++divisor > 7) break;
2021-07-13 19:19:25 +02:00
2022-02-02 10:29:30 +01:00
spi_clk = (spi_clk >> 1);
}
2021-07-13 19:19:25 +02:00
2022-02-02 10:29:30 +01:00
return presc;
2021-07-13 19:19:25 +02:00
}