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);
}
Другие вопросы по тегам