首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在verilog中使用枚举

在verilog中使用枚举
EN

Stack Overflow用户
提问于 2019-10-02 01:54:17
回答 4查看 7.1K关注 0票数 1

我正在用Quartus verilog (.v)编写一段代码,并尝试在我的模块中编写枚举类型:

代码语言:javascript
复制
module Controller(clk, IorD);

    enum {READ, DECODE} state;
    myState = READ;
    //...

但它给出了以下错误:Error (10170): Verilog HDL syntax error at Controller.v(3) near text "{"; expecting ";"

我做错了什么?如何在verilog中使用枚举?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2019-10-02 02:27:04

enum是SystemVerilog的一项功能。您需要确保Quartus中的文件类型为SystemVerilog (通常也使用.sv扩展名)。

票数 3
EN

Stack Overflow用户

发布于 2019-10-10 23:52:13

如果您被限制只能在该工具中使用verilog,则可以使用参数来代替枚举。如果您可以切换到其他工具,请尝试edaplayground(.)com

示例代码如下:

代码语言:javascript
复制
localparam START =1;
localparam STOP  =2;

使用localparam而不是参数,因为您确实不希望在实例化期间更改这些值。

票数 1
EN

Stack Overflow用户

发布于 2019-11-26 07:05:56

您将需要使用typedef。

在您的例子中是=>

模块控制器(clk、IorD);

代码语言:javascript
复制
typedef enum {READ, DECODE} state_e;

state_e myState;

//Now you can use myState ... 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58189988

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档