软件环境: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。白白。