背景:
本人使用Xilinx的FPGA+CortexM0/M3进行SOC应用设计时,使用Keil生成和Hex无法作为Ram/Rom的初始文件进行存储,因此写了一段Matlab代码进行转换,提高设计效率。在此分享给大家,希望对大家有用。
(欢迎关注与支持,后期会不断更新创作)
clear all; close all; clc;
HexDataTemp = textread('SourceFile\U3V_CPU_PRJ.hex','%s');
FileByteLenth=length(HexDataTemp(:));%计算数组的长度
MixtraCol=4;
MixtraRow=FileByteLenth/MixtraCol;
a=cell2mat(HexDataTemp);
b = hex2dec(a);
d4 = reshape(b,MixtraCol,[]);
fid=fopen('SourceFile\U3V_CPU_PRJ.coe','w+');
fprintf(fid,'memory_initialization_radix=16;\nmemory_initialization_vector=\n');
for i = 0:MixtraRow-1
fprintf(fid,'%x,\n',((d4(1,i+1)*16777216)+(d4(2,i+1)*65536)+(d4(3,i+1)*256)+d4(4,i+1)));
end
% fprintf(fid,'%x;',d4(FileByteLenth));
fclose(fid);