FPGA verilog 中调用的task 的问题

2019-07-15 23:08发布

[source lang="verilog"]module process (clk,rst,ad,out);input clk,rst;input [15:0] ad;output [15:0] out; reg [15:0] memory_3,memory_2,memory_1;reg clock,clkout;reg [12:0] ii,jj,kk;reg [15:0] adc_rms ;wire  remainder;wire [15:0] RMS_adc_sqr;wire [15:0] ad,data;reg [2:0] stat;reg [13:0] count;reg [31:0] rms_adc_s2,rms_adc_s;reg [15:0] RMS_adc;reg wren;reg [7:0] address; parameter idle =3'b001,         start=3'b010,                             ram =3'b011,                             fsh =3'b100,                             work =3'b101;                                                                 always@(negedge rst or posedge clk)begin if(!rst) begin  count<=0;         clkout<=0;  end else  if(count<=4999)          begin          count<=count+1;          clkout<=0;          end          else if (count>4999 &&count<9999)            begin            count<=count+1;                   clkout<=1;           end           else            begin              count<=0;                    clkout<=1;           endend  always @(negedge rst or posedge clkout)begin if(!rst) begin  memory_1<=0;         memory_2<=0;         memory_3<=0;          stat<=idle;          ii<=1;         kk<=0;         jj<=0;   end else begin   memory_3<=memory_2;         memory_2<=memory_1;         memory_1<=ad;          case(stat) idle: if(memory_2>memory_1 && memory_2>memory_3)         begin                             address=0;                             wren=1;                             ram2(clk,wren,address,memory_1,adc_rms);                              stat<=start;                                   ii<=1;                                     kk<=0;                       end                              else                              stat<=idle;         start:                                 if(ii<256)                                     begin                                      address=ii;                                wren=1;                                ram2(clk,wren,address,ad,adc_rms);                   adc_rms[ii]<=ad;                                      if(memory_2>memory_1 &&memory_2>memory_3&&ii>4)                    begin                             jj<=ii-1;                              ii<=256;                                                stat<=start;                           end                                       else                                         begin                                        ii<=ii+1;                                               stat<=start;                                       end                                       end                                      else stat<=ram;         ram:    if(ii>=256)           begin           address=0;                                wren=0;                  rms_adc_s=ram2(clk,wren,address,ad,adc_rms);                                     rms_adc_s2<=rms_adc_s2*rms_adc_s2;                                     stat<=work;                                     end                                     elsestat<=idle;  work:                      if(kk<=jj)            begin           address=jj;                                wren=0;                                     rms_adc_s=ram2(clk,wren,address,ad,adc_rms)    ;                            rms_adc_s2<=rms_adc_s2+(rms_adc_s*rms_adc_s);              stat<=work;                                       kk<=kk+1;                                     end                                       else           stat<=fsh;         fsh:    if(kk>=jj)                  begin                                     RMS_adc<=rms_adc_s2/(jj+1);                                      stat<=idle;                                     ii<=1;                                     kk<=0;                                     jj<=0;                                     rms_adc_s2<=0;                                     end                            defaultstat<=idle;                            endcase                                     end  end assign out = RMS_adc; task ram2;input clk,wren,address,data;output adc_rms;beginram ram1(      .address           (address),                                               .q                 (adc_rms),                                               .clock             (clk),                                               .wren              (wren),                                               .data              (data)                                               );endendtaskendmodule[/source]ram 是我调用的一个IP RAM-1PORT,因为不能在case里面调用,就把他放在了task 中,然后再task里面调用他,不知道这样写可以不,本人初学,谢谢各位了

O9KK0OTI3PV6[{9]0OPF7M8.png

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
8条回答
twz
1楼-- · 2019-07-16 04:33
1、task如果是组合逻辑的话,是可以综合的
2、调用IP,直接例化就可以,不能在task或者always模块中调用
最佳答案
烦恼的维特
2楼-- · 2019-07-16 07:11
自顶。。。。。。。。。。。。
runileking
3楼-- · 2019-07-16 09:25
task不能综合,只能在testbench里边用,或者说与综合软件有关,有些软件不能综合,不建议使用task
烦恼的维特
4楼-- · 2019-07-16 09:27
twz 发表于 2016-1-10 16:29
1、task如果是组合逻辑的话,是可以综合的
2、调用IP,直接例化就可以,不能在task或者always模块中调用

谢谢2位的回答,直接例化后就好了,但是有个疑问,那task 和function 啥时候用呢?
twz
5楼-- · 2019-07-16 15:23
 精彩回答 2  元偷偷看……
南盗
6楼-- · 2019-07-16 15:28
恩,twz说的是对的,task一般是用在tb中的,一般module不用task,function这些的。

一周热门 更多>