ZYNQ裸板:DDR篇

简介: DDR是zynq的内存又可以叫做主存。是CPU能直接寻址的存储空间,没有DDR的话,运行内存只有很小的内部RAM,软件大小受限,也几乎没法跑操作系统。作为下一篇AXIDMA的基础知识提前做个准备,内容很简单这里就简单做一个读写测试,也可以当做验证下DDR是否都可以正常访问

前言

 DDR是zynq的内存又可以叫做主存。是CPU能直接寻址的存储空间,没有DDR的话,运行内存只有很小的内部RAM,软件大小受限,也几乎没法跑操作系统。作为下一篇AXIDMA的基础知识提前做个准备,内容很简单这里就简单做一个读写测试,也可以当做验证下DDR是否都可以正常访问

 还是找到我们的老朋友"xparameters_ps.h"可以看到如下代码:

/* Canonical definitions for DDR MEMORY */
#define XPAR DDR MEM BASEADDR 0x00000000U 
#define XPAR DDR MEM HIGHADDR 0X3FFFFFFFU

 这就是DDR的基址和偏移了也就是说1GB的内存,

20210209135208687.png

 关于DDR的详细描述在芯片手册第十章10.6部分有详细的DDR编程介绍,但是呢按照现在的认知来看,大部分情况下是用不到的,只需要会简单的读写就好了)

 而在xil_io.h里又能找到下面这些读写函数(xilinx真香)

//从某个地址读数据 
u8 Xil_In8(INTPTR Addr); 
u16 Xil_In16(INTPTR Addr); 
u32 Xil_In32(INTPTR Addr);
//向某个地址写数据。 
void Xil_Out8(INTPTR Addr, u8 Value); 
void Xil_Out16(INTPTR Addr, u16 Value); 
void Xil_Out32(INTPTR Addr, u32 Value); 

 有了这些已经完完全全可以对DDR进行读写了

 那下面要做的就很简单了,挑几个地址访问验证一下就好啦!所以我为什么要单独写一篇,真是奇怪

#include "xparameters_ps.h"
#include "xil_io.h"
#include "xil_printf.h"
int main ()
{
  int value;
   Xil_Out32(XPAR_DDR_MEM_BASEADDR,0x12);
   value = Xil_In32(XPAR_DDR_MEM_BASEADDR);
   xil_printf("the address 0 is 0x%x\r\n",value);
   Xil_Out32(0x1FFFFFFF,0x34);
   value = Xil_In32(0x1FFFFFFF);
   xil_printf("the address 0x1FFFFFFF is 0x%x\r\n",value);
   Xil_Out8(XPAR_DDR_MEM_HIGHADDR,0x7);
   value = Xil_In8(XPAR_DDR_MEM_HIGHADDR);
   xil_printf("the address 0x3FFFFFFF is 0x%x\r\n",value);
}


相关文章
|
存储 缓存 测试技术
ZYNQ-AXI Interconnect IP介绍
ZYNQ-AXI Interconnect IP介绍
2684 0
ZYNQ-AXI Interconnect IP介绍
|
存储 缓存 开发工具
ZYNQ-双核AMP通信(一)
ZYNQ-双核AMP通信(一)
1880 0
ZYNQ-双核AMP通信(一)
|
开发工具 芯片 Perl
【ZYNQ】裸机 PS + PL 双网口实现之 ZYNQ 配置
【ZYNQ】裸机 PS + PL 双网口实现之 ZYNQ 配置
2725 0
|
测试技术 Perl
【ZYNQ】ZYNQ7000 UART 控制器及驱动应用示例
【ZYNQ】ZYNQ7000 UART 控制器及驱动应用示例
692 0
【ZYNQ】SPI 简介及 EMIO 模拟 SPI 驱动示例
【ZYNQ】SPI 简介及 EMIO 模拟 SPI 驱动示例
1417 0
|
存储 安全 开发工具
【ZYNQ】基于 BRAM 的 PS 与 PL 数据交互
【ZYNQ】基于 BRAM 的 PS 与 PL 数据交互
1211 0
|
缓存 网络性能优化 SoC
ZYNQ-AXI_GP接口和AXI_HP接口的异同
ZYNQ-AXI_GP接口和AXI_HP接口的异同
1278 0
ZYNQ-AXI_GP接口和AXI_HP接口的异同
|
Linux 开发工具 异构计算
【ZYNQ】QSPI Flash 固化程序全攻略
【ZYNQ】QSPI Flash 固化程序全攻略
3175 0
|
存储 缓存 网络协议
ZYNQ裸板:AXIDMA篇(简单模式)
DMA(Direct Memory Access,直接存储器访问)是计算机科学中的一种内存访问技术。它允许某些计算机内部的硬件子系统可以独立地直接读写系统内存,而不需中央处理器( CPU)介入处理。 DMA 是一种快速的数据传送方式, 通常用来传送数据量较多的数据块
2150 0
ZYNQ裸板:AXIDMA篇(简单模式)
|
网络协议 测试技术 芯片
基于ZYNQ+DSP平台Zynq7035/45 FPGA高速串行接口的千兆以太网UDP例程设计和使用说明
Xilinx XC7Z035/45-2FFG676I PL端高速串行接口的千兆以太网UDP例程设计和使用说明
基于ZYNQ+DSP平台Zynq7035/45 FPGA高速串行接口的千兆以太网UDP例程设计和使用说明