zoukankan      html  css  js  c++  java
  • Chisel3

     
    介绍创建模块顺序逻辑的connect命令。
     
     
    0. 这里先简单对 "=" 和 ":="做一个讨论。
     
    假设 a & b 的结果输出到一个匿名变量,记为anonymousVariable。
     
    a & b的用法有两种:
     
    1) c := a & b
     
    ":="的意思为连接。变量c作为下游,连接到anonymousVariable,接收其值。即anonymousVariable的值的变化会传播到下游c中。
     
    2) c = a & b
     
    "="的意思是赋予。之所以不说赋值,是因为更多情况下赋予的不是值,而是引用。
     
    这里就是把anonymousVariable赋给c。就相当于给a & b的输出这个匿名变量取了一个名字,叫做c。
     
    因为anonymousVariable是匿名的,所以这里使用c来简化引用也是有意义的。
     
    总结下来:
    1) 两者的区别在于,一个是匿名变量本身,一个是匿名变量的下一级连接。
    2) ":="是连接到的意思(connect to);
    3) "="也不是赋值,而是赋引用,取名字或者起别名的意思;
     
     
    1. connect
     
    连接符号为:
     
    ":=" 使用connect方法实现:
    final def := (that: Data)(implicit sourceInfo: SourceInfo, connectionCompileOptions: CompileOptions): Unit = this.connect(that)(sourceInfo, connectionCompileOptions)
     
    connect定义在Data类中:
     
    sink为下游,source为上游:
     
     
     
    2. bulkConnect
     
    批量连接的调用过程如下:
     
     
     
     
     
  • 相关阅读:
    【Nginx】开启 gzip和缓存
    webpack分离css单独打包
    【转】为什么Github没有记录你的Contributions
    Swiper使用遇到的问题
    Jenkins 自动化构建
    Pre标签 自动换行
    Gulp入门教程
    计数排序
    直接插入排序
    等差素数列
  • 原文地址:https://www.cnblogs.com/wjcdx/p/10224281.html
Copyright © 2011-2022 走看看