Verilog写入输出字节



我知道如果我在verilog中输出二进制文件,那么我可以使用以下verilog IO标准函数:

$fwrite(fd,"%u",32'hABCDE124); 

但是上面的命令将4字节的数据写入文件。如果我想写入的二进制数据只有一个字节、两个字节或三个字节怎么办?我该怎么做呢?

例如,我知道下面的代码不会达到我想要的效果:

$fwrite(fd,"%u",8'h24);
$fwrite(fd,"%u",16'hE124);
$fwrite(fd,"%u",24'hCDE124);

是否有任何方法可以将非4字节的多个数据写入文件?

谢谢,

——鲁迪

您可以使用%c来写入单个字节。您可以使用位流强制转换将数据转换为字节数组,然后执行

foreach(array_of_bytes[i]) $fwrite(fd,"%c",array_of_bytes[i]);

如果您有大量的数据,您可能希望通过使用%u写出4字节的倍数,并使用' %c'写出其余字节来进行优化。

我建议另一个版本的dave_59的答案。关键是使用多个%c

wire [7:0] byte;
wire [15:0] two_bytes;
wire [23:0] three_bytes;
----
assign byte = 8'h24;
assign two_bytes = 16'hE124;
assign three_bytes = 24'hCDE124;
----
$fwrite(fd_s,"%c",byte);
$fwrite(fd_s,"%c%c",two_bytes[15-:8],two_bytes[7-:8]);
$fwrite(fd_s,"%c%c%c",three_bytes[23-:8],three_bytes[15-:8],three_bytes[7-:8]);

当使用%u -注意您的系统字节排序时,它默认使用native

你可以用%s代替%u:

$fwrite(fd_s,"%s",8'h24);
$fwrite(fd_s,"%s",16'hE124);
$fwrite(fd_s,"%s",24'hCDE124);   
https://www.edaplayground.com/x/4vJn

最新更新