##################################################################
# Copyright (C) 2000 Greg London All Rights Reserved.
# This program is free software; you can redistribute it and/or
# modify it under the same terms as Perl itself.
##################################################################
Hardware::Verilog::Parse.pm is currently in "beta" status
The Hardware::Verilog::Parser.pm file contains a Verilog grammar.
This grammar is used by Parse::RecDescent to parse any
Verilog design file. The parser was developed with version
1.77 of Parse::RecDescent.
parser.pl is a script which uses this module to do the actual parsing.
a test Verilog file is included called test1.v
to parse the file, type:
parser.pl test1.v
(or "parser.pl test1.v test2.v test3.v")
This should print out a report on test1.v that looks something like this:
module testmodule
contained the following input ports:
clock
myin
reset_n
contained the following inout ports:
contained the following output ports:
myout
outwire
contained the following wires:
type wire clock
type wire myin
type wire mywire
type wire outwire
type wire reset_n
contained the following regs:
myout
temp_reg1 [ 23 : 0 ]
temp_reg2 [ 35 : 0 ]
contained the following instances:
c is instance of clkblk
c1 is instance of clkbufrd
u2 is instance of core
u3 is instance of and08
u4 is instance of or02
contained the following function declarations :
contained the following parameters :
line count is 677
timit result is 58 wallclock secs (58.05 usr + 0.06 sys = 58.11 CPU)
using 58.05 seconds parse time
parse_rate is 11.66 lines/sec ( 677 / 58.05 ) src/test2.v
=========================================================
parser.pl will generate a similar report for all
modules it encounters in the files it is given.
a sample parser.pl file could look like this:
#! /bin/perl -sw
use Hardware::Verilog::Parser;
$parse = new Hardware::Verilog::Parser;
$parse->SearchPath(
'./',
'./include/'
);
$parse->Filename(@ARGV);
This will parse all the files passed as command line parameters.
Note, it also sets a "search path" which gives the parser a list
of paths to search for the given filenames.
If no search path is specified, files are assumed to be at ./
If search path is specified, and you want to start searching at ./
then you need to explicitly specify this.
=========================================================
The parser is now precompiled, and runs much faster than
the previous versions. Without precompilation, it took
about 60 seconds to run, with precompilation, it takes
roughly 6 seconds. An order of magnitude improvement.
you'll notice the report above lists performance numbers,
and they aren't exactly impressive.
currently, benchmarks average about 20 lines of Verilog
code parsed per second. So, yes, its still slow.
Damian has promised me the next version (2.0) of
Parse::RecDescent will have about a 5x speed improvement.
Unfortunately, it may be a couple months before its
released.
given its slow speed, the parser would be useful for
applications that can be run overnight, such as checking
coding rules on all the verilog currently checked into RCS.
I would eventually like to be able to detect signals
that can be categorized as asyncronous, syncronous,
clocks, registered output, gated outputs, and use that
information to automatically generate synthesis scripts,
and flag problem areas, such as combinatorial paths
that cross multiple hierarchy boundaries, and the like.
=========================================================
Directory structure / installation information:
once you untarred the file, you can install
the files by creating a directory structure
similar to this:
~home/Hardware/Verilog
inside that directory, copy the following files:
Hierarchy.pm
Parser.pm
StdLogic.pm
The remaining files go into ~home.
This would be where you run your perl scripts from.
You will need to run the perl script:
generate_precompiled_parser.pl
to generate the file PrecompiledParser.pm
this also goes into ~home
(or whatever directory you are running your perl
scripts from)
If you have any corrections or questions,
please send them to me at
[email protected]
thanks,
Greg London