📄 00179.html
字号:
<p class="Element10">
</p>
<p class="Element10">
在这个例子中,时钟控制事件<span class="Element146"><span style="color: #800080">(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span></span>被应用到<span style="color: #0000FF">$rose</span>。只要<i><span class="Element146">b</span></i>的采样值从时钟控制事件前一个标记上的值改变到<span style="color: #FF0000">1</span>,那么<span style="color: #0000FF">$rose</span>的结果即为“真”。 </p>
<p class="Element10">
</p>
<p class="Element10">
除了访问值改变外,以前的值可以通过<span style="color: #0000FF">$past</span>函数访问。SystemVerilog为<span style="color: #0000FF">$past</span>函数提供了下面的三个可选的参数: </p>
<p class="Element10">
<i><span class="Element146">expression2</span></i>被用作是时钟控制事件的门表达式; </p>
<p class="Element10">
<i><span class="Element146">number_of_ticks</span></i>指定了过去发生的时钟标记的数目; </p>
<p class="Element10">
<i><span class="Element146">clocking_event</span></i>为<i><span class="Element146">expression1</span></i>指定了时钟控制事件; </p>
<p class="Element10">
</p>
<p class="Element10">
<i><span class="Element146">expression1</span></i>和<i><span class="Element146">expression2</span></i>可以是断言中允许使用的任何表达式。 </p>
<p class="Element10">
</p>
<p class="Element10">
<i><span class="Element146">number_of_ticks</span></i>必须大于或等于<span style="color: #FF0000">1</span>。如果没有指定<i><span class="Element146">number_of_ticks</span></i>,。那么它的缺省值为<span style="color: #FF0000">1</span>。<span style="color: #0000FF">$pas</span>t函数返回在<span style="color: #0000FF">$past</span>被计算之前的<i><span class="Element146">number_of_ticks</span></i>个时钟标记处表达式的采样值。一个时钟标记基于<i><span class="Element146">clocking_event</span></i>。如果指定的过去的时钟标记在仿真开始之前,那么<span style="color: #0000FF">$past</span>函数的返回值为<span style="color: #FF0000">X</span>。 </p>
<p class="Element10">
</p>
<p class="Element10">
可选参数<i><span class="Element146">clocking_event</span></i>指定了函数的时钟。<i><span class="Element146">clocking_event</span></i>的使用规则与值改变函数中描述的规则相同。 </p>
<p class="Element10">
</p>
<p class="Element10">
当不需要两个参数中间的可选参数的时候,必须为每一个被忽略的参数放置一个逗号。例如: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00616');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00616"><pre class="Element12"><span style="color: #0000FF">$past</span><span style="color: #800080">(</span>in1<span style="color: #800080">, ,</span> enable<span style="color: #800080">);</span></pre></div></div>
<p class="Element10">
</p>
<p class="Element10">
在这里指定了一个逗号来忽略number_of_ticks。对于空的number_of_ticks参数,会使用缺省值1。注意,如果想要忽略clocking_event,就不需要放置一个逗号,因为它没有位于指定的参数之间。 </p>
<p class="Element10">
</p>
<p class="Element10">
$past函数可以用于任何SystemVerilog表达式中,下面的代码就展示了一个这样的例子。 </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00617');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00617"><pre class="Element12"><span style="color: #0000FF">always</span> <span style="color: #800080">@(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span>
reg1 <span style="color: #800080"><=</span> a <span style="color: #800080">&</span> <span style="color: #0000FF">$past</span><span style="color: #800080">(</span><span style="color: #0000FF">b</span><span style="color: #800080">);</span></pre></div></div>
<p class="Element10">
</p>
<p class="Element10">
在这个例子中,时钟控制事件<i><span class="Element146"><span style="color: #800080">(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span></span></i>被应用到<span style="color: #0000FF">$pas</span>t函数。<span style="color: #0000FF">$pas</span>t在<i><span style="color: #800080">(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span></i> 当前发生的时候被计算,并返回<i><span style="color: #800080">(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span></i>前一次发生时候的采样值。 </p>
<p class="Element10">
</p>
<p class="Element10">
当指定了<i><span class="Element146">expression2</span></i>的时候,<i><span class="Element146">expression1</span></i>的采样基于<i><span class="Element146">expression2</span></i>的门控时钟。例如, </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00618');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00618"><pre class="Element12"><span style="color: #0000FF">always</span> <span style="color: #800080">@(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span>
<span style="color: #0000FF">if</span> <span style="color: #800080">(</span>enable<span style="color: #800080">)</span> q <span style="color: #800080"><= </span>d<span style="color: #800080">;</span>
<span style="color: #0000FF">always</span> <span style="color: #800080">@(</span><span style="color: #0000FF">posedge</span> clk<span style="color: #800080">)</span>
<span style="color: #0000FF">assert</span> <span style="color: #800080">(</span>done <span style="color: #800080">|=> (</span>out <span style="color: #800080">==</span> <span style="color: #0000FF">$past</span><span style="color: #800080">(</span>q<span style="color: #800080">, </span><span style="color: #FF0000">2</span><span style="color: #800080">, </span>enable<span style="color: #800080">));</span></pre></div></div>
<p class="Element10">
</p>
<p class="Element10">
在这个例子中,计算<span style="color: #0000FF">$past</span>时<i><span class="Element146">q</span></i>的采样基于下面的时钟控制表达式: </p><div class="Element170">
<a href="#" onclick="CopyElementToClipboard('code00619');">Copy Code</a></div>
<div class="Element13"><div class="Element12" id="code00619"><pre class="Element12"><span style="color: #0000FF">posedge</span> clk <span style="color: #0000FF">iff</span> enable</pre></div></div>
</div>
</div>
<a name="Group"></a><div class="Element14">
<a onclick="toggleVisibilityStored('Group');" class="a_Element14"><img src="sectionminus.png" border="0" alt="" title="" id="imgGroup">Group</a></div>
<div id="divGroup">
<div class="Element11">
<div class="Element10">
<p class="Element10">
<a href="00175.html" target="topic">17.7 序列操作</a></p></div>
</div>
</div>
<a name="Links"></a><div class="Element14">
<a onclick="toggleVisibilityStored('链接');" class="a_Element14"><img src="sectionminus.png" border="0" alt="" title="" id="img链接">链接</a></div>
<div id="div链接">
<div class="Element11">
<div class="Element10">
<a href="00175.html" target="topic">17.7 序列操作</a></div>
</div>
</div>
</div>
<!-- End Page Content -->
<!-- Begin Page Footer -->
<hr width="98%" align="center" size="1" color="#CCCCCC" />
<table align="center" cellpadding="0" cellspacing="0" border="0">
<tbody>
<tr height="10">
<td></td>
</tr>
<tr align="center">
<td>
<script type="text/javascript"><!--
google_ad_client = "pub-5266859600380184";
google_ad_width = 468;
google_ad_height = 60;
google_ad_format = "468x60_as";
google_ad_type = "text_image";
google_ad_channel ="";
google_page_url = document.location;
//--></script>
<script type="text/javascript"
src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script>
</td>
</tr>
<tr height="15">
<td></td>
</tr>
<tr align="center">
<td>
<font size=2>除非特别声明,原文版权归作者所有,如有转摘请注明原作者以及译者(<a href="http://www.fpgatech.net/" target="_blank">FPGA技术网</a>)信息。<br />
如果您对本主题有何建议或意见,请登陆<a href="http://www.fpgatech.net/forum/forumdisplay.php?fid=18" target="_blank">FPGA开发者家园</a>提交,您的参与是我们前进的动力。</font>
<script language="javascript" type="text/javascript" src="http://js.users.51.la/195685.js"></script>
<noscript><a href="http://www.51.la/?195685" target="_blank"><img alt="我要啦免费统计" src="http://img.users.51.la/195685.asp" style="border:none" /></a></noscript>
</td>
</tr>
</tbody>
</table>
<!-- End Page Footer -->
</div>
</div>
<!-- End Client Area -->
</body></html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -