[sv-ac] RE: AC 296

From: Kulshrestha, Manisha <Manisha_Kulshrestha@mentorg.com>
Date: Thu Nov 11 2004 - 10:22:45 PST

Hi All,

As we discussed in the meeting. I think we need to discuss the
following things before I can update my proposal:

1. Is .ended allowed in event expressions (i.e. in wait statement)
in the procedural code. My impression is it is allowed based on
the discussion few weeks ago. If it is allowed then why not make
it available till the time the event wakes up to get executed.

2. Is .triggered allowed to be used to form sequence expressions ?
Here we need to consider .triggered property of any event not just
sequence events. Current syntax allows it and LRM does not prohibit it.

3. Joseph raised this question: can .triggered be invoked on sequences
which have formal arguments ?

4. In what region .triggered goes high ? Currently LRM says that it
goes high in Observe region. My understanding is that it should go
high at the same time .ended goes high. Here is a statement from
LRM section 8.11:

The triggered status of a sequence is set during the Observe region and
persists through the remainder of the time-step (i.e., until simulation
time advances).

From this, it looks like the only difference in .ended and .triggered is
that .triggered defines when it goes down but .ended does not define it.
I think it will be good idea if we clearly define in the LRM when .ended

goes down even if we restrict its usage to sequence expressions only.

Thanks.
Manisha

-----Original Message-----
From: Eduard Cerny [mailto:Eduard.Cerny@synopsys.com]
Sent: Wednesday, November 10, 2004 1:27 PM
To: sv-ac@eda.org; Kulshrestha, Manisha
Cc: Ed Cerny
Subject: AC 296

Hello Manisha,

I agree with you and think that it is a good idea to summarize the
sequence methods in a se[arate section. However I would like to suggest
a some changes to your proposal. In particular, ended and matched should
not be allowed outside expressions in sequences. They are more like
boolean events valid only at the clock tick. We should discuss it
tomorrow at the meeting.

Best regards,

ed

---
In the paragraph on ended you say:
"The ended status of the sequence is set in the Observe region and
persists through the remainder of the time step (i.e. until simulation
time advances). This method can be used to detect the endpoint of a
sequence used in another sequence."
I think that extending the duration of the ended in not necessary as it
cannot be used anywhere but in another sequence which does also evaluate
in the Observed region. (Clearly, when evaluating sequences the
evaluation must be ordered by mutual dependency and the dependency graph
must not have
cycles.) Perhaps you would agree if the text is changed as follows:
"The ended status of the sequence is set in the Observed region. This
method can only be used to detect the endpoint of a sequence in another
sequence.
There must be no circular dependency between sequences induced by the
use of ended."
---
In the paragraph on triggered :
"The value of method triggered evaluates to true if the given sequence
has reached its endpoint at that particular point in time and false
otherwise.
The triggered status of the sequence is set in the Observe region and
persists through the remainder of the time-step.  This method can be
used anywhere that the triggered property of events can be used (section
13.5.4).
It is an error to pass a local variable as an actual argument to a
sequence instance on which method triggered is applied. This prevents
local variables from flowing out of method triggered.  (See section
17.8)"
I propose that you add:
"... This method can be used anywhere that the triggered property of
events can be used (section 13.5.4), including the boolean expressions
in disable iff statements of properties. There should be no circular
dependency between properties and sequences induced by the use of
sequence triggered in disable if clauses. It is an error ... "
---
The paragraph starting with: "The  methods ended and triggered ..."
Change as
"The  method triggered can be used in wait statements or boolean
expressions outside of property context. However, it is an error to
invoke those methods on sequences which treat their formal arguments as
local variables. A sequence treats its formal argument as a local
variable if the formal argument is used as an lvalue in
operator_assignment or inc_or_dec_expression in sequence_match_item."
---
The paragraph starting with: "Unlike ended and triggered, matched uses
..."
Change to:
"Unlike ended and triggered, matched provides means for synchronization
between two clocks by making available the result of the source sequence
match to the evaluation of the destination sequence at the first clock
tick of the destination sequence after the source sequence match. This
method is used to detect the endpoint of a sequence in a multi-clocked
sequence. If the source and destination clocks are the same, again the
result is transferred to the first subsequent clock tick. Like ended,
matched can only be used in boolean expressions in sequences."
Received on Thu, 11 Nov 2004 10:22:45 -0800

This archive was generated by hypermail 2.1.8 : Thu Nov 11 2004 - 10:22:57 PST