Verilog之函数和任务

本文介绍了Verilog编程语言中函数(function)和任务(task)的概念及其区别。函数具有输入变量,可返回值,常用于简化代码。任务则包含input、output和inout变量,无返回值,且能调用函数。两者都只能在module内定义,generate语句与genvar一起用于模块内的信号实例化,实现相同操作的重复应用。
摘要由CSDN通过智能技术生成

函数和任务都具有减少代码冗杂度的功能,但两者不完全相同。

  1. 函数function只有input变量,在调用时就用函数名,形参和实参传递,本质上和matlab相同。函数有返回值任务是没有返回值的
function [7:0] sum;
        input [7:0] a ,b;
        begin
            sum = a + b;
        end
    endfunction
调用格式:assign sum1 = sum(din1,din2);
  1. 任务task具有input output inout三种类型变量
task result
    input   [7:0] A;
    input   [7:0] B;
    output  [7:0]   C;
    begin
        C = A + B;
        end
endtask
  1. 两者都只能够放在module里面,任务可以调用函数,函数不能调用任务。函数能返回值,而任务没有返回值。两者里面不能不能有过程赋值,也就是出现always和initial模块
  2. 说说generate
    主要针对同一个模块中信号例化链接,就如同平时的复制操作相同。用此模块一般情况必定有循环语句。
genvar i ;
    generate
        for (i=0;i<8;i=i+1)begin
            NOR NOR_U1(
                .a(din_a[i]);
            );
        end
    endgenerate

模块的意思是指把din_a八位有效数据的每bit都进行或非操作。generate-- endgenerate就起这样一个作用,搭配genvar使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值