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

Материал из MIK32 микроконтроллер
Нет описания правки
Нет описания правки
Строка 1: Строка 1:
В примере будет проведена настройка SPI в режиме ведущего. Ведущий будет читать и передавать 12 байт.
В примере будет проведена настройка SPI в режиме ведущего. Ведущий будет читать и передавать 12 байт.
[[Файл:ImageTESTtest.png|мини|dsv]]


== Работа с конфигуратором (В разработке) ==
==Работа с конфигуратором (В разработке)==
Для начала настроем в конфигураторе тактирование mik32, например, от внешнего кварца 32МГц. Затем настроем делители шины. Так как SPI тактируется от шины APB_P_CLK, то зададим делитель AHB_DIV и APB_P_CLK. В данном примере оставим делитель по умолчанию. В итоге вкладка с тактированием должна выглядеть так:
Для начала настроем в конфигураторе тактирование mik32, например, от внешнего кварца 32МГц. Затем настроем делители шины. Так как SPI тактируется от шины APB_P_CLK, то зададим делитель AHB_DIV и APB_P_CLK. В данном примере оставим делитель по умолчанию. В итоге вкладка с тактированием должна выглядеть так:


Строка 9: Строка 8:
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек.  
Затем перейдем к настройке самого SPI. Для этого откроем вкладку интерфейсы, выберем SPI и зададим режим работы ведомый. После этого появятся несколько настроек.  


Зададим им следующие значения:
Зададим им следующие значения:  


* Делитель частоты - 64;
*Делитель частоты - 64;
* Фаза тактового сигнала - Тактовая частота активна вне слова;
*Фаза тактового сигнала - Тактовая частота активна вне слова;
* Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне;
*Полярность тактового сигнала вне слова - Тактовый сигнал удерживается на низком уровне;
* Длина передаваемой посылки - 8 бит;
*Длина передаваемой посылки - 8 бит;
* Периферийный декодер - Выбор 1 из 4 устройств;
*Периферийный декодер - Выбор 1 из 4 устройств;
* Режим управления сигналом выбора ведомого - Автоматический;
* Режим управления сигналом выбора ведомого - Автоматический;
* Ведомый - Устройство 1.
*Ведомый - Устройство 1.


В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке.
В итоге настройки SPI в конфигураторе должны выглядеть как на рисунке.
Строка 23: Строка 22:
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code.
Нажимаем кнопку сохранения и генерации. В итоге у нас появится проект для PlatformIo. Далее работа идет в visual studio code.


== Использование библиотеки HAL_SPI ==
==Использование библиотеки HAL_SPI==
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так:<syntaxhighlight lang="c" line="1">
В сгенерированном проекте в файле main.c должна быть функция SPI0_Init, в которой будут заданы настройки для SPI. Выглядит она так:<syntaxhighlight lang="c" line="1">
static void SPI0_Init(void)
static void SPI0_Init(void)

Версия от 18:55, 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. Сама функция должна выглядеть примерно так: