Hi Steven: I am having trouble figuring out from the SV LRM the semantics of multi-bit 4-state equality comparison and multi-bit 4-state cond_predicate in procedural if-else. I have looked at 11.4.5 and 12.4, but what I find there does not say clearly what to do with multi-bit 4-state expressions. Can you clarify? Are there other sections of the LRM that are relevant? Is there a Mantis item on this subject? J.H. > Date: Wed, 31 Oct 2007 15:33:03 -0500 > Cc: doron.bustan@intel.com, john.havlicek@freescale.com > From: John Havlicek <john.havlicek@freescale.com> > Reply-To: john.havlicek@freescale.com > X-OriginalArrivalTime: 31 Oct 2007 20:33:05.0803 (UTC) FILETIME=[3DD3DDB0:01C81BFD] > > Hi Shalom: > > We have Mantis 1786 in SV-AC to align the semantics of property > if-else with the procedural if-else statement when 4-state values > are involved. > > Jonathan Bromley suggested using > > !(bit'(b!=0)) > > to get a condition for the "else" of "if(b) .. else ..". > > I made a little table for this: > > b b!=0 bit'(b!=0) !(bit'(b!=0)) > ----------------------------------- > 0 0 0 1 > 1 1 1 0 > x x 0 1 > z x 0 1 > > which shows that this works for 1-bit b. > > I am trying to convince myself that the same expression works for > multi-bit. > > I am having trouble understanding the semantics of the procedural > if-else when multi-bit expressions are used in the cond_predicate. > > If I use reduction or to get the semantics of the multi-bit expression > as a cond_predicate, then a bit with value 1 is enough to make the > result known even if other bits may be x or z. > > I don't know what happens if I use the "b != 0" because the > description of "!=" is not clear for multi-bit expressions. However, > the LRM does say that > > if (expression) > > is equivalent to > > if (expression != 0) > > > Can you clarify? Is there a Mantis item on this? > > J.H. > > -- This message has been scanned for viruses and dangerous content by MailScanner, and is believed to be clean.Received on Thu Nov 1 03:37:34 2007
This archive was generated by hypermail 2.1.8 : Thu Nov 01 2007 - 03:38:03 PDT