This patent application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2010-111673 filed on May 14, 2010, the entire contents of which are incorporated herein by reference.
The embodiment discussed herein is related to a computer-readable recording medium, a method, and an apparatus for calculating information related to a power consumption of an integrated circuit.
Conventionally, the power consumption of a system LSI (Large Scale Integration) was reduced by reducing a wiring scale. But recently, it has become difficult to further reduce the power consumption by the reduction of the wiring scale. Also, the likelihood of generating a leakage current due to the reduced wiring scale has increased.
Accordingly, recently, the power consumption is estimated by a simulation or an emulation in an implementation level such as a RTL (Register Transfer Language) description or a netlist. Based on the estimation, measures are taken to reduce the power consumption of the system LSI.
However, approximately one and a half years are required to implement the RTL description or the netlist depending on the scale of the circuit to be designed. In a case in which the power consumption is estimated after the RTL description or the netlist is implemented, and the estimated value does not fall within a tolerable range, the design workload increases due to a relatively large amount of redesigning that is required of the circuit.
According to one aspect of the embodiment, there is provided a computer-readable, non-transitory medium recorded with a program which, when executed by a computer, causes the computer to perform an index value calculating process, the process including reading out, from a storage part, data indicating an execution procedure of process steps which each of function units of an integrated circuit executes; reading out, from the storage part, a coefficient corresponding to each of the process steps; calculating an index value of power consumption based on the coefficient corresponding to each of the process steps included in each of unit steps into which the execution procedure is divided; and outputting the index value for each of the unit steps to be stored in the storage part.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the appended claims. It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention as claimed.
In the following, an embodiment of the present invention will be described with reference to the accompanying drawings. In the embodiment, a system LSI (Large Scale Integration) including modules (function units) illustrated in
Moreover, the system LSI in the embodiment is the same as a generally known system LSI, and is an LSI including a circuit which includes a CPU (Central Processing Unit) and a specific function, an LSI in which only a specific function such as media processing or the like is implemented and a CPU may not be implemented, or the like. Moreover, power consumption information is information concerning power consumption, and is not always limited to an amount of the power consumption as described later.
In the embodiment, the power consumption information related to a system LSI having the module configuration as illustrated in
In the embodiment, when the power consumption information of the system LSI is calculated, information, which indicates an execution procedure (a process sequence) of process steps (operation steps) of each of the modules (function units) m1 through m5, is regarded as input information. In the embodiment, a sequence diagram of UML (Unified Modeling Language) is used as the information indicating the execution procedure. In
First, a weighting coefficient (hereinafter, simply called “coefficient”) for the power consumption information is assigned to each of the modules ml through m5. In
Next, a power consumption index value of a time-sequence (for each term) is calculated based on process steps conducted in a unit (or a term) and a coefficient of a module which conducted the process steps for each unit (or for each term). The unit (or the term) is made by segmenting a series of the process sequence (the execution procedure) from the start of a first step to the end of a last step in the sequence diagram Seq1 by a predetermined rule. In
Next, for each of the modules m1 through m5 (that is, in a vertical axis direction of the sequence diagram Seq1 in
The power consumption index values in the time-sequence, and the module power consumption index values are the power consumption information in the embodiment. It should be noted that the power consumption index values are relative values based on the coefficients. In the embodiment, for the sake of convenience, an implementation level of the circuit of the system LSI is the TLM.
In the following, a power consumption information calculating apparatus 10, which calculates the power consumption information, will be described.
A program realizing a process, which is executed by the power consumption information calculating apparatus 10, is provided by a recording medium 101 such as a CD-ROM (Compact Disk Read Only Memory) or the like. For example, the recording medium 101 may be formed by a non-transitory (or tangible) computer-readable recording medium. When the recording medium 101 storing the program is set in the drive unit 100, the program is installed into the auxiliary storage unit 102 through the drive unit 100 from the recording medium 101. However, it is not always required to install the program from the recording medium 101. The program may be downloaded from another computer through a network. The auxiliary storage unit 102 stores necessary files, data, and the like as well as the program.
The recording medium 101, the auxiliary storage unit 102, and the memory unit 103 may form a storage part.
When the CPU 104 is instructed to execute the program, the program is read from the auxiliary storage unit 102 and stored in the memory unit 103. The CPU 104 realizes a function of the power consumption information calculating apparatus 10 in accordance with the program stored in the memory unit 103. The interface unit 105 provides an interface to connect the power consumption information calculating apparatus 10 to the network. The display unit 106 displays a GUI (Graphical User Interface) by the program, and the like. The input unit 107 may include a keyboard, a mouse, and the like, and may be used to input various operation instructions.
The specification data storing part 11 may form a storage area to store specification data in the auxiliary storage unit 102. The specification data are electronic data of a specification in which a functional specification is written for each module in a natural language. The coefficient calculating part 12 calculates the coefficient for each module by using the specification data. The coefficient storing part 13 may form a storage area to store the coefficient calculated by the coefficient calculating part 12 in the auxiliary storage unit 102 by associating with the module. The sequence diagram data storing part 14 may form a storage area to store data indicating the sequence diagram Seq1 (hereinafter, called “sequence diagram data”.) in the auxiliary storage unit 102.
The time-sequential index value calculating part 15 calculates the power consumption index value of the time-sequence based on the sequence diagram data stored in the sequence diagram data storing part 14 and the coefficients stored in the coefficient storing part 13. The time-sequential index value storing part 16 may form a storage area to store the power consumption index value calculated by the time-sequential index value calculating part 15 in the auxiliary storage unit 102. The module index value calculating part 17 calculates the module power consumption index value for each module based on the sequence diagram data stored in the sequence diagram data storing part 14 and the coefficients stored in the coefficient storing part 13. The module index value storing part 18 may form a storage area to store the power consumption index value for each module calculated by the module index value calculating part 17 in the auxiliary storage unit 102. In this example, the storing parts 11, 13, 14, 16, and 18 are formed by the auxiliary storage unit 102, however, these storing parts 11, 13, 14, 16, and 18 may be formed by the storage part including one or more storage units.
In the following, the process sequence of the power consumption information calculating apparatus 10 will be described.
In step S101, the coefficient calculating part 12 receives an indication of the specification data from a user, and stores the specification data indicated by the user in the memory unit 103. For example, the indication of the specification data is conducted by indicating a file name of a file in which the specification data are stored.
Next, the coefficient calculating part 12 receives an indication of a mark (hereafter, called “module delimiter”) to identify a segment (for example, a title) of a description for each module, and a mark (hereinafter, called “function delimiter”) to identify the segment (for example, the title) of a description for each function in the module, in the specification data from the user (S102). For example, in a case of the specification data in
Next, the coefficient calculating part 12 searches for the module delimiter from a beginning (a first line of a first page) of the specification data (step S103). When the module delimiter is found, the coefficient calculating part 12 initializes a variable N to zero to store the coefficient (step S104). Next, the coefficient calculating part 12 searches for the function delimiter from a location where the module delimiter is found (step S105), and increments the variable N by one every time the function delimiter is found (step S106). That is, in the embodiment, the number of functions of the module is a value of the coefficient. Since the more the number of functions the more power the module consumes, it may be regarded that a correlation exists between the number of functions and the power consumption. In a case in which the function delimiter is not found, the coefficient calculating part 12 records a value of the variable N as the coefficient by associating it with the module name of the module which is a current subject to process (step S107). A case in which the function delimiter is not found includes a case in which the module delimiter of a next module is found, a case in which an end of the specification data is found, or the like.
After that, the steps S103 through 107 are repeated until the module delimiter is not found. As a result, for example, the coefficient storing part 13 stores data 13d as illustrated in
As described above, for a calculation of the coefficient based on the specification data, it is preferable to create the specification data to be a structural document in such as XML (extensible Markup Language), SGML (Standard Generalized Mark-up Language), or the like. For example, if the specification data are XML data, the module delimiter and the function delimiter may be indicated by respective tag names.
Also, instead of counting the functions, the number of lines in the description concerning the module may be counted, since it may be regarded that a correlation exists between a quantity of functions and an amount of the explanation.
Moreover, the coefficient may be given by the user, instead of being automatically calculated. In this case, the user may determine a weight, a size, or the like of the functions of each module, and may apply the coefficient to the corresponding module based on a determination result. The value of the coefficient may be a relative value between the modules. Thus, if a relative relationship between the modules becomes apparent, the value of the coefficient may be counted in any manner.
Next, a calculation process of the power consumption index value in the time-sequence will be described.
In step S201, the time-sequential index value calculating part 15 initializes a variable N to zero to store the power consumption index value in the time-sequence (hereinafter, called “time-sequential index value”). Next, the time-sequential index value calculating part 15 searches for one process step in the time-sequence from the sequence diagram data of the sequence diagram Seq1 (step S202). When the process step is found, the time-sequential index value calculating part 15 determines whether or not the process step is an internal process (step S203). The internal process is a process executed inside the module such as a step s1 of the sequence diagram Seq1 in
When the process step is the internal process (Yes in the step S203), the time-sequential index value calculating part 15 acquires the coefficient with respect to the module which is an execution subject of the process step, from the coefficient storing part 13, and adds the coefficient to the variable N (step S204). After that, the step S202 and the following steps are repeated.
On the other hand, when the process step is not the internal process (No in the step S203), the time-sequential index value calculating part 15 determines whether or not the process step is a message to a RAM module (step S205). The message calls another module such as a step s2 of the sequence diagram Seq1 in
When the process step is the message to the RAM module (Yes in the step S205), the time-sequential index value calculating part 15 acquires the coefficient with respect to the RAM module from the coefficient storing part 13, and adds the coefficient to the variable N (step S206). Then, the step S202 and the following steps are repeated.
On the other hand, when the process step is not the message to the RAM module (No in the step S205), it is determined that the process message is a message for another module other than the RAM module. The message for another module is to switch the execution subject of a process. Accordingly, in this case, the coefficient calculating part 12 determines the process step to be a delimiter of a calculation term of the power consumption index value in the time-sequence, and records a current value of the variable N as the time-sequential index value for the calculation term in the time-sequential index value storing part 16 (step S207). That is, in the embodiment, a timing to switch the execution subject of the process is determined as the delimiter of a term in which the coefficient is additionally recorded with the power consumption in the time-sequence. The term related to the power consumption index value in the time-sequence, in which a process is consecutively conducted by the same module, is considered proper as the delimiter.
After that, the step S201 and the following steps are conducted until the process step is not found (that is, until an end of the sequence diagram Seq1). As a result, for example, the time-sequential index value storing part 16 stores data 16d as illustrated in
In general, a user is a designer of a circuit, and comprehends an operation of the circuit. Thus, the delimiter of the execution procedure may be arbitrarily indicated by the user. The user may indicate more than one process step (hereinafter, called “delimiter step”.) which sections between terms, when calculating the power consumption index value in
Next, a calculation process of the module power consumption index value will be described.
In step S301, the module index value calculating part 17 initializes a variable N to zero to store the module power consumption index value (hereinafter, called “module index value”). Next, the module index value calculating part 17 searches for one module (in a vertical axis direction of the sequence diagram Seq1 in
When the module is the RAM module (Yes in the step S303), the module index value calculating part 17 searches for a message for the module from the sequence diagram data (step S304). For example, referring to the sequence diagram Seq1 in
On the other hand, when the module is not the RAM module (No in the step S303), the module index value calculating part 17 searches for an internal process of the module from the sequence diagram data, and counts the internal process when the internal process is found (step S306). For example, in the sequence diagram Seq1 illustrated in
After that, the step S301 and the following steps are repeated until the module is not found. As a result, for example, the module index value storing part 18 stores data 18d as illustrated in
Based on the power consumption index value calculated as described above, for example, the user can acquire knowledge as follows.
Also,
Also, it is possible to comprehend a relative relationship of the power consumption between the modules based on the module index value. A designer of a circuit is greatly interested in which module the power consumption may be greater. Accordingly, it is significantly useful for the designer to comprehend the relative relationship of the power consumption between the modules.
For example, in a case in which the design is advanced and the MAIN module m2 in the embodiment is segmented, the time-sequential index value and the module index value may be calculated for a module group included in the MAIN module m2.
As described above, according to the embodiment, if data (for example, data indicating a sequence diagram) are defined in which the data indicate an execution order of the process steps conducted by each of modules (by a function unit) of a semiconductor integrated circuit such as the system LSI or the like, and also indicate a call step between the modules, the power consumption index value can be acquired. If a transaction between the modules such as in the TLM is clearly described in a step, the embodiment can be applied. Accordingly, in an upstream of an implementation step of the circuit, it is possible to provide useful information concerning the power consumption.
In addition, the embodiment can be applied to implementations other than the TLM, such as the RTL description, the netlist, or the like. In a case in which the embodiment is applied to such other implementations, a substance, to which the module is applied, is changed based on an implementation to be a subject to apply. In a case of the RTL description, the netlist, or the like, a further specific or physical circuit element may be applied to the module.
In the embodiment, a function count for each module is applied to be the coefficient for the corresponding module. The function count is a numeral value concerning all process steps which the module executes. For example, referring to
Alternatively, the coefficient may be applied for each module and each process step. That is, based on a process weight or the like applied to the process step, the coefficient is defined for each of the process steps. In this case, even if there are multiple process steps in the same module, the coefficient to be added can be different depending on each of the multiple process steps.
It may be regarded that the coefficient is applied for each process step. That is, in the embodiment, it may be regarded that the coefficient for each process step is applied (shared) by the module unit. As described in the embodiment, in a manner of applying the coefficient by the module unit, advantageously, it is possible to reduce workload applying the coefficient.
According to the embodiment, in an upstream step in a higher abstraction level of a circuit above the design step of the RTL, the netlist, or the like, useful information concerning the power consumption can be provided. Therefore, it is possible to reduce the likelihood of an occurrence of a re-design when an abstraction level of the circuit becomes lower.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiment of the present invention has been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2010-111673 | May 2010 | JP | national |