SPI-соединение между обнаружением и bluenrg-ms
Я работаю над проектом с платой обнаружения stm32f4 (stm43f407xx), я хотел бы связаться с SPBTLE-RF (плата IDB05A1).
Я использую SPI2 с прескалером 8 (у меня 168 МГц, apb1 работает на 42 МГц, поэтому тактовая частота составляет 5,25 МГц), в таблице говорится, что Spi Clock в bluenrg-ms работает до 8 МГц, но я не могу связаться с чипом.
Я пробовал с одной платой с ядром (spi1 prescaler 4), и она работает очень хорошо, так что HW в порядке, тогда я безуспешно пробовал с двумя платами обнаружения.
Я дважды проверил все соединения, и программное обеспечение на открытии такое же, как и у платы с ядром, модифицированной только для пин-кода и часов.
Кто-нибудь работал с этим HW или может что-то подсказать?
1 ответ
Я решил! Теперь я объясняю, что я забыл объявить правильный обработчик прерываний, поскольку bluenrg использует 5-проводный SPI с выводом IRQ, который должен обрабатываться прерыванием.
Интересно, что я использую прескалер 16, потому что в противном случае он не работает, я не знаю почему, потому что с прескалером 8 тактовая частота SPI2 ниже максимальной 8 МГц. Здесь есть мой код инициализации для часов:
void SystemClock_Config(void) {
RCC_OscInitTypeDef RCC_OscInitStruct;
RCC_ClkInitTypeDef RCC_ClkInitStruct;
__HAL_RCC_PWR_CLK_ENABLE();
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
RCC_OscInitStruct.PLL.PLLM = 8;
RCC_OscInitStruct.PLL.PLLN = 336;
RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
RCC_OscInitStruct.PLL.PLLQ = 4;
HAL_RCC_OscConfig(&RCC_OscInitStruct);
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5);
HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);
HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);
HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);
}