Режим ведомого: различия между версиями
Андрей (обсуждение | вклад) Нет описания правки |
Андрей (обсуждение | вклад) Нет описания правки |
||
Строка 8: | Строка 8: | ||
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек. Зададим им следующие значения: | Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек. Зададим им следующие значения: | ||
* Фаза тактового сигнала - Тактовая частота | * Фаза тактового сигнала - Тактовая частота неактивна вне слова; | ||
* Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне; | *Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне; | ||
* Длина передаваемой посылки - 8 бит. | *Длина передаваемой посылки - 8 бит. | ||
В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке. | В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке. | ||
Строка 16: | Строка 16: | ||
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code. | Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code. | ||
== Использование библиотеки HAL_SPI == | ==Использование библиотеки HAL_SPI== | ||
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так: | В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так: | ||
{{#spoiler:show=Развернуть код|hide=Свернуть код| | |||
<syntaxhighlight lang="c" line="1"> | <syntaxhighlight lang="c" line="1"> | ||
static void SPI0_Init(void) | static void SPI0_Init(void) | ||
Строка 35: | Строка 36: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
}} | |||
Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Сама функция должна выглядеть примерно так: | Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Сама функция должна выглядеть примерно так: | ||
{{#spoiler:show=Развернуть код|hide=Свернуть код| | |||
<syntaxhighlight lang="c" line="1"> | <syntaxhighlight lang="c" line="1"> | ||
void SystemClock_Config(void) | void SystemClock_Config(void) | ||
Строка 58: | Строка 61: | ||
HAL_RCC_ClockConfig(&PeriphClkInit); | HAL_RCC_ClockConfig(&PeriphClkInit); | ||
} | } | ||
</syntaxhighlight>Для демонстрации вывода текста в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_UART_0_M. У вас его может не быть так как UART нужно включить отдельно. В начале main.c можно видеть объявление структуры с набором настроек для крипто-блока, которую использует функция инициализации SPI0_Init.<syntaxhighlight lang="c" line="1"> | </syntaxhighlight> | ||
}} | |||
Для демонстрации вывода текста в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_UART_0_M. У вас его может не быть так как UART нужно включить отдельно. В начале main.c можно видеть объявление структуры с набором настроек для крипто-блока, которую использует функция инициализации SPI0_Init. | |||
{{#spoiler:show=Развернуть код|hide=Свернуть код| | |||
<syntaxhighlight lang="c" line="1"> | |||
SPI_HandleTypeDef hspi0; | SPI_HandleTypeDef hspi0; | ||
void SystemClock_Config(void); | void SystemClock_Config(void); | ||
static void SPI0_Init(void); | static void SPI0_Init(void); | ||
</syntaxhighlight>Создадим в функции main массив slave_output, который будет содержать в себе 12 байт, которые ведомый будет отправлять ведущему. Создадим массив slave_input такого же размера как и slave_output для принятых данных. | </syntaxhighlight> | ||
}} | |||
Создадим в функции main массив slave_output, который будет содержать в себе 12 байт, которые ведомый будет отправлять ведущему. Создадим массив slave_input такого же размера как и slave_output для принятых данных. | |||
Обмен данными запускается с помощью функции HAL_SPI_Exchange. | Обмен данными запускается с помощью функции HAL_SPI_Exchange. | ||
Функция main | Функция main | ||
{{#spoiler:show= | {{#spoiler:show=Развернуть код|hide=Свернуть код| | ||
<syntaxhighlight lang="c" line="1"> | <syntaxhighlight lang="c" line="1"> | ||
int main() | int main() | ||
Строка 99: | Строка 108: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
}} |
Версия от 07:37, 16 марта 2023
В примере будет проведена настройка SPI в режиме ведомого. Ведомый будет читать и передавать 12 байт.
Работа с конфигуратором (В разработке)
Для начала настроем в конфигураторе тактирование mik32, например, от внешнего кварца 32МГц. Затем настроем делители шины. Так как SPI тактируется от шины APB_P_CLK, то зададим делитель AHB_DIV и APB_P_CLK. В данном примере оставим делитель по умолчанию. В итоге вкладка с тактированием должна выглядеть так:
(Картинка тактирования из конфигуратора. В работе)
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек. Зададим им следующие значения:
- Фаза тактового сигнала - Тактовая частота неактивна вне слова;
- Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне;
- Длина передаваемой посылки - 8 бит.
В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке.
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code.
Использование библиотеки HAL_SPI
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так:
Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Сама функция должна выглядеть примерно так:
Для демонстрации вывода текста в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_UART_0_M. У вас его может не быть так как UART нужно включить отдельно. В начале main.c можно видеть объявление структуры с набором настроек для крипто-блока, которую использует функция инициализации SPI0_Init.
Создадим в функции main массив slave_output, который будет содержать в себе 12 байт, которые ведомый будет отправлять ведущему. Создадим массив slave_input такого же размера как и slave_output для принятых данных.
Обмен данными запускается с помощью функции HAL_SPI_Exchange.
Функция main