A low power consumption in a semiconductor integrated circuit device can be achieved by reducing a glitch power in a flip-flop. In a pulse-generator-incorporated auto-clock-gating flip-flop in which data latch is performed by using a pulsed clock, input data is latched based on an output of a dynamic XOR circuit, which is a comparator circuit, during a period when the pulsed clock is at a high level, and the dynamic XOR circuit is cut off during a period when the pulsed clock is at a low level.
|
1. A semiconductor integrated circuit device comprising:
a pulse generator circuit to which an external clock signal is input, and which outputs a pulsed clock signal in synchronization with a transition of said external clock signal from a first level to a second level, a pulsed clock signal having a second level period shorter than that of said external clock signal;
a data latch circuit to which an input data signal and an internal clock signal are input, and which incorporates a value of said input data signal during a period when the internal clock signal is at a fourth level, retains the incorporated value during a period when the internal clock signal is at a third level, and outputs the incorporated value as a retained data signal; and
a data comparator circuit to which said pulsed clock signal, said input data signal of said data latch circuit, and said retained data signal are input,
wherein said data comparator outputs the internal clock signal at the third level during a period when said pulsed clock signal is at the first level,
wherein said data comparator compares said input data signal with said retained data signal during a period when said pulsed clock signal is at the second level, outputs said internal clock signal at the fourth level when the comparison result is inconsistent, and outputs said internal clock signal at the third level when the comparison result is consistent, and
wherein, in said data comparator circuit, when the pulsed clock signal is at the first level, transistors to which said input data signal, said retained data signal, and inverted values of the input data signal and the retained data signal are respectively input is cut off from one of a power supply and ground by the pulsed clock signal.
2. The semiconductor integrated circuit device according to
wherein said data comparator circuit includes an exclusive OR circuit,
said exclusive OR circuit includes said transistors,
said transistors comprise two sets of two n-type MOSFETs each connected in series with each set connected in parallel, and
a connection portion of one of said n-type MOSFETs connected in series is connected to ground, and a connection portion of the other one of said n-type MOSFETs connected in series is connected to a source side of an n-type MOSFET of an inverter circuit to which the pulsed clock signal is input.
3. The semiconductor integrated circuit device according to
wherein said data comparator circuit includes an exclusive OR circuit,
said exclusive OR circuit includes said transistors,
said transistors comprise two sets of two p-type MOSFETs each connected in series with each set connected in parallel, and
a connection portion of one of the p-type MOSFETs connected in series is connected to the power supply, and a connection portion of the other one of the p-type MOSFETs connected in series is connected to a source side of a p-type MOSFET of an inverter circuit to which the pulsed clock signal is input.
4. The semiconductor integrated circuit device according to
wherein said data comparator circuit includes a feedback circuit which ensures the third level of the internal clock when the input data signal and the stored data signal are matched as a result of comparison during the period when the pulsed clock signal is at the second level.
5. The semiconductor integrated circuit device according to
a transistor for controlling a current value supplied to said feedback circuit.
6. The semiconductor integrated circuit device according to
wherein a clocked inverter is used as a loop circuit for retaining data in said data latch circuit.
7. The semiconductor integrated circuit device according to
wherein an inverter is used as a loop circuit for retaining data in said data latch circuit.
8. The semiconductor integrated circuit device according to
wherein, in said data comparator circuit, a threshold voltage of each of the transistors to which the input data signal, the retained data signal, and inverted values of the input data signal and the retained data signal are input is lower than a threshold voltage of a transistor to which the pulsed clock signal is input.
9. The semiconductor integrated circuit device according to
wherein said first level is a low level, said second level is a high level, said third level is a low level, and said fourth level is a high level.
10. The semiconductor integrated circuit device according to
wherein said first level is a low level, said second level is a high level, said third level is a high level, and said fourth level is a low level.
11. The semiconductor integrated circuit device according to
wherein said first level is a high level, said second level is a low level, said third level is a low level, and said fourth level is a high level.
12. The semiconductor integrated circuit device according to
wherein said first level is a high level, said second level is a low level, said third level is a high level, and said fourth level is a low level.
13. The semiconductor integrated circuit device according to
wherein said pulse generator circuit, said data latch circuit, and said data comparator circuit are laid out as one cell.
14. The semiconductor integrated circuit device according to
wherein said pulse generator circuit is laid out as one cell, and said data latch circuit and said data comparator circuit are laid out as another cell.
15. The semiconductor integrated circuit device according to
wherein a plurality of cells of said data latch circuit and said data comparator circuit are disposed at a predetermined distance from a cell of said pulse generator circuit so as to ensure a short second level period of said pulsed clock signal is output from said pulse generator circuit.
16. The semiconductor integrated circuit device according to
wherein a cell of said pulse generator circuit, a plurality of cells of said data latch circuit, and a plurality of cells of said data comparator circuit are laid out in an array as one flip-flop cell.
17. The semiconductor integrated circuit device according to
18. The semiconductor integrated circuit device according to
|
The present application claims priority from Japanese Patent Application No. JP 2005-189102 filed on Jun. 29, 2005, the content of which is hereby incorporated by reference into this application.
The present invention relates to a semiconductor integrated circuit device. More particularly, it relates to a technology effectively applied to a system LSI for portable equipment.
In recent years, SoC (System-on-a-Chip) such as a system LSI for a mobile phone has become multifunctional mainly because of the increased ease of IP (Intellectual Property) integration.
With the increase in the number of integrated IPs, the power consumption at the time of operation thereof has significantly increased. Therefore, for the LSI for use in portable equipment required to be driven with a limited battery capacity, the low power consumption has become more and more important.
In order to reduce the power consumption at the time of operation of the LSI, a technology called clock gating has been conventionally used because power consumption in a clock system accounts for a large share of the total power consumption in the LSI.
For example, in Kitahara, T. et al., “A Clock-Gating Method for Low-Power LSI Design,” Proceedings of the ASC-DAC '98, Conference, pp. 307-312 (Non-patent document 1), it is reported that power consumption can be reduced by 39% or more. However, under present circumstances, implementation of the clock gating is not sufficient (see Non-patent document 1). This is because, in view of the clock distribution, the number of circuits is explosively increased in a lower layer of a clock distribution hierarchy called a clock tree, which makes the conditions for implementing clock gating severer.
The conditions for implementing clock gating are those for determining in which case clock signal is to be distributed or not.
In such an environment, the inventors of the present invention have found that it is relatively easy to implement individual clock gating in a flip-flop disposed at the end of the clock tree, and have studied its implementation method.
As an attempt to implement gating at a flip-flop, for example, circuits as shown in Japanese Patent Application Laid-Open Publication No. 2000-232339 (Patent document 1) and Japanese Patent Application Laid-Open Publication No. 2004-056667 (Patent document 2) have been suggested. However, noise called a glitch that may occur on an actual circuit has not been sufficiently studied (see Patent documents 1 and 2).
As described above, the power consumption is large in a clock system of a general LSI and it is particularly large in the flip-flop. Therefore, it is important to reduce the power required for the flip-flop.
For the achievement of the power reduction, auto-clock-gating flip-flops have been suggested. The patent document 1 discloses a flip-flop circuit with a clock signal control function and a clock control circuit, and the patent document 2 discloses a conditional clocking flip-flop circuit.
In these flip-flops, as shown in
First, when the logical value of the input data (D) and the logical value of the stored data (Q) are equal to each other, an exclusive NOR becomes a high level VDD and an output of NOR becomes a low level VSS, and thus an output of NAND is fixed to the high level VDD. As a result, irrespectively of the logical value of a clock (CLK), CKI is fixed to the low level VSS, and CKIB is fixed to the high level VDD.
Next, when the logical value of the input data D and the logical value of the stored data Q are different from each other, exclusive NOR becomes the low level VSS. At this time, if the clock CLK is at the low level VSS, an output of AND is also at the low level VSS, and therefore an output of NOR is at the high level VDD.
At this time, when the clock CLK becomes the high level VDD, the output of NAND is changed to the low level VSS, the internal CKI is changed to the high level VDD, CKIB is changed to the low level VSS, and the input data D is latched into the stored data Q.
As a result, the inverted value becomes the high level VDD, the output of NOR is changed to the low level VSS, the output of NAND is changed to the high level VDD, CKI is changed to the low level VSS, and CKIB is changed to the high level VDD.
Incidentally, since the input data D is not incorporated in this auto-clock-gating flip-flop when the input data is not changed, an effect of the reduction in power consumption can be achieved. However, in an actual LSI, influences of noise called glitch have to be also considered. As a result of consideration of such influences, it has been revealed that power consumption due to the glitch is large in the conventional technology. A glitch means several transitions of a signal between the low level VSS and the high level VDD until the final logical value of the signal is determined.
One reason for such a glitch is a difference in delay time between flip-flops. A glitch can be prevented if the delay times of the flip-flops are exactly equalized. However, such a design is practically impossible. Thus, this is an essential problem in designing a synchronous circuit.
When a glitch occurs in a conventional circuit, a period occurs in which transmission gates connected to the stored data Q and QB are simultaneously in a conductive state, and through current flows between the stored data Q and QB during this period. This through current flows as many times as the number of times the glitch occurs.
As described above, from the viewpoint of the glitch power, the conventional technology is insufficient, and this glitch power has to be reduced.
An object of the present invention is to provide a technology for reducing glitch power of a flip-flop, thereby achieving power consumption reduction of a semiconductor integrated circuit device.
The above and other objects and novel characteristics of the present invention will be apparent from the description of this specification and the accompanying drawings.
The typical ones of the inventions disclosed in this application will be briefly described as follows.
According to the studies prior to the present invention, the inventors of the present invention have reached an understanding that, in order to reduce current caused by the above-mentioned glitch, it is important to make a clear distinction among a period of comparing the input data D and the stored data Q, a period of incorporating them, and a period of retaining the stored data Q so as to prevent a glitch during the period of retaining the stored data Q.
For its achievement, the inventors have realized that it is essential to pulse a clock supplied to a normal flip-flop and to clearly separate the short data incorporating period and the long data retaining period. This is because, when a process of comparing the input data D and the stored data Q and a process of updating the stored data Q are performed in as short period as possible and the entire remaining period is allocated for retaining the stored data Q and preventing a glitch, the feedback control is required for a clock signal with a duty ratio of 50%.
Since a comparison result between the input data D and the stored data Q is required in the feedback control, the input data D and the stored data Q have to be compared even during the period of retaining the stored data Q. In such a case, similar to the conventional technology, the through current flows due to a glitch.
Furthermore, in the present invention, a pulsed clock is used only for the distribution to flip-flops (FF) and is laid out as a macro cell. By this means, an influence on a conventional design flow is minimized.
The effects obtained by typical aspects of the present invention will be briefly described below.
(1) Since the power in the flip-flop, in particular, glitch power can be reduced, the reduction in power consumption can be achieved in a semiconductor integrated circuit device.
(2) Also, a flip-flop with low power consumption can be implemented without significantly changing the conventional design flow. Thus, it is possible to achieve a semiconductor integrated circuit device with low power consumption at low cost.
Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings. Note that components having the same function are denoted by the same reference symbols throughout the drawings for describing the embodiment, and the repetitive description thereof will be omitted.
The auto-clock-gating flip-flop PGACGFF of
The pulse generator PG1 includes an odd number of inverters INV1 to INV5 forming an inverter chain and an AND circuit AND1 composed of an NAND (negative AND) circuit NAND1 and an inverter INV6. In this case, the number of stages in an inverter chain is 5. However, this number can be appropriately changed in accordance with the pulse width generated in the pulse generator PG1.
The dynamic XOR circuit DXOR1 includes inverters INV7 and INV8, an XOR circuit XOR1 composed of four n-type MOSFETs (Metal Oxide Semiconductor Field Effect Transistors) MN2 to MN5, and a feedback circuit FB1 composed of two p-type MOSFETs MP2 and MP3.
The pulsed-latch circuit PL1 includes two inverters INV9 and INV10, a transmission gate TM1 composed of a p-type MOSFET MP4 and an n-type MOSFET MN6, and a latch circuit L1 composed of an inverter INV11 and a clocked inverter CKINV1.
In the pulse generator PG1, a clock CP is connected to the inverters INV1 to INV5 and one end of the AND circuit AND1, and an output of the inverters INV1 to INV5 is connected to the other end of the AND circuit AND1.
In the dynamic XOR circuit DXOR1, the pulsed clock CKI is connected to the inverter INV8. The XOR circuit XOR1 is connected to an n-type MOSFET MN1 of the inverter INV8. The inverter INV7 is connected to an inverted signal CKIB2 of an output internal pulsed clock of the inverter INV8. The feedback circuit FB1 is connected in parallel to an internal pulsed clock CKI2 of the inverter INV7 and its inverted signal CKIB2.
In the pulsed-latch circuit PL1, an input data D is connected to the inverter INV9. An output DB of the inverter INV9 is connected to the transmission gate TM1. An output QB of the transmission gate TM1 is connected to the latch circuit L1 and the inverter INV10. An output of the inverter INV10 is an output data OUT. Also, the internal pulsed clock CKI2 and its inverted signal CKIB2 are connected to the transmission gate TM1 and the clocked inverter CKINV1, respectively.
A feature of the present invention is to perform the cutoff control of the pulsed clock CKI during a period when the logical value of the pulsed clock CKI is at the high level VDD by using the input data D, the stored data Q, and their inverted logical values DB and QB.
Another feature of the present invention is to suppress unwanted power consumption due to a glitch of the input data D by using a period when the logical value of the pulsed clock CKI is at the low level VSS.
The cutoff control of the pulsed clock CKI is performed during the period when the logical value of the pulsed clock CKI is at the high level VDD and is achieved by forwarding the pulsed clock CKI to the subsequent stage only when the input data D and the stored data Q have different logical values.
This is because, at this time, the set of the n-type MOSFETs MN2 and MN3 and the set of the n-type MOSFETs MN4 and MN5 forming the XOR circuit XOR1 are selectively turned on in accordance with the logical values of the input data D and the stored data Q, which makes it possible to drive the inverter INV8.
When the inverter INV8 is driven, the pulsed clock CKI makes transitions of VSS→VDD→VSS. With this transition, the inverted signal CKIB2 of the internal pulsed clock makes transitions of VDD→VSS→VDD.
As a result, the transmission gate TM1 is placed in a conductive state and the clocked inverter CKINV1 is driven. By this means, the logical value of the stored data Q is updated to the logical value of the input data D.
Also, when the input data D and the stored data Q have the same logical value, the set of the n-type MOSFETs MN2 and MN5 or the set of the n-type MOSFETs MN3 and MN4 forming the XOR circuit XOR1 is selectively turned on, and the XOR circuit is thus turned off. Therefore, even if the logical value of the pulsed clock CKI makes transitions of VSS→VDD→VSS, the logical value of the inverted signal CKIB2 of the internal pulsed clock remains at the high level VDD.
At this time, the inverted signal CKIB2 of the internal pulsed clock is momentarily in a floating state. However, since the feedback circuit FB1 provides a feedback to the inverted signal CKIB2 of the internal pulsed clock, there is no need to worry about an erroneous operation.
The basic operation of the present invention shown in
Operating waveforms in the case where the logical value of the input data D and the logical value of the stored data Q are different from each other are shown at each time from T1 to T4 and from T7 to T10, and operating waveforms in the case where the logical value of the input data D and the logical value of the stored data Q are equal to each other are shown at each time from T5 to T6 and from T11 to T12.
First, the case where the input data D is changed from the low level VSS to the high level VDD and the input data is incorporated will be described.
When the clock CP of the pulse generator PG1 is changed as VSS→VDD, a delay T2′-T2 of the inverters INV1 to INV5 appears as a pulse, and the pulsed clock CKI is changed as VSS→VDD→VSS.
The pulsed clock CKI is inputted to the dynamic XOR circuit DXOR1. Since the input data D is at the high level and the stored data Q is at the low level VSS at the time T3, two n-type MOSFETs MN2 and MN3 forming the XOR circuit XOR1 are turned on, which makes it possible to drive the inverter INV8.
As a result, although not shown here, the inverter INV8 is driven to change the inverted signal CKIB2 of the internal pulsed clock as VDD→VSS→VDD and also change the internal pulsed clock CKI2 as VSS→VDD→VSS.
During a period when the internal pulsed clock CKI2 is at the high level VDD and the inverted signal CKIB2 of the internal pulsed clock is at the low level VSS, the transmission gate TM1 of the pulsed-latch circuit PL1 is closed, and the clocked inverter CKINV1 is open. Therefore, at the time T4, the logical value of the input data D of the pulsed-latch circuit PL1 is written to the stored data Q.
Next, the case where the input data D is changed from the high level VDD to the low level VSS and the input data D is incorporated will be described.
When the clock CP of the pulse generator PG1 is changed as VSS→VDD at the time T7, similar to the case where the input data D makes a transition from the low level VSS to the high level VDD, a delay in the inverter chain appears as a pulse, and the pulsed clock CKI is changed as VSS→VDD→VSS. Then, at the time T8, the pulsed clock CKI is changed as VSS→VDD→VSS.
In this case, since the input data D is at the low level VSS and the stored data Q is at the high level VDD, two n-type MOSFETs MN4 and MN5 forming the dynamic XOR circuit DXOR1 are turned on, which makes it possible to drive the inverter INV8.
At the time T9, the inverted signal CKIB2 of the internal pulsed clock is changed as VDD→VSS→VDD, and the internal pulsed clock CKI2 is changed as VSS→VDD→VSS. During a period when the internal pulsed clock CKI2 is at the high level VDD and the inverted signal CKIB2 of the internal pulsed clock is at the low level VSS, the transmission gate TM1 of the pulsed-latch circuit PL1 is closed and the clocked inverter CKINV1 is open. Therefore, at the time T10, the logical value of the input data D of the pulsed-latch circuit PL1 is written to the stored data Q.
On the other hand, the case where the input data D is not changed will be described.
First, the case where the input data D and the stored data Q are both at the high level VDD will be described. Since the clock CP rises to the high level VDD at the time T5, the pulsed clock CKI is changed as VSS→VDD→VSS at the time T6. In this case, since the logical value of the input data D and the logical value of the stored data Q are equal to each other at the high level VDD, two n-type MOSFETs MN3 and MN4 forming the XOR circuit XOR1 in the dynamic XOR circuit DXOR1 are turned on, but the inverter INV8 is not driven.
As a result, the internal pulsed clock CKI2 remains at the previous low level VSS. At the time T6 when the pulsed clock CKI becomes the high level VDD, the inverted signal CKIB2 of the internal pulsed clock is momentarily in a floating state. However, owing to the presence of the feedback circuit FB1, the inverted signal CKIB2 of the internal pulsed clock can be kept at the high level VDD.
Next, since the clock CP rises to the high level VDD at the time T11, the pulsed clock CKI which is an output from the pulse generator PG1 is changed as VSS→VDD→VSS at the time T12. In this case, however, since the logical value of the input data D and the logical value of the stored data Q are equal to each other at the low level VSS, two n-type MOSFETs MN2 and MN5 forming the XOR circuit XOR1 in the dynamic XOR circuit DXOR1 are turned on, but the inverter INV8 is not driven.
As a result, the internal pulsed clock CKI2 remains at the previous low level VSS. At the time T12 when the pulsed clock CKI becomes the high level VDD, the inverted signal CKIB2 of the internal pulsed clock is momentarily in a floating state. However, owing to the presence of the feedback circuit FB1, the inverted signal CKIB2 of the internal pulsed clock remains at the high level VDD.
In the foregoing, the operation of the flip-flop according to the present invention at the time of normal operation has been described. Next, the operation of the pulse-generator-incorporated auto-clock-gating flip-flop PGACGFF when a glitch occurs in the input data D, which is a conventional problem to be solved by the present invention will be described.
When a glitch as external noise occurs in the input data D, unwanted power consumption is required in the conventional technology. By contrast, according to the present invention, such unwanted power consumption can be suppressed.
In the present invention, a high resistance can be achieved against a glitch which occurs in the input data D during a period when the logical value of the pulsed clock CKI is at the low level VSS. During this period, since the transmission gate TM1 is in an off state, even when the logical value of the input data D transits, this transition drives only the inverter INV9 and the gates of two n-type MOSFETs MN2 and MN4. Therefore, the power consumption due to the glitch in the input data D is only the power consumption in the inverter INV9 and gate charge and discharge power in the two n-type MOSFETs MN2 and MN4.
The operation in the case where a glitch occurs in the input data D will be described with reference to
First, an example in which a glitch occurs in the input data D when the logical value of the input data D is at the low level VSS will be described.
At the time T13, a glitch occurs in the input data D, which causes the change as VSS→VDD→VSS. However, since the pulsed clock CKI is at the low level VSS, this glitch only drives the inverter INV9 and the following propagation of this glitch is prevented.
Therefore, the power consumed at this time is only the driving power of the inverter INV9 and the gate charge and discharge power in these two n-type MOSFETs MN2 and MN4. The same goes for the operation of the pulse-generator-incorporated auto-clock-gating flip-flop PGACGFF at the time T18.
Note that, in this example, a glitch causing a transition as VSS→VDD→VSS occurs in the input data D when the logical value of the input data D is at the low level VSS. Also, power consumption in the case where a glitch causing a transition as VDD→VSS→VDD occurs in the input data D when the logical value of the input data D is at the high level VDD can be similarly suppressed.
Furthermore, the clock CP rises at the times T14, T16, T19, and T21, and the pulsed clock CKI rises at the times T15, T17, T20, and T22 delayed by the inverters INV1 to INV5 of the pulse generator PG1. However, since the input data D and the stored data Q are both at the low level VSS, as described with reference to
If it is acceptable to reduce the operation speed of the pulsed-latch circuit PL1, it is possible to reduce the area of the pulsed-latch circuit PL1 by replacing the clocked inverter CKINV1 in the pulsed-latch circuit PL1 by an inverter INV12. In
When the logical value of the pulsed clock CKI is at the high level VDD in the case where the logical value of the input data D and the logical value of the stored data Q are equal to each other, the inverted signal CKIB2 of the internal pulsed clock in the dynamic XOR circuit DXOR1 is momentarily in a floating state because a path to the high level VDD is cut off. However, if a clock frequency is high, in consideration of a time constant of discharge due to a leakage current, the level of the floating state does not exceed a logical threshold in some cases.
In such a case, it is possible to achieve the reduction in the area of the dynamic XOR circuit DXOR1 by eliminating the feedback circuit FB1. In
If two types of MOSFETs having different threshold values can be used, it is possible to achieve the increase in the control speed of cutting off the pulsed clock CKI by replacing the four n-type MOSFETs forming the XOR circuit XOR1 in the dynamic XOR circuit DXOR1 by an XOR circuit XOR2 composed of n-type MOSFETs MNL1 to MNL4 having a low threshold voltage. Note that the effect achieved in
If two types of MOSFETs having different threshold values can be used, it is possible to achieve the further increase in the control speed of cutting off the pulsed clock CKI by replacing the n-type MOSFET forming the inverter circuit INV8 by an n-type MOSFET MNL5 having a low threshold voltage to form an inverter circuit INV8a as well as the four n-type MOSFETs forming the XOR circuit XOR2 in a dynamic XOR circuit DXOR3.
When using a MOSFET having a low threshold voltage, the leakage current is increased in general. In this embodiment, however, since three MOSFETs having a low threshold voltage are connected in series, a leakage current is not much increased. Note that the effect achieved in
If p-type MOSFETs can be used to form an XOR logic, it is possible to reduce the area of the pulse generator PG1 by removing the inverter INV6 from the elements forming the AND circuit AND1, connecting an XOR circuit XOR3 obtained by using p-type MOSFETs MP5 to MP8 in place of the XOR circuit XOR1 in the dynamic XOR circuit DXOR1 to the p-type MOSFET MP1 of the inverter INV8 in series, and using n-type MOSFETs MN7 and MN8 in place of the feedback circuit FB1 to form the feedback circuit FB2. Note that the effect achieved in
An input pin of the ACGFF macro cell ACGFFMC is the clock CP and the input data D having a 16-bit width, and an output pin thereof is the output data OUT having a 16-bit width. A cell in which the pulse generator PG1 and the auto-clock-gating flip-flop ACGFF are laid out together is called a hard macro cell.
With this hard macro cell, the pulse width for VSS→VDD→VSS of the pulsed clock CKI in the auto-clock-gating flip-flop ACGFF can be ensured. Note that the number of auto-clock-gating flip-flops ACGFF disposed in one ACGFF macro cell ACGFFMC may be arbitrary as long as it is equal to one or more.
The components thereof include fill cells FC, the pulse generator PG1, and auto-clock-gating flip-flops ACGFF. The fill cells are provided to fill gaps between cells.
The pulse generator PG1 is disposed at the center, and a plurality of auto-clock-gating flip-flops ACGFF are disposed above and below the pulse generator PG1. By this means, the input and output pins of the auto-clock-gating flip-flops ACGFF are not concentrated, wiring distance between the pulsed clock CK1 and each auto-clock-gating flip-flop ACGFF can be easily kept constant, and thus the load of the power sources can be distributed.
Note that, in
In this case, unlike
The auto-clock-gating flip-flops ACGFF can be freely disposed as long as the wiring distances of the pulsed clock CKI to the respective auto-clock-gating flip-flops ACGFF are equal to one another. Thus, an optimum layout can be achieved.
A clock CP transmitted from an oscillator circuit using a PLL is propagated through a clock tree while being buffered by clock buffers BUF and then transferred to flip-flops and latch circuits at the end of the clock tree.
When an ACGFF macro cell ACGFFMC is to be applied to the semiconductor integrated circuit device LSI, the clock buffer BUF at the final stage of the clock tree and thereafter are replaced by the ACGFF macro cell ACGFFMC.
At this time, the ACGFF macro cell ACGFFMC for replacement may be a soft macro cell instead of a hard macro cell. Similarly, ACGFF macro cells ACGFFMC described below can be all replaced by not only a hard macro cell ACGFFMC but also a soft macro cell.
Furthermore, only a part of the flip-flops are replaced by a hard macro cell in
Still further,
In
In
The ACGFF macro cell ACGFFMC has relatively more restrictions on the layout compared with other cells. Therefore, for example, if such a cell is applied to an interface between modules MDLs in which flip-flops having equal restrictive conditions are disposed in a concentrated manner or to a flip-flop for latency adjustment in a module MDL, the low power consumption can be achieved relatively easily.
In this case, before synthesizing a clock tree for distributing a clock signal to a semiconductor integrated circuit device, the conventional flip-flop is replaced in advance by the ACGFF macro cell ACGFFMC of a hard macro cell or soft macro cell.
In this manner, it is possible to synthesize the above-described clock tree with taking into consideration the timing of clock supply to a conventional flip-flop or an ACGFF macro cell ACGFFMC of a hard macro cell or soft macro cell.
In the foregoing, the invention made by the inventors of the present invention has been concretely described based on the embodiments. However, it is needless to say that the present invention is not limited to the foregoing embodiments and various modifications and alterations can be made within the scope of the present invention.
The present invention is effectively applied to a technology for reducing glitch power of a flip-flop provided in a semiconductor integrated circuit device.
Shimazaki, Yasuhisa, Mizuno, Hiroyuki, Kanno, Yusuke, Yamada, Tetsuya, Onouchi, Masafumi
Patent | Priority | Assignee | Title |
10075153, | Feb 05 2016 | Samsung Electronics Co., Ltd. | Low-power clock-gated synchronizer, a data processing system that incorporates the same and a synchronization method |
10248155, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device including clock generating circuit and channel management circuit |
10291211, | Sep 08 2016 | QUALCOMM TECHNOLOGIES, INC | Adaptive pulse generation circuits for clocking pulse latches with minimum hold time |
10296065, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Clock management using full handshaking |
10296066, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device, semiconductor system, and method of operating the semiconductor device |
10303203, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device, semiconductor system and method for operating semiconductor device |
10928849, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device, semiconductor system and method for operating semiconductor device |
10969854, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device including clock management unit for outputing clock and acknowledgement signals to an intellectual property block |
11314278, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device, semiconductor system and method for operating semiconductor device |
11340685, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device including clock management unit for outputting clock and acknowledgment signals to an intelectual property block |
11747853, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device, semiconductor system and method for operating semiconductor device |
11789515, | Jan 25 2016 | Samsung Electronics Co., Ltd. | Semiconductor device |
11799458, | Jun 08 2021 | Samsung Electronics Co., Ltd. | Flip flop circuit |
7694242, | Dec 11 2006 | Cadence Design Systems, Inc. | System and method of replacing flip-flops with pulsed latches in circuit designs |
7746138, | Mar 07 2007 | DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT | Semiconductor integrated circuit with flip-flop circuits mounted thereon |
8074190, | Dec 11 2006 | Cadence Design Systems, Inc. | Integrated circuit design systems for replacing flip-flops with pulsed latches |
8120406, | Jul 06 2009 | ATI Technologies ULC | Sequential circuit with dynamic pulse width control |
8487681, | Feb 23 2011 | Nvidia Corporation | Dual-trigger low-energy flip-flop circuit |
8656324, | Dec 11 2006 | Cadence Design Systems, Inc. | Circuit design systems for replacing flip-flops with pulsed latches |
9473117, | Feb 13 2015 | SAMSUNG ELECTRONICS CO , LTD | Multi-bit flip-flops and scan chain circuits |
9891283, | Feb 13 2015 | Samsung Electronics Co., Ltd. | Multi-bit flip-flops and scan chain circuits |
Patent | Priority | Assignee | Title |
5861762, | Mar 07 1997 | Oracle America, Inc | Inverse toggle XOR and XNOR circuit |
6204707, | Aug 26 1998 | Kabushiki Kaisha Toshiba | Flip-flop circuit with clock signal control function and clock control circuit |
6630853, | Jul 23 2002 | Kabushiki Kaisha Toshiba | Semiconductor integrated circuit including conditional clocking flip-flop circuit |
20030006806, | |||
20030160289, | |||
20040160852, | |||
JP2000232339, | |||
JP200456667, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jun 12 2006 | ONOUCHI, MASAFUMI | Renesas Technology Corp | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 018023 | /0066 | |
Jun 12 2006 | KANNO, YUSUKE | Renesas Technology Corp | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 018023 | /0066 | |
Jun 13 2006 | SHIMAZAKI, YASUHISA | Renesas Technology Corp | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 018023 | /0066 | |
Jun 13 2006 | YAMADA, TETSUYA | Renesas Technology Corp | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 018023 | /0066 | |
Jun 15 2006 | MIZUNO, HIROYUKI | Renesas Technology Corp | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 018023 | /0066 | |
Jun 28 2006 | Renesas Technology Corp. | (assignment on the face of the patent) | / | |||
Apr 01 2010 | Renesas Technology Corp | NEC ELECTRRONICS CORPORATION | MERGER SEE DOCUMENT FOR DETAILS | 024933 | /0869 | |
Apr 01 2010 | NEC Electronics Corporation | Renesas Electronics Corporation | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 024953 | /0404 | |
Aug 06 2015 | Renesas Electronics Corporation | Renesas Electronics Corporation | CHANGE OF ADDRESS | 044928 | /0001 |
Date | Maintenance Fee Events |
Aug 04 2010 | ASPN: Payor Number Assigned. |
Apr 11 2012 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Apr 13 2016 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Apr 22 2020 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Oct 28 2011 | 4 years fee payment window open |
Apr 28 2012 | 6 months grace period start (w surcharge) |
Oct 28 2012 | patent expiry (for year 4) |
Oct 28 2014 | 2 years to revive unintentionally abandoned end. (for year 4) |
Oct 28 2015 | 8 years fee payment window open |
Apr 28 2016 | 6 months grace period start (w surcharge) |
Oct 28 2016 | patent expiry (for year 8) |
Oct 28 2018 | 2 years to revive unintentionally abandoned end. (for year 8) |
Oct 28 2019 | 12 years fee payment window open |
Apr 28 2020 | 6 months grace period start (w surcharge) |
Oct 28 2020 | patent expiry (for year 12) |
Oct 28 2022 | 2 years to revive unintentionally abandoned end. (for year 12) |