/** ****************************************************************** * @file main.c * @author fire * @version V1.0 * @date 2018-xx-xx * @brief FMC-SDRAM ****************************************************************** * @attention * * 实验平台:野火 STM32H750 开发板 * 论坛 :http://www.firebbs.cn * 淘宝 :http://firestm32.taobao.com * ****************************************************************** */ #include "stm32h7xx.h" #include "main.h" #include "./led/bsp_led.h" #include "./delay/core_delay.h" #include "./mpu/bsp_mpu.h" #include "./sdram/bsp_sdram.h" #include "./usart/bsp_debug_usart.h" void Delay(__IO uint32_t nCount); void SDRAM_Check(void); uint32_t RadomBuffer[10000]; uint32_t ReadBuffer[10000]; uint32_t *pSDRAM; RNG_HandleTypeDef hrng; /** * @brief 主函数 * @param 无 * @retval 无 */ int main(void) { long long count=0; RCC_PeriphCLKInitTypeDef PeriphClkInitStruct; /* 系统时钟初始化成480MHz */ SystemClock_Config(); /* 默认不配置 MPU,若需要更高性能,当配置 MPU 后,使用 DMA 时需注意 Cache 与 内存内容一致性的问题, 具体注意事项请参考配套教程的 MPU 配置相关章节 */ // Board_MPU_Config(0, MPU_Normal_WT, 0xD0000000, MPU_32MB); // Board_MPU_Config(1, MPU_Normal_WT, 0x24000000, MPU_512KB); SCB_EnableICache(); // 使能指令 Cache SCB_EnableDCache(); // 使能数据 Cache /* LED 端口初始化 */ LED_GPIO_Config(); /* 串口初始化 */ DEBUG_USART_Config(); printf("\r\n 欢迎使用野火 STM32 H750 开发板。\r\n"); printf("\r\n野火STM32H750 SDRAM 读写测试例程\r\n"); /*初始化SDRAM模块*/ SDRAM_Init(); /*蓝灯亮,表示正在读写SDRAM测试*/ LED_BLUE; /*选择PLL输出作为RNG时钟源 */ PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RNG; PeriphClkInitStruct.RngClockSelection = RCC_RNGCLKSOURCE_PLL; HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct); /*使能RNG时钟*/ __HAL_RCC_RNG_CLK_ENABLE(); /*初始化RNG模块产生随机数*/ hrng.Instance = RNG; HAL_RNG_Init(&hrng); SDRAM_Test(); printf("开始生成10000个SDRAM测试随机数\r\n"); for(count=0;count<10000;count++) { HAL_RNG_GenerateRandomNumber(&hrng,&RadomBuffer[count]); } printf("10000个SDRAM测试随机数生成完毕\r\n"); SDRAM_Check(); while(1); } void SDRAM_Check(void) { long long count=0,sdram_count=0; pSDRAM=(uint32_t*)SDRAM_BANK_ADDR; printf("开始写入SDRAM\r\n"); for(sdram_count=0;sdram_count=10000) { count=0; } } printf("写入总字节数:%d\r\n",(uint32_t)pSDRAM-SDRAM_BANK_ADDR); count=0; pSDRAM=(uint32_t*)SDRAM_BANK_ADDR; printf("开始读取SDRAM并与原随机数比较\r\n"); sdram_count=0; for(;sdram_count=10000) { count=0; } } printf("比较通过总字节数:%d\r\n",(uint32_t)pSDRAM-SDRAM_BANK_ADDR); if(sdram_count == SDRAM_SIZE/4) { LED_GREEN; printf("SDRAM测试成功\r\n"); } else { LED_RED; printf("SDRAM测试失败\r\n"); } } /** * @brief System Clock 配置 * system Clock 配置如下: * System Clock source = PLL (HSE) * SYSCLK(Hz) = 480000000 (CPU Clock) * HCLK(Hz) = 240000000 (AXI and AHBs Clock) * AHB Prescaler = 2 * D1 APB3 Prescaler = 2 (APB3 Clock 120MHz) * D2 APB1 Prescaler = 2 (APB1 Clock 120MHz) * D2 APB2 Prescaler = 2 (APB2 Clock 120MHz) * D3 APB4 Prescaler = 2 (APB4 Clock 120MHz) * HSE Frequency(Hz) = 25000000 * PLL_M = 5 * PLL_N = 192 * PLL_P = 2 * PLL_Q = 4 * PLL_R = 2 * VDD(V) = 3.3 * Flash Latency(WS) = 4 * @param None * @retval None */ /** * @brief System Clock Configuration * @retval None */ void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** 启用电源配置更新 */ HAL_PWREx_ConfigSupply(PWR_LDO_SUPPLY); /** 配置主内稳压器输出电压 */ __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE0); while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {} /** 初始化CPU、AHB和APB总线时钟 */ 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 = 5; RCC_OscInitStruct.PLL.PLLN = 192; RCC_OscInitStruct.PLL.PLLP = 2; RCC_OscInitStruct.PLL.PLLQ = 2; RCC_OscInitStruct.PLL.PLLR = 2; RCC_OscInitStruct.PLL.PLLRGE = RCC_PLL1VCIRANGE_2; RCC_OscInitStruct.PLL.PLLVCOSEL = RCC_PLL1VCOWIDE; RCC_OscInitStruct.PLL.PLLFRACN = 0; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { while(1); } /** 初始化CPU、AHB和APB总线时钟 */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2 |RCC_CLOCKTYPE_D3PCLK1|RCC_CLOCKTYPE_D1PCLK1; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.SYSCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.AHBCLKDivider = RCC_HCLK_DIV2; RCC_ClkInitStruct.APB3CLKDivider = RCC_APB3_DIV2; RCC_ClkInitStruct.APB1CLKDivider = RCC_APB1_DIV2; RCC_ClkInitStruct.APB2CLKDivider = RCC_APB2_DIV2; RCC_ClkInitStruct.APB4CLKDivider = RCC_APB4_DIV2; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK) { while(1); } } /****************************END OF FILE***************************/