2023-04-27 16:54:45 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2006-2023, RT-Thread Development Team
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2023-04-27 RealThread first version
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
#include <board.h>
|
|
|
|
#include <drv_common.h>
|
|
|
|
|
|
|
|
RT_WEAK void rt_hw_board_init()
|
|
|
|
{
|
|
|
|
extern void hw_board_init(char *clock_src, int32_t clock_src_freq, int32_t clock_target_freq);
|
|
|
|
|
|
|
|
/* Heap initialization */
|
|
|
|
#if defined(RT_USING_HEAP)
|
|
|
|
rt_system_heap_init((void *) HEAP_BEGIN, (void *) HEAP_END);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
hw_board_init(BSP_CLOCK_SOURCE, BSP_CLOCK_SOURCE_FREQ_MHZ, BSP_CLOCK_SYSTEM_FREQ_MHZ);
|
|
|
|
|
|
|
|
/* Set the shell console output device */
|
|
|
|
#if defined(RT_USING_DEVICE) && defined(RT_USING_CONSOLE)
|
|
|
|
rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Board underlying hardware initialization */
|
|
|
|
#ifdef RT_USING_COMPONENTS_INIT
|
|
|
|
rt_components_board_init();
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief SPI MSP Initialization
|
|
|
|
* This function configures the hardware resources used in this example
|
|
|
|
* @param hspi: SPI handle pointer
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi)
|
|
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
2023-05-23 14:59:35 +08:00
|
|
|
if(hspi->Instance==SPI2)
|
2023-04-27 16:54:45 +08:00
|
|
|
{
|
|
|
|
/* USER CODE BEGIN SPI1_MspInit 0 */
|
|
|
|
|
|
|
|
/* USER CODE END SPI1_MspInit 0 */
|
|
|
|
/* Peripheral clock enable */
|
2023-05-23 14:59:35 +08:00
|
|
|
__HAL_RCC_SPI2_CLK_ENABLE();
|
2023-04-27 16:54:45 +08:00
|
|
|
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
|
|
/**SPI1 GPIO Configuration
|
|
|
|
PB3 ------> SPI1_SCK
|
|
|
|
PB4 ------> SPI1_MISO
|
|
|
|
PB5 ------> SPI1_MOSI
|
|
|
|
*/
|
2023-05-23 14:59:35 +08:00
|
|
|
/**SPI2 GPIO Configuration
|
|
|
|
PB13 ------> SPI1_SCK
|
|
|
|
PB14 ------> SPI1_MISO
|
|
|
|
PB15 ------> SPI1_MOSI
|
|
|
|
*/
|
2023-04-27 16:54:45 +08:00
|
|
|
|
2023-05-23 14:59:35 +08:00
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
2023-04-27 16:54:45 +08:00
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
2023-05-23 14:59:35 +08:00
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
2023-04-27 16:54:45 +08:00
|
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SPI1_MspInit 1 */
|
|
|
|
|
|
|
|
/* USER CODE END SPI1_MspInit 1 */
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2023-04-27 17:10:08 +08:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief ADC MSP Initialization
|
|
|
|
* This function configures the hardware resources used in this example
|
|
|
|
* @param hadc: ADC handle pointer
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
|
|
|
|
{
|
|
|
|
if(hadc->Instance==ADC1)
|
|
|
|
{
|
|
|
|
/* USER CODE BEGIN ADC1_MspInit 0 */
|
|
|
|
|
|
|
|
/* USER CODE END ADC1_MspInit 0 */
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
|
|
|
/* USER CODE BEGIN ADC1_MspInit 1 */
|
|
|
|
|
|
|
|
/* USER CODE END ADC1_MspInit 1 */
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2023-04-28 11:39:00 +08:00
|
|
|
//185.47kB/103180B no ETH
|
|
|
|
/**
|
|
|
|
* @brief ETH MSP Initialization
|
|
|
|
* This function configures the hardware resources used in this example
|
|
|
|
* @param heth: ETH handle pointer
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void HAL_ETH_MspInit(ETH_HandleTypeDef* heth)
|
|
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
if(heth->Instance==ETH)
|
|
|
|
{
|
|
|
|
/* USER CODE BEGIN ETH_MspInit 0 */
|
|
|
|
|
|
|
|
/* USER CODE END ETH_MspInit 0 */
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
__HAL_RCC_ETH_CLK_ENABLE();
|
|
|
|
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
|
|
/**ETH GPIO Configuration
|
|
|
|
PC1 ------> ETH_MDC
|
|
|
|
PA1 ------> ETH_REF_CLK
|
|
|
|
PA2 ------> ETH_MDIO
|
|
|
|
PA7 ------> ETH_CRS_DV
|
|
|
|
PC4 ------> ETH_RXD0
|
|
|
|
PC5 ------> ETH_RXD1
|
|
|
|
PG11 PB11 ------> ETH_TX_EN
|
|
|
|
PG13 PB12 ------> ETH_TXD0
|
|
|
|
PG14 PB13 ------> ETH_TXD1
|
|
|
|
*/
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5;
|
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
|
|
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_7;
|
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
|
|
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_14|GPIO_PIN_13;
|
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
|
|
|
|
HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
/* ETH interrupt Init */
|
|
|
|
HAL_NVIC_SetPriority(ETH_IRQn, 0, 0);
|
|
|
|
HAL_NVIC_EnableIRQ(ETH_IRQn);
|
|
|
|
/* USER CODE BEGIN ETH_MspInit 1 */
|
|
|
|
|
|
|
|
/* USER CODE END ETH_MspInit 1 */
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void phy_reset(void)
|
|
|
|
{
|
|
|
|
rt_pin_mode(ETH_RESET_PIN, PIN_MODE_OUTPUT);
|
|
|
|
rt_pin_write(ETH_RESET_PIN, PIN_HIGH);
|
|
|
|
rt_thread_mdelay(50);
|
|
|
|
rt_pin_write(ETH_RESET_PIN, PIN_LOW);
|
|
|
|
rt_thread_mdelay(50);
|
|
|
|
rt_pin_write(ETH_RESET_PIN, PIN_HIGH);
|
|
|
|
}
|
2023-04-27 17:10:08 +08:00
|
|
|
|
2023-04-28 11:39:00 +08:00
|
|
|
//242.16 KB /51556-64564-70868 add ETH
|
2023-06-19 15:56:45 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief SD MSP Initialization
|
|
|
|
* This function configures the hardware resources used in this example
|
|
|
|
* @param hsd: SD handle pointer
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void HAL_SD_MspInit(SD_HandleTypeDef* hsd)
|
|
|
|
{
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
|
|
if(hsd->Instance==SDIO)
|
|
|
|
{
|
|
|
|
/* USER CODE BEGIN SDIO_MspInit 0 */
|
|
|
|
|
|
|
|
/* USER CODE END SDIO_MspInit 0 */
|
|
|
|
/* Peripheral clock enable */
|
|
|
|
__HAL_RCC_SDIO_CLK_ENABLE();
|
|
|
|
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOD_CLK_ENABLE();
|
|
|
|
/**SDIO GPIO Configuration
|
|
|
|
PC8 ------> SDIO_D0
|
|
|
|
PC9 ------> SDIO_D1
|
|
|
|
PC10 ------> SDIO_D2
|
|
|
|
PC11 ------> SDIO_D3
|
|
|
|
PC12 ------> SDIO_CK
|
|
|
|
PD2 ------> SDIO_CMD
|
|
|
|
*/
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10|GPIO_PIN_11
|
|
|
|
|GPIO_PIN_12;
|
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_SDIO;
|
|
|
|
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_2;
|
|
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_SDIO;
|
|
|
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
|
|
|
|
|
|
/* USER CODE BEGIN SDIO_MspInit 1 */
|
|
|
|
|
|
|
|
/* USER CODE END SDIO_MspInit 1 */
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|