Method of operating semiconductor device

-

System on chip including plurality of processors including first and second processors; plurality of intellectual properties (IPs) including first and second IPs; memory interface; internal clock circuit to receive reference clock signal, generate first internal clock signal, and provide first internal clock signal to first IP; memory interface clock circuit to receive reference clock signal, generate memory interface clock signal, and provide memory interface clock signal to memory interface; and power management unit (PMU), wherein first internal clock signal drives first IP, memory interface clock signal drives memory interface, PMU generates first control signal based on operational states of plurality of processors, and provides first control signal to internal clock circuit, PMU generates second control signal based on operational states of plurality of processors, and provides second control signal to memory interface clock circuit, internal clock circuit sets clock rate of first internal clock signal based on first control signal, and memory interface clock circuit sets clock rate of memory interface clock signal based on second control signal.

Skip to: Description  ·  Claims  ·  References Cited  · Patent History  ·  Patent History
Description
PRIORITY

This application is a continuation of, and claims priority under U.S.C. § 120 to, U.S. application Ser. No. 16/284,698, filed on Feb. 25, 2019 in the United States Patent and Trademark Office, issued on Apr. 6, 2021 as U.S. Pat. No. 10,969,855, and was a continuation of and claimed priority under 35 U.S.C. § 120 to U.S. patent application Ser. No. 14/959,824, filed on Dec. 4, 2015 in the United States Patent and Trademark Office, issued on Apr. 9, 2019 as U.S. Pat. No. 10,254,813, which claimed priority under 35 U.S.C. § 119(a) to Korean Patent Application No. 10-2014-0173175, filed on Dec. 4, 2014 in the Korean Intellectual Property Office, the content of each of which is incorporated herein by reference in its entirety.

BACKGROUND 1. Field of the Disclosure

The present disclosure relates generally to a method of operating a semiconductor device, and more particularly to minimizing power consumption in a mobile or portable device.

2. Description of the Related Art

The battery life of a mobile or portable device, in which a mobile telecommunications system on chip (hereinafter, “mobile SoC”) is used, is closely related to the amount of power consumed by the mobile SoC. Thus, there is a need for systems, apparatuses, and methods that minimize the power consumed by the mobile SoC when the mobile SoC is neither completely powered on nor completely powered off, such as when the mobile device is in standby mode. Hereinafter, “standby mode” or “standby” may mean any state of the mobile SoC that is neither completely powered on nor completely powered off.

SUMMARY

An aspect of the present disclosure provides a method of operating a semiconductor device so that the standby power of a mobile SoC is minimized.

In one aspect of the present disclosure, an SoC is provided. The SoC includes a plurality of processors including a first processor and a second processor; a plurality of intellectual properties (IPs) including a first IP and a second IP; a memory interface; an internal clock circuit configured to receive a reference clock signal, generate a first internal clock signal, and provide the first internal clock signal to the first IP; a memory interface clock circuit configured to receive the reference clock signal, generate a memory interface clock signal, and provide the memory interface clock signal to the memory interface; and a power management unit (PMU), wherein the first internal clock signal drives the first IP, the memory interface clock signal drives the memory interface, the PMU generates a first control signal based on operational states of the plurality of processors, and provides the first control signal to the internal clock circuit, the PMU generates a second control signal based on the operational states of the plurality of processors, and provides the second control signal to the memory interface clock circuit, the internal clock circuit sets a clock rate of the first internal clock signal based on the first control signal, and the memory interface clock circuit sets a clock rate of the memory interface clock signal based on the second control signal.

In another aspect of the present disclosure, an SoC is provided. The SoC includes a plurality of processors including a first processor and a second processor; a plurality of IPs including a first IP and a second IP; a memory interface; a PMU; an internal clock circuit configured to receive a reference clock signal, generate a first internal clock signal, and provide the first internal clock signal to the first IP; and a memory interface clock circuit configured to receive the reference clock signal, generate a memory interface clock signal, and provide the memory interface clock signal to the memory interface, wherein the first internal clock signal drives the first IP, the memory interface clock signal drives the memory interface, when an operating state of each of the plurality of processors is idle, the first internal clock signal is set to have a first clock rate that is a minimum clock rate for minimizing a standby power of the first IP.

In still another aspect of the present disclosure, an SoC is provided. The SoC includes a plurality of processors; a first IP; a PMU; and an internal clock circuit configured to receive a reference clock signal, generate a first internal clock signal, and provide the first internal clock signal to the first IP, wherein the PMU is configured to generate a first control signal based on operating states of the plurality of processors, and provide the first control signal to the internal clock circuit, wherein the first control signal indicates a clock rate for the first internal clock signal, and the internal clock circuit is further configured to set the clock rate of the first internal clock signal based on the first control signal.

The present disclosure is generally directed to power management of a system on a chip (SoC) and, more particularly, to reducing power consumption by reducing the rate of the clock signal driving one or more ancillary components on the SoC (such as, for example, memory interfaces and IPs) when the primary components (i.e., cores/processors) associated with those ancillary components are in a lower power mode, such as idle or standby.

BRIEF DESCRIPTION OF THE DRAWINGS

The above and other aspects, features and advantages of the present disclosure will become more apparent by describing in detail embodiments thereof with reference to the attached drawings in which:

FIG. 1 is a schematic diagram of a system on a chip (SoC) according to an embodiment of the present disclosure;

FIG. 2 is a schematic diagram of an INT clock module of an SoC according to an embodiment of the present disclosure;

FIG. 3 is a schematic diagram of a memory interface (MIF) clock module of an SoC according to an embodiment of the present disclosure;

FIG. 4 is a schematic diagram of the operation of an SoC according to an embodiment of the present disclosure;

FIG. 5 is a timing diagram of INT clock signals according to an embodiment of the present disclosure;

FIG. 6 is a timing diagram of MIF clock signals according to an embodiment of the present disclosure;

FIG. 7 is a schematic diagram of the operation of an SoC according to another embodiment of the present disclosure;

FIG. 8 is a schematic diagram of an INT clock module of an SoC according to another embodiment of the present disclosure;

FIG. 9 is a flowchart of a method according to an embodiment of the present disclosure; and

FIG. 10 is a flowchart of a method according to another embodiment of the present disclosure.

DETAILED DESCRIPTION OF EMBODIMENTS OF THE PRESENT DISCLOSURE

Embodiments of the present disclosure are described below in detail with reference to the accompanying drawings. The disclosure, however, may be embodied in various different forms, and should not be construed as being limited only to the illustrated embodiments. Rather, these embodiments are provided as examples so that this disclosure will be thorough and complete, and so that this disclosure will fully convey the concept of the disclosure to those skilled in the art. Processes, elements, and techniques known to those of ordinary skill in the art may not be described with respect to some of the embodiments of the disclosure. Like reference numerals may denote like elements throughout the attached drawings and written description. Where possible and/or convenient, descriptions will not be repeated. In the drawings, the sizes and relative sizes of layers and regions may be exaggerated for clarity.

It will be understood that, although the terms “first”, “second”, “third”, etc., may be used herein to describe various elements, components, regions, layers and/or sections, these elements, components, regions, layers and/or sections are not limited by these terms. These terms are only used to distinguish one element, component, region, layer or section from another element, component, region, layer or section. Thus, a first element, component, region, layer or section discussed below could be termed a second element, component, region, layer or section without departing from the teachings of the disclosure.

Spatially relative terms, such as “beneath”, “below”, “lower”, “under”, “above”, “upper” and the like, may be used herein for ease of description to describe one element/feature's relationship to another element(s)/feature(s) as illustrated in the drawings. It will be understood that the spatially relative terms are intended to encompass different orientations in addition to the orientation depicted in the figures. Moreover, it should be understood that when an element or layer is referred to as being “on”, “connected to”, “coupled to”, or “adjacent to” another element or layer, it can be directly on, connected, coupled, or adjacent to the other element or layer, or intervening elements or layers may be present. In contrast, when an element is referred to as being “directly on,” “directly connected to”, “directly coupled to”, or “immediately adjacent to” another element or layer, there are no intervening elements or layers present.

The terminology used herein is only for the purpose of describing particular examples and/or embodiments and is not intended to limit the disclosure. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, components, etc., but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, groups thereof, etc. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items.

Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art. It will be further understood that terms, including those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and/or the present specification and should not be interpreted in an idealized or overly formal sense unless expressly so defined herein.

FIG. 1 is a schematic diagram of a system on a chip (SoC) 10 according to an embodiment of the present disclosure. SoC 10 may be included in a semiconductor device according to an embodiment of the present disclosure. In several embodiments of the present disclosure, the SoC 10 may be a mobile SoC.

The SoC 10 includes a multi-core 100, a power management unit (PMU) 110, an internal (INT) clock module 120, and a memory interface (MIF) clock module 130. It is noted that each of the modules herein is a component than can also be, for example, a unit or circuit.

The multi-core 100 is operated by core clock CORE_CLK to generally control the SoC 10 and includes a plurality of cores. In several embodiments of the present disclosure, the multi-core 100 may be a multi-processor including a plurality of central processing units (CPUs). In several embodiments of the present disclosure, the multi-core 100 may also include a graphic processing unit (GPU) or a general purpose GPU (GPGPU).

The PMU 110 manages power of the SoC 10. As will be described below, the PMU 110 is involved in adjustment of standby power of the SoC 10 by controlling the INT clock module 120 and the MIF clock module 130. The PMU 110 includes a storage region including a register, and data may be written in the storage region of the PMU 110 by software controlling the INT clock module 120 and the MIF clock module 130. The PMU 110 transmits control signals INT_CTL and MIF_CTL to the INT clock module 120 and the MIF clock module 130, respectively. This may be done according to a recording state of data in, for example, the register in the storage region.

The INT clock module 120 generates an INT clock INT_CLK for operating various IPs included in the SoC 10. Particularly, the INT clock module 120 receives a reference clock REF_CLK for driving the SoC 10. The INT clock module 120 receives the reference clock REF_CLK, generates the INT clock INT_CLK from REF-CLK, and provides the generated INT clock INT_CLK to the first IP 126 (shown as “IP1”) or the second IP 128 (shown as “IP2”). Although FIG. 1 only shows the first IP 126 and the second IP 128, the number of IPs according to the present disclosure is not limited to two. The first IP 126 and the second IP 128 are operated by INT_CLK received from the INT clock module 120.

The MIF clock module 130 generates an MIF clock MIF_CLK for operating one or more memory interfaces MIFs 136 included in the SoC 10. Hereinafter, MIF 136 will be referred to in the singular for convenience; however, MIF 136 may be more than one memory interface. The MIF clock module 130 receives the reference clock REF_CLK, generates an MIF clock MIF_CLK from the received REF_CLK, and provides the generated MIF clock MIF_CLK to the memory interface 136. The memory interface 136 is operated by the MIF clock MIF_CLK to transmit/receive data with a memory 200 operated by a memory clock MEM_CLK.

FIG. 2 is a schematic diagram of an INT clock module of an SoC according to the embodiment of the present disclosure.

Referring to FIG. 2, the INT clock module 120 according to an embodiment of the present disclosure includes a reference clock receiving unit 122 and an INT clock generating unit 124.

The reference clock receiving unit 122 receives the reference clock REF_CLK, which is used generally for driving the SoC 10. In several embodiments of the present disclosure, the reference clock REF_CLK may be generated by, for example, a 24 MHz oscillator, but the present disclosure is not limited thereto.

The INT clock generating unit 124 generates the INT clock INT_CLK, which is used for operating various IPs included in the SoC 10, based on the reference clock REF_CLK. In embodiments of the present disclosure, the clock rate of the INT clock INT_CLK is higher than that of the reference clock REF_CLK. Accordingly, for example, the first IP 126 on the SoC 10 may be operated at a higher clock rate than that of the reference clock REF_CLK.

The INT clock generating unit 124 is controlled by the PMU 110. Particularly, the INT clock generating unit 124 receives a control signal INT_CTL from the PMU 110, which indicates the clock rate for the generated INT clock INT_CLK. Thus, for example, PMU 110 may transmit a control signal INT_CTL which indicates that the INT clock generating unit 124 should generate the INT clock INT_CLK at the same clock rate as that of the reference clock REF_CLK.

FIG. 3 is a schematic diagram of an MIF clock module according to an embodiment of the present disclosure.

Referring to FIG. 3, the MIF clock module 130 according to the embodiment of the present disclosure includes a reference clock receiving unit 132 and an MIF clock generating unit 134.

Similar to the reference clock receiving unit 122 of the INT clock module 120 in FIG. 2, the reference clock receiving unit 132 of the MIF clock module 130 in FIG. 3 receives the reference clock REF_CLK which drives the SoC 10.

The MIF clock generating unit 134 generates the MIF clock MIF_CLK based on the reference clock REF_CLK. In embodiments of the present disclosure, the clock rate of the MIF clock MIF_CLK is higher than that of the reference clock REF_CLK. Accordingly, for example, the memory interface 136 on the SoC 10 may be operated at a higher clock rate than that of the reference clock REF_CLK.

The MIF clock generating unit 134 is also controlled by the PMU 110. Particularly, the MIF clock generating unit 134 receives a control signal MIF_CTL from the PMU 110, which indicates the clock rate for the generated MIF clock MIF_CLK. For example, the PMU 110 may send a control signal MIF_CTL indicating that the MIF clock generating unit 134 should generate the MIF clock MIF_CLK with a clock rate which is higher than that of the reference clock REF_CLK, but lower than that of the INT clock INT_CLK.

FIG. 4 is a schematic diagram of the operation of an SoC according to an embodiment of the present disclosure.

Referring to FIG. 4, when operating the SoC according to an embodiment of the present disclosure, a state of each of the plurality of cores 102, 104, 106, and 108 provided on the SoC 10 is examined. The states of the plurality of cores 102, 104, 106, and 108 may include a busy state and an idle state. The busy state includes a state in which the system on chip is in a power on mode and performs calculation, and the idle state includes a state in which the system on chip is in a power on mode, but stands by without performing calculation. Although only two states (busy or standby) are described in reference to this embodiment, the present disclosure is not limited thereto, and other embodiments may have two or more low power states or modes.

When all of the plurality of cores 102, 104, 106, and 108 are in the idle state, which is the case in FIG. 4, the INT clock generating unit 124 generates a minimum INT clock INT_MIN_CLK. Here, the minimum INT clock INT_MIN_CLK is a lower clock rate signal for making one or more of the IPs on the SoC 10 driven by the INT clock module 120 consume minimum power in the power on state. That is, when all of the plurality of cores 102, 104, 106, and 108 are in the idle state, the PMU 110 sends a control signal INT_CTL to INT clock module 120 indicating that the INT clock generating unit 124 should generate the minimum INT clock INT_MIN_CLK obtained by decreasing the clock rate from the clock rate of the INT clock INT_CLK.

In several embodiments of the present disclosure, the minimum INT clock INT_MIN_CLK may have the same clock rate as that of the reference clock REF_CLK, or a clock rate higher than the clock rate of the reference clock REF_CLK and lower than that of the original INT clock INT_CLK. One, more, or all of the IPs on the SoC 10 are not completely powered off when provided with the minimum INT clock INT_MIN_CLK.

Similar to the INT clock generating unit 124, when all of the plurality of cores 102, 104, 106, and 108 are in the idle state, which is the case in FIG. 4, the MIF clock generating unit 134 generates a minimum MIF clock MIF_MIN_CLK. Here, the minimum MIF clock MIF_MIN_CLK is a lower clock rate signal for allowing the memory interface 136 driven by the MIF clock module 130 to consume minimum power while still in a power on state. That is, when all of the plurality of cores 102, 104, 106, and 108 are in the idle state, the PMU 110 sends a control signal MIF_CTL to MIF clock module 120 indicating that the MIF clock generating unit 134 should generate the minimum MIF clock MIF_MIN_CLK obtained by decreasing the clock rate from the clock rate of the MIF clock MIF_CLK.

In several embodiments of the present disclosure, the minimum MIF clock MIF_MIN_CLK may have the same clock rate as that of the reference clock REF_CLK, or a clock rate higher than the clock rate of the reference clock REF_CLK and lower than that of the original MIF clock MIF_CLK. The memory interface on the SoC 10 is not completely powered off while provided with the minimum MIF clock MIF_MIN_CLK.

By the aforementioned method, it is possible to improve battery efficiency of a mobile device or a portable device in which the SoC 10 is used by minimizing standby power consumption of the SoC 10, which may be, for example, a mobile SoC, without powering off the SoC 10.

While the minimum INT clock INT_MIN_CLK or the minimum MIF clock MIF_MIN_CLK may have the same clock rate as that of the reference clock REF_CLK, in several embodiments of the present disclosure, the INT clock generating unit 124 or the MIF clock generating unit 134 may directly provide the reference clock REF_CLK received by the reference clock receiving unit 122 or reference clock receiving unit 132 to the IPs 126 and 128 or the memory interface 136, respectively.

FIG. 5 is a timing diagram of INT clock signals according to an embodiment of the present disclosure.

FIG. 5 shows the reference clock REF_CLK, the INT clock INT_CLK, a first minimum TNT clock INT_MIN_CLK1, and a second minimum INT clock INT_MIN_CLK2 signals. First minimum INT clock INT_MIN_CLK1, which is generated by the INT clock generating unit 124 according to a control signal INT_CTL from the PMU 110, has the same clock rate as that of the reference clock REF_CLK. Second minimum INT clock INT_MIN_CLK2, which is generated by the INT clock generating unit 124 according to a control signal INT_CTL from the PMU 110, has a clock rate higher than that of the reference clock REF_CLK, but lower than that of the original INT clock INT_CLK.

Thus, the IPs driven by the INT clock module can consume minimum power in the power on state by receiving either the first minimum INT clock INT_MIN_CLK1 or the second minimum INT clock INT_MIN_CLK2. Which clock rate value is appropriate for minimizing the standby power of the SoC 10 may depend on, for example, the battery level, the SoC state or condition, and/or particular implementation or application.

FIG. 6 is a timing diagram of MIF clock signals according to an embodiment of the present disclosure.

FIG. 6 shows the reference clock REF_CLK, the MIF clock MIF_CLK, a first minimum MIF clock MIF_MIN_CLK1, and a second minimum MIF clock MIF_MIN_CLK2 signals. First minimum MIF clock MIF_MIN_CLK, which is generated by the MIF clock generating unit 134 according to a control signal MIF_CTL received from the PMU 110, has the same clock rate as that of the reference clock REF_CLK. Second minimum MIF clock MIF_MIN_CLK2, which is generated by the MIF clock generating unit 134 according to a control signal MIF_CTL received from the PMU 110, has a clock rate higher than that of the reference clock REF_CLK but lower than that of the original MIF clock MIF_CLK.

Thus, memory interface 136 driven by the MIF clock module may consume minimum power in the power on state by receiving either the first minimum MIF clock MIF_MIN_CLK1 or the second minimum MIF clock MIF_MIN_CLK2. Which clock rate value is appropriate for minimizing the standby power of the SoC 10 may depend on, for example, the battery level, the SoC state or condition, and/or the particular implementation or application.

FIG. 7 is a schematic diagram of the operation of an SoC according to another embodiment of the present disclosure.

Referring to FIG. 7, when operating the SoC according to this embodiment of the present disclosure, a state of each of the plurality of cores 102, 104, 106, and 108 provided on the SoC 10 is examined. In FIG. 7, the first core 102 and the second core 104 are in the busy state, and the third core 106 and the fourth core 108 are in the idle state.

When at least one of the plurality of cores 102, 104, 106, and 108 is not in the idle state, as is the case in FIG. 7, the PMU 110 sends a control signal INT_CTL to INT clock module 120 indicating that the INT clock generating unit 124 should generate the INT clock INT_CLK with the normal clock rate for operating the IPs. For example, if the IPs were previously receiving the INT_MIN_CLK as shown in FIG. 4, the IPs would be restored to operation again by generating the normal INT clock INT_CLK.

Similar to the INT clock generating unit 124, when at least one of the plurality of cores 102, 104, 106, and 108 is not in the idle state, as is the case in FIG. 7, the PMU 110 sends a control signal MIF_CTL to MIF clock module 130 indicating that the MIF clock generating unit 134 should generate the MIF clock MIF_CLK which has the normal clock rate for operating the memory interface 136. For example, if the memory interface 136 was previously receiving the INT_MIN_CLK as shown in FIG. 4, the memory interface 136 would be restored to normal operation again by generating the normal MIF clock MIF_CLK.

FIG. 8 is a schematic diagram of an INT clock module of an SoC according to another embodiment of the present disclosure.

Referring to FIG. 8, when operating an SoC according to this embodiment of the present disclosure, a first clock INT_CLK1 and a second clock INT_CLK2 are provided to the first IP 126 and the second IP 128, respectively. Assuming that INT_CLK1 and INT_CLK2 are for normal, i.e., power on, operation, when and if all of the plurality of cores provided on the SoC 10 are in the idle state, a third clock INT_CLK3 and a fourth clock INT_CLK4 would be provided to the first IP 126 and the second IP 128, respectively. The third clock INT_CLK3 and the fourth clock INT_CLK4 may have different clock rates.

In several embodiments of the present disclosure, when the first IP 126 is controlled by a core/processor which is in the idle state and the second IP 128 is controlled by a core/processor which is not in the idle state, the third clock INT_CLK3 having a lower clock rate than that of the first clock INT_CLK1 would drive the idle first IP 126 and the second clock INT_CLK2 would drive the active second IP 128. That is, the PMU 110 and/or INT clock module 120 according to an embodiment of the present invention may drive individual IPs differently, depending on what function and/or core-processor the specific IP is working with. Accordingly, as in the previous example, when some cores/processors on the SoC are in the idle state, the IPs controlled by those cores may receive a lower clock rate INT clock signal than the IPs controlled by the cores/processors which are not in the idle state.

FIG. 9 is a flowchart of a method according to an embodiment of the present disclosure.

Referring to the method in FIG. 9 for operating an SoC according to an embodiment of the present disclosure, the states of all of the cores/processors provided on the SoC 10 are examined in step S901. If any one core is in the busy state in step S903 (N), the process loops, i.e., returns to step S901. By contrast, when the states of the all of the cores are in the idle state in step S903 (Y), the INT clock signal for driving the IPs on the SoC 10 is set to a lower clock rate in order to minimize power consumption in step S905. Further, in step S907, the MIF clock signal for driving the memory interface 136 on the SoC 10 is set to a lower clock rate in order to minimize power consumption.

Accordingly, when all of the cores are in the idle state, the SoC 10 enters a standby mode, and at this time, embodiments of the present disclosure make it possible to minimize power consumed in the standby mode.

FIG. 10 is a flowchart of a method according to another embodiment of the present disclosure.

Referring to the method in FIG. 10 of operating an SoC according to this embodiment of the present disclosure, the states of all of the cores/processors provided on the SoC 10 are examined in step S1001. If any one core is in the busy state in step S903 (N), the process loops, i.e., returns to step S1001. By contrast, when the states of the all of the cores are in the idle state in step S1003 (Y), the INT clock signal driving the first IP 126 is set to a first clock rate in step S1005, and the INT clock signal driving the second IP 128 is set to a second clock rate in step S1007.

In several embodiments of the present disclosure, the first clock rate may be the minimum clock rate for minimizing the standby power of the first IP 126, and the second clock rate may be an original/normal clock rate for operating the second IP 128. In several embodiments of the present disclosure, the first clock rate and the second clock rate may be the minimum clock rates for minimizing the standby power of the first IP 126 and the second IP 128, respectively.

According to the aforementioned various embodiments of the present disclosure, it is possible to improve battery efficiency of a mobile device or a portable device in which an SoC is used by minimizing the standby power consumption of one or more components on the SoC, such as, for example, a mobile SoC, without powering off the SoC.

The foregoing is illustrative of the present disclosure and is not to be construed as limiting thereof. Although a few embodiments of the present disclosure have been described, those skilled in the art will readily appreciate that many modifications of the embodiments are possible without materially departing from the novel teachings and advantages of the present disclosure. Accordingly, all such modifications are intended to be included within the scope of the present disclosure. Therefore, it is to be understood that the foregoing is illustrative of the present disclosure and is not to be construed as limited to the specific embodiments disclosed, and that modifications to the disclosed embodiments, as well as other embodiments, are intended to be included within the scope of the appended claims. The present invention is defined solely by the following claims and their equivalents.

Claims

1. A method of operating a system on chip (SoC), comprising:

receiving a reference clock signal;
providing a first internal (INT) clock signal at a first clock rate based on the reference clock signal, to a first intellectual property (IP) on the SoC;
providing a second internal (INT) clock signal at a second clock rate to a second IP on the SoC; and
when both of a first core/processor and a second core/processor provided on the SoC are in an idle state, changing the first INT clock signal to the first IP to a third clock rate and changing the second INT clock signal to the second IP to a fourth clock rate,
wherein the third and fourth clock rates are same, and the third and fourth clock rates are equal to or higher than a clock rate of the reference clock signal.

2. The method of claim 1, wherein the third clock rate of the first INT clock signal is different from the first clock rate of the first INT clock signal, and

the fourth clock rate of the second INT clock signal is different from the second clock rate of the second INT clock signal.

3. The method of claim 2, wherein the third clock rate of the first INT clock signal is lower than the first clock rate of the first INT clock signal, and

the fourth clock rate of the second INT clock signal is lower than the second clock rate of the second INT clock signal.

4. The method of claim 1, further comprising:

when the first IP is controlled by a core/processor which is in the idle state and the second IP is controlled by a core/processor which is not in the idle state, providing the first INT clock signal at the third clock rate to the first IP and providing the second INT clock signal at a fifth clock rate to the second IP,
wherein the fourth clock rate is different from the fifth clock rate.

5. The method of claim 4, wherein the fourth clock rate of the second INT clock signal is lower than the fifth clock rate the second INT clock signal.

6. The method of claim 1, wherein the idle state includes a state in which the SOC is in a power on mode and both the first core/processor and the second core/processor stand by without performing calculation.

7. A method of operating a system on chip (SoC), comprising:

receiving a reference clock signal;
providing a first memory interface (MIF) clock signal at a first clock rate based on the reference clock signal, to a first memory interface on the SoC; and
when both of a first core/processor and a second core/processor provided on the SoC are in an idle state, changing the first MIF clock signal to the first memory interface to a second clock rate,
wherein the first and second clock rates are different, and the second clock rate is equal to or higher than a clock rate of the reference clock signal.

8. The method of claim 7, wherein the second clock rate of the first MIF clock signal is lower than the first clock rate the first MIF clock signal.

9. The method of claim 7, further comprising:

providing a second memory interface (MIF) clock signal at a third clock rate to a second memory interface on the SoC; and
when both of the first core/processor and the second core/processor provided on the SoC are in the idle state, changing the second MIF clock signal to the second memory interface to a fourth clock rate,
wherein the third and fourth clock rates are different.

10. The method of claim 7, wherein the fourth clock rate of the second MIF clock signal and the second clock rate of the first MIF clock signal are same.

11. A method of operating a system on chip (SoC), comprising:

receiving a reference clock signal;
providing a first internal (INT) clock signal with a first clock rate based on the reference clock signal, to a first intellectual property (IP) on the SoC;
examining states of a first core/processor and a second core/processor provided on the SoC;
when both the first core/processor and the second core/processor are in an idle state, changing the first INT clock signal to a second INT clock signal having a second clock rate lower than the first clock rate;
providing a first memory interface (MIF) clock signal with a third clock rate based on the reference clock signal, to a first memory interface on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the first MIF clock signal to a second MIF clock signal having a fourth clock rate different from the third clock rate.
wherein the second clock rate of the second INT clock signal is same with the fourth clock rate of the second MIF clock signal, and the second and fourth clock rates are equal to or higher than a clock rate of the reference clock signal.

12. The method of claim 11, wherein the fourth clock rate of the second MIF clock signal is lower than the third clock rate of the first MIF clock signal.

13. The method of claim 11, wherein the idle state includes a state in which the SOC is in a power on mode and both the first core/processor and the second core/processor stand by without performing calculation.

14. The method of claim 11, further comprising:

providing a third INT clock signal with a fifth clock rate to a second IP different from the first IP on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third INT clock signal to a fourth INT clock signal having a sixth clock rate lower than the fifth clock rate,
wherein the sixth clock rate of the fourth INT clock signal is different from the second clock rate of the second INT clock signal.

15. The method of claim 11, further comprising:

providing a third INT clock signal with a fifth clock rate to a second IP different from the first IP on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third INT clock signal to a fourth INT clock signal having a sixth clock rate lower than the fifth clock rate,
wherein the sixth clock rate of the fourth INT clock signal is same with the second clock rate of the second INT clock signal.

16. The method of claim 11, further comprising:

providing a third MIF clock signal with a fifth clock rate to a second memory interface different from the first memory interface on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third MIF clock signal to a fourth MIF clock signal having a sixth clock rate lower than the fifth clock rate,
wherein the sixth clock rate of the fourth MIF clock signal is different from the fourth clock rate of the second MIF clock signal.

17. The method of claim 11, further comprising:

providing a third MIF clock signal with a fifth clock rate to a second memory interface different from the first memory interface on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third MIF clock signal to a fourth MIF clock signal having a sixth clock rate lower than the fifth clock rate,
wherein the sixth clock rate of the fourth MIF clock signal is same with the fourth clock rate of the second MIF clock signal.

18. The method of claim 11, further comprising:

providing a third INT clock signal with a fifth clock rate to a second IP different from the first IP on the SoC;
providing a third MIF clock signal with a sixth clock rate to a second memory interface different from the first memory interface on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third INT clock signal to a fourth INT clock signal having a seventh clock rate lower than the fifth clock rate, and changing the third MIF clock signal to a fourth MIF clock signal having an eighth clock rate lower than the sixth clock rate,
wherein the seventh clock rate of the fourth INT clock signal is different from the eighth clock rate of the fourth MIF clock signal.

19. The method of claim 11, further comprising:

providing a third INT clock signal with a fifth clock rate to a second IP different from the first IP on the SoC;
providing a third MIF clock signal with a sixth clock rate to a second memory interface different from the first memory interface on the SoC; and
when both the first core/processor and the second core/processor are in the idle state, changing the third INT clock signal to a fourth INT clock signal having a seventh clock rate lower than the fifth clock rate, and changing the third MIF clock signal to a fourth MIF clock signal having an eighth clock rate lower than the sixth clock rate,
wherein the seventh clock rate of the fourth INT clock signal is same with the eighth clock rate of the fourth MIF clock signal.

20. The method of claim 19, wherein the seventh clock rate of the fourth INT clock signal is same with the second clock rate of the second INT clock signal, and the eighth clock rate of the fourth MIF clock signal is same with the fourth clock rate of the second MIF clock signal.

Referenced Cited
U.S. Patent Documents
7243250 July 10, 2007 Ueda
7398414 July 8, 2008 Sherburne, Jr.
7539878 May 26, 2009 Vaglica
7882376 February 1, 2011 Ozawa
7991992 August 2, 2011 Guan
8190935 May 29, 2012 Hitaka
8281171 October 2, 2012 Tang
8347130 January 1, 2013 Park
9075608 July 7, 2015 Finch
20020184547 December 5, 2002 Francis
20030210247 November 13, 2003 Cui
20040199803 October 7, 2004 Suzuki
20040230754 November 18, 2004 Gumm
20050034002 February 10, 2005 Flautner
20050108591 May 19, 2005 Mendelson
20050278561 December 15, 2005 Seo
20060174142 August 3, 2006 Lin
20070182475 August 9, 2007 Shimazaki
20070220289 September 20, 2007 Hoile
20080104434 May 1, 2008 May
20080140879 June 12, 2008 Lee et al.
20080244491 October 2, 2008 Ganesan
20090150602 June 11, 2009 Sauber
20090204832 August 13, 2009 Ma
20090213125 August 27, 2009 Shibasaki
20100031209 February 4, 2010 Luan
20100037038 February 11, 2010 Bieswanger
20100162019 June 24, 2010 Kumar
20100174933 July 8, 2010 Lu
20100205468 August 12, 2010 Kim
20110060924 March 10, 2011 Khodorkovsky
20110185126 July 28, 2011 Sasaki
20110213991 September 1, 2011 Wolfe
20110276812 November 10, 2011 Lee
20110314314 December 22, 2011 Sengupta
20120054511 March 1, 2012 Brinks
20120095607 April 19, 2012 Wells
20120117363 May 10, 2012 Cummings
20130007413 January 3, 2013 Thomson
20130083611 April 4, 2013 Ware
20130111120 May 2, 2013 Ananthakrishnan
20130147526 June 13, 2013 Kim
20130166832 June 27, 2013 Peng
20130198545 August 1, 2013 Lee
20140064420 March 6, 2014 Ling
20140089697 March 27, 2014 Kim
20140115366 April 24, 2014 Joo
20140129858 May 8, 2014 Varma
20140132340 May 15, 2014 Finch
20140173297 June 19, 2014 Varma
20140181351 June 26, 2014 Fatemi
20140181537 June 26, 2014 Manne
20140258760 September 11, 2014 Wells
20140281616 September 18, 2014 Moran
20140365798 December 11, 2014 Wen
20150026495 January 22, 2015 Jain
20150082060 March 19, 2015 Persson
20150143141 May 21, 2015 Echeverri Escobar
20150180540 June 25, 2015 Logvinov
20150205344 July 23, 2015 Diefenbaugh
20150296452 October 15, 2015 Hu
20150317762 November 5, 2015 Park
20150323975 November 12, 2015 Ambapuram
20160041775 February 11, 2016 Hanson
Foreign Patent Documents
2000347762 December 2000 JP
2004326153 November 2004 JP
20093655 January 2009 JP
2011198044 October 2011 JP
Other references
  • Resve Saleh et al., “System-on-Chip: Reuse and Integration”, Proceedings of the IEEE, vol. 94, No. 6, Jun. 2006, pp. 1050-1069.
  • Xiaotao Chang et al., “Adaptive Clock Gating Technique for Low Power IP Core in SoC Design”, 2007 IEEE, 4 pages.
Patent History
Patent number: 11543874
Type: Grant
Filed: Apr 5, 2021
Date of Patent: Jan 3, 2023
Patent Publication Number: 20210223847
Assignee:
Inventors: Hyo-Sang Jung (Gyeonggi-do), Sang-Wook Ju (Gyeonggi-do), Jung-Hun Heo (Gyeonggi-do)
Primary Examiner: Volvick Derose
Application Number: 17/222,364
Classifications
Current U.S. Class: Synchronization, E.g., Clock Skew (epo) (712/E9.063)
International Classification: G06F 1/00 (20060101); G06F 1/324 (20190101); G06F 1/3287 (20190101); G06F 1/3234 (20190101); G06F 9/46 (20060101); G06F 1/3203 (20190101); G06F 1/3237 (20190101);