US 7770147 B1
A method for generating hardware description language source files is provided. The method includes extracting an input/output (I/O) list and building a port list declaration file from the I/O list. The method also includes building a default instantiation file according to renaming rules and interpreting coding constructs to determine both variable types and sizes. The method further includes generating a sensitivity list.
1. A computer implemented method for generating hardware description language source files, comprising:
extracting an input/output (I/O) list;
building a port list declaration file from the I/O list, the building including,
distinguishing between the variable types in the extracted input/output list; and
defining variables according to the variable types;
building a default instantiation file according to renaming rules where signal names and port names are kept constant for multiple instantiations;
interpreting coding construct to determine both I/O variable types and sizes; and
generating a sensitivity list, wherein each operation is executed by a microprocessor.
2. The method of
3. The method of
reading input/output variables; and
generating the port list written into a Verilog source code file.
4. The method of
a direction and a size of the input/output variables.
5. The method of
labeling port names and wire names which are obtained from the port list declaration file.
6. The method of
7. The method of
list of signals in the input/output list.
8. The method of
instantiation file further comprising:
obtaining renaming rules from a configuration file where the rules are defined through regular expression syntax; and
applying renaming rules.
9. A computer readable storage medium for generating hardware description language source files, comprising:
program instruction for extracting an input/output (I/O) list;
program instruction for building a port list declaration file from the I/O list, the program instructions for building including,
program instruction for distinguishing between the variable types in the extracted input/output list; and
program instruction for defining variables according to the variable types;
program instruction for building a default instantiation file according to renaming rules where signal names and port names are kept constant for multiple instantiations;
program instruction for interpreting coding construct to determine both I/O variable types and sizes; and
program instruction for generating a sensitivity list.
10. The computer readable storage medium as recited in
The present application is a continuation-in-part and claims priority under 35 U.S.C. §120 of application that is commonly assigned to the assignee of the present invention, which is entitled “Automatic Generators for Verilog Programming”, application Ser. No. 11/075,830 filed Mar. 8, 2005 now abandoned. This application claims priority under 35 U.S.C. §119(e) from U.S. Provisional Patent Application No. 60/551,531, filed Mar. 8, 2004. The disclosures of each Application, and the Provisional Application, are incorporated by reference.
Writing ASIC source files in Verilog Hardware Description Language, (Verilog HDL), requires certain redundant overhead. The redundant overhead occurs when the RTL file is being built during which the same signals have to be listed at different places within the list. For example, a port list might list signals a, b, and c as they are coming in and then in the input/output list, the same signals a, b, and c might be listed as pins coming out. Some of the redundant information includes declaring the type and sizes of signals used in the design, sensitivity lists for constructs such as state machines and case statements, port lists which are the same as the input/output declarations, and module file instantiations. Moreover, such redundant information was previously entered manually, and such maintenance consumes large portions of an individual's time.
As a result, there is a need to eliminate the creation of such redundant information manually in order to reduce the overhead involved with respect to an individual's time.
Broadly speaking, the present invention fills these needs by providing a method and apparatus for removing redundant overhead for programming in the Verilog HDL language. It should be appreciated that the present invention can be implemented in numerous ways, including as a process, an apparatus, a system, or a device. Several inventive embodiments of the present invention are described below.
In one embodiment, a method for generating hardware description language source files is provided. The method includes extracting an input/output (I/O) list and building a port list declaration file from the I/O list. The method provides building a default instantiation file according to renaming rules and interpreting coding constructs to determine both variable types and sizes. The method further includes generating a sensitivity list.
Other aspects and advantages of the invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrating by way of example the principles of the invention.
The present invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, and like reference numerals designate like structural elements.
An invention is described for an apparatus and method that automatically generates a sensitivity list for Verilog programming. The redundancy associated with programming in the Verilog HDL language is eliminated by having a method that will automatically parse the source file to extract the needed information and from the extracted information, and corrects the extracted information, if necessary, in order to make the appropriate type and size declarations of signals being used. The method further generates the sensitivity lists for programming constructs, such as state machines and case statements, and lists out the port signals. The method also generates a module file instantiation and stores it in a separate file. A configuration file may be utilized to direct the program on multiple file parsing, as well as when, and how many instantiation files need to be generated per file parsed. The embodiments described below are described with reference to Verilog coding syntax. However, one skilled in the art will appreciate that these embodiments may be expanded to apply to any hardware description language (HDL).
When coding in a HDL language, e.g., Verilog, there is certain redundant overhead which is eliminated by the embodiments described herein. It will be obvious, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process operations have not been described in detail in order not to unnecessarily obscure the present invention.
If the registers and the wires are not defined, the compiler flags an error message and indicates which one of the registers or the wires is not defined. For example, a register size may not be defined properly because the register may be a bus of more than one bit, or a single bit. In this case, the compiler is likely to signal an error indicating that the register is not defined. This becomes an iterative process because the compiler detects only one error during each compilation process. Therefore, the compiler has to be compiled several times to locate all the variables that are not defined. This is one type of redundancy that the present invention is capable of eliminating. The system and method described herein is capable of distinguishing between different circuit elements such as a wire and a register or the difference between the two. A considerable amount of time can be saved by not having to define each and every variable. In one embodiment, defining the variable includes declaring the variables.
Still referring to
Thereafter, in operation 406, a default instantiation file is generated. The default instantiation file includes a list of port names, and the wire names to which the ports get connected. When a module file of the type described above is instantiated, the signal names going in and out of the module file should be the same. The signal name should be associated with a port name and the port name should be associated with a wire name. The method described herein automatically builds the default instantiation file where by labeling the port names and the wire names, which are obtained from the port list declaration file. The renaming rules are obtained and applied to the instantiation file as indicated in operations 408 and 410. The renaming procedure will be discussed in detail below.
It should be appreciated that a module file may be instantiated multiple times provided a different instantiation name is used each time. However, during each instantiation, the signal names are kept the same. In cases where the module file gets instantiated multiple times, the module file builds multiple instantiation files and the renaming rules are applied per instantiation as shown in operation 410 and 414. The renaming rules are defined and is obtainable as needed as indicated in operation 408. In one embodiment, the renaming rules are defined in a configuration file. It should be appreciated that the rules are well-defined rules and, in one embodiment, a regular expression syntax is used. One of the advantages of this method is that the regular expression syntax is used to search only the connected wires and not the ports, since the ports will remain the same.
Once the instantiation files are built, the operation moves onto processing the body in operation 416. During the processing, the information provided in the instantiation files are interpreted and followed accordingly. For example, from the information provided in the instantiation files, a determination can be made as to the type of variable, i.e. a register or a wire and the corresponding size, etc. With respect to the size, a size suitable for the application or a programming construct may be used to declare the size. It should be understood that when a variable is being declared, the method described herein will maintain parameters. Parameters are Verilog HDL construct. Parameters can be used to declare wire sizes, and register sizes, etc. In case of buses, parameters may be used to establish relationship between buses. Parameters can also be placed in a separate file and be included into multiple module files by using the “include” statement. Thereby, multiple designers may write around a common set of parameters, so that the separate module files by the designers may interact with each other. In one embodiment, the parameters are declared in a common file that is accessible by all of the designers. Thus, when a parameter has to be changed, the parameter only has to be changed in the common file and not in the individual module files which uses the parameter.
In one embodiment, the method described herein includes scripts or codes, which automatically generates Verilog HDL based source code files to contain the redundancy removed from the originally parsed Verilog HDL based source code. One such generated source coded file contains the port list. The second such generated source code file contains all the declarations for wires versus registers and the size of such wires. Without a notice, what was previously defined as a register may become a wire, and vice versa and the script takes this into account and makes the changes accordingly. Therefore, the embodiments described herein have a macro script that combs through the body of the module files and parses the module files multiple times and determines whether there are any changes. In one embodiment, the body of the module files describes the combinatorial logic and which values get loaded into registers. Thus, the macro script eliminates the need to write declarations. The script scans the body of the module files, and follows the instructions, to determine what variables are needed, and the weight of their registers, or wires, thereby automating what used to be the manual inputting of items.
Subsequent to body processing, a sensitivity list is generated in operation 418. Sensitivity lists are specific coding constructs. In one embodiment, the sensitivity list is called by an “always @” statement. Sensitivity lists are used when there are multiple signals involved and a common path needs to be declared. In one embodiment, the sensitivity list provides a list of signals that are going to be used in a certain body of the code. Therefore, at the time of code execution, the codes to be executed are determined by the signals listed in the sensitivity list. When a particular signal in the sensitivity list changes, a corresponding section of the code is executed. Therefore, if a signal is not listed in the sensitivity list, the code corresponding to the signal will not be executed. The embodiments described herein will automatically generate the sensitivity list. Therefore, the signals to be listed in the sensitivity list will not be missed. Even in cases where the signals are changing, the sensitivity list will automatically rebuild to accommodate the changes. The script is capable of detecting which signals are active and which signals are used in the body that are different from the sensitivity list.
The script will automatically generate the instantiation files if a different name is used. As described above, when a module file is instantiated multiple times, different instance names are given for each instantiation. The use of multiple instantiations requires the use of the configuration file to list the desired instance names. By default, the program will generate a separate instantiation file each instance name provided. Also by default, no name changes of the wire names utilized in the instantiation files, will be changed. If wire name changes are desired, a separate section of the configuration file is provided to list these name changes. The name changes are listed for each instance separately. In other words, each group of desires name changes designates itself by using the instance name they are to be applied to. In one embodiment, there will be no sharing of name changes. For instance, if two instances need the same set of name changes applied, these name changes will be listed twice.
As can be seen, the method described herein forces the user to declare the variables at the beginning, which helps to prevent errors due to undeclared variables. For example, if a wire or a register is only going between two included files, then that variable is declared as a Verilog syntax. However, when a wire is being utilized, the wire need not be declared since Verilog HDL, allows for “implied wire declarations”. When some of the undeclared wires are eventually turned into buses, and if the interconnect wire remains undeclared, this can lead to errors. Therefore, by generating all the instantiation files first, names become known, even though the variables might have been renamed using the renaming rules.
Moreover, the port names are not decided a priori, instead, port names reflect the names used in the input/output port list section of the module file being connected. As such, based on which wire the port is connected to and depending on this information, an appropriate wire size and an appropriate name are declared. As described above, port and wire names need not match. The wire names generally determined by the parent module file which is using the instantiation file that is being generated. In one embodiment, the wire names match the port names. In another embodiment, where there are multiple versions of a module file, some or all of the wire names are changed to depend on the instantiation file being generated to make some or all wires coming out of each of the instantiation unique.
With the above embodiments in mind, it should be understood that the invention may employ various computer-implemented operations involving data stored in computer systems. These operations are those requiring physical manipulation of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. Further, the manipulations performed are often referred to in terms, such as producing, identifying, determining, or comparing.
Any of the operations described herein that form part of the invention are useful machine operations. The invention also relates to a device or an apparatus for performing these operations. The apparatus may be specially constructed for the required purposes, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can be thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, magnetic tapes, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.