0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

多输入门、多输出门和三态门详解

CHANBAEK 来源:数字IC与好好生活的两居室 作者:除夕之夜啊 2023-03-30 11:35 次阅读

门级建模,是使用基本的逻辑单元,例如与门,与非门等,进行更低级抽象层次上的设计。 与行为级建模相比,门级建模更注重硬件的实现方法,即通过连接一些基本门电路去实现多种逻辑功能。 虽然行为级建模最后也会被综合成基本的门级电路网络,但对于复杂的设计来说,行为级建模的效率远远高于门级建模。 所以目前 Verilog 大多数用于描述数字设计的行为级层次(RTL),一般只注重设计实现的算法或流程,而不用特别关心具体的硬件实现方式。

有些设计,例如门控时钟,就需要使用基本门单元,来增加电路的可控性与可靠性。

多输入门

多输入门只有单个输出,有单个或多个输入端。 Verilog 内置多输入门如下:

and(与门) nand(与非门) or(或门) nor(或非门) xor(异或门) xnor(同或门)

使用基本的逻辑门单元去实现一些简单的逻辑功能时,使用模块例化的方式即可。

门级单元第一个端口是输出,后面端口是输入,例化调用时需要注意。

门级单元实例调用的时候,也可以不指定实例的名字,这为代码编写提供了方便。

当输入端口超过 2 个时,只需将输入信号在端口列表中继续排列即可,Verilog 可自动识别。

//basic gate instantiation
  and  a1      (OUTX,  IN1, IN2) ;
  nand na1     (OUTX1, IN1, IN2) ;
  or   or1     (OUTY,  IN1, IN2) ;
  nor  nor1    (OUTY1, IN1, IN2) ;


  //3 input
  xor xor1     (OUTZ,  IN1, IN2, IN3) ;
  //no instantiation name
  xnor         (OUTZ1, IN1, IN2) ;

多输入门的真值表如下,注意输出不会出现“Z”。

0 1 x 南德 0 1 x
0 0 0 0 0 0 1 1 1 1
1 0 1 x x 1 1 0 x x
x 0 x x x x 1 x x x
0 x x x 1 x x x
0 1 x 也不 0 1 x
0 0 1 x x 0 1 0 x x
1 1 1 1 1 1 0 0 0 0
x x 1 x x x x 0 x x
x 1 x x x 0 x x
异或 0 1 x 出去 0 1 x
0 0 1 x x 0 1 0 x x
1 1 0 x x 1 0 1 x x
x x x x x x x x x x
x x x x x x x x

多输出门

多输出门只有单个输入,有单个或多个输出端,又可称之为 buffer,起缓冲、延时作用。

内置多输入门如下:

buf(缓冲器) not(非门)

和多输入门类似,可以使用模块例化的方式对多输出门进行调用。

门级单元第一个端口是输出,最后一个端口是输入。 当输出端口超过 1 个时,需将输出信号在最后一个输入端口前排列。

例化时也可以不指定实例的名字。

//buf
  buf buf1     (OUTX2, IN1) ;
  //2 output
  buf buf2     (OUTY2, OUTY3, IN2) ;
  //no instantiation name
  not          (OUTZ3, IN3) ;

多输出门的真值表如下,注意输出不会出现“Z”。

布夫 0 1 x 0 1 x
输出 0 1 x x 输出 1 0 x x

三态门

Verilog 中还提供了 4 个带有控制端的 buffer 门单元,称为三态门。 只有当控制信号有效时,数据才能正常传递,否则输出为高阻抗状态“Z”。

4 个三态门名称及符号如下:

图片

例化时,三态门第一个端口为输出端,第二个端口为数据输入端,第三个端口为控制输入端。 例化时信号排列顺序要一致。

三态门不支持输出端口超过 1 个,但例化时可以不指定实例的名字。

//tri
  bufif1 buf1     (OUTX, IN1, CTRL1) ;
  bufif0 buf2     (OUTY, IN1, CTRL2) ;
  notif1 buf3     (OUTZ, IN1, CTRL3) ;
  //no instantiation name
  notif0          (OUTX1, IN1, CTRL4) ;

三态门的真值表如下。

表中有些为可选项,例如,1/z 表明,根据输入端和控制端的信号强度,输出端既可能为 1,也可能为 “z”。

布菲夫1 控制端 布菲夫0 控制端
0 1 x 0
0 0 3/9 3/9
1 1 3/8 3/8
x x x x
x x x
通知1 控制端 通知0 控制端
0 1 x 0
0 1 3/8 3/8
1 0 3/9 3/9
x x x x
x x x

利用三态门实现可配置输入输出 PAD 功能的例程,可参见该教程《1.2 开关级建模》一节。

利用三态门实现可配置上下拉 PAD 功能的例程,可参见《Verilog 教程》的《5.1 Verilog 模块与端口》一章。

上下拉电阻

上拉是将不确定的信号通过一个电阻钳制在一个高电平。

下拉是将不确定的信号通过一个电阻与地相连,固定在低电平。

模块端口的上拉或下拉电阻,具有限流、提高驱动能力、防静电等作用,可以有效保护电路

当信号方向为输入且没有输入信号(高阻态)时,上拉会将该信号的逻辑值置为 “1”,下拉会将该信号的逻辑值置为 “0”。

Verilog 提供了为信号设置上、下拉电阻的逻辑门单元,多用于模块端口信号。

此类门单元没有输入,只有输出。 关键字如下:

pullup(设置上拉) pulldown(设置下拉)

例化调用时,只需填写需要设置上下拉电阻的信号即可。

实例的名字也可以不指定。

pullup  p1      (IN1);
  pulldown        (OUTX);

此处设置上下拉电阻后就不能再更改。 在《Verilog 教程》的《5.1 Verilog 模块与端口》一章中,利用三态门 buffer 实现了可配置上下拉 PAD 功能的实例,欢迎参考。

4 选 1 多路选择器

下面对比四选一选择的实现方式,来说明门级建模较行为级建模的繁琐性。

输入为 A、B、C、D,输出为 F,选择信号为 SEL1、SEL0,则 4 路选择器的表达式为:

图片

门级建模如下:

module mux4to1_gate(
    input       A, B, C, D ,
    input       S0, S1,
    output      F );


   //reversing
   wire         S0R, S1R ;
   not  (S0R, S0) ;
   not  (S1R, S1) ;


   //logic and
   wire         AAND, BAND, CAND, DAND ;
   and  (AAND, A, S1R, S0R);
   and  (BAND, B, S1R, S0);
   and  (CAND, C, S1,  S0R);
   and  (DAND, D, S1,  S0);


   //logic or
   or (F, AAND, BAND, CAND, DAND) ;


endmodule

行为级建模如下:

module mux4to1_behavior(
   input       A, B, C, D ,
   input       S0, S1,
   output      F );


   assign F = {S1, S0} == 2'b00 ? A :
              {S1, S0} == 2'b01 ? B :
              {S1, S0} == 2'b10 ? C :
              {S1, S0} == 2'b11 ? D : 0 ;
endmodule

虽然行为级建模综合后的结果可能与门级建模一致,但是在设计时,显然行为级建模有更好的可读性、简洁性。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Verilog
    +关注

    关注

    28

    文章

    1351

    浏览量

    110154
  • 三态门
    +关注

    关注

    1

    文章

    34

    浏览量

    18849
  • 门控时钟
    +关注

    关注

    0

    文章

    27

    浏览量

    8961
  • 门级电路
    +关注

    关注

    0

    文章

    15

    浏览量

    1995
  • 逻辑单元
    +关注

    关注

    0

    文章

    25

    浏览量

    5131
收藏 人收藏

    评论

    相关推荐

    什么是三态和OC

    输入时读入外部电平用.1. 三态的特点三态输出门又称三态电路。它与一般门电路不同,它的
    发表于 05-26 13:01

    三态输入输出之间接电阻是什么用法?

    三态输入信号和输出信号之间接电阻是什么用法?
    发表于 04-09 19:36

    高阻三态的电路原理分析

    高阻三态高阻 高阻的实质:电路分析时高阻可做开路理解。你可以把它看作
    发表于 01-08 11:03

    三态输出门的电路图是什么样?

    三态输出门的电路图和图形符号
    发表于 10-25 07:17

    【梦翼师兄今日分享】 三态程序设计讲解

    等,要求信号为三态类型,也就是我们所说的输入输出(inout)类型。那么,本节梦翼师兄将和大家一起来探讨三态的用法。项目需求设计一个三态
    发表于 12-12 16:11

    集电极开路三态输出门的应用

    集电极开路三态输出门的应用 一、 实训目的1.熟悉集电极开路(OC)和三态
    发表于 04-07 23:23 59次下载

    什么是三态? 三态逻辑与非门电路以及三态门电路

    什么是三态? 三态,是指逻辑输出除有高、低电平两种状态外,还有第
    发表于 05-26 12:48 4.7w次阅读
    什么是<b class='flag-5'>三态</b><b class='flag-5'>门</b>? <b class='flag-5'>三态</b>逻辑与非门电路以及<b class='flag-5'>三态</b>门电路

    三态输出门的电路图和图形符号

    三态输出门的电路图和图形符号
    发表于 07-15 19:03 3269次阅读
    <b class='flag-5'>三态</b><b class='flag-5'>输出门</b>的电路图和图形符号

    多输入多输出天线系统MIMO分析

    多输入多输出(MIMO)天线系统是发送端和接收端同时采用多个天线单元的分集接收系统。具有T M 副发送天线、R M 副接收天线的MIMO 系统模型。 对于多输入多输出(MIMO)系统,
    发表于 01-18 15:06 81次下载
    <b class='flag-5'>多输入</b><b class='flag-5'>多输出</b>天线系统MIMO分析

    基于LSSVM的多输入多输出开关磁阻电机建模_徐宇柘

    基于LSSVM的多输入多输出开关磁阻电机建模_徐宇柘
    发表于 01-08 11:51 0次下载

    三态有哪三态_三态有什么特点

    本文开始介绍了三态的定义与三态的应用,其次对三态三态
    发表于 03-01 14:47 13w次阅读
    <b class='flag-5'>三态</b><b class='flag-5'>门</b>有哪<b class='flag-5'>三态</b>_<b class='flag-5'>三态</b><b class='flag-5'>门</b>有什么特点

    三态怎么理解

    三态亦称“三态输出门”、“三态输出电路”。是一种
    的头像 发表于 03-10 09:29 1.8w次阅读

    三态输出门的工作原理

    三态输出门电路的输出端除了出现高、低电平外,还会出现第种状态——高阻,所以叫做三态
    的头像 发表于 08-12 11:39 1.3w次阅读

    TTL三态输出门能否实现“线与”?为什么?

    TTL三态输出门是一种特殊的数字逻辑,它具有高电平、低电平和高阻抗(三态输出状态。
    的头像 发表于 05-28 16:14 4524次阅读

    三态输出门可以实现线与功能吗

    三态输出门(Tri-State Output Gate)是一种特殊类型的逻辑,它具有个状态:高电平、低电平和高阻抗状态(也称为高阻抗或浮空状态)。这种
    的头像 发表于 07-30 15:32 1923次阅读