目录
- 太长不看版
- 正文
- 总结
太长不看版
举例如下:
% Port definition fprintf(fID,[... '\n'... 'input clk;' '\n'... 'input rst_n;' '\n'... 'input [%d:0] msg;' '\n'...%row-1 'input in_valid;' '\n'... 'output reg [%d:0] codeword;' '\n'...%col-1 'output reg out_valid;' '\n'... ],row-1,col-1);
- 加上中括号;
- 将长字符串分割成多个子字符串;
- 子字符串之间至少隔一个空格;
- 换行符用
...
正文
最近在搞毕设的东西,其中有一个需要写很麻烦的verilog文件。
麻烦但是却不复杂,LDPC的编码器,大概就是一个200多bits宽的输入信号,500多bit宽的输出信号,输出每个bit都是由某些输入的bit进行相同的运算得到的,用一个200多*500多的矩阵表示对应关系。
如果要单纯写ve编程客栈rilog,会死人的,如果在verilog里写生成逻辑,又要占用很大的内存来存放生成矩阵,而且逻辑难写。于是就想到用Matlab代码来生成verilog代码。
Matlab里有fprintf函数可以输出数据到文件。
举个栗子:
fprintf(fID,'Hello world!');
就可javascript以把“Hello world!”输出到fID对应的文件中。
打开文件的函数是fID = fopen('f编程客栈ilepath/filename.postfix','w');其中w表示写入,如果是读取则换成r,更多用法请help fopen
那么问题来了,如果我把verilog代码的每一行分别用一个fprintf输出,那么我的.m文件就会充斥着一大堆fprintf,我这个强迫症对这种高度重复的代码简直不能忍。android
但是如果我把每个功能块单独写在一个fprintf里,可读性确实高很多,但是fprintf那行就会很长,同样不能忍,并且修改的时候会非常痛苦!
于是我就去找有没有类似linux脚本中‘\’的换行符,让解释器把多行代码当成一行去执行。
确实有这个换行符,
... ←三个点就是Matlab里的换行符。可以将该行的尾部和下一行的头部连接起来。
但是另一个问题就出来了,这个换行符没办法用在字符串中间,我把一整块的代码当成一个字符串,如果中间加上换行符,那么解释器会把换行符也当做要输出的内容,一起输出去了。
由于 fprintf 的参数分别为:文件handler、输出array、输出数据(如有)。
举栗子:
fprintf( fID, 'data1: %d\n', data1);
其中中间的字符串会被当成一个只有一个元素的array。
所以解决方法就来了,只要把中间的array多加几个元素,就可以分割长字符串,并在子字符串之间添加换行符。
举栗子:
% Port definition fprintf(fID,[... '\n'... 'input clk;' '\n'... 'input rst_n;' '\n'... 'input [%d:0] msg;' '\n'...%row-1 'input in_valid;' '\n'... 'output reg [%d:0] codeword;' '\n'...%col-1 'output reg out_valid;' '\n'... ],row-1,col-1);
用单引号括起来的每一个小字符串会被解释为输出array的一个元素,子字符串之间用空格(可多个,至少一个) 或逗号隔开,即一个单行的矩阵(array)。
中括号必不可少,是将各子字符串结合为一个array的标识。
另外因为verilog里经常需要输出类似 3b'101之类的东西,而单引号会被当做元素的起/止符。想要输出单引号,就需要连续打2个单引号。
比如:
fprintf(fID, 'outdata <= 3''b101 ')
这也是为什么两个子字符串中间至少要有一个空格的原因,如果没有空格就会被连接起来,并且中间多了个单引号。
总结
以上为个人经验tiYIaPHk,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。
精彩评论