【iCore4 双核心板_ARM】例程三十七:SDRAM实验——读写SDRAM
2017-09-30 10:52
453 查看
实验现象:
上电即开始读写SDRAM测试,测试过程中,蓝色LED点亮,如果出现错误,红色LED闪烁,测试成功,绿色LED点亮。
核心代码:
源代码下载链接:
链接:http://pan.baidu.com/s/1i5kqcst 密码:d03o
iCore4链接:
上电即开始读写SDRAM测试,测试过程中,蓝色LED点亮,如果出现错误,红色LED闪烁,测试成功,绿色LED点亮。
核心代码:
int main(void) { /* USER CODE BEGIN 1 */ int i,j; /* USER CODE END 1 */ /* MCU Configuration----------------------------------------------------------*/ /* Reset of all peripherals, Initializes the Flash interface and the Systick. */ HAL_Init(); /* USER CODE BEGIN Init */ /* USER CODE END Init */ /* Configure the system clock */ SystemClock_Config(); /* USER CODE BEGIN SysInit */ /* USER CODE END SysInit */ /* Initialize all configured peripherals */ MX_GPIO_Init(); /* USER CODE BEGIN 2 */ //SDRAM³õʼ»¯ BSP_SDRAM_Init(); LED_BLUE_ON; //ÏòSDRAMÖÐдÈë0x5555²¢¶ÁȡУÑé for(i = 0;i < SDRAM_SIZE;i++){ write_sdram(i,0x5555); } for(i = 0;i < SDRAM_SIZE;i++){ if(0x5555 != read_sdram(i)){ while(1){ LED_RED_ON; HAL_Delay(500); LED_RED_OFF; HAL_Delay(500); } } } //ÏòSDRAMÖÐдÈë0xAAAA²¢¶ÁȡУÑé for(i = 0;i < SDRAM_SIZE;i++){ write_sdram(i,0xAAAA); } for(i = 0;i < SDRAM_SIZE;i++){ if(0xAAAA != read_sdram(i)){ while(1){ LED_RED_ON; HAL_Delay(500); LED_RED_OFF; HAL_Delay(500); } } } //ÏòSDRAMÖÐдÈë0x0000~0xFFFF²¢¶ÁȡУÑé for(j = 0; j < 256; j++){ for(i = 0;i < 65536;i++){ write_sdram((65536 * j + i),i); } } for(j = 0; j < 256; j ++){ for(i = 0;i < 65536;i++){ if(i != read_sdram((65536 * j + i))){ while(1){ LED_RED_ON; HAL_Delay(500); LED_RED_OFF; HAL_Delay(500); } } } } //²âÊԳɹ¦ LED_BLUE_OFF; LED_GREEN_ON; /* USER CODE END 2 */ /* Infinite loop */ /* USER CODE BEGIN WHILE */ while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ } /* USER CODE END 3 */ }
源代码下载链接:
链接:http://pan.baidu.com/s/1i5kqcst 密码:d03o
iCore4链接:
相关文章推荐
- 【iCore4 双核心板_ARM】例程二十八:FSMC实验——读写FPGA
- 【iCore4 双核心板_ARM】例程三十一:HTTP_IAP_FPGA实验——更新升级FPGA
- 【iCore4 双核心板_ARM】例程十一:DMA实验——存储器到存储器的传输
- 【iCore4 双核心板_ARM】例程三十二:UART_IAP_ARM实验——更新升级STM32
- 【iCore4 双核心板_ARM】例程三十三:SD_IAP_ARM实验——更新升级STM32
- 【iCore4 双核心板_ARM】例程四:USART实验——通过命令控制LED
- 【iCore4 双核心板_FPGA】例程十二:基于UART的ARM与FPGA通信实验
- 【iCore4 双核心板_ARM】例程二十二:LWIP_UDP实验——以太网数据传输
- 【iCore4 双核心板_ARM】例程三十四:U_DISK_IAP_ARM实验——更新升级STM32
- 【iCore4 双核心板_FPGA】例程十七:基于FIFO的ARM+FPGA数据存取实验
- 【iCore4 双核心板_FPGA】例程十六:基于双口RAM的ARM+FPGA数据存取实验
- 【iCore4 双核心板_ARM】例程三十五:HTTP_IAP_ARM实验——更新升级STM32
- 【iCore4 双核心板_ARM】例程十六:USB_HID实验——双向数据传输
- 【iCore4 双核心板_ARM】例程二十四:LWIP_DHCP实验——动态分配IP地址
- 【iCore4 双核心板_ARM】例程十八:USBD_VCP实验——虚拟串口
- 【iCore4 双核心板_ARM】例程二十五:LWIP_DNS实验——域名解析
- 【iCore4 双核心板_ARM】例程三十六:DAC实验——输出直流电压
- 【iCore4 双核心板_ARM】例程二十六:LWIP_MODBUS_TCP实验——电源监控
- 【iCore4 双核心板_ARM】例程十三:SDIO实验——读取SD卡信息
- 【iCore4 双核心板_ARM】例程二十三:LWIP_HTTP实验——网页服务器