405 lines
11 KiB
C
405 lines
11 KiB
C
/*
|
|
* 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};
|
|
if(hspi->Instance==SPI2)
|
|
{
|
|
/* USER CODE BEGIN SPI1_MspInit 0 */
|
|
|
|
/* USER CODE END SPI1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_SPI2_CLK_ENABLE();
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
/**SPI1 GPIO Configuration
|
|
PB3 ------> SPI1_SCK
|
|
PB4 ------> SPI1_MISO
|
|
PB5 ------> SPI1_MOSI
|
|
*/
|
|
/**SPI2 GPIO Configuration
|
|
PB13 ------> SPI1_SCK
|
|
PB14 ------> SPI1_MISO
|
|
PB15 ------> SPI1_MOSI
|
|
*/
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_SPI2;
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN SPI1_MspInit 1 */
|
|
|
|
/* USER CODE END SPI1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* @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 */
|
|
}
|
|
|
|
}
|
|
//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(200);
|
|
rt_pin_write(ETH_RESET_PIN, PIN_LOW);
|
|
rt_thread_mdelay(200);
|
|
rt_pin_write(ETH_RESET_PIN, PIN_HIGH);
|
|
}
|
|
|
|
//242.16 KB /51556-64564-70868 add ETH
|
|
|
|
/**
|
|
* @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 */
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static uint32_t FSMC_Initialized = 0;
|
|
|
|
void HAL_FSMC_MspInit(void){
|
|
/* USER CODE BEGIN FSMC_MspInit 0 */
|
|
|
|
/* USER CODE END FSMC_MspInit 0 */
|
|
GPIO_InitTypeDef GPIO_InitStruct ={0};
|
|
if (FSMC_Initialized) {
|
|
return;
|
|
}
|
|
FSMC_Initialized = 1;
|
|
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_FSMC_CLK_ENABLE();
|
|
|
|
/** FSMC GPIO Configuration
|
|
PF0 ------> FSMC_A0
|
|
PF1 ------> FSMC_A1
|
|
PF2 ------> FSMC_A2
|
|
PF3 ------> FSMC_A3
|
|
PF4 ------> FSMC_A4
|
|
PF5 ------> FSMC_A5
|
|
PF12 ------> FSMC_A6
|
|
PF13 ------> FSMC_A7
|
|
PF14 ------> FSMC_A8
|
|
PF15 ------> FSMC_A9
|
|
PG0 ------> FSMC_A10
|
|
PG1 ------> FSMC_A11
|
|
PE7 ------> FSMC_D4
|
|
PE8 ------> FSMC_D5
|
|
PE9 ------> FSMC_D6
|
|
PE10 ------> FSMC_D7
|
|
PE11 ------> FSMC_D8
|
|
PE12 ------> FSMC_D9
|
|
PE13 ------> FSMC_D10
|
|
PE14 ------> FSMC_D11
|
|
PE15 ------> FSMC_D12
|
|
PD8 ------> FSMC_D13
|
|
PD9 ------> FSMC_D14
|
|
PD10 ------> FSMC_D15
|
|
PD11 ------> FSMC_A16
|
|
PD12 ------> FSMC_A17
|
|
PD13 ------> FSMC_A18
|
|
PD14 ------> FSMC_D0
|
|
PD15 ------> FSMC_D1
|
|
PG2 ------> FSMC_A12
|
|
PG3 ------> FSMC_A13
|
|
PG4 ------> FSMC_A14
|
|
PG5 ------> FSMC_A15
|
|
PD0 ------> FSMC_D2
|
|
PD1 ------> FSMC_D3
|
|
PD4 ------> FSMC_NOE
|
|
PD5 ------> FSMC_NWE
|
|
PG10 ------> FSMC_NE3
|
|
PE0 ------> FSMC_NBL0
|
|
PE1 ------> FSMC_NBL1
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3
|
|
|GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_12|GPIO_PIN_13
|
|
|GPIO_PIN_14|GPIO_PIN_15;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_FSMC;
|
|
HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3
|
|
|GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_10;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_FSMC;
|
|
HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10
|
|
|GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14
|
|
|GPIO_PIN_15|GPIO_PIN_0|GPIO_PIN_1;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_FSMC;
|
|
HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
|
|
|
|
GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9|GPIO_PIN_10|GPIO_PIN_11
|
|
|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14|GPIO_PIN_15
|
|
|GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_4|GPIO_PIN_5;
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
GPIO_InitStruct.Pull = GPIO_PULLUP;
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
GPIO_InitStruct.Alternate = GPIO_AF12_FSMC;
|
|
HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
|
|
|
|
/* USER CODE BEGIN FSMC_MspInit 1 */
|
|
|
|
/* USER CODE END FSMC_MspInit 1 */
|
|
}
|
|
|
|
void HAL_SRAM_MspInit(SRAM_HandleTypeDef* hsram){
|
|
/* USER CODE BEGIN SRAM_MspInit 0 */
|
|
|
|
/* USER CODE END SRAM_MspInit 0 */
|
|
HAL_FSMC_MspInit();
|
|
/* USER CODE BEGIN SRAM_MspInit 1 */
|
|
|
|
/* USER CODE END SRAM_MspInit 1 */
|
|
}
|
|
|
|
|
|
SRAM_HandleTypeDef hsram1;
|
|
/* FSMC initialization function */
|
|
void MX_FSMC_Init(void)
|
|
{
|
|
|
|
/* USER CODE BEGIN FSMC_Init 0 */
|
|
|
|
/* USER CODE END FSMC_Init 0 */
|
|
|
|
FSMC_NORSRAM_TimingTypeDef Timing = {0};
|
|
|
|
/* USER CODE BEGIN FSMC_Init 1 */
|
|
|
|
/* USER CODE END FSMC_Init 1 */
|
|
|
|
/** Perform the SRAM1 memory initialization sequence
|
|
*/
|
|
hsram1.Instance = FSMC_NORSRAM_DEVICE;
|
|
hsram1.Extended = FSMC_NORSRAM_EXTENDED_DEVICE;
|
|
/* hsram1.Init */
|
|
hsram1.Init.NSBank = FSMC_NORSRAM_BANK3;
|
|
hsram1.Init.DataAddressMux = FSMC_DATA_ADDRESS_MUX_DISABLE;
|
|
hsram1.Init.MemoryType = FSMC_MEMORY_TYPE_SRAM;
|
|
hsram1.Init.MemoryDataWidth = FSMC_NORSRAM_MEM_BUS_WIDTH_16;
|
|
hsram1.Init.BurstAccessMode = FSMC_BURST_ACCESS_MODE_DISABLE;
|
|
hsram1.Init.WaitSignalPolarity = FSMC_WAIT_SIGNAL_POLARITY_LOW;
|
|
hsram1.Init.WrapMode = FSMC_WRAP_MODE_DISABLE;
|
|
hsram1.Init.WaitSignalActive = FSMC_WAIT_TIMING_BEFORE_WS;
|
|
hsram1.Init.WriteOperation = FSMC_WRITE_OPERATION_ENABLE;
|
|
hsram1.Init.WaitSignal = FSMC_WAIT_SIGNAL_DISABLE;
|
|
hsram1.Init.ExtendedMode = FSMC_EXTENDED_MODE_DISABLE;
|
|
hsram1.Init.AsynchronousWait = FSMC_ASYNCHRONOUS_WAIT_DISABLE;
|
|
hsram1.Init.WriteBurst = FSMC_WRITE_BURST_DISABLE;
|
|
hsram1.Init.PageSize = FSMC_PAGE_SIZE_NONE;
|
|
/* Timing */
|
|
Timing.AddressSetupTime = 0;
|
|
Timing.AddressHoldTime = 0;
|
|
Timing.DataSetupTime = 8;
|
|
Timing.BusTurnAroundDuration = 0;
|
|
Timing.CLKDivision = 0;
|
|
Timing.DataLatency = 0;
|
|
Timing.AccessMode = FSMC_ACCESS_MODE_A;
|
|
/* ExtTiming */
|
|
|
|
if (HAL_SRAM_Init(&hsram1, &Timing, NULL) != HAL_OK)
|
|
{
|
|
Error_Handler( );
|
|
}
|
|
|
|
/* USER CODE BEGIN FSMC_Init 2 */
|
|
else {
|
|
// LOG_I("sram init success, mapped at 0x%X, size is %d bytes, data width is %d", SRAM_BANK_ADDR, SRAM_SIZE, SRAM_DATA_WIDTH);
|
|
#ifdef RT_USING_MEMHEAP_AS_HEAP
|
|
/* If RT_USING_MEMHEAP_AS_HEAP is enabled, SRAM is initialized to the heap */
|
|
|
|
static struct rt_memheap sram_heap;
|
|
rt_memheap_init(&sram_heap, "sram", (void *)SRAM_BANK_ADDR, SRAM_SIZE);
|
|
#endif
|
|
}
|
|
/* USER CODE END FSMC_Init 2 */
|
|
}
|
|
|
|
|