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

paramter 和 localparam 有什么区别?

[复制链接]
  • TA的每日心情
    开心
    2019-11-20 15:00
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-3-25 13:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

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

    x
    paramter 和 localparam 有什么区别?
    ' M1 l6 V7 V$ Q3 `( {! g5 h

    2 ^- M" [5 \# ?# S3 A* \

    3 x' n* i9 T' x; s

    9 [, V2 G. Y# a; k( h, v) Y这是一个Verilog中有争议的问题,即Parameter即作为常数,也作为参数使用是否合理合法的问题。6 \: {/ [4 T# O, S- G+ q
    & [4 [! E8 q4 l0 Q. ~: C
    在IEEE 2005标准之前,Verilog就是这样做的。但常数不仅需要安全的封装,而且还涉及知识产权(IP),常数参数不区分带来很多质疑,随这EDA规模发展,IP意识加强,常数更需要安全,因此IEEE在2005之后,加入localpara保留字,用于定义常数。! o, U* D. f4 M4 I, B
    常数用于定义当前工程和文件中那些固定不变的变量。而参数则是可以用作LPM交换的数值,类似于C语言中的形式参数。Verilog中的代码模型被重复引用时,使用LPM可以根据现场需要,修改这些参数进行定制。* }) r5 L2 B$ S( X# J0 r1 V  e% O5 [
    $ z; f  s; ]/ E* _
    显然常数是不需要被传递出去,不需要也不允许被现场定制的。在2005版Verilog之前,常数参数不分的情况下,重用代码的使用者和重用代码的设计者可能不是同一个人(或团队),这样,很容易造成不明内部细节的使用者,不经意的修改常数,使得原本稳定的系统出问题,并反馈给该重用代码的设计者。& n5 D& @" Q' H- c0 O4 j- C
    1 ?! l! b! d/ p. s6 @
    另外一种情况,或更严峻的情况是,IP核的复杂性和成本都在增加。保护IP的意识在争强,而攻击破解IP的人和团队也开始出现。这就使得IP作者必须保护自己的代码,常数如果作为参数传递出去,是一个非常重要的攻击漏洞,当然要补上。& W  {, ~, V1 d* u
    / a- S. A, q: X+ }& r' w
    因此,从现在开始,我们要将常数封装好,保护好自己的代码。
    5 g. X: w( ^8 G0 h' E) b* l

    该用户从未签到

    2#
    发表于 2019-3-25 16:01 | 只看该作者
    总结的很到位
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-7-29 00:58 , Processed in 0.093750 second(s), 23 queries , Gzip On.

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

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

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