US20010014964A1 - Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method - Google Patents

Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method Download PDF

Info

Publication number
US20010014964A1
US20010014964A1 US09/062,656 US6265698A US2001014964A1 US 20010014964 A1 US20010014964 A1 US 20010014964A1 US 6265698 A US6265698 A US 6265698A US 2001014964 A1 US2001014964 A1 US 2001014964A1
Authority
US
United States
Prior art keywords
flop
flip
logic circuit
logic
clock
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US09/062,656
Other versions
US6434722B2 (en
Inventor
Masamichi Kawarabayashi
Takuo Nakaki
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NEC Electronics Corp
Original Assignee
NEC Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by NEC Corp filed Critical NEC Corp
Assigned to NEC CORPORATION reassignment NEC CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KAWARABAYASHI, MASAMICHI, NAKAKI, TAKUO
Publication of US20010014964A1 publication Critical patent/US20010014964A1/en
Application granted granted Critical
Publication of US6434722B2 publication Critical patent/US6434722B2/en
Assigned to NEC ELECTRONICS CORPORATION reassignment NEC ELECTRONICS CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: NEC CORPORATION
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/32Circuit design at the digital level
    • G06F30/327Logic synthesis; Behaviour synthesis, e.g. mapping logic, HDL to netlist, high-level language to RTL or netlist

Definitions

  • This invention relates to a method of designing a large-scale integrated LSI circuit, and in particular, to a circuit design method using a logic synthesis technique.
  • a circuit design method using the known EDA (electronic design automation) tool has increasingly became important.
  • Such a circuit design method is normally classified into five phases, namely, (1) a system design, (2) a function/logic design, (3) a layout design, (4) a test design, and (5) a macrocell design.
  • the LSI to be designed is expressed as a resistor or a combination between the resistors.
  • the known RTL (resistor transfer level) description which is obtained in the system design phase is expressed by the use of a hardware description language, such as the known VHDL, to obtain a logic circuit (net list) of a gate level.
  • the logic circuit of the gate level which is used in the function/logic phase includes a variety of logic circuits. Under the circumstances, when the logic synthesis is directly carried out for the logic circuit which is described by the use of the VHDL, the constraints are often satisfied.
  • the logic is optimized within the range independent of a semiconductor manufacturing technology.
  • the number of the logic gates (chip area) and the number of logic stages are suitably adjusted so as to satisfy the constraints which are requested by an user.
  • a redundant logic is eliminated, a logic is opened, and a multi-stage is carried out by the use of a nature of Boolean algebra.
  • a mapping process is performed for the semiconductor manufacturing technology.
  • the logic circuit to be designed includes, for example, a plurality of logic circuits each of which retains a signal value under a predetermined condition and inputs data under the other condition.
  • this logic circuit is expressed by the use of a specific description, such as the VHDL.
  • the logic circuit is logically synthesized by a combination of a multiplexer, a delay flip-flop and a feedback loop.
  • the multiplexer operates by receiving an enable signal and a data signal.
  • the flip-flop is connected to the multiplexer and is turned on and off in response to a timing clock. Further, the feedback loop is connected between the delay flip-flop and the multiplexer.
  • the delay flip-flop itself repeats on and off operations every when the timing clocks are supplied to the logically synthesized combination of the multiplexer, the delay flip-flop and the feedback loop.
  • electrical power is largely consumed when the delay flip-flop repeats the on and off operations. Consequently, the above logically synthesized logic circuit must be manually adjusted so as to reduce the power consumption of the logic circuit.
  • a method of this invention designs a circuit having a flip-flop which performs an on and off operation in response to timing clocks and a feedback loop.
  • the logic circuit having a lower power consumption can be obtained with a simple operation by automatically generating the logic circuit which is formed by the use of the gated clock.
  • This also means that the circuit having a small chip area can be structured.
  • FIG. 1 shows a structure of a logic circuit according to this invention
  • FIG. 2 is a circuit diagram for explaining a principle of this invention in relation to FIG. 1;
  • FIG. 3 is a flow chart for explaining a circuit design method according to an example of this invention.
  • FIG. 4 is a circuit diagram for explaining a circuit which requires a pretreatment process according to this invention.
  • FIG. 5 is a circuit diagram for explaining the pretreatment process which is performed for the circuit illustrated in FIG. 4;
  • FIG. 6 is a circuit diagram for explaining variation of logic circuits which are formed by the use of a gated clock process and which are generated according to this invention.
  • FIG. 7 is a flow chart for explaining an operation for generating a logic circuit which is formed by the use of a gated clock process according to this invention.
  • a circuit which is logically synthesized on the basis of the above-mentioned description is structured by a combination of a delay flip-flop 1 (DFF) and a multiplexer 2 (MUX). Further, the delay flip-flop (DFF) and the multiplexer (MUX) are connected to each other via feedback loop 3 . More specifically, the multiplexer 2 (MUX) in the logically synthesized circuit is given data (data1, namely (d)) and data (data 2, namely (h)) which is fed back from the delay flip-flop 1 (DFF).
  • the logically synthesized logic circuit has the delay flip-flop 1 (DFF) which performs the on and off operation in response to the timing clock (c). Therefore, with such a structure, every time when each cycle of the clock timing (c) begins and finishes, the delay flip-flop 1 (DFF) repeats the on and off operation. Consequently, the power consumption becomes large.
  • DFF delay flip-flop 1
  • the circuit according to this invention is automatically changed into a gated clock circuit so as to suppress a change due to the clocks (c) when the above-mentioned expression is used.
  • the multiplexer 1 (MUX) is removed and the delay flip-flop 1 (DFF) is left in the logic circuit which is formed by the use of the gated clock. Further, the data 1 (d) is directly given to the delay flip-flop 1 (DFF) in the circuit illustrated in FIG. 2.
  • the enable signal (e) and the timing clock (c) are given to an OR gate OR 1 4 and are supplied to the delay flip-flop 1 (DFF) via the OR gate OR 1 4 .
  • step S 1 goes to the step S 2 to select FF.
  • the selected FF is represented by g in the step S 2 .
  • e and eb are the enable signal and a Not enable signal (called an enable bar signal) thereof, respectively.
  • h is an output signal of g while d is a data signal (data 1 ).
  • step S 4 proceeds to the step S 5 . If h is not included, the process returns to the step S 1 .
  • the process proceeds to a calculation process of a co-factor in the step S 5 and the latter because h is included in the logic function with respect to the input f.
  • the co-factor can be calculated by inputting a logic “1” and a logic “0” as e and eb.
  • the co-factor can be calculated by the use of the following equation.
  • the operation process transfers from the step S 6 into the step S 7 to generate the logic circuit which is formed by the use of the gated clock because the above condition is satisfied.
  • the operation process goes to the step S 8 to calculate the co-factor for the enable signal eb base upon the following equation.
  • step 9 is returned back to the step S 1 to select another flip-flop and to repeat the same operation because the above relation is not satisfied in the step S 9 .
  • This operation is carried out for all of the flip-flops until all of the logic circuits which are formed by the use of the gated clock are generated.
  • the gated clock logic circuit is generated as shown in the step S 7 in FIG. 3, it is required that the input f for the selected flip-flop g is single.
  • the signal f which is obtained by logically calculating the enable signal e and the output h of the delay flop-flop 1 (DFF) is branched or fanned out other than the delay flip-flop 1 (DFF) as illustrated in FIG. 4, the gated clock illustrated in FIG. 2 is not accurately and logically synthesized.
  • a pretreatment process must be carried out to equivalently constitute the circuit illustrated in FIG. 1.
  • the multiplexer (MUX) 2 illustrated in FIG. 4 is doubled to structure a multiplexer 20 a (MUX1) and a multiplexer 20 b (MUX2) which are equivalent to each other.
  • the multiplexer 20 a (MUX1) and the delay flip-flop 1 (DFF) is formed by the use of gated clock in the same manner with FIG. 2.
  • a circuit (not shown) which is connected to the multiplexer 20 b (MUX2) may be dealt with the other logic circuit.
  • the gated clock logic circuit when the gated clock logic circuit is generated, it is desirable that consideration is made about a case that the data d is stored to the flip-flop g which is selected at the rise of the clock and another case that the date d is stored to the flip-flop g which is selected at the fall of the clock. Further, another consideration may be preferably made about a case that the enable signal e is sometimes equal to a logic “1” or “0”.
  • FIG. 6 a structure of a logic circuit which stores the data d on the basis of the rise clock is illustrated in a first column.
  • a structure of a logic circuit which stores the data d on the basis of the fall clock is illustrated in a second column.
  • the gated clock logic circuit (thereinafter, referred to as a logic circuit A) can be obtained by using an OR gate 60 between the enable signal e and the timing clock c in the same manner with FIG. 2.
  • the corresponding logic circuit (thereinafter, referred to as a logic circuit B) can be obtained by inputting Not signal (namely, eb) of the enable signal e to the OR gate 61 .
  • step SS 1 it is judged whether or not the logic circuit is required to be doubled in the step SS 1 .
  • This judgement can be easily carried out by detecting whether or not the signal f is branched or fanned out.
  • the circuit with respect to the signal f for example, the multiplexer MUX
  • the step SS 2 the circuit with respect to the signal f (for example, the multiplexer MUX) is doubled in the step SS 2 .
  • step SS 4 it is judged whether or not the selected flip-flop (FF) stores the data at either one of the rise and the fall of the timing clock in the step SS 3 .
  • the step SS 4 is successively carried out after the step SS 3 .
  • the logic circuit A illustrated in FIG. 6 in is determined in the step SS 5 .
  • the logic circuit B in FIG. 6 is determined in the step SS 6 .
  • the logic circuit C illustrated in FIG. 6 is determined in the step SS 8 .
  • the logic circuit D in FIG. 6 is determined in the step SS 9 .

Abstract

A method designs a logic circuit having a flip-flop which performs an on and off operation in response to a timing clock and a feedback loop. With such a structure, a logic circuit portion which operates in accordance with an enable signal automatically is extracted. Further, the logic circuit portion is formed by the use of a gated clock obtained by gating the timing clock via the enable signal. Thereby, the number of a change of the flip-flop in response to the timing clock can be largely reduced.

Description

    BACKGROUND OF THE INVENTION
  • This invention relates to a method of designing a large-scale integrated LSI circuit, and in particular, to a circuit design method using a logic synthesis technique. [0001]
  • Generally, as the LSI has been increased in size with a high speed, a circuit design method using the known EDA (electronic design automation) tool has increasingly became important. Such a circuit design method is normally classified into five phases, namely, (1) a system design, (2) a function/logic design, (3) a layout design, (4) a test design, and (5) a macrocell design. [0002]
  • In the function/logic design phase among the above phases, the LSI to be designed is expressed as a resistor or a combination between the resistors. In this event, the known RTL (resistor transfer level) description which is obtained in the system design phase is expressed by the use of a hardware description language, such as the known VHDL, to obtain a logic circuit (net list) of a gate level. [0003]
  • In this case, a constraint, a truth table, a logic equation and a state transition description and like are given as inputs in the function/logic design phase. Further, a state code of a state machine is assigned, a flip-flop is assigned and further, a combination logic is generated. Consequently, the logic circuit is generated as the gate level. [0004]
  • In this event, the logic circuit of the gate level which is used in the function/logic phase includes a variety of logic circuits. Under the circumstances, when the logic synthesis is directly carried out for the logic circuit which is described by the use of the VHDL, the constraints are often satisfied. [0005]
  • To this end, the logic is optimized within the range independent of a semiconductor manufacturing technology. Thereby, the number of the logic gates (chip area) and the number of logic stages are suitably adjusted so as to satisfy the constraints which are requested by an user. In such an adjustment, a redundant logic is eliminated, a logic is opened, and a multi-stage is carried out by the use of a nature of Boolean algebra. Finally, a mapping process is performed for the semiconductor manufacturing technology. [0006]
  • Herein, a low power consumption and a small chip are often considered as the constraint in the LSI. Conventionally, it is normal that the constraint, such as the power consumption and the chip area, is manually applied when the number of the logic gates and the number of the logic stages are adjusted. Consequently, the above conventional technique requires enough time to design the circuit. [0007]
  • On the other hand, the logic circuit to be designed includes, for example, a plurality of logic circuits each of which retains a signal value under a predetermined condition and inputs data under the other condition. In this event, this logic circuit is expressed by the use of a specific description, such as the VHDL. The logic circuit is logically synthesized by a combination of a multiplexer, a delay flip-flop and a feedback loop. Herein, the multiplexer operates by receiving an enable signal and a data signal. The flip-flop is connected to the multiplexer and is turned on and off in response to a timing clock. Further, the feedback loop is connected between the delay flip-flop and the multiplexer. [0008]
  • As mentioned before, the delay flip-flop itself repeats on and off operations every when the timing clocks are supplied to the logically synthesized combination of the multiplexer, the delay flip-flop and the feedback loop. Generally, electrical power is largely consumed when the delay flip-flop repeats the on and off operations. Consequently, the above logically synthesized logic circuit must be manually adjusted so as to reduce the power consumption of the logic circuit. [0009]
  • SUMMARY OF THE INVENTION
  • It is therefore an object of this invention to provide a circuit design method which is capable of designing a circuit at a short time. [0010]
  • It is another object of this invention to provide a circuit design method which is capable of realizing a lower power consumption. [0011]
  • It is still another object of this invention to provide a circuit design method which is applicable for a logic circuit having a feedback loop. [0012]
  • It is the other object of this invention to provide a circuit design method which is applicable for a logic circuit which retains a signal value under a predetermined condition and inputs a data signal under the other condition. [0013]
  • It is the other object of this invention to provide a circuit design method which is capable of realizing a lower power consumption and a small chip area by preventing a change due to unnecessary timing clocks. [0014]
  • A method of this invention designs a circuit having a flip-flop which performs an on and off operation in response to timing clocks and a feedback loop. [0015]
  • With such a structure, a logic circuit portion which operates in accordance with an enable signal automatically is extracted. Further, the logic circuit portion is formed by the use of gated clock. In this event, the timing clock is gated by the enable signal. Consequently, the number of a change of the flip-flop in response to the timing clock can be largely reduced. [0016]
  • Thus, according to this invention, the logic circuit having a lower power consumption can be obtained with a simple operation by automatically generating the logic circuit which is formed by the use of the gated clock. This also means that the circuit having a small chip area can be structured. [0017]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 shows a structure of a logic circuit according to this invention; [0018]
  • FIG. 2 is a circuit diagram for explaining a principle of this invention in relation to FIG. 1; [0019]
  • FIG. 3 is a flow chart for explaining a circuit design method according to an example of this invention; [0020]
  • FIG. 4 is a circuit diagram for explaining a circuit which requires a pretreatment process according to this invention; [0021]
  • FIG. 5 is a circuit diagram for explaining the pretreatment process which is performed for the circuit illustrated in FIG. 4; [0022]
  • FIG. 6 is a circuit diagram for explaining variation of logic circuits which are formed by the use of a gated clock process and which are generated according to this invention; and [0023]
  • FIG. 7 is a flow chart for explaining an operation for generating a logic circuit which is formed by the use of a gated clock process according to this invention. [0024]
  • DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • Referring to FIGS. 1 and 2, description will be made about a principle of this invention. [0025]
  • Before explaining FIGS. 1 and 2, it is assumed that a logic relation between hardware is specified by the following description by the use of the hardware description language VHDL. [0026]
  • if(clock'event and clock=‘1’) then [0027]
  • if(enable=‘0’) then [0028]
  • data2<=data1: [0029]
  • endif: [0030]
  • endif: [0031]
  • As illustrated in FIG. 1, a circuit which is logically synthesized on the basis of the above-mentioned description is structured by a combination of a delay flip-flop [0032] 1 (DFF) and a multiplexer 2 (MUX). Further, the delay flip-flop (DFF) and the multiplexer (MUX) are connected to each other via feedback loop 3. More specifically, the multiplexer 2 (MUX) in the logically synthesized circuit is given data (data1, namely (d)) and data (data 2, namely (h)) which is fed back from the delay flip-flop 1 (DFF).
  • With such a structure, when an enable signal (e) is equal to a logic “1”, the data 2 (h) is selected. On the other hand, when the enable signal (e) is equal to a logic “0”, the [0033] data 1 is selected to be supplied to the delay flip-flop 1 (DFF) as a signal f. A timing clock (clock), namely, (c) is given to the delay flip-flop 1 (DFF) and the signal (f) is retained in the delay flip-flop 1 (DFF) in response to the timing clock (c). It is clear from this operation that when the enable signal (e) is equal to a logic “0”, the input data and the output data of the delay flip-flop 1 (DFF) are identical to each other. That is, the data 1 is equal to the date 2, and namely, (d) is equal to (h).
  • As illustrated in FIG. 1, the logically synthesized logic circuit has the delay flip-flop [0034] 1 (DFF) which performs the on and off operation in response to the timing clock (c). Therefore, with such a structure, every time when each cycle of the clock timing (c) begins and finishes, the delay flip-flop 1 (DFF) repeats the on and off operation. Consequently, the power consumption becomes large.
  • In this event, it is preferable to reduce the on and off operation of the delay flip-flop [0035] 1 (DFF) in order to reduce the power consumption. Taking this into consideration, the circuit according to this invention is automatically changed into a gated clock circuit so as to suppress a change due to the clocks (c) when the above-mentioned expression is used.
  • Referring to FIG. 2, the multiplexer [0036] 1 (MUX) is removed and the delay flip-flop 1 (DFF) is left in the logic circuit which is formed by the use of the gated clock. Further, the data 1 (d) is directly given to the delay flip-flop 1 (DFF) in the circuit illustrated in FIG. 2. On the other hand, the enable signal (e) and the timing clock (c) are given to an OR gate OR1 4 and are supplied to the delay flip-flop 1 (DFF) via the OR gate OR1 4.
  • In the circuit changed as illustrated in FIG. 2, only when the enable signal (e) is equal to a logic “0”, the timing clock (c) is given to the delay flip-flop [0037] 1 (DFF). When the enable signal (e) is equal to “1”, namely, (d) is given to the delay flip-flop 1 (DFF) and the delay flip-flop 1 (DFF) does not perform the on and off operation in response to the timing clock (c). Consequently, the on and off operations of the delay flip-flop 1 (DFF) can be remarkably reduced. Therefore, the power consumption can be also reduced. Thus, this invention is characterized in that the invention has the logic synthesis tool for automatically changing the logically synthesized logic circuit illustrated in FIG. 1 into the logic circuit illustrated in FIG. 2.
  • As mentioned before, it is judged whether or not the gated clock illustrated in FIG. 2 can be automatically extracted in the circuit design method according to this invention. When the gated clock is extracted, the circuit in FIG. 2 which is formed by the use of the gated clock is generated. [0038]
  • Subsequently, referring to FIG. 3 together with FIG. 1, description will be made about the circuit design method according to an example of this invention. [0039]
  • In a flow chart illustrated in FIG. 3, the flip-flop (hereinafter, abbreviated to FF) which is formed by the use of the gated clock will be extracted. [0040]
  • First, it is detected whether or not the operation is completed for all of FFs in the step S[0041] 1.
  • If the operation for all of FFs is not completed in the step S[0042] 1, the step S1 goes to the step S2 to select FF. Herein, the selected FF is represented by g in the step S2.
  • Next, a logic function of an input f is produced with respect to the selected g in the [0043] step 3.
  • In the case of the delay flip-flop [0044] 1 (DFF) illustrated in FIG. 1, the logic function with respect to the input f can be represented by the following equation.
  • f=e·h+eb·d
  • Herein, e and eb are the enable signal and a Not enable signal (called an enable bar signal) thereof, respectively. Further, h is an output signal of g while d is a data signal (data [0045] 1).
  • Subsequently, it is judged whether or not the output signal h of g is included in the logic function with respect to the output f in the step S[0046] 4. As a result of the judgement, if h is included, the step S4 proceeds to the step S5. If h is not included, the process returns to the step S1. In the illustrated example, the process proceeds to a calculation process of a co-factor in the step S5 and the latter because h is included in the logic function with respect to the input f. The co-factor can be calculated by inputting a logic “1” and a logic “0” as e and eb.
  • Specifically, the co-factor can be calculated by the use of the following equation. [0047]
  • F(e)=1h+0d=h
  • In FIG. 3, after the co-factor is calculated, the operation process transfers from the step S[0048] 5 to the step S6.
  • In the step S[0049] 6, it is judged whether or not a relation of F(e)=h is satisfied. In this example, the operation process transfers from the step S6 into the step S7 to generate the logic circuit which is formed by the use of the gated clock because the above condition is satisfied. —On the other hand, when the above co-factor does not satisfy the above-mentioned condition in the step S6, the operation process goes to the step S8 to calculate the co-factor for the enable signal eb base upon the following equation.
  • F(eb)=0d+1d=d
  • Successively, judgement is made about whether or not a relation of F(eb)=h is satisfied in the step S[0050] 9. In this example, the step 9 is returned back to the step S1 to select another flip-flop and to repeat the same operation because the above relation is not satisfied in the step S9. This operation is carried out for all of the flip-flops until all of the logic circuits which are formed by the use of the gated clock are generated.
  • In the above-mentioned example, description has been made about the extracting operation of the gated clock in a single hierarchy. Alternatively, the extracted gated clock logic circuits may be combined into a hierarchy of a further high level. Thereby, a single logic circuit which is controlled by a single enable signal e and a single clock c may be combined. [0051]
  • Subsequently, when the gated clock logic circuit is generated as shown in the step S[0052] 7 in FIG. 3, it is required that the input f for the selected flip-flop g is single. For instance, when the signal f which is obtained by logically calculating the enable signal e and the output h of the delay flop-flop 1 (DFF) is branched or fanned out other than the delay flip-flop 1 (DFF) as illustrated in FIG. 4, the gated clock illustrated in FIG. 2 is not accurately and logically synthesized. Thus, when the above branch exists, a pretreatment process must be carried out to equivalently constitute the circuit illustrated in FIG. 1.
  • Referring to FIG. 5, description will be made about the pretreatment process executed when the signal f which is logically calculated is branched or fanned out. [0053]
  • For example, the multiplexer (MUX) [0054] 2 illustrated in FIG. 4 is doubled to structure a multiplexer 20 a (MUX1) and a multiplexer 20 b (MUX2) which are equivalent to each other. In this event, the multiplexer 20 a (MUX1) and the delay flip-flop 1 (DFF) is formed by the use of gated clock in the same manner with FIG. 2. On the other hand, a circuit (not shown) which is connected to the multiplexer 20 b (MUX2) may be dealt with the other logic circuit.
  • Moreover, when the gated clock logic circuit is generated, it is desirable that consideration is made about a case that the data d is stored to the flip-flop g which is selected at the rise of the clock and another case that the date d is stored to the flip-flop g which is selected at the fall of the clock. Further, another consideration may be preferably made about a case that the enable signal e is sometimes equal to a logic “1” or “0”. [0055]
  • In FIG. 6, a structure of a logic circuit which stores the data d on the basis of the rise clock is illustrated in a first column. On the other hand, a structure of a logic circuit which stores the data d on the basis of the fall clock is illustrated in a second column. In this case, even when the data d is stored in response to the rising clock, the logic circuit which satisfies the condition of f(e)=h and the logic circuit which satisfies the condition of f(eb)=h are structured, respectively. Therefore, four logic circuits which correspond to the respective conditions and clocks are illustrated in FIG. 6. [0056]
  • More specifically, when the data d is stored in response to the rise clock and the condition f(e)=h is satisfied, the gated clock logic circuit (thereinafter, referred to as a logic circuit A) can be obtained by using an [0057] OR gate 60 between the enable signal e and the timing clock c in the same manner with FIG. 2. Further, when the date d is stored in response to the rise clock and the condition f(eb)=h is satisfied, the corresponding logic circuit (thereinafter, referred to as a logic circuit B) can be obtained by inputting Not signal (namely, eb) of the enable signal e to the OR gate 61.
  • Moreover, the logic circuit which stores the data d in response to the fall clock and satisfies the condition of f(e)=h can be formed by the use of the gated clock via an AND [0058] gate 62 which is given the enable bar signal eb of the enable signal e and the clock c, and is thereinafter called a logic circuit C. In addition, the logic circuit which stores the data d in response to the fall clock and satisfies the condition of f(eb)=h can be formed by the use of gated clock via an AND gate 63 which is given the enable signal e and the clock c, and is thereinafter called as a logic circuit D.
  • Referring to FIG. 7, detail description will be made about the operation of the step S[0059] 7 for generating the gated clock logic circuit in FIG. 3.
  • referring to FIG. 7, description will be made about the operation for performing the pretreatment process shown in FIGS. 4 and 5 and obtaining either one of the gated clock logic circuits A through D in FIG. 6. [0060]
  • First, it is judged whether or not the logic circuit is required to be doubled in the step SS[0061] 1. This judgement can be easily carried out by detecting whether or not the signal f is branched or fanned out. When the logic circuit is required to be doubled, the circuit with respect to the signal f (for example, the multiplexer MUX) is doubled in the step SS2.
  • When the circuit is doubled, the process transfers to the step SS[0062] 3. On the other hand, the circuit is not required to be doubled, the process directly goes to the step SS3.
  • Next, it is judged whether or not the selected flip-flop (FF) stores the data at either one of the rise and the fall of the timing clock in the step SS[0063] 3. As a result of the judgement, when the data is stored at the rise clock, the step SS4 is successively carried out after the step SS3.
  • In the step SS[0064] 4, it is judged whether or not the condition of f(e)=h is satisfied. When the condition is satisfied, the logic circuit A illustrated in FIG. 6 in is determined in the step SS5. On the other hand, when the above condition is not satisfied, the logic circuit B in FIG. 6 is determined in the step SS6.
  • On the other hand, when it is judged that the data is stored at the fall clock of the flip-flop (FF) in the step SS[0065] 3, the process operation transfers to the step SS7. In the step SS7, it is judged whether or not the condition of f (eb)=h is satisfied. When this condition is satisfied, the logic circuit C illustrated in FIG. 6 is determined in the step SS8. Further, when the above condition is not satisfied, the logic circuit D in FIG. 6 is determined in the step SS9.
  • Above mentioned before, the gated clock logic circuits are sequentially and automatically determined according to this invention. Consequently, a manual adjustment can be remarkably simplified. [0066]

Claims (12)

What is claimed is:
1. A method of designing a circuit having a flip-flop which performs an on and off operation in response to a timing clock, comprising the steps of:
automatically extracting a logic circuit portion which operates in accordance with an enable signal; and
changing said logic circuit portion into a gated clock portion which is formed by the use of a gated clock obtained by gating the timing clock with reference to the enable signal.
2. A method as claimed in
claim 1
, wherein:
said changing step is carried out to reduce the number of a change of said flip-flop in response to the timing clock.
3. A method as claimed in
claim 1
, wherein:
said changing step comprises;
a step for combining said gated clock portion with a common gate; and
a step for raising said gate to a hierarchy of a further high level.
4. A method as claimed in
claim 1
, wherein:
said extracting step comprises the steps of;
selecting said flip-flop; and
expressing a logic function with respect to an output of said flip-flop.
5. A method as claimed in
claim 4
, wherein:
said extracting step further comprises the steps of;
detecting whether or not the logic function includes an output of said flip-flop; and
calculating a co-factor for the enable signal with respect to the logic function; and
judging whether or not the logic circuit portion exists.
6. A method as claimed in
claim 1
, wherein:
said extracting step further comprises a step for performing a pretreatment to judge whether or not an input of said flip-flop is branched.
7. A recording medium which stores a program for executing the following procedures as a tool for EDA (electronic design automation):
automatically extracting a logic circuit portion which operates in accordance with an enable signal from a circuit having a flip-flop which performs an on and off operation in response to a timing clock and a feedback loop; and
changing said logic circuit portion into a gated clock proportion which is formed by the use of a gated clock by gating the timing clock via the enable signal.
8. A recording medium as claimed in
claim 7
, wherein:
said changing step is carried out in order to reduce the number of a change of said flip-flop in response to the timing clock.
9. A recording medium as claimed in
claim 7
, wherein:
said changing step comprises the steps of;
combining said gated clock portion with a common gate; and
raising said gate to a hierarchy of a further high level.
10. A recording medium as claimed in
claim 7
, wherein:
said extracting step comprises the steps of;
selecting said flip-flop; and
expressing a logic function with respect to an output of said flip-flop.
11. A recording medium as claimed in
claim 10
, wherein:
said extracting step comprises the steps of;
detecting whether or not said logic function includes an output of said flip-flop; and
calculating a co-factor for the enable signal with respect to the logic function; and
judging whether or not the logic circuit portion exists.
12. A recording medium as claimed in
claim 7
, wherein:
said extracting step further comprises a step for performing a pretreatment to judge whether or not an input of said flip-flop is branched.
US09/062,656 1997-04-18 1998-04-20 Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method Expired - Fee Related US6434722B2 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP9-101189 1997-04-18
JP10118997A JP3179363B2 (en) 1997-04-18 1997-04-18 Circuit design method and storage medium

Publications (2)

Publication Number Publication Date
US20010014964A1 true US20010014964A1 (en) 2001-08-16
US6434722B2 US6434722B2 (en) 2002-08-13

Family

ID=14294028

Family Applications (1)

Application Number Title Priority Date Filing Date
US09/062,656 Expired - Fee Related US6434722B2 (en) 1997-04-18 1998-04-20 Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method

Country Status (2)

Country Link
US (1) US6434722B2 (en)
JP (1) JP3179363B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7080334B2 (en) * 2003-05-09 2006-07-18 Incentia Design Systems Corp. Automatic clock gating insertion in an IC design

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6557161B2 (en) * 2001-06-28 2003-04-29 Sun Microsystems, Inc. Method for prototyping asynchronous circuits using synchronous devices
US7082582B1 (en) * 2001-12-06 2006-07-25 Synplicity, Inc. Reducing clock skew in clock gating circuits
US7500205B2 (en) * 2001-12-06 2009-03-03 Synopsys, Inc. Skew reduction for generated clocks
GB0301251D0 (en) * 2003-01-20 2003-02-19 Paradigm Design Systems Ltd Generation of clock gating function for synchronous circuit
JP4696051B2 (en) * 2006-11-28 2011-06-08 富士通株式会社 Power consumption analysis method and program
US7958476B1 (en) * 2007-07-10 2011-06-07 Magma Design Automation, Inc. Method for multi-cycle path and false path clock gating
JP2009296548A (en) * 2008-06-09 2009-12-17 Toshiba Corp Semiconductor integrated circuit device
JP5520790B2 (en) * 2010-11-19 2014-06-11 株式会社日立製作所 Design support apparatus and design support program

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5452239A (en) * 1993-01-29 1995-09-19 Quickturn Design Systems, Inc. Method of removing gated clocks from the clock nets of a netlist for timing sensitive implementation of the netlist in a hardware emulation system
JPH07129641A (en) * 1993-11-05 1995-05-19 Nec Corp Method for retiming vlsi system
US5504910A (en) * 1994-02-02 1996-04-02 Advanced Micro Devices, Inc. Power management unit including software configurable state register and time-out counters for protecting against misbehaved software
US5526276A (en) * 1994-04-21 1996-06-11 Quicklogic Corporation Select set-based technology mapping method and apparatus
JP2776262B2 (en) * 1994-08-18 1998-07-16 日本電気株式会社 Logic circuit synthesis method and apparatus
US5754837A (en) * 1994-12-22 1998-05-19 Texas Instruments Incorporated Clock control circuits, systems and methods
US5649176A (en) * 1995-08-10 1997-07-15 Virtual Machine Works, Inc. Transition analysis and circuit resynthesis method and device for digital circuit modeling
US5841663A (en) * 1995-09-14 1998-11-24 Vlsi Technology, Inc. Apparatus and method for synthesizing integrated circuits using parameterized HDL modules
US5801955A (en) * 1996-05-31 1998-09-01 Mentor Graphics Corporation Method and apparatus for removing timing hazards in a circuit design
US5956256A (en) * 1996-11-19 1999-09-21 Unisys Corporation Method and apparatus for optimizing a circuit design having multi-paths therein
US5864487A (en) * 1996-11-19 1999-01-26 Unisys Corporation Method and apparatus for identifying gated clocks within a circuit design using a standard optimization tool
JP3357813B2 (en) 1997-04-01 2002-12-16 株式会社東芝 Gated clock design support method, gated clock design support device, and computer-readable recording medium storing gated clock design support program

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7080334B2 (en) * 2003-05-09 2006-07-18 Incentia Design Systems Corp. Automatic clock gating insertion in an IC design

Also Published As

Publication number Publication date
US6434722B2 (en) 2002-08-13
JP3179363B2 (en) 2001-06-25
JPH10294375A (en) 1998-11-04

Similar Documents

Publication Publication Date Title
US6318911B1 (en) Gated clock design supporting method, gated clock design supporting apparatus, and computer readable memory storing gated clock design supporting program
KR101471237B1 (en) System and method for designing integrated circuits that employ adaptive voltage scaling optimization
JP3331968B2 (en) Register transfer level power consumption optimization circuit, method and recording medium with emphasis on glitch analysis and reduction
US7594200B2 (en) Method for finding multi-cycle clock gating
US7587693B2 (en) Apparatus and method of delay calculation for structured ASIC
US6434722B2 (en) Method of changing logic circuit portion into gated clock portion and recording medium storing a program for carrying out the method
US6463567B1 (en) LSI design system through model creation for functional block and LSI design method therefor
US20020157065A1 (en) Clock synchronizing circuit and method of designing the same
Posluszny et al. Design methodology for a 1.0 GHz microprocessor
US20120062283A1 (en) Scan-based reset
Kitahara et al. A clock-gating method for low-power LSI design
US7774730B2 (en) Method of and system for designing semiconductor integrated circuit
US7194715B2 (en) Method and system for performing static timing analysis on digital electronic circuits
US6990641B2 (en) Integrated circuit design system and method using preprocessor which changes hardware description in accordance with configuration
JP2002312410A (en) Logically designed circuit layout design, method, device for controlling timing, and program for executing the method, and outline flow chart showing processing order by computer readable program recorded with the program
US6457167B1 (en) Gated clock design supporting method, gated clock design supporting apparatus, and computer readable memory storing gated clock design supporting program
US6704916B1 (en) Method and apparatus for optimizing placement and routing and recording medium for recording program for optimizing placement and routing
US6157903A (en) Method of minimizing macrocell characterization time for state dependent power analysis
US5515526A (en) Apparatus for detecting redundant circuit included in logic circuit and method therefor
US6700946B2 (en) System and method for automatic generation of an at-speed counter
Hamour et al. Analog IP design flow for SoC applications
US6721932B2 (en) Semiconductor integrated circuit device including circuit block having hierarchical structure and method of designing the same
Bogliolo et al. An RTL power estimation tool with on-line model building capabilities
JP4642304B2 (en) General purpose hardware devices and methods and tools used therewith
US7512918B2 (en) Multimode delay analysis for simplifying integrated circuit design timing models

Legal Events

Date Code Title Description
AS Assignment

Owner name: NEC CORPORATION, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KAWARABAYASHI, MASAMICHI;NAKAKI, TAKUO;REEL/FRAME:009116/0944

Effective date: 19980414

AS Assignment

Owner name: NEC ELECTRONICS CORPORATION, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NEC CORPORATION;REEL/FRAME:013755/0392

Effective date: 20021101

FPAY Fee payment

Year of fee payment: 4

REMI Maintenance fee reminder mailed
LAPS Lapse for failure to pay maintenance fees
STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20100813