generic check

S

Stephane

how can a component perform a self-check on its generic map at
instanciation?

for example

entity mycomp is
generic(
param1 : integer := 1;
param2 : integer := 2);
.....
architecture...
....
begin...
....


let's say, I want to be sure that param2 is greater than param1 and
detect this assertion? "assert" does the job too late.
 
A

Andy

how can a component perform a self-check on its generic map at
instanciation?

for example

entity mycomp is
generic(
param1 : integer := 1;
param2 : integer := 2);
....
architecture...
...
begin...
...

let's say, I want to be sure that param2 is greater than param1 and
detect this assertion? "assert" does the job too late.

Some tools (nc-sim) will try assertions on constant (including
generic) expressions during elaboration.

Most tools would trip out during compilation/elaboration if you had a
declaration that was out of bounds:

constant test_param1 : integer range 0 to param2 - 1 := param1;

Or more generally, maybe something like:

subtype test_t is boolean range true to true; -- is this legal?

constant test1: test_t := testfunc1(generic1);

Andy
 
S

Stephane

Some tools (nc-sim) will try assertions on constant (including
generic) expressions during elaboration.

Most tools would trip out during compilation/elaboration if you had a
declaration that was out of bounds:

constant test_param1 : integer range 0 to param2 - 1 := param1;

Or more generally, maybe something like:

subtype test_t is boolean range true to true; -- is this legal?

absolutely:

** Fatal: (vsim-3421) Value 0 is out of range 1 to 1.


thank you for your solution; it matches my need!

It is true that the problem would have appeared later at elaboration,
but it is far easier to have the line of an assertion to correct the bug
quickly.
Plus, the assertions at the beginning of architecture are almost part of
the specification...
 
A

Amal

absolutely:

** Fatal: (vsim-3421) Value 0 is out of range 1 to 1.

thank you for your solution; it matches my need!

It is true that the problem would have appeared later at elaboration,
but it is far easier to have the line of an assertion to correct the bug
quickly.
Plus, the assertions at the beginning of architecture are almost part of
the specification...

If the types do not match that can be caught by the simulator. Say if
you declare a positive parameter and assign 0 or negative to it,
elaboration would stop with an error.

One way to check for valid range, is to put assertions in your entity
declaration as follows:

entity mycomp is
generic(
param1 : integer := 1;
param2 : integer := 2
);
port (
);
-- -----------------------
-- translate_off
begin
assert( 1 < param1 and param1 < 5 )
report "param1 can should be in range [2..4]!"
severity ERROR;
-- translate_on
end entity mycomp;

architecture ??? of mycomp is
begin
end architecture ???;

Not that not all synthesis tools like to see begin before the entity
end statement. So, you need to put translate off/on pragmas around
it.

-- Amal
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
474,171
Messages
2,570,934
Members
47,472
Latest member
KarissaBor

Latest Threads

Top