VHDL & Signal: A Cooperative Approach by Belhadj, Mohammed
VHDL & Signal: A Cooperative Approach
Mohammed Belhadj
To cite this version:
Mohammed Belhadj. VHDL & Signal: A Cooperative Approach. International Conference
on Simulation and Hardware Description Languages (ICSHDL), Jan 1994, Tempe, Arizona,
United States. Society for Computer Simulation, pp.76-81, 1994. <hal-00545943>
HAL Id: hal-00545943
https://hal.archives-ouvertes.fr/hal-00545943
Submitted on 13 Dec 2010
HAL is a multi-disciplinary open access
archive for the deposit and dissemination of sci-
entific research documents, whether they are pub-
lished or not. The documents may come from
teaching and research institutions in France or
abroad, or from public or private research centers.
L’archive ouverte pluridisciplinaire HAL, est
destine´e au de´poˆt et a` la diffusion de documents
scientifiques de niveau recherche, publie´s ou non,
e´manant des e´tablissements d’enseignement et de
recherche franc¸ais ou e´trangers, des laboratoires
publics ou prive´s.
VHDL & SIGNAL: A COOPERATIVE APPROACH
Mohammed BELHADJ
IRISA
Campus de Beaulieu
35042 RENNES, FRANCE
ABSTRACT
This work presents the study done to integrate VHDL
with the Signal environment for reactive systems,
signal processing and real-time applications. This
will be done by translating the language Signal into
VHDL and conversly, VHDL into Signal. As the
scope and the use of these two languages are dierent,
a subset of both languages will be dened to correctly
interface them. By allowing description in a mixture of
VHDL and Signal, designers gain from the strengths
of both languages and their tool environments.
1 INTRODUCTION
Rapidly growing complexity of digital systems justi-
es extensive research activity on the topics of de-
sign methodologies. Hardware description languages
(HDLs) have made possible productivity gains in the
design of VLSI circuits. However, the gap between
the possibilities oered by HDL tools (as part of CAE
tools) and the capabilities of VLSI is still very large,
and there is a need for new design methodologies.
In the past, the design activities like simulation,
design entry, etc, was done at the silicon level. The
rst abstraction step was the move to gate level, then
to the RTL level.
Now, good CAE tools for silicon compilation from
RTL description exist, generally described by VHDL
(LRM 1987) or Verilog code. However, to address to-
day's technology and market constraints (particularly
small time to market) we need to move to more ab-
stract tools (i.e at behavioral and system level). This
will improve the productivity of circuit design.
The need for new methodologies and tools for high
level design of systems motivates the following work.
It uses the Signal language (Le Guernic 1991) for
system and behavior level design and VHDL for con-
nection with CAD/CAE tools. In the following we
present the Signal language and its environment. It
is an abstract language for reactive, signal processing
and real-time applications. Next, we discuss the choice
of interfacing Signal and VHDL. Then, the way we
link Signal to VHDL is presented.
2 FEATURES OF Signal
2.1 Signals, Clocks And Events
The basic object handled by Signal is a possibly in-
nite sequence of values called a signal. The set of
instants where those values occur is called a clock. No
universal (absolute) time exists, the set of occurrence
instants of a signal is dened relatively to other ob-
served signals. Consider the following (isolated) signal
"-1,1,-4,3,2,..." observed together with another signal:
-1 ? 1 ? -4 3 2 ...
? 0 4 -5 2 ? 1 ...
The rst signal is absent at instants 2 and 4 ("?"
represents the absence of value) with respect to the
second signal. Signal uses relative clocks rather than
a time index. Consider the following equation:
y
n
= if x
n
> 0 then x
n
else ? (1)
and the usual addition of sequences, namely
z
n
= y
n
+ u
n
(2)
In combining these two equation, it is certainly prefer-
able to match the successive occurences y
1
; y
2
; ::: in (2)
with the corresponding present occurences in (1). But
this is in contradiction with the immediate mathemat-
ical interpretation of the system of equations (formed
by (1) and (2)), which yields z
n
= ? + u
n
whenever
x
n
 0, and certainly does not match the usual in-
terpretation of the addition of sequences. So, the use
of such a notation is not convenient either as a spec-
ication technique or as a mathematical model. The
Signal language uses \clocks", the example bellow
shows a signal and its clock (observed relatively to a
given context) :
X : x
1
x
2
? x
3
? x
4
x
5
x
6
...
bX : T T ? T ? T T T ...
The bX signal is of event type (a boolean always
true) and is present when X is present and absent
otherwise. It represents the clock extraction.
Any two signals which are absent (?) simultane-
ously for any environment are said to be synchronous
(e.g a signal and its clock are synchronous).
2.2 Signal Kernel
A Signal process is a set of relations between sig-
nals, specifying both constraints on values and con-
straints on relative timing of these signals (i.e con-
straints on clocks). The Signal kernel is the min-
imum set of operators with which we can construct
any Signal process.
 Functions: Usual functions AND, OR, +, *, etc
from instantaneous domains (boolean, integer,...)
are extended to signals. Y :=f(X1,...,Xn) where
Y,X1,...,Xn, are synchronous.
 Delay: The delay operator gives access to past
values of a signal. The Signal statement corre-
sponding to delay is: ZX := X $ 1 , with ZX init
x
0
. For every occurrence of the signal X, ZX car-
ries the previous value of X. We can easily extend
this operator to a delay of k where k > 1.
 When: This operator allows one to condition-
ally extract values from a given signal. The ex-
pression: Y := X when C, where X and Y are
signals of the same type and C is a boolean signal
describing the under sampling of X. Y is present
when both X and C are present and C is TRUE.
X : x
1
x
2
? x
3
? x
4
x
5
x
6
...
C : F T F F T T ? T ...
Y : ? x
2
? ? ? x
4
? x
6
...
 Default: This operator allows the merge of sig-
nals of the same type: Z := X defaultY, Z merges
X and Y, with priority to X when both signals are
simultaneously present.
X : x
1
x
2
? x
3
? ...
Y : y
1
? y
2
? y
3
...
Z : x
1
x
2
y
2
x
3
y
3
...
2.3 Processes Composition And Extended Language
We can build elementary processes as equations be-
tween signals " X := exp", where X is a signal and exp
is any valid Signal expression built using the kernel
operators and other signals (e.g X:= (A when B) de-
fault (C+D) ). We can also express equations as con-
straints on signals :" synchro f exp1, exp2, .., expn g"
means that exp1,..,expn must be synchronous. More
complex processes can be built using the commutative
and associative composition operator "j". The process
(j P1 j P2 ....j Pn j)
simply denotes the union of the constraints expressed
by P1,P2,...,Pn, where Pi is an elementary process (ei-
ther a signal denition X:= exp or a synchro state-
ment) or a composed process.
Consider the following example :
(j Y := X default ZY
j ZY := Y$ 1
j synchro f Y, bX default when B)g j)
The rst statements means that Y is equal to X
when X is present and equal to the value of ZY (Y's
last value, see the second statement) when X is absent
and B is true (specied by the synchro statement).
This is a memory operator (see example below).
X : x
1
x
2
? x
3
? x
4
? ? ...
B : T ? T F T F T F ...
Y : x
1
x
2
x
2
x
3
x
3
x
4
x
4
? ...
Other operators have been dened from the kernel
that permit the reduction of programming eort. The
memory operator described in the previous example is
noted as follows : Y := X cell B.
Signal oers the possibility to specify constraints
on clocks : Ab = B denotes the equality of clocks,
i.e. A and B are synchronous. A b+ B denotes
the upper bound or the union of clocks, i.e. it is the
clock present when A or B are present. Note that all
the clock operators described above can be expressed
using the Signal kernel. Other operators and array
based operators can be found in (Le Guernic 1991).
2.4 Compiler And Proof System
The Signal compiler transforms any program into
the kernel language, and tries to verify constraints im-
plied by signal assignment statement (recall that any
signal assignment statement sets constraints on data
and clocks) or explicitly specied by the constraints-
specication capabilities.
The checking of the coherence of constraints is done
by the compiler. The compiler is in fact a formal cal-
culus system. It handles (i) the presence/absence (ii)
boolean values (iii) dependency graphs to encode data
dependencies in non-boolean functions. This is called
the clock calculus. If an incoherence is detected the
program is rejected, in the case where the system con-
straints are coherent there are two possibilities: (1) if
the system is fully functional then it generates an ex-
ecution schema (2) the system is relational i.e it sets
constraints on its inputs. In the second case we can
not always have an execution schema but we can prove
properties on the partially described system.
The formal proof is done by transforming the de-
pendency graph and the constraints of clocks into a
more compact representation:Ternary Decision Dia-
gram TDD, an extension of the Binary Decision Dia-
gram (Dutertre 1992).
2.5 The Signal Environment
The Signal environment consists of: a mixed
schematic/textual programs entry, a compiler, and
generation tools (see Figure 1). The compiler trans-
forms Signal programs into an intermediate graph
format. This format is used for sequential code gener-
ation (C, Fortran77). It can be also used for parallel
execution on general purpose machines: iPSC, T-node
( some details and applications on these architectures
are presented in e.g. (ICS 1990)) or specialized paral-
lel machines. The intermediate format is also used for
generation of TDD and for hardware synthesis.
Intermediate Graph Code
Text editor Schematic editor
SIGNAL programs
compiler
Other tools
...
Formal verification
tool
Hardware
synthesis
(to ASICs)
Generation of
parallel code
Generation of
sequential code
Figure 1 : Signal environment
3 WHY USING VHDL AND Signal ?
From our point of view, Signal is used as high level
design tool on top of VHDL (see Figure 2). The use of
VHDL is motivated by several reasons. One of them
is the access to existing CAD/CAE tools: as VHDL
is the standard HDL, compiling Signal into VHDL
gives possibilities to use tools developed around it.
Another important reason is the simulation capa-
bilities of both languages: Signal always computes
the current output using current and/or past values
of the input, while VHDL has a preemptive simula-
tion model that computes the possible future output
using actual inputs. VHDL uses an event-driven sim-
ulation that leads to good performance when model-
ing hardware at the gate level with detailed timing
information, while Signal will lead to an inecient
simulation. Consider the following tiny program:
process INV_GATE= (integer DELAY)
{? logical X ! logical Y}
(| Y := not (X $ DELAY) |)
end
If we consider that DELAY represents the propaga-
tion time of INV GATE expressed in nano-second (in
Signal this means: X and Y are synchronous with
a clock that ticks every ns). Suppose that the input
X changes every micro-second. In Signal the output
is computed every ns, while in VHDL we will have
two transactions every micro-second. Signal cycle-
driven simulation mode will be ecient when describ-
ing clocked logic or event-based circuit, it seems to be
inecient if detailed timing information is modeled.
Correctness
Preserving
Transformations Verification
Formal
Synthesis
High Level
Simulation
(functional,
Simulation
multilevels,..)
Circuits Libraries,
Test, and other
CAD tools
SIGNAL programs
VHDL programs
CAE/CAD synthesis
tools
(SynopSys, Compass)
Figure 2 : VHDL/Signal interface
Thus, when the hardware modeling is at low or
mixed (low/high) levels, it is suitable to use VHDL
simulator, while the high level description (Register-
transfer, behavioral) can be handled by Signal.
This cooperative approach (combining the two lan-
guages) can be extended to other activities than sim-
ulation: use of formal proof capabilities of Signal
for some VHDL programs, incorporation of VHDL li-
braries in Signal designs, using time abstraction and
hardware/software codesign mechanisms of Signal,
and capability of describing partial specications in
Signal (suitable for system level design where the
designer does not necessarily know the exact function-
ality of his sub-systems).
The next section describes how we intend to build
the interface to handle the activities listed above.
4 INTERFACING VHDL AND Signal
VHDL has been dened with a simulation oriented
behavior. It consists of evaluating every simulation
step if there is at least one process to execute (we
suppose that a VHDL program is a set of processes).
A process can be executed if the wait statement can
be passed. If no process can be executed, move to
next value of TIME (where a new value of a signal
may pass its wait statement(s) ).
The Signal language does not use the same simula-
tion model. No reference to the future is allowed. Ex-
ecution time is always incremented by one (no \jump"
is done) and physical time is not used.
It is obvious that the two styles of simulationmodel
serve dierent needs. We will present how we can link
Signal model with VHDL.
This section is divided into four parts. The rst
one discusses the representation of signals in both lan-
guages. The second and third ones present VHDL to
Signal and Signal to VHDL interfaces, and nally
the last part discusses the limitations on the subsets
of both languages that can be translated.
4.1 The Representation Of Signals
One of the most important features of both lan-
guages is the representation of signals. However, the
signals do not have the same representation and mod-
eling in the two languages.
In Signal, a signal is a ow of values using logical
time \clocks" (cf. section 2). No absolute time ex-
ists for signals. A signal is observable only when it is
present (its clock is true).
In VHDL, a signal is a ow of values using a time
metric (e.g femto-second), and holds its value (i.e. it
is observable) between two events.
Thus, the rst step is to represent VHDL's time
model in Signal and conversely ( Signal in VHDL).
4.1.1Modeling of VHDL timing in Signal VHDL
uses an event-driven simulation-oriented semantics.
The semantics of its timing constructs are expressed as
operations on an abstract discrete event simulator. In
this section we give a model for time scales in VHDL.
 Time scales VHDL uses two scales of time: the
real or macro-time, and the delta or micro-time (Fig-
ure 3). The macro-time scale represents \real" time,
e.g. a nano-second or a micro-second. The smallest
unit of time which can be expressed in VHDL is the
femto-second.
Macro-time
Micro-time
Figure 3 : Time scales
The micro-time (or delta time) is a non-measurable
delay. Any (even innite) number of delta's can exist
between two instants of real time.
 The modeling of time scales Unlike the model de-
scribed in (Pierre et al. 1992; Wilsey 1992), the model
described here uses both macro-time and micro-time.
D
T
SIMULATION CYCLE
4fs3fs2fs
1fs
0fs
Figure 4 : Time models
Let the clock T represent real time (or macro-time).
Let the clock D represent micro time, where every step
corresponds to one simulation cycle (see gure 4).
Let F denote an imaginary global clock. It cor-
responds to the union of T clock and D clock. We
can express this formally in Signal with the following
clock relation: Fb=Tb+D corresponds to F = T [D.
A possible graphical interpretation is shown below:
F
The VHDL current simulation time denoted by
NOW, can be easily described in Signal as: NOW
:= # T -1, where '#' counts the number of T events.
Signals are visible to the VHDL user in macro-time,
i.e. in the domain of T , and it is in macro time that
signals are available for interactions with exterior pro-
cesses. A signal may not be observed to change faster
than macro time. Nevertheless, the signal can be rep-
resented in micro-time during calculations.
 Signal Modelization One can identify two dier-
ent models for a VHDL signal S, depending on the
time domain in which the signal is used.
For the simulation domain, we use the representa-
tion Sa, which is the value of S when it is active.
For the observation domain (the external user's
view) the signal is noted S. The observed (or real-time)
signal can be derived from simulation domain across
imaginary clock F (Sf=Sa cell F), by down-sampling
Sf. A possible pictoral view of the signal models is
given below.
F
Sa
0 1 1 1 0
S
1 011
Sf
0 11 0011110
1
0
Observed signal
Note that if no zero-delay signal assignement is used
the VHDL signals can be represented with T .
 Variable Modelisation Variables in VHDL are
represented in Signal as signals. The Signal as-
signment operation is instantaneous, it is the same as
the delay semantics of variables in VHDL. We suppose
that variable representation in Signal is synchronous
with respect to D.
4.1.2 Modeling of Signal timing in VHDL For ex-
ecutable Signal programs, the compiler synthesizes a
master (logical) clock. Every signal can be described
as a down-sampling of the master clock. Thus, for
every signal X, we have two corresponding VHDL sig-
nals : XV, XC. XC is true when X is present and
false otherwise. XV has the value of X when XC is
true otherwise its value is not important (we keep the
same value).
X
Master
Clock
XV
XC
V1 V1V2 V1 V3 V1
V1 V2 V1 V3 V1
Note that if all Input/Output signals are syn-
chronous we need only one signal XV for a signal X
(the clock signals are not needed).
4.2 Translating VHDL Into Signal
We use a small VHDL subset for validating the
model; it is composed of: processes that contain one
wait before the key word end process, ports of mode
in and out, scalar type signals and variables, variables
and signal assignment and the If-then-else control
structure.
4.2.1 Signal attributes Due to space limitations,
we will only present the EVENT attribute; for the
remaining attributes see (Belhadj et al. 1993).
The EVENT attribute is expressed by taking ad-
vantage of the micro-time capabilities of Signal. Fol-
lowing the denition, EVENT is true when there is a
change in the value of the signal:
process EVENT= % process name %
{? logical SA; % input of logical type %
event CLK_D % input clock D %
! logical EVENT } % output EVENT %
(| EVENT:= (when(not(SA=ZSA))default (not CLK_D)
| ZSA:= SA $1 |)
where
logical ZSA init false %local signal declaration%
end;
4.2.2 Variable assignment As the variables propa-
gate with no delay, variable assignment can be con-
sidered as a Signal assignment. We substitute the
value of variables with the corresponding expression.
For example consider the variable V dened in follow-
ing the process:
variable V: ...;
begin
V := EXP1;
use of V;
...
V := EXP2;
use of V;
For the rst use of V we substitue the value of
EXP1, and EXP2 for the second one. If a variable
is used before it has been assigned then V$1 is used
(variables hold their old value) for all occurence before
the V assignment.
4.2.3 Signal assignment statement In Signal no
reference to future is allowed, the statement Y
<= transport X after N, is translated as Y <=
X'DELAYED(N) which can be coded in Signal as :
process TRANSPORT_DELAY=
(integer N)
{? X; event CLK_T
! Y}
(| synchro {X,Y,CLK_T}
| Y := X$N |)
end
For the inertial delay, the input wave form has to
be longer than delay N to appear in the output. We
use the process STABLE(N)fXg that is true when the
number of time ticks during which the signal X did
not change is greater than N.
process INERTIAL_DELAY=
(integer N)
{? X; event CLK_T
! Y}
(| Y := (X$N) when STABLE(N){X} default ZY
| ZY := Y$1
| synchro{X,Y,CLK_T} |)
...
For signal assignment without delay, as the model
captures micro-time, it can be coded as follow:
Ya := Xa$1
4.2.4 If-then-else statement For the conditional
structure, we use the following schema :
IF C THEN S1 <= EXP1;
ELSE S1 <= EXP2;
ENDIF;
It is transformed into the Signal statement :
S1 := EXP1 when C default EXP2 when not C.
This can be extended to the case form.
4.2.5 Wait statement Let's consider the statement:
wait on S1,S2 until B for TEXP;
We write a Signal process that evaluates true if the
wait is passed (i.e if either B is true when there is
an EVENT on S1 or S2, or the process is waiting for
TEXP units of time). The corresponding Signal pro-
gram is:
process WAITING=
(integer TEXP)
{? S1;S2;
logical B;
event CLK_T
! logical Y}
(| Y := when(START)
default WATCH(TEXP){START,CLK_T}
| START:= ( when (EVENT{S1,CLK_T}) default
when (EVENT{S2,CLK_T})) when B |)
.... % intially START is true
where WATCH(TEXP)fSTART,CLK Tg is true
whenever the process is waiting for TEXP units of
time (CLK T) after the last occurence of START.
4.2.6 Process statement Let's consider that the
VHDL program contains m processes P
0
; ::; P
m
.We
transform the sequential VHDL processes into Signal
parallel (data ow) processes.
Thus, successive execution of a VHDL process (sim-
ulation step) is done by the wait activation (note here
Wi is the waiting statement of process Pi). When Wi
is true the process Pi is executed.
For the signals in the input/output interface we use
the Signal format: we represent the value of a signal
for every time unit of T . Then, we use the following
rules for the generation of clock D (simulation step) :
if W
0
or...or W
m
then a new simulation step (D) is
generated, otherwise move to the next step of T .
4.3 Translating Signal Into VHDL
This step is simpler than the VHDL to Signal in-
terface. We consider only the functional (executable)
Signal programs. Then, two generators can be built:
a behavioral and a structural one.
Behavioral translation uses the same scheme as the
one used for sequential code generation (C and For-
tran77). Signal programs are equational, it is the
compiler who generates a control structure. The gen-
erated code may contain conditionals (If-then-else),
loops, variables and signal assignments in one VHDL
sequential process. We use the VHDL representation
of Signal signals discussed previously.
Structural translation converts graphic interface in-
formation, boxes (representing processes) and inter-
connexions (signals) into structural VHDL.
4.4 Constraints On The Interface
Translation in both directions can be extended, but
we must keep in mind some important issues:
 The rst constraint of an interface is that simu-
lation of VHDL or Signal programs obtained by
translation must be equivalent.
 We can translate non executable Signal pro-
cesses into assert statements and generate a
VHDL entity without architecture, but the SIG-
NAL to VHDL interface is designed to be used as
CAE/CAD entry. Thus, it must use functional
(executable) programs.
 Some limitations on the data types come from
both sides. For VHDL, as we intended to generate
synthesizable VHDL code, e.g. real types are not
used because they cannot be handled by current
synthesis tools. Some data types in VHDL do not
exist in Signal's current version.
 Not all VHDL is translatable in Signal. More-
over, the possibly translatable VHDL is not al-
ways useful for formal verication. This is due
to the current limitation of the proof system of
Signal (e.g. integer based proofs).
5 CONCLUSION AND FURTHER WORKS
We have presented a study and design of an in-
terface between two languages (VHDL and Signal)
and their environments. The major diculty was the
dierent simulation models. We describe a common
representation in both models. This will permit the
simulation of Signal programs in VHDL and VHDL
programs in Signal. As the capabilities and the tools
of the two languages exist, the important aspect was
the accuracy of the interface. However, we found a
number of restrictions and limitations. We are now
improving our interface by adding more constructs, to
handle a larger set of designs.
This, we hope, will permit high level design using
Signal and VHDL, and easy design of Real-time and
Signal processing systems (hardware and software).
Thanks to E. Rutten, T. Gautier, R. McConnell,
D. Wilde and anonymous reviewers for their careful
reading of the paper.
This work is partially supported by the Doctoral-
candidate Network for System and Machine Architec-
ture of the DRED
REFERENCES
 Belhadj M., R. McConnell and P. Le Guernic P. 1993.
\A framework for macro- and micro-time to model VHDL
attributes." In Proceedings of the European Design Au-
tomation Conference(Hamburg, Sep.).IEEE, 520-525.
 Dutertre B. 1992. Specication et preuve de systemes dy-
namiques Ph.D. thesis University of RENNES.
 ICS 1990. International Conference on Supercomputing.
ACM Press.
 LRM 1987. IEEE Standard VHDL Language Reference
Manual. IEEE Press. IEEE Std 1076-1987.
 Pierre L.; D. Borrione; and A. Salem. 1992. \Formal veri-
cation of VHDL description in the Prevail environment."
IEEE Design & Test of Computers,(Jun.):42-55.
 Le Guernic P. 1991. \The signal programming environ-
ment." In Proceedings of the Conference on Algorithms
and Parallel VLSI Architectures II (Gers, France, June).
Elsevier Science Publishers B.V.,347-358.
 Wilsey P. A. 1992. \Developing a Formal Semantic De-
nition of VHDL." In VHDL for simulation, Synthesis and
Formal Proofs of Hardware, J. Mermet ed. Kluwer Aca-
demic Publishers,245-256.
