Режим ведущего: различия между версиями
Андрей (обсуждение | вклад) Нет описания правки |
Андрей (обсуждение | вклад) Нет описания правки |
||
Строка 100: | Строка 100: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
}} | }} | ||
Создадим в функции main массив | Создадим в функции main массив master_output, который будет содержать в себе 12 байт, которые ведущий будет отправлять ведомому. Создадим массив maser_input такого же размера как и master_output для принятых данных. | ||
Обмен данными запускается с помощью функции HAL_SPI_Exchange. | Обмен данными запускается с помощью функции HAL_SPI_Exchange. | ||
Функция main | |||
{{#spoiler:show=Развернуть код|hide=Свернуть код| | |||
int main() | |||
{ | |||
SystemClock_Config(); | |||
UART_Init(UART_0, 3333, UART_CONTROL1_TE_M | UART_CONTROL1_M_8BIT_M, 0, 0); | |||
SPI0_Init(); | |||
uint8_t master_output[] = {0xA0, 0xA1, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8, 0xA9, 0xB0, 0xB1}; | |||
uint8_t master_input[sizeof(master_output)]; | |||
while (1) | |||
{ | |||
/* Передача и прием данных */ | |||
HAL_SPI_Exchange(&hspi0, master_output, master_input, sizeof(master_output)); | |||
/* Вывод принятый данных и обнуление массива master_input */ | |||
for(uint32_t i = 0; i < sizeof(master_input); i++) | |||
{ | |||
xprintf("master_input[%d] = %02x\n", i, master_input[i]); | |||
master_input[i] = 0; | |||
} | |||
for (volatile int i = 0; i < 1000000; i++); | |||
} | |||
} | |||
</syntaxhighlight> | |||
}} |
Версия от 08:19, 16 марта 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. Выглядит она так:
Кроме этого в функции SystemClock_Config приведены настройки для тактирования. Убедитесь что в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_SPI_0_M. Сама функция должна выглядеть примерно так:
Для демонстрации вывода текста в PeriphClkInit.PMClockAPB_P присутствует PM_CLOCK_UART_0_M. У вас его может не быть так как UART нужно включить отдельно. Для этого нужно подключить библиотеки uart_lib и xprintf:
Для инициализации UART в функции main после функции тактирования SystemClock_Config следует написать
UART_Init(UART_0, 3333, UART_CONTROL1_TE_M | UART_CONTROL1_M_8BIT_M, 0, 0);
Скорость UART задается делителем во втором аргументе функции. При такой записи скорость будет 9600 бод.
В начале main.c можно видеть объявление структуры с набором настроек для SPI, которую использует функция инициализации SPI0_Init.
Создадим в функции main массив master_output, который будет содержать в себе 12 байт, которые ведущий будет отправлять ведомому. Создадим массив maser_input такого же размера как и master_output для принятых данных.
Обмен данными запускается с помощью функции HAL_SPI_Exchange. Функция main