Режим ведущего: различия между версиями

Материал из MIK32 микроконтроллер
(Новая страница: «TODO»)
 
Нет описания правки
Строка 1: Строка 1:
TODO
В примере будет проведена настройка 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. Сама функция должна выглядеть примерно так: