1 硬件环境搭建
见ZYNQ基本用法------DDR(1)
链接: link.
2 软件部分
见ZYNQ基本用法------DDR(1)
2.1 源代码
//使用PS控制DDR3的读写
/*
C语言中%X的意思是以十六进制数形式输出整数,类似%x的输出格式还有:
1.%c:单个字符
2.%d:十进制整数
3.%f :十进制浮点数
4.%o:八进制数
5. %s :字符串
6.%u:无符号十进制数
*/
/*
Canonical definitions for DDR MEMORY
#define XPAR_DDR_MEM_BASEADDR 0x00000000U
#define XPAR_DDR_MEM_HIGHADDR 0x3FFFFFFFU
//从某个地址读数据
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);
*/
#include "stdio.h"
#include "platform.h"
#include "xparameters.h"
#include "xparameters_ps.h"
#include "xil_printf.h"
#include "xil_io.h"
#define DDR_BASEARDDR XPAR_DDR_MEM_BASEADDR + 0x10000000
#define NUM 16
typedef struct//结构体
{
double real;
double img;
}complex;
complex array1[2*NUM] = {0}; //定义一个结构体数组,用于存放从DDR读取的数据,所有的数据按照 实部、虚部 依次放入数组中
int main()
{
init_platform();
int i;
int value;
double a[NUM]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
// 写数据
for(i=0; i<NUM; i++)
{
//Xil_Out32(DDR_BASEARDDR+i*4,0xFF);//向某个地址写数据。
Xil_Out32(DDR_BASEARDDR+i*4,a[i]);//向某个地址写数据,写入的数据为i。
// 第一个参数:写入数据的地址 第一个参数:待写入的数据
}
printf("you have finished write data!\n");
// 读数据
for(i=0; i<NUM; i++)
{
value= Xil_In32(DDR_BASEARDDR+i*4);//从某个地址读数据
// 第一个参数:写入数据的地址
printf("the address at %x data is : %x \n\r" ,DDR_BASEARDDR+i*4, value);
array1[i].real=value;//将从DDR读到的数据放到数组的实部
printf("the address at %x data is : %f \n\r" ,DDR_BASEARDDR+i*4, array1[i].real);
}
printf("you have finished read data!\n");
cleanup_platform();
return 0;
}