Various embodiments described herein relate to computer devices, and more particularly to display controllers.
Mobile computing systems such as laptop computers, notebook computers, PDAs (Personal Digital Assistants) and the like are popular. A critical aspect of such systems is that they typically run using battery power when they are not or cannot be connected to an AC power source. As a result, mobile computers typically provide power management capabilities in order to run as long as possible off of battery power.
Various components on computing systems consume power. For example, a video display and memory associated with video display consume power. The display can be a Liquid Crystal Display (LCD) flat-panel display screens incorporating TFT (thin film transistor) technology to control pixels.
Most video displays need to be continually refreshed, typically by a graphics engine on a graphics (display) controller. The display may be refreshed pixel by pixel, with the graphics engine fetching the pixel data from memory. The act of fetching data can consume power on the graphics engine (or controller), the memory subsystem containing the pixel data, communication buses and the display device itself.
If the memory subsystem is a dynamic memory based system, the memory contents may need to be periodically refreshed. As such, the memory can perform a self-refresh operation when the memory is not actively being accessed. Further, it can be valuable to keep the memory in a self-refresh state when the computer system is idle. The display controller, however, can update the pixels of the display on a regular basis which can keep both the memory and the communication bus interface between the display controller and display screen in an active state.
A First-In First-Out (FIFO) buffer can be provided on the memory, or host side of the display controller. The display image data can be loaded into the FIFO from the memory, and the FIFO can then be used to refresh the display. The time between loading the FIFO with new image data can be used as idle time to place the memory into a self-refresh state. This idle time on the host memory bus may be related to the capacity size of the FIFO, the size/resolution of the display and the clock frequency (dotclock) used to refresh the display. For example, an 8 Kbyte to 16 Kbyte FIFO buffer can create from 20 to 60 us of idle time on the memory bus depending on attributes of the display.
In the following detailed description of exemplary embodiments of the invention, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific exemplary embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the various embodiments of the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical and other changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense.
Embodiments of the invention may be implemented in one or a combination of hardware, firmware and software. Embodiments of the invention may also be implemented as instructions stored on a machine-readable medium, which may be read and executed by at least one processor to perform the operations described herein. A machine-readable medium may include any mechanism for storing or transmitting information in a form readable by a machine (e.g., a computer). For example, a machine-readable medium may include read-only memory (ROM), random-access memory (RAM), magnetic disk storage media, optical storage media, flash-memory devices, and others.
In the Figures, the same reference number is used throughout to refer to an identical component which appears in multiple Figures. Signals and connections may be referred to by the same reference number or label, and the actual meaning will be clear from its use in the context of the description.
Processor 102 may be any type of computational circuit such as, but not limited to, a microprocessor, a complex instruction set computing (CISC) microprocessor, a reduced instruction set computing (RISC) microprocessor, a very long instruction word (VLIW) microprocessor, a graphics processor, a digital signal processor (DSP), or any other type of processor, processing circuit, execution unit, or computational machine. Although only one processor 102 is shown, multiple processors may be connected to system bus 120.
Graphics and memory controller 104 may provide graphics and video functions and interface one or more memory devices 110. In some embodiments, graphics and memory controller 104 may be integrated on a single chip and may include graphics controller 106 and memory controller 108. In alternative embodiments, graphics controller 106 may reside on a separate chip or chipset from memory controller 108. In further alternative embodiments, graphics controller 106 may reside on a video controller card (not shown). Graphics controller 106 may include various graphics sub-portions such as a 3-dimensional (3D) engine, 2-dimensional (2D) engine, video engine, etc.
Graphics controller 106 can provide data to display 112 via bus 114. Display 112 can be any pixel based display, for example the display may be an LCD (Liquid Crystal Display) that is integral to many mobile computing environments, or an external display. In some embodiments, the bus interface 114 may be a LVDS (Low Voltage Differential Signal) interface. Additionally, bus 114 may be a Digital Video Out Port (DVOB or DVOC) or a CRT interface such as a VGA interface.
Memory controller 108 can interface with system memory 110. In some embodiments, memory 110 comprises DDR-SDRAM (Double Data Rate-Synchronous DRAM), a type of SDRAM that supports data transfers on both edges of each clock cycle (the rising and falling edges), effectively doubling the memory chip's data throughput. DDR-SDRAM typically consumes less power, which makes it well-suited to mobile computing environments. Other dynamic memory devices requiring periodic refresh operations can be used in embodiments of the present invention.
In some embodiments, a frame buffer 116 is provided to store data transferred from the memory 110 and destined for display 112. Frame buffer 116 may be a FIFO buffer or other memory that stores pixel values for pixels of display 112. Although buffer 116 is illustrated as coupled to controller 104 via bus 132 and coupled to memory 110 via bus 134, the buffer can be located anywhere between a core of memory 110 and the display. As such, in some embodiments the buffer can be incorporated in the memory or the controller. The amount of storage required for buffer 116 typically depends on the pixel depth (e.g. the number of bits used for each color), the display screen width and the display screen height.
Embodiments of the invention increase idle time of the memory bus 130 and idle time of the controller 104 between display frame updates. In embodiments where display 112 includes liquid crystal and thin film transistors a display write remains stable for a time period, for example in one embodiment pixels are stable for about 22 ms. In general, a display pixel can maintain its color for roughly 20 ms. Other displays may have similar data retention periods.
Each pixel of display panel 112 can be written once and then allowed to decay based on a refresh rate, for example a refresh operation can be initiated once every 1/60 of a second or every 16.67 ms. Traditionally the display panel is updated at a constant rate based upon the refresh rate and in combination with the display characteristics including pixel depth, horizontal and vertical resolutions and vertical and horizontal blanking rates. In prior systems, the clocking rate (dot clock) of a bus such as bus 114 is generated to allow the display pixels to be updated at an even rate. For example, a display panel with an SXGA+ resolution (horizontal×vertical=1400×1050) with a pixel depth of 32 bpp (bits per pixel) with a refresh rate of 60 Hz requires a dot clock frequency of about 121 MHz.
In prior systems the display interface bus 114 remains active at all times.
Embodiments of the invention can modify the display refresh rate during idle periods in system 100, or display inactivity (where pixel data of the display does not change) to increase an idle time of the controller 104 and/or display bus 114. That is, increasing the time between display refresh operations can increase the idle time of the controller(s). Referring to
Embodiments of the invention can modify the dot clock relative to an allotted display refresh time period to create idle periods on a display bus. This modification can be related to, but is not limited to, system video display idle times. In one embodiment, the clock (dot clock) frequency used to communicate pixel data to the display can be increased during the system idle time to decrease the time needed to perform a refresh of the display. Referring to
For an example display that is refreshed with a 60 Hz refresh rate, increasing the dot clock can increase bus 114 idle times. That is, for a specific configuration, increasing the dot clock by 10% can provide 1.5 ms of idle time generated at the end of a frame interval. Increasing the dot clock by 20% can provide 2.7 ms of idle time, and increasing the dot clock by 30% can provide 3.8 ms of idle time on the display bus.
Therefore, by providing a slightly higher dot clock to a display panel, the idle time generated after the entire display frame has been updated can be used for power management techniques such as powering down the panel interface bus 114, powering down logic of controller 104 and powering down clocking systems such as phase lock loop (PLL) circuits (not shown).
It is noted that while not all embodiments incorporate all of the above features, the features can be combined in some embodiments. For example, combining the features during system 100 idle, or video display inactive, periods can allow more self refresh time for memory 110 and additionally allow the powering down of external clocking and the panel interface bus 114 on the client side of the controller. Additional embodiments of the invention can align the idle time of the display bus 114 with the interruption frequency of an operating system (OS tick rate) executed by the processor 102.
Table 1 helps illustrate some benefits of an embodiment of the invention.
Column one of Table 1 provides the display characteristics for seven different example displays. The characteristics include Horizontal×Vertical relative resolution at a bit per pixel (bpp) depth. Column two is the display refresh rate, and column three is a Dot Clock frequency needed to refresh the display at the specified refresh (no idle time). Column four provides the memory bus self refresh duty cycle between FIFO fill operations (prior art), without display bus idle time provided by embodiments of the present invention. Column four, therefore, provides a prior art self refresh base-line for comparison purposes. In the above examples a 16 K byte FIFO buffer can provide an average memory auto refresh period of about 77.55% for the 1600×1200 @ 32 bpp display.
In this embodiment, the dot clock frequency is increased by 20% while the display refresh time remains constant. By increasing the dot clock frequency, the FIFO may be filled by the memory more often. As such, the memory bus idle time and memory refresh can be decreased. As shown in column five, an average memory auto refresh duty cycle decreases from 77.55% to 73.4% for the 1600×1200 @ 32 bpp display as a result of the increased memory bus activity.
By increasing the dot clock, idle time can be provided on the display bus 114. When the display bus is idle, the FIFO does not need to be filled. As such, the display bus idle time can contribute to the memory self refresh time. Column six shows that the memory self refresh duty cycle can be increased by the extended idle time at the end of the display frame update. For the 1600×1200 @ 32 bpp display, the average memory auto refresh duty cycle increases from the prior art value of 77.55% to 77.86% when the display idle time is considered.
The above illustrated examples are provided for explanatory purposes only. The buffer size, memory bus communication speed and other variables may alter table values. As such, Table 1 is provided to illustrate that increasing the display dot clock frequency while maintaining a display refresh rate can provide added idle time that can be used for memory self refresh. It will be appreciated that further increases in the dot clock frequency (above the illustrated 20%) can provide additional self refresh duty cycle.
As explained, the memory self refresh (SR) duty cycle percentage can be slightly increased while also creating more opportunities to save power with very little logic cost. That is, additional power savings beyond the memory self refresh can be achieved by turning off external system phase lock loops (PLL's) and powering down the physical interface(s) between the display controller 104 and the FIFO 116.
As described above, the system can optionally detect display idle time 510 when the display data remains constant. In response to the detection, or in the absence of the optional detection step, the video display can be updated 520. The display update can be adjusted 530 to manage the communication bus to the display. To provide idle time on the display bus, the display clock frequency can be increased 540, the display refresh rate can be decreased 550, or both the display clock frequency can be increased and the display refresh rate can be decreased 560. The power consumption of the system can be managed 570 for example by placing the memory in self-refresh, and idling clock circuits and processors.
Embodiments of the inventive subject matter may be referred to herein, individually and/or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is in fact disclosed. Thus, although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the above description.
The accompanying drawings that form a part hereof show by way of illustration, and not of limitation, specific embodiments in which the subject matter may be practiced. The embodiments illustrated are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed herein. Other embodiments may be utilized and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. This Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
Number | Name | Date | Kind |
---|---|---|---|
5446840 | Kiuchi et al. | Aug 1995 | A |
5524249 | Suboh | Jun 1996 | A |
5991883 | Atkinson | Nov 1999 | A |
6079025 | Fung | Jun 2000 | A |
6392619 | Nitta et al. | May 2002 | B1 |
6678834 | Aihara et al. | Jan 2004 | B1 |
6820209 | Culbert et al. | Nov 2004 | B1 |
20030210247 | Cui et al. | Nov 2003 | A1 |
Number | Date | Country |
---|---|---|
1239448 | Sep 2002 | EP |
WO-9641253 | Dec 1996 | WO |
WO-2007002921 | Jan 2007 | WO |
Number | Date | Country | |
---|---|---|---|
20070002036 A1 | Jan 2007 | US |