quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bulllet_4dots_orange.gif Driving Signals

In this section we will be seeing different drives features in VERA. We will be seeing following. Syntax of driving a signal is as below.

   

space.gif

[delay] signal_name range drive_operator expression;

   

space.gif

Where

Delay is optional and when specified the signal signal_name will be driven after delay number of cycles.

signal_name is signal that needs to be driven

range specifies which bits of the signal are driven.

drive_operator must be either =, which specifies a blocking drive, or <=, which specifies a non-blocking drive.

expression can be any valid Vera expression.

   

space.gif

   

space.gif

We will be seeing following in detail

   

space.gif

  • Blocking/Non Blocking drive
  • Soft/Strong drive
  • Void Drives
   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Blocking And Non-Blocking Drives

There are two types of drives specified by the drive operator: blocking and non-blocking. Blocking drives suspend Vera execution until the statement completes. Note that the clock edge (NHOLD or PHOLD) that the drive signal is associated with is used for counting synchronized edges during suspension. Once the statement completes, Vera execution resumes. Non-blocking drives schedule the drive at a future synchronized edge and Vera execution continues. When the specified synchronized edge occurs, the drive is executed.

   

space.gif

  • = : When used for assignment, then it is blocking
  • <= : When used for assignment, then it is non-blocking. This is same as Verilog.
   

space.gif

  ../images/main/bullet_star_pink.gif Strong And Soft Drives

There are two strengths of drives: strong (default) and soft. Till now we have seen strong drive.

   

space.gif

Syntax

   

space.gif

[delay] signal_name range drive_operator expression soft;

   

space.gif

A given signal should only be driven by a single strong drive at any given time. Multiple strong drives at the same time result in conflicting drives. Conflicting strong drives drive the signal to X and result in a simulation error. However, conflicting soft drives can drive a signal to X without causing a simulation error. Finally, if a signal is driven by a conflicting strong and soft drive, the strong drive dominates and the signal is driven by the strong drive.

   

space.gif

  ../images/main/bullet_star_pink.gif Void Drives

Drives block until the appropriate driving clock edge occurs. If you want to wait for this clock edge without actually driving the signal, use the void construct.

   

space.gif

Syntax

delay signal_name = void;

   

space.gif

   

space.gif

   

space.gif

   

space.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

  

Copyright © 1998-2025

Deepak Kumar Tala - All rights reserved

Do you have any Comment? mail me at:deepak@asic-world.com