找回密码
 注册
关于网站域名变更的通知
查看: 159|回复: 3
打印 上一主题 下一主题

请教一个verilog的问题

[复制链接]
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2022-5-12 11:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x

    现在有一个verilog的问题想请教

    比如有一个输入数据

    input   [16:0] REG

    为了方便使用,现在想把REG拆开,比如

    a = REG[16:8];

    b = REG[7:0];

    - p4 i4 G2 P8 Z" g+ s6 w" o  [

    我能想到下边这种方式,不知道这样做对不对,如果不对应该怎么做,谢谢?

    wire a;

    wire b;

    assign a[16:8] = REG[16:8];

    assign b16:8] = REG[7:0];


    ; R3 {. W" Z- T9 q

    另外再问一下,为什么使用define定义的“a”在always里使用会提示没有声明

    `define a REG[16:8]


    / e: j/ o* D) q2 {; i
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-5-12 13:16 | 只看该作者
    应为a是wire型
  • TA的每日心情
    开心
    2022-1-29 15:07
  • 签到天数: 2 天

    [LV.1]初来乍到

    3#
    发表于 2022-5-12 13:32 | 只看该作者
    没有看懂你的意思6 p. a' E9 o) @% x3 K5 t: {5 \, K
    但是有几个问题。$ `3 o, o) v/ t7 M. z
    1、wire a  表示a是一根线,但是后边使用a[16:8],表示8根线6 p6 O" ]1 g( R3 b
    2、REG最好不要用,好像编译环境有可能会将其认为是一个特定字符用。
  • TA的每日心情
    奋斗
    2022-1-21 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2022-5-12 13:39 | 只看该作者
    你要定义一个 reg [7:0] ADDR;的寄存器。( ?* ~0 x2 x  w( V6 h
    毕竟是两种语言。
    9 H0 i2 G) y! h" f- |% V3 d所以要承认他们的不同点。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-27 10:44 , Processed in 0.125000 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表