1. Field
The present disclosure relates to apparatus and methods for control of sleep modes in a transceiver and, more particularly, for automated control of different sleep modes using a hardware implemented sleep mode controller.
2. Background
Conservation of energy in battery-powered devices, such as mobile phones, is an important concern in order to maximize the limited energy available to such devices. During operation of mobile devices such as mobile phones, however, it is known that some of the power consuming units within such devices can be temporarily powered down without adversely affecting the performance of the mobile device. This powering down, known as “sleep,” affords power savings since current consuming units only consume power periodically, rather than continuously.
In order to improve the battery life of a device, it is known to place numerous current consuming units within the device into a power saving mode and maintain the system time using low-power sleep circuits. Because of the high current draw (and, thus, power usage) of voltage-controlled temperature-compensated oscillators (VCTCXOs) that are used for accurate system timing in a mobile device, in particular, it is not energy efficient to use such devices to maintain system time for sleep circuits. Accordingly, it is known to maintain system timing during sleep or power saving modes by using a sleep controller consuming much less power and clocked by a crystal oscillator at lower frequency (e.g., 30-60 kHz) rather than the VCTCXO frequency, which is usually much higher (e.g., 19.2 MHz). Usage of the cost effective crystal oscillator as the sleep controller clocking device is at the expense of some accuracy in time keeping because the clock frequency tends to drift with temperature. This clock is otherwise known as the “sleep clock” or “slow clock.” Thus, when the mobile device is asleep, the system clock or “fast clock” (and VCTCXO) is off. The sleep clock is used as a timer to wake up the system. Upon wake up, once the fast clock becomes stable after waking up, system timing is once again handed over to the fast clock.
Furthermore, in certain types of transceivers that receive burst type communications, such as in orthogonal frequency division multiplexed (OFDM) systems, the nature of such systems lend themselves to sleep mode usage due to the periodic nature of when system resources are actually used. In such devices, however, the use of software execution of timing events for shutting down components or waking up components can engender latencies that cause errors or do not result in effective reduction of power consumption during sleep mode due to under utilization of the potentially available time for shutdown of components.
According to an aspect of the present disclosure, a wireless transceiver is disclosed including a processor configured to determine timing information concerning sleep periods for at least a portion of components within the transceiver; and a sleep control logic coupled to the processor to receive information concerning sleep periods from the processor and configured to effect shutting down and waking up of the at least a portion of the components of the transceiver during power reduction periods independent of the processor.
According to another aspect of the present disclosure, a sleep controller for use in a wireless transceiver is disclosed and includes a sleep control logic communicatively coupled to a processor to receive information concerning sleep periods from the processor and configured to effect shutting down and powering up of the at least a portion of the components of the transceiver during power reduction periods independent of the processor.
According to yet another aspect of the present disclosure, a method for controlling sleep modes in a wireless transceiver is disclosed and includes determining timing information concerning sleep periods for at least a portion of components within the transceiver with a processor; and receiving information concerning sleep periods from the processor with a sleep control logic coupled to the processor; and shutting down of the at least a portion of the components of the transceiver during power reduction periods independent of and synchronously with the system time.
According to a further aspect of the present disclosure, another transceiver apparatus is disclosed. The transceiver apparatus includes means for determining timing information concerning sleep periods for at least a portion of components within the transceiver; means for outputting information concerning sleep periods from the means for determining; and means for executing sleep periods configured to shut down the at least a portion of the components of the transceiver during power reduction periods independent of and synchronous with the means for determining timing information.
According to still another aspect, a computer-readable medium encoded with a set of instructions is disclosed. The instructions include an instruction for determining timing information concerning sleep periods for at least a portion of components within the transceiver with a processor; an instruction for receiving information concerning sleep periods from the processor with a sleep control logic coupled to the processor; and an instruction for shutting down of the at least a portion of the components of the transceiver during power reduction periods independent of and synchronous with a transceiver system timing.
It is noted that like numerals refer to like parts throughout the several views of the drawings.
The transceiver 100 also includes another chipset used to receive communication signals, such as burst communications in an orthogonal frequency division multiplexed (OFDM) system, for example. This chipset is shown as a receiver chipset 112 in the example of
Additionally, the transceiver 100 includes a fast and accurate system clock 124, originating from a stable source, such as a voltage controlled temperature compensated crystal oscillator (VCTCXO) used for providing system timing when the transceiver 100 is in awake modes. A sleep clock source 126, which consumes less power and is slower than the fast clock 124, is used for system timing during sleep modes to conserve battery energy. Each of the chipsets 102 and 112 receive clock signals from clocks 124 and 126 as illustrated by connections 128 and 130, respectively.
In the particular architecture exemplified in
As further illustrated in the particular example of
Since a goal of a sleep controller is to conserve power by reducing the power consumption of as many devices within a mobile transceiver, the sleep functionality of the present disclosed system interacts or affects various devices in the transceiver 100. For example, as explained above, various components within the transceiver chipset 102 are controlled to enter sleep modes. For instance, the baseband transceiver 106 may include sleep control. Additionally, the processor 104 may actually be put to sleep as well.
The sleep clock or crystal oscillator 126 is run continuously to provide a low power, uninterrupted clock source for the transceiver 100 during sleep modes. The system clock 124 also is affected by the sleep functionality. In particular, the sleep software 200 running on microprocessor 104 will issue controls via a bus 216 to a power management chip 204, which, in turn, controls the delivery of power to the VCTCXO 124 (thereby turning the system clock 128 on and off). As explained previously, the high power consumption clock 124 is turned off during sleep modes to converse energy.
The RF ICs 108, which support the baseband transceiver 106 and accompanying modes, are also affected by sleep functionality. In particular, the microprocessor 104 may issue instructions to RF IC 108 via a bus 218, such as a serial bus interface. Also the baseband receiver 114 may issue control signals to the RF IC or chip 116 via a serial bus 220.
It is noted here that the digital logic and other various devices in the transceiver 100 are operable with multiple clock regimes, which may be turned on/off to conserve power. Switching may be effected by a clock gating logic (not shown) or any other suitable switching device. As further illustrated in
In the transceiver 100 of
In the disclosed transceiver 100 and, in particular, the receiver chipset 112, sleep modes can be activated during various states of the receiver chipset 112. The first of these states is an active state where data received via the RF chip 116 and ADC 118 is being demodulated burst by burst (e.g., a group of adjacent active symbols is forming a burst, in the case of an OFDM system). When receiving bursts of information in the active state, for example, sleep modes may be effected such as when received overhead information is being demodulated (e.g. OFDM overhead information symbols) or when receiving traffic or control channel data. Another state when sleep modes may be effected include deep sleep states, which are dormant states where no pending requests are being received and only periodic wakeups are necessary, such as for example updating information concerning what information will be broadcast (e.g., a program guide).
A function of the sleep control logic 120 is to minimize power consumption during sleep when the receiver chipset 112 is not receiving active bursts of information. Due to the nature of burst communication that the receiver chipset 112 is designed to receive, the operation of the chipset 112 tends to be systolic (i.e., occurring in bursts of processing corresponding to received bursts of information with idle processing times in between bursts). In certain systems, such as OFDM systems, bursts can last about 10 ms (4% duty cycle) or longer, depending on the payload configuration. Since there is no correlation between on/off cycles of the sleep controller 120 and other modes in the wireless device 100, the presently disclosed example includes independent sleep timelines for processor 104, which may include separate sleep timelines for multiple processors in the transceiver 102, and the baseband receiver chipset 112, although they share the same system clock derived from the VCTCXO clock 124. Furthermore, in order to prevent problems due to latencies inherent to software run by the microprocessor 104 and that the receiver chipset 112 could not tolerate such latency, it was recognized that sleep control for the receiver 112 would be more efficient using separate hardware logic (e.g., 120) to execute sleep modes in the receiver 112.
Although in the particular disclosed examples, the sleep control logic 120 executes a separate sleep timing operation for chipset 112, logic 120 nonetheless is configured to interface with various other portions of the transceiver 100. This is because the timing operation of the receiver affects and is affected by other operations of other parts of the transceiver 100. A more detailed block diagram of an exemplary implementation of the sleep control logic 120 and its interactions is illustrated in
As shown in
The baseband receiver 112 also includes a phase lock loop (PLL) 314, which generates the system clock and other clock domains or regimes. These clock signals are fed to a clock gating logic 316, which is used to selectively turn on and off the different clock domains based on clock disable signals received from core logic 300. From the Sleep Control Logic standpoint in the disclosed example of
It is noted that the microprocessor 104 can disable or enable each clock via a halt input, overriding the sleep controller hardware.
As illustrated, the core logic 300 is configured to issue a wakeup interrupt signal (wakeup_int) to the interrupt controller in the transceiver chipset 102. It is noted that this interrupt is dynamically determined based on programming information from the microprocessor 104 since the wakeup point is not the same for every sleep mode operation and changes from burst to burst.
In operation, sleep control logic 120 disables the primary and secondary system clocks via clock disable signals to conserve energy during a sleep mode. The sleep core logic 300 also disables one or more Phase Lock Loops (PLLs) 314, which are used to generate system clock regimes. The control logic, in turn, receives a system time synchronization pulse, sys_time_en, and exact timing information (sys_time_in) from Receiver Core Logic 114 before sleep begins, and updates (or triggers the update) the system time before sleep finishes. The microprocessor 104 and sleep control logic 120 operation are synchronized via interrupts multiplexed to a single transceiver GPIO signal 322 by interrupt controller 320, and wakeup_int. The microprocessor 104 (not shown in
According to the disclosed examples, software or instructions run by the microprocessor 104 are used to configure the sleep timeline. It is noted that the software can also “tag” bursts after which a snooze cycle or partial sleep cycle can automatically start. It is further noted that the sleep control logic hardware 120 executes the sleep and/or snooze timeline with the resolution of the system clock (sys_clk), which is greater than sleep clock frequency to preserve maximum accuracy.
As may be seen in the timeline of
It was recognized, however, that a substantial source of power inefficiency in the receiver chipset 112 is long response times (latency) of the microprocessor (i.e., software) to real-time events, such as interrupts. This resulted in delay of shutdown of the RF chip 116. Accordingly, the presently disclosed sleep control logic 120 includes a “snooze” feature to provide for immediate RF chips 116 shutdown after the end of a received burst. The “snooze” allows shutdown of a portion of components, while leaving a minimum clock domain (secondary system clock) active, in order to allow the microprocessor 104 to finish processing the current task and drain the decoder output buffer. After processing is finished, the secondary system clock regime and the PLL can also be shut down. The majority of power consumption, however, is due to resources that are shut down at snooze time, particularly the RF chip 116. Thus, a significant degree of efficiency can be garnered through partial shutdown of components in the “snooze”.
In an specific implementation, the “snooze” feature allows software to tag received bursts after which snooze/sleep cycle can occur, and let the sleep control logic 120 initiate RF and part of the digital circuitry shutdown automatically at the end of those bursts, when the snooze trigger (snooze_trig) is generated by hardware (see
It is also noted that sleep control logic 120 executes the sleep timeline based on the secondary system clock during snooze. The reason for this is twofold. First, the secondary system clock domain is still needed by the decoder output buffer, interrupt controller, and other blocks. Second, the process of computing sleep parameters and sleep clock frequency estimation is too complex to be done by hardware. For those reasons, the complete shutdown of the system clock and the PLL and switch to the sleep clock is not possible.
If before the other processing 510 is completed, and the software and hardware processing latency 512 does not exceed this time, a go_to_signal 514 may be processed. After signal 514 has issued, synchronization occurs between hardware and software and software proceeds to issue a sleep execution 518. If request 518 occurs before wakeup signal 520, then sleep is accepted by hardware and starts immediately. Otherwise it is rejected and snooze 508 continues to start of next pulse and the remaining components are put to sleep for a full sleep cycle 516. If the latency 512 is longer than processing 510 (this is not shown on timeline), then the sleep control logic will not initiate a full sleep.
After the determination in block 604, flow proceeds to block 606 where the logic control 120 receives the determined information or programming. This is performed, for example, by the microprocessor 104 writing the information to the sleep control logic 120 via bus interface 306, bus 308, bus interface 310 and sleep registers 312 as illustrated in
At block 608, the sleep control logic 120 automatically shuts down at least a potion of the components of the transceiver 100 during sleep modes, either full sleep mode or snooze modes. The operation in block 608 also includes bringing back or using sleep control logic 120 independent of, but synchronous with receiver or transceiver 106 or 114. That is, the sleep control logic 120 is configured to effect or execute the sleep timeline from entering sleep modes to bringing powered down components back out of sleep mode to powered up operation. This operation is automatically executed by the logic 120 independent of the microprocessor 104 in the sense that the microprocessor does not trigger the sleep modes for the receiver chipset 112. Notwithstanding, the sleep mode operation is performed synchronous with the system timing (e.g., TCXO system clock) used by the receiver or transceiver 106 or 114.
It is noted that the process of block 608 is repeated for each awake/sleep mode cycle, which continue while the transceiver is operational. The process in blocks 604 and 606 may be performed during initialization of the transceiver 100, but can also be performed anytime after initialization as well if desired.
As described in the foregoing, the inefficiencies that arise from latencies due to software processing may be overcome by effecting sleep mode execution through hardware logic. Furthermore, utilization of a partial shutdown of components yields a further rise in the efficiency of sleep mode in cases where sleep modes would be thwarted due to software latency.
It is noted that the baseband receiver 114 and the sleep control logic 120 may reside in a separate ASIC or similar processing circuit as illustrated, but may also be part of an ASIC or chipset incorporated with the transceiver chipset 102. It is further noted that the above-described apparatus and methods may also be utilized for sleep control performed by the baseband transceiver 106.
The examples described above are merely exemplary and those skilled in the art may now make numerous uses of, and departures from, the above-described examples without departing from the inventive concepts disclosed herein. Various modifications to these examples may be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other examples, e.g., in an instant messaging service or any general wireless data communication applications, without departing from the spirit or scope of the novel aspects described herein. Thus, the scope of the disclosure is not intended to be limited to the examples shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein. The word “exemplary” is used exclusively herein to mean “serving as an example, instance, or illustration.” Any example described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other examples. Accordingly, the novel aspects described herein are to be defined solely by the scope of the following claims.
The present Application for Patent claims priority to Provisional Application No. 60/660,916 entitled “RECEIVER SLEEP MODE CONTROLLER” filed Mar. 11, 2005, and assigned to the assignee hereof and hereby expressly incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5428820 | Okada et al. | Jun 1995 | A |
5708658 | Sugita | Jan 1998 | A |
5950120 | Gardner et al. | Sep 1999 | A |
6073035 | Witter | Jun 2000 | A |
6088602 | Banister | Jul 2000 | A |
6282415 | Buhler et al. | Aug 2001 | B1 |
6311081 | Northcutt et al. | Oct 2001 | B1 |
6341224 | Dohi et al. | Jan 2002 | B1 |
6353749 | Siponen | Mar 2002 | B1 |
6356538 | Li | Mar 2002 | B1 |
6400961 | Lillie et al. | Jun 2002 | B1 |
6418127 | Laurent | Jul 2002 | B1 |
6522873 | Moles et al. | Feb 2003 | B1 |
6584330 | Ruuska | Jun 2003 | B1 |
6691071 | Kerr et al. | Feb 2004 | B2 |
6728234 | Hofmann et al. | Apr 2004 | B1 |
6760579 | Yokoyama et al. | Jul 2004 | B1 |
6799030 | Barber et al. | Sep 2004 | B2 |
6876874 | Arnaud et al. | Apr 2005 | B2 |
6947732 | Fraser | Sep 2005 | B2 |
6952571 | Garrabrant et al. | Oct 2005 | B1 |
7073080 | Lou | Jul 2006 | B2 |
7133702 | Amerga et al. | Nov 2006 | B2 |
7200379 | Edwards et al. | Apr 2007 | B2 |
7289832 | Enoki et al. | Oct 2007 | B1 |
7421291 | Karaoguz et al. | Sep 2008 | B2 |
7463910 | Wang et al. | Dec 2008 | B2 |
7512423 | Karaoguz | Mar 2009 | B2 |
7733835 | Sammour et al. | Jun 2010 | B2 |
Number | Date | Country |
---|---|---|
0 865 167 | Sep 1998 | EP |
2000023263 | Jan 2000 | JP |
2000165963 | Jun 2000 | JP |
2002-009688 | Jan 2002 | JP |
2002009688 | Jan 2002 | JP |
2002314678 | Oct 2002 | JP |
2002-0057209 | Jul 2002 | KR |
200414707 | Aug 2004 | TW |
200726129 | Jul 2007 | TW |
WO2004042941 | May 2004 | WO |
Entry |
---|
International Search Report, PCT/US2006/009478, International Searching Authority, European Patent Office, Jul. 4, 2006. |
Written Opinion, PCT/US2006/009478, International Searching Authority, European Patent Office, Jul. 4, 2006. |
International Preliminary Report on Patentability, PCT/US2006/009478, The International Bureau of WIPO, Geneva, Switzerland, Sep. 12, 2007. |
Taiwan Search Report—TW095108449—TIPO—Dec. 20, 2011. |
Number | Date | Country | |
---|---|---|---|
20060240798 A1 | Oct 2006 | US |
Number | Date | Country | |
---|---|---|---|
60660916 | Mar 2005 | US |