【JokerのZYNQ7020】SDK_DDR数据导出。

软件环境:vivado 2017.4        硬件平台:XC7Z020


是这个样子的,在做上一个1080p_hdmi显示测试的时候,刚开始一直出不来图像,就想着看看数据有没有从SD卡导进DDR,或者进DDR以后,是不是格式或者哪里存的不对,但是从传统的右下角的memory窗口看内存数据,看是能看到,却很难有个直观的感觉,在与其他人一起调工程的时候,也会有类似这种的问题,你说你数据按要求导进DDR了,你怎么证明?所以就想到了看有没有办法把数据从DDR里导出来,保存到外部,做数据分析来有个直观的结果。

看调试界面右上角,有个XSCT Console控制台,就是利用这里。

 依次输入connect来链接正在工作的板子,ta来查看可供链接的arm核,ta 2(注意,有个空格)来链接正在工作的core0核。

而后通过cd d:/memory_storage/来设置存储路径,mrd -bin -file bmp_orig.bin 0x2a93be0 0x17bb00命令用来存储数据,后面带-的option都很好理解,就不多哔哔了,要注意,当存储指令敲完,下面一行出现xsct%时候,才说明数据已经存储好了。

这里我保存了两个数据,一个是原始图片直接导进内存的数据,另一个是大小端翻转以后用来显示的数据,说下怎么看这个数据地址和长度,其实很简单,对于全局数组,程序初始化以后,随便加个断点,鼠标放在数组名上,信息直接就能看到。

不细心的盆友可能不会发现,这里数组是6220800 byte大小,而我存储的长度0x17bb00换算过来只有6220800的四分之一,为什么这样,是因为我如果按照6220800 = 0x5eec00存储的话,最终保存到PC上文件大小是6220800*4这么大,至于为什么会是这样,估计跟导出到PC保存的机制有关,这里先不细纠,按四分之一保存就完事儿了。

 最终,到盘里的两个文件就是这么大啦,但是怎么用呢,开启万能的matlab,代码如下。

clear all;
clc;

%数据读取
image_orig = fopen('D:\memory_storage\bmp_orig.bin','rb');
image_final = fopen('D:\memory_storage\bmp_final.bin','rb');

[data_orig,count_orig] = fread(image_orig,'uint8');
[data_final,count_final] = fread(image_final,'uint8');
[data_bmp,count_bmp] = imread('D:\memory_storage\joker.bmp','bmp');

M = 1920;
N = 1080;

%按bmp格式码齐
count=1;
for i = 1:N
    for j = 1:1:M
        b1(i,j) = uint8(data_orig(count*3-2));
        g1(i,j) = uint8(data_orig(count*3-1));
        r1(i,j) = uint8(data_orig(count*3-0));
        
        b2(i,j) = uint8(data_final(count*3-2));
        g2(i,j) = uint8(data_final(count*3-1));
        r2(i,j) = uint8(data_final(count*3-0));
        count = count + 1;
    end
end

%直接读进DDR的图组合成RGB
rgb1(:,:,1) = r1(:,:,1);
rgb1(:,:,2) = g1(:,:,1);
rgb1(:,:,3) = b1(:,:,1);

%只是简单大小端翻转组合成的RGB
rgb2(:,:,1) = r2(:,:,1);
rgb2(:,:,2) = g2(:,:,1);
rgb2(:,:,3) = b2(:,:,1);

%R和B对换+水平翻转才是最终显示
rgb3(:,:,1) = b2(:,:,1);
rgb3(:,:,2) = g2(:,:,1);
rgb3(:,:,3) = r2(:,:,1);
rgb4 = fliplr(rgb3);

%图像显示
subplot(2,2,1)
imshow(rgb1)
title('直接读取');

subplot(2,2,2)
imshow(rgb2)
title('大小端翻转');

subplot(2,2,3)
imshow(data_bmp,count_bmp)
title('原图像');

subplot(2,2,4)
imshow(rgb4)
title('最终显示');

显示结果如下

 可以看到,从卡里直接读到DDR的图片,上下是翻转的,而后如果只是像上篇文章中,只做简单的按字节重新颠倒,把最后的放第一个,次低的放第二个,首先,RGB肯定是反的,也就是BGR,其次,从上下颠倒变成水平颠倒,所以,这时候要么对图像做水平翻转,要么每行从后往前显示,上篇文章中选择了后面那种,显示时候顺便把RGB重排了。

所以说,借助从XSCT控制台,从DDR导出数据,做数据分析,很直观的就能得到处理的结果,还是非常方便的。

更多的XSCT控制指令,指路UG1208。白白。

  • 10
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值