【Verilog-语法】 条件编译 `ifdef/`ifndef

news/2024/10/21 5:48:00/

一、前言

在Verilog项目开发过程中某功能是,一部分代码可能有时候用,有时候不用,为了避免全部编译占用资源,可以使用条件编译语句;尤其在大型项目中还可以节约大量的时间。

二、语法

语法书写格式:

(`define FLAG1/2/3)
`ifdef/`ifndef FLAG1// Statements
`elsif FLAG2// Statements
`elsif FLAG3// Statements
`else// Statements
`endif

其中,`ifdef/`ifndef和`endif之间的`elsif和`else都是可选的。

对条件编译的理解很好理解,都是字面逻辑。唯一值得探讨的一点是,条件编译的FLAG是否必须由`define语句宏定义,可不可以在代码中自己定义?答案是必须要`define来定义,也即条件编译的使用与`define是紧密相关的。比如下面的例子尝试自定义变量在条件编译中使用,但编译工具并不支持,对比可以发现并不认同自己定义的变量。

使用宏定义的:

`timescale 1ns / 1ps`define MACRO_FLAG;  //use `define
module prac_condition_compile(input     a,input     b,output    c,input     d,input     e);   `ifdef MACRO_FLAGassign   c = a&b;`endif`ifndef MACRO_FLAGassign   c = d & e;`endifendmodule

使用自己的定义的:

`timescale 1ns / 1ps//`define MACRO_FLAG;
module prac_condition_compile(input     a,input     b,output    c,input     d,input     e);   wire    MACRO_FLAG; //do not use `define `ifdef MACRO_FLAGassign   c = a&b;`endif`ifndef MACRO_FLAGassign   c = d & e;`endifendmodule


http://www.ppmy.cn/news/1442642.html

相关文章

制作和合入git补丁

制作git补丁 git log -u a44bc4cf08e94741052cb471512868d14e803f2a -n 1 > log.patch -u显示详细差异 -n日志数量 合入git补丁 git apply log.patch 确保补丁目录与git目录一致

Mybatis学习周报总结

学习Mybatis的周报 在过去的一周里,我们在飞思学习和掌握Mybatis这一优秀的持久层框架。通过谭老师的两周课程,我也有很大的收获。以下是本周的学习总结和收获: 一:Mybatis概述: MyBatis,全称为My Batis …

微信第三方开放平台,实现代公众号保留排版样式和图片发布文章

大家好,我是小悟 要想实现代公众号发布文章的功能,就得接入富文本编辑器,市面上富文本编辑器有很多,轻量的、重量的都有。 从开发者的角度,自然把轻量作为第一选择,因为好对接,怎么方便怎么来…

小型架构实验模拟

一 实验需求 二 实验环境 22 机器: 做nginx 反向代理 做静态资源服务器 装 nginx keepalived filebeat 44机器: 做22 机器的备胎 装nginx keepalived 99机器:做mysql的主 装mysqld 装node 装filebeat 77机器:做mysq…

Android常用的延迟执行任务及轮询定时任务的几种方式

Android常用的延迟执行任务及轮询定时任务的几种方式 Executor 的 execute() 方法:向线程池中提交任务(异步执行)代码示例Timer 的 schedule() 方法:安排执行任务、延时执行任务、轮询定时任务代码示例ScheduledExecutorService:提供了一系列方法用于安排任务的延迟执行、周…

redis基础(一)

启动与关闭 启动命令在/usr/local/bin目录 服务端后台启动:redis-server opt/redis-6.2.1/redis.conf 客户端连接:执行 redis-cli 关闭操作 ​ 方式1:进入终端后关闭 ​ 方式2:直接kill 掉进程 方式3:通过实例关闭 …

uniapp自定义国际化语言uni.chooseImage、picker组件文本错误问题

最近遇到国际化后 uni.chooseImage、picker 组件文本显示问题 如图: 解决方法: 在对应的语言包中加入: 即可完美解决

C语言基础—多线程基础

C语言基础—多线程基础 简介正文 简介 多线程是一种并发编程技术,允许程序同时执行多个任务。在C语言中,我们可以使用POSIX线程库(pthread)来实现多线程编程。 正文 在C语言中,创建线程的基本步骤如下: …