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.
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.
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.
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:
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.
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
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 MI F 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.
Referring to
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 NT clock generating unit 124 should generate the INT clock INT_CLK at the same clock rate as that of the reference clock REF_CLK.
Referring to
Similar to the reference clock receiving unit 122 of the INT clock module 120 in
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.
Referring to
When all of the plurality of cores 102, 104, 106, and 108 are in the idle state, which is the case in
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
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.
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.
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.
Referring to
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
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
Referring to
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.
Referring to the method in
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.
Referring to the method in
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.
Number | Date | Country | Kind |
---|---|---|---|
10-2014-0173175 | Dec 2014 | KR | national |
This continuation application claims 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, 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.
Number | Name | Date | Kind |
---|---|---|---|
7243250 | Ueda | Jul 2007 | B2 |
7398414 | Sherburne, Jr. | Jul 2008 | B2 |
7539878 | Vaglica | May 2009 | B2 |
7882376 | Ozawa | Feb 2011 | B2 |
7991992 | Guan | Aug 2011 | B2 |
8190935 | Hitaka | May 2012 | B2 |
8281171 | Tang | Oct 2012 | B2 |
8347130 | Park | Jan 2013 | B2 |
9075608 | Finch | Jul 2015 | B2 |
20020184547 | Francis | Dec 2002 | A1 |
20030210247 | Cui | Nov 2003 | A1 |
20040199803 | Suzuki | Oct 2004 | A1 |
20040230754 | Gumm | Nov 2004 | A1 |
20050034002 | Flautner | Feb 2005 | A1 |
20050108591 | Mendelson | May 2005 | A1 |
20050278561 | Seo | Dec 2005 | A1 |
20060174142 | Lin | Aug 2006 | A1 |
20070182475 | Shimazaki | Aug 2007 | A1 |
20070220289 | Holle | Sep 2007 | A1 |
20080104434 | May | May 2008 | A1 |
20080140879 | Lee et al. | Jun 2008 | A1 |
20080244491 | Ganesan | Oct 2008 | A1 |
20090150602 | Sauber | Jun 2009 | A1 |
20090204832 | Ma | Aug 2009 | A1 |
20100031209 | Luan | Feb 2010 | A1 |
20100037038 | Bieswanger | Feb 2010 | A1 |
20100162019 | Kumar | Jun 2010 | A1 |
20100205468 | Kim | Aug 2010 | A1 |
20110185126 | Sasaki | Jul 2011 | A1 |
20110213991 | Wolfe | Sep 2011 | A1 |
20110276812 | Lee | Nov 2011 | A1 |
20110314314 | Sengupta | Dec 2011 | A1 |
20120054511 | Brinks | Mar 2012 | A1 |
20120095607 | Wells | Apr 2012 | A1 |
20120117363 | Cummings | May 2012 | A1 |
20130007413 | Thomson | Jan 2013 | A1 |
20130083611 | Ware | Apr 2013 | A1 |
20130111120 | Ananthakrishnan | May 2013 | A1 |
20130147526 | Kim | Jun 2013 | A1 |
20130166832 | Peng | Jun 2013 | A1 |
20130198545 | Lee | Aug 2013 | A1 |
20140064420 | Ling | Mar 2014 | A1 |
20140089697 | Kim | Mar 2014 | A1 |
20140129858 | Varma | May 2014 | A1 |
20140132340 | Finch | May 2014 | A1 |
20140173297 | Varma | Jun 2014 | A1 |
20140181351 | Fatemi | Jun 2014 | A1 |
20140181537 | Manne | Jun 2014 | A1 |
20140258760 | Wells | Sep 2014 | A1 |
20140281616 | Moran | Sep 2014 | A1 |
20150026495 | Jain | Jan 2015 | A1 |
20150082060 | Persson | Mar 2015 | A1 |
20150108591 | Takizawa | Apr 2015 | A1 |
20150143141 | Echeverri Escobar | May 2015 | A1 |
20150180540 | Logvinov | Jun 2015 | A1 |
20150205344 | Diefenbaugh | Jul 2015 | A1 |
20150296452 | Hu | Oct 2015 | A1 |
20150317762 | Park | Nov 2015 | A1 |
20150323975 | Ambapuram | Nov 2015 | A1 |
20160041775 | Hanson | Feb 2016 | A1 |
Number | Date | Country |
---|---|---|
2000347762 | Dec 2000 | JP |
2004326153 | Nov 2004 | JP |
20093655 | Jan 2009 | JP |
2011198044 | Oct 2011 | JP |
Entry |
---|
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. |
Number | Date | Country | |
---|---|---|---|
20190187769 A1 | Jun 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14959824 | Dec 2015 | US |
Child | 16284698 | US |