- If you have verification environment loaded on Specman and one method is extended in multiple files and you want to see all the extension of that method in a single place, "collect" command is what you are looking for.
- If you want to debug temporal expression, you would like to visualise how different events are triggered. Event chart is basic but sometimes useful for debugging temporal expressions. To see the events you first have to collect events you are interested in by using "collect events" Specman command.
- If you want to see the events triggered during simulation, you can use Specman command "show events" after collecting the events as mentioned above.
- If you want to have a summarized report about the events count, if it is associated with cover group, its source etc, you can use "show events def" command.
- Executing actions on command line. You can define variables or call methods or start a TCMs. (you can not call a TCM on command line). Remember, you can not give "gen" action on command line, but you can call a method which has gen action in it.
- You can search/grep within the loaded files using "search" command
- You can open a file (known as "module" in Specman terms) in source browser by using "source" command. It will open a source browser with that perticular line number into focus.
- You can run unix commands using "shell" command.
- You can also get the value of define by issuing "show define" command.
- If you want to know what are the modules that are loaded you can use "show modules" command.
- You can get unix environment variables value within your e code by using get_symbol() method.
- 12. If you wish to execute specman command in e code, then you can use specman() method as shown below.
- If you wish to execute unix command from your e code, you can use output_from() method.
- If you want to uderstand port binding in Specman, use "show ports" command.
- You can use "trace bind' to follow the binding process
- If you have executed a set of commands and want to see the history of executed commands, you can use "show redo" command.
- Once you know the hisotry of executed command, you can reexecute them by issueing "redo" Specman command.
- If you have wave command executed to view e fields into waveform and want to dump all these wave tracing commands into a file, you can use "write wave" command.
collect sys.mystruct.monitor
collect sys.run
File temp.erld - created by collecting:
sys.run (after module specman)
<'
----------------------- Reset sys.run:
extend sys {
run(
) is as was after specman;
};
----------------------- From temp.e at line 6:
extend sys {
run() is also
{
var x : mystruct_s;
gen x;
};
};
----------------------- End of sys.run
'>
collect events *.*
collect events sys.mystruct.* //collects all events for the instance sys.mystruct
collect events mystruct_s.* //collects all the events of struct mystruct_s
show events
show events 100 //This command shows events since time 100
show events 100..150 //This command shows events in the time range 100..150
show events -chart //Pops up event chart
show events def sys.any
count echo col covr name source
------------------------------------------------------------------
0 10000 FALSE TRUE FALSE sys.any @sn_te_tick
var x : uint(bits: 4) = 5;
var y : uint = x + 10;
print x + y;
sys.non_tcm()
start sys.tcm()
sys.non_tcm_with_arg(4, TRUE)
search mystruct_s
syntax: source
source mystruct.e 50
syntax: shell
shell echo $SPECMAN_PATH
shell pwd
syntax: show define [-v] [-e]
show define -v "*WIDTH*"
show modules
my_method() is
{
outf ("SPECMAN_PATH=%s",get_symbol("SPECMAN_PATH"));
};
pre_generate() is
{
specman("break on error");
};
my_method() is
{
var list_of_files: string;
list_of_files = output_from("ls");
print list_of_files;
};
show redo
show redo
The redo buffer (default is 'redo 0..') =
0. "restore specman.esv"
1. "load temp.e"
2. "test"
3. "clear screen; restore; reload; test"
redo 3 //this will execute command 3 (clear screen; restore; reload; test)
redo 0..2 //this will execute command 0 to 2 (restore specman.esv, load temp.e, test)
syntax: write wave to
1 comment:
Great info!! Thanks!
Post a Comment