任务
任务就是一段封装在“task-endtask”之间的程序。任务是通过调用来执行的,而且只有在调用时才执行,如果定义了任务,但是在整个过程中都没有调用它,那么这个任务是不会执行的。调用某个任务时可能需要它处理某些数据并返回操作结果,所以任务应当有接收数据的输入端和返回数据的输出端。另外,任务可以彼此调用,而且任务内还可以调用函数。
注意:任务是不可综合的,它只能用于仿真。
任务中的语句是按顺序执行的,并不是硬件的并行执行。这点像C。
1 任务定义
任务定义的形式如下:
task task_id
[declaration]
procedural_statement
endtask
其中,task_id是任务名;可选项declaration是端口声明语句和变量声明语句,任务接收输入值和返回输出值就是通过此处声明的端口进行的;procedural_statement是一段用来完成这个任务操作的过程语句,如果过程语句多于一条,应将其放在语句块内。
2 任务调用
任务调用语句可以在initial语句和always语句中使用,其语法形式如下:
task_id[(expr1, expr2, ........, exprN)];
task_id是要调用的任务名,expr1, expr2, ........是参数列表。参数列表给出传入任务的数据(进入任务的输入端)和接收返回结果的变量(从任务的输出端接收返回结果),任务调用语句中参数列表的顺序必须与任务定义中的端口声明顺序相同。任务调用语句是过程性语句,所以任务调用中接收返回数据的变量必须是寄存器类型。来看下例:
module Has_Task;
parameter MAXBITS = 8;
task Reverse_Bits;
input [MAXBITS-1:0] Din;
output [MAXBITS-1:0] Dout;
integer K;
begin
for(K=0; K
Dout[MAXBITS-K] = Din[K];
end
endtask
end module
下面调用Reverse_Bits的代码:
reg[MAXBITS-1:0] Reg_X, New_Reg;
Reverse_Bits(Reg_X, New_Reg);
其中,Reg_X的值作为输入数据送到任务的输入端Din,任务的返回值从其输出端Dout输出并交给New_Reg,在寄存器new_reg中得到返回值。
调用任务时,可以引用任务声明所在的模块内定义的任何变量。
任务内可以带有时序控制,如时延。但要注意,任务的输出值必须等到整个任务的全部语句都执行完之后才能返回。