Режим ведущего: различия между версиями
Андрей (обсуждение | вклад) (Новая страница: «TODO») |
Андрей (обсуждение | вклад) Нет описания правки |
||
Строка 1: | Строка 1: | ||
В примере будет проведена настройка SPI в режиме ведущего. Ведущий будет читать и передавать 12 байт. | |||
== Работа с конфигуратором (В разработке) == | |||
Для начала настроем в конфигураторе тактирование mik32, например, от внешнего кварца 32МГц. Затем настроем делители шины. Так как SPI тактируется от шины APB_P_CLK, то зададим делитель AHB_DIV и APB_P_CLK. В данном примере оставим делитель по умолчанию. В итоге вкладка с тактированием должна выглядеть так: | |||
(Картинка тактирования из конфигуратора. В работе) | |||
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек. | |||
Зададим им следующие значения: | |||
* Делитель частоты - 64; | |||
* Фаза тактового сигнала - Тактовая частота активна вне слова; | |||
* Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне; | |||
* Длина передаваемой посылки - 8 бит; | |||
* Периферийный декодер - Выбор 1 из 4 устройств; | |||
* Режим управления сигналом выбора ведомого - Автоматический; | |||
* Ведомый - Устройство 1. | |||
В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке. | |||
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code. | |||
== Использование библиотеки HAL_SPI == | |||
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так:<syntaxhighlight lang="c" line="1"> | |||
static void SPI0_Init(void) | |||
{ | |||
hspi0.Instance = SPI_0; | |||
/* Режим SPI */ | |||
hspi0.Init.SPI_Mode = HAL_SPI_MODE_MASTER; | |||
/* Настройки */ | |||
hspi0.Init.BaudRateDiv = SPI_BAUDRATE_DIV64; | |||
hspi0.Init.CLKPhase = SPI_PHASE_OFF; | |||
hspi0.Init.CLKPolarity = SPI_POLARITY_LOW; | |||
hspi0.Init.Decoder = SPI_DECODER_NONE; | |||
hspi0.Init.DataSize = SPI_DATASIZE_8BITS; | |||
/* Натсройки для ведущего */ | |||
hspi0.Init.ManualCS = SPI_MANUALCS_OFF; /* Настройки ручного режима управления сигналом CS */ | |||
hspi0.ChipSelect = SPI_CS_0; /* Выбор ведомого устройства в атоматическом режиме управления CS */ | |||
HAL_SPI_Init(&hspi0); | |||
} | |||
</syntaxhighlight>Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Если вы хотите использовать UART для отладки, то добавьте в PM_CLOCK_UART_0_M в PeriphClkInit.PMClockAPB_P. Сама функция должна выглядеть примерно так: |
Версия от 14:32, 13 марта 2023
В примере будет проведена настройка SPI в режиме ведущего. Ведущий будет читать и передавать 12 байт.
Работа с конфигуратором (В разработке)
Для начала настроем в конфигураторе тактирование mik32, например, от внешнего кварца 32МГц. Затем настроем делители шины. Так как SPI тактируется от шины APB_P_CLK, то зададим делитель AHB_DIV и APB_P_CLK. В данном примере оставим делитель по умолчанию. В итоге вкладка с тактированием должна выглядеть так:
(Картинка тактирования из конфигуратора. В работе)
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек.
Зададим им следующие значения:
- Делитель частоты - 64;
- Фаза тактового сигнала - Тактовая частота активна вне слова;
- Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне;
- Длина передаваемой посылки - 8 бит;
- Периферийный декодер - Выбор 1 из 4 устройств;
- Режим управления сигналом выбора ведомого - Автоматический;
- Ведомый - Устройство 1.
В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке.
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code.
Использование библиотеки HAL_SPI
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так:
static void SPI0_Init(void) { hspi0.Instance = SPI_0; /* Режим SPI */ hspi0.Init.SPI_Mode = HAL_SPI_MODE_MASTER; /* Настройки */ hspi0.Init.BaudRateDiv = SPI_BAUDRATE_DIV64; hspi0.Init.CLKPhase = SPI_PHASE_OFF; hspi0.Init.CLKPolarity = SPI_POLARITY_LOW; hspi0.Init.Decoder = SPI_DECODER_NONE; hspi0.Init.DataSize = SPI_DATASIZE_8BITS; /* Натсройки для ведущего */ hspi0.Init.ManualCS = SPI_MANUALCS_OFF; /* Настройки ручного режима управления сигналом CS */ hspi0.ChipSelect = SPI_CS_0; /* Выбор ведомого устройства в атоматическом режиме управления CS */ HAL_SPI_Init(&hspi0); }
Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Если вы хотите использовать UART для отладки, то добавьте в PM_CLOCK_UART_0_M в PeriphClkInit.PMClockAPB_P. Сама функция должна выглядеть примерно так: