This invention is related to the field of graphical information processing, more particularly, to refresh rate matching for graphics displays.
Part of the operation of many computer systems, including portable digital devices such as mobile phones, notebook computers and the like is the use of some type of display device, such as a liquid crystal display (LCD), organic light emitting diode (OLED) display, or plasma display, to display images, video information/streams, and data. Accordingly, these systems typically incorporate functionality for generating images and data, including graphics and video information, which are subsequently output to the display device. Such devices typically include video graphics circuitry to process images and video information for subsequent display.
In digital imaging, the smallest item of information in an image is called a “picture element”, more generally referred to as a “pixel”. For convenience, pixels are generally arranged in a regular two-dimensional grid. By using this arrangement, many common operations can be implemented by uniformly applying the same operation to each pixel independently. Since each pixel is an elemental part of a digital image, a greater number of pixels can provide a more accurate representation of the digital image. The intensity of each pixel can vary, and in color systems each pixel has typically three or four components such as red, green, blue, and black.
Most images and video information displayed on display devices such as LCD screens are interpreted as a succession of image frames, or frames for short. While generally a frame is one of the many still images that make up a complete moving picture or video stream, a frame can also be interpreted more broadly as simply a still image displayed on a digital (discrete, or progressive scan) display. A frame is typically composed of a specified number of pixels according to the resolution of the image/video frame. Information associated with a frame typically consists of color values for every pixel to be displayed on the screen. Color values are commonly stored in 1-bit monochrome, 4-bit palletized, 8-bit palletized, 16-bit high color and 24-bit true color formats. An additional alpha channel is oftentimes used to retain information about pixel transparency. The color values can represent information corresponding to any one of a number of color spaces.
Systems that feature a display device, such as an LCD screen or other type of display, also typically feature a Display Controller to control the timing of the signals, including video synchronization signals that are provided—from a graphics-processing unit, for example—to be displayed. Some Display Controllers are divided into multiple functional stages, for example an interface to receive the pixels from the source (e.g. from the graphics processing unit), and a port control unit to provide the appropriate signals to a display port physically coupling to the display. In some cases, additional functional or logic blocks are instantiated within the Display Controller between the interface and the port control unit. It is important for all components, including the additional functional/logic blocks within the Display Controller to communicate seamlessly and efficiently with each other.
One functionality related to the interoperability of the display controller and the display is the display panel's refresh rate (most commonly the “vertical refresh rate”), which refers to the frequency at which the display hardware draws the graphics data. The display refresh rate is distinct from the frame rate at which image frames may be delivered to the display. A given refresh rate may result in the repeated display of identical frames, while the frame rate is indicative of the frequency at which entire frames of new data are sent to the display. For example, the refresh rate or temporal resolution of an LCD display is indicative of the number of times per second that the LCD display draws the data provided to it. Because (most) progressive scan displays do not turn activated pixels on/off between frames, such displays exhibit no refresh-induced flicker, no matter how low their refresh rate is. Typically the closest equivalent to a refresh rate on an LCD monitor is its frame rate, which is often locked at 60 frames/s. For this reason many present day systems are required to implement a refresh rate that is exactly 60 Hz. However, depending on the display resolution parameters and available options for pixel clock rate of a given design, the acceptable pixel clock rates may be very limited or even impossible to find, which may also prevent the implementation of an exact refresh rate of 60 Hz.
Other corresponding issues related to the prior art will become apparent to one skilled in the art after comparing such prior art with the present invention as described herein.
In a graphics system, it may not be possible to implement a pixel clock rate that exactly corresponds to the target refresh rate of a graphics display intended to display the generated image frames, which may be still frames or video frames or overlay graphics frames and the like. However, a method may be employed to match the target refresh rate while providing pixels to the graphics display at the implemented pixel clock rate. The pixel clock rate that can be implemented may be selected to correspond to an effective refresh rate that is nearest to the target refresh rate (e.g. to 60 Hz) while also being lower than the target refresh rate. A calculation, based on at least the effective refresh rate, the target refresh rate, and the pixel resolution of the image frame, may be performed to determine the total number of pixels that would have to be provided at the implemented pixel clock rate to match the target refresh rate for each frame. Accordingly, a number of additional pixels required for each frame may be determined based on the calculated total number of pixels and the number of pixels present in each frame. That is, the number of additional pixels represents the number of pixels that when added to the pixels present in the image frame may result in the target refresh rate when providing all the pixels at the implemented pixel clock rate.
The additional pixels may be implemented as “dummy pixels”, or blank pixels that can be included in the blanking portion of the frame. In one set of embodiments, one or more individual pixels can be added at the end of one or more horizontal lines, as required, to bring the total number of pixels to the desired number. These pixels may simply be detected as errors by the display panel (or graphics display) used to display the image frames, and may therefore not affect operation. In another set of embodiments, the additional pixels may be added to the end of the frame in the vertical blanking interval, in which case the vertical blanking interval may simply appear to be slightly longer than expected, again not affection normal operation.
The following detailed description makes reference to the accompanying drawings, which are now briefly described.
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the present invention as defined by the appended claims. The headings used herein are for organizational purposes only and are not meant to be used to limit the scope of the description. As used throughout this application, the word “may” is used in a permissive sense (i.e., meaning having the potential to), rather than the mandatory sense (i.e., meaning must). Similarly, the words “include”, “including”, and “includes” mean including, but not limited to.
Various units, circuits, or other components may be described as “configured to” perform a task or tasks. In such contexts, “configured to” is a broad recitation of structure generally meaning “having circuitry that” performs the task or tasks during operation. As such, the unit/circuit/component can be configured to perform the task even when the unit/circuit/component is not currently on. In general, the circuitry that forms the structure corresponding to “configured to” may include hardware circuits and/or memory storing program instructions executable to implement the operation. The memory can include volatile memory such as static or dynamic random access memory and/or nonvolatile memory such as optical or magnetic disk storage, flash memory, programmable read-only memories, etc. Similarly, various units/circuits/components may be described as performing a task or tasks, for convenience in the description. Such descriptions should be interpreted as including the phrase “configured to.” Reciting a unit/circuit/component that is configured to perform one or more tasks is expressly intended not to invoke 35 U.S.C. § 112, paragraph six interpretation for that unit/circuit/component.
As shown in
Computing device 110 includes an external interface 130 to couple to external display 160 via connection 150. Similarly, display 160 may contain a panel driver interface 132 to receive the information from computing device 110 for displaying on display panel 160. Interface 130 may be any type of standard or proprietary interface, and may be wired or wireless. A given interface 130 can be understood to have a “data width” (e.g., a number of pins) dedicated to a specified amount of data the interface can transfer at a given point in time. Specifically, interface 130 may have a specified number of lines dedicated to transferring graphics (e.g. video/image) information to external display 160. Interface 130 may also be configured to provide data to other types of external devices that may also be coupled to computing device 110 via interface 130, in lieu of or in addition to external display 160. Connection 150 is a logical representation of the connection between device 110 and display 160. In various embodiments, connection 150 may be wireless. In other embodiments, connection 150 may be wired, and may include one or more intervening hardware components, such as a scaling unit or timing controller chip. In one embodiment, display 160 is a high-definition TV (HDTV) compatible device.
Computing device 110 may include various structures (not depicted in
Memory controllers within device 110 may comprise any circuitry configured to interface to the various memory requestors (e.g. processors, graphics circuitry, etc.). Any sort of interconnect may be supported for such memory controllers. For example, a shared bus (or buses) may be used, or point-to-point interconnects may be used. Hierarchical connection of local interconnects to a global interconnect to the memory controller may be used. In one implementation, a memory controller may be multi-ported, with processors having a dedicated port, graphics circuitry having another dedicated port, etc.
Alternatively, the devices may be mounted with a system on a chip in a chip-on-chip configuration, a package-on-package configuration, or a multi-chip module configuration. Graphics controllers within device 110 may be configured to render objects to be displayed into a frame buffer in the memory. The graphics controller may include one or more graphics processors that may execute graphics software to perform a part or all of the graphics operation, and/or hardware acceleration of certain graphics operations. The amount of hardware acceleration and software implementation may vary from embodiment to embodiment.
Referring now to
In some embodiments, the video frames/information may be represented in a first color space, according the origin of the video information. For example, the video information may be represented in the YCbCr color space. At the same time, the image frame information may be represented in the same color space, or in another, second color space, according to the preferred operating mode of the graphics processors. For example, the image frame information may be represented in the RGB color space. Display generation unit 210 may include components that blend the processed image frame information and processed video image information to generate output frames that may be stored in a buffer, from which they may be provided to a display controller 212, which may provide the output pixel stream to display port (physical layer and link) 130 to be sent out over connection 150.
In one set of embodiments, the output frames may be presented to the display controller 212 through an asynchronous FIFO (First-In-First-Out) buffer in display generation unit 210. The display controller may control the timing of the display through a Vertical Blanking Interval (VBI) signal that may be activated at the beginning of each vertical blanking interval. This signal may cause the graphics processor(s) to initialize (Restart) and start (Go) the processing for a frame (more specifically, for the pixels within the frame). Between initializing and starting, configuration parameters unique to that frame may be modified. Any parameters not modified may retain their value from the previous frame. As the pixels are processed and put into the output FIFO, the display controller may issue signals (referred to as pop signals) to remove the pixels at the display controller's clock frequency. The pixels thus obtained may be queued up in the output FIFO at the clock rate of the processing elements within display generation unit 210, and fetched by the display controller at the display controller's clock rate.
Computing device 110 may operate to display frames of data. Generally, a frame is data describing an image to be displayed. As mentioned above, a frame may include pixel data describing the pixels included in the frame (e.g. in terms of various color spaces, such as RGB or YCbCr), and may also include metadata such as an alpha value for blending. Static frames may be frames that are not part of a video sequence. Alternatively, video frames may be frames in a video sequence. Each frame in the video sequence may be displayed after the preceding frame, at a rate specified for the video sequence (e.g. 15-30 frames a second). Video frames may also be complete images, or may be compressed images that refer to other images in the sequence. If the frames are compressed, a video pipeline in device 110 may decompress the frames.
The display generation unit 210 may be configured to read frame data from memory 232 and to process the frame data to provide a stream of pixel values for display. Generally, a pixel value in a stream of pixel values may be a representation of a pixel to be displayed on a display coupled to device 110, such as display 160. The pixel stream may be a series of rows of pixels, each row forming a line on the display screen. In a progressive-mode display, the lines are drawn in consecutive order and thus the next line in the pixel stream is immediately adjacent to the previous line. In an interlaced-mode display, consecutive passes over the display draw either the even or the odd lines, and thus the next line in the pixel stream skips one line from the previous line in the pixel stream. For brevity, the stream of pixel values may be referred to as a pixel stream, or a stream of pixels. Display generation unit 210 within device 110 may perform various pixel operations on the pixel stream, and eventually provide the processed pixel stream to the display port physical layer and link (DP Phy & Link) 130 via display controller 212, as mentioned above.
Oftentimes, the resolution (i.e., the number of pixels in the horizontal and vertical directions) of the image frame generated by unit 210 is different from the resolution of display 160. In order to facilitate display of images on such a display, the data sent to panel driver 132 may be downscaled/compressed. The compression means loss of image resolution, requiring a retiming of the frames before they are transmitted to panel driver 132. Thus, some embodiments may include a scaling unit/timing controller 230 that may be used to scale and retime the frames before they reach panel driver 132. It should be noted also, with reference to both
Referring to system 100 in
A pixel clock rate that can be implemented and provides a refresh rate that is nearest to 60 Hz (but less than 60 Hz) may be selected/specified. The number of additional pixels that would be required in one image frame to yield exactly 60 Hz can then be calculated, and these pixels (referred to as dummy pixels) may be included in the blanking portion of the frame. In one set of embodiments, individual pixels may be added at the end of each horizontal line. These pixels may simply be detected as errors by the display panel (e.g. display panel 160), and may therefore not affect operation. In another embodiment, the pixels may be added to the end of the frame, in the vertical blanking interval. The result of adding the pixels to the end of the frame may be the appearance of a slightly longer than expected vertical blanking interval.
The concept of adding dummy pixel(s) at the end of each horizontal line of the image frame is illustrated in
As illustrated in
The concept of adding dummy pixel(s) at the end of the image frame is illustrated in
As shown above, a desired refresh rate may therefore be matched by implementing a pixel clock rate that does not directly yield the desired refresh rate. The pixel clock rate (or frequency) may be selected to result in (or yield) a refresh rate nearest to the desired refresh rate, with the nearest refresh rate also being lower than the desired refresh rate. Subsequently, a specified number of additional pixels may be added in each image frame to cause an achieved refresh rate that matches the desired refresh rate. The additional pixels may be distributed in the image frame by adding an extra blank (or dummy pixel) at the end of one or more horizontal lines of the frame, which may simply lead to the display interpreting the blank pixels as errors, thereby ignoring those pixels and not affecting proper operation. Alternatively, the blank pixels may be added together at the end of the frame, in the vertical blanking interval, as an extra blank (partial) line, which may result in the appearance of a slightly longer than expected vertical blanking interval, also without affecting proper operation.
As shown in 708, the processed pixels and the number of blank pixels are provided at a first frequency representative of the first refresh rate to a graphics display operating at the second refresh rate. As also mentioned previously, in one set of embodiments, the blank pixels may be distributed to have one (or more, if necessary) pixel(s) provided at the end of a number (or all) horizontal lines of the image frame. In those embodiments, the blank pixels may simply be interpreted by the graphics display as errors, and be safely discarded without affecting normal operation. In alternate embodiments, the blank pixels may be added together at the end of the frame in the vertical blanking interval as an extra vertical blank partial line. In those embodiments, the vertical blank partial line may simply result in the appearance of a slightly longer than expected vertical blanking interval, also without affecting normal operation. Thus, as indicated in 710, the received processed pixels are displayed on the graphics display, while the received blank pixels are not displayed. The process may repeat for additional frames (‘Yes’ branch taken at 712), or if no more image frames are to be displayed, the process is complete (714).
It should also be noted (as also mentioned above) that step 706 may need to be performed only once, prior to processing and displaying the image frames. Specifically, the calculation may be performed once all the specifications required to perform the calculations in the system have been set. That is, in some embodiments, the process may begin with the calculation being performed, and fetching, processing, and displaying of the pixels may then be performed. Accordingly, in those embodiments step 706 is not part of the feedback loop shown in
Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications.
Number | Name | Date | Kind |
---|---|---|---|
6054980 | Eglit | Apr 2000 | A |
7388618 | Tardif | Jun 2008 | B2 |
7430018 | Patel | Sep 2008 | B1 |
7948556 | Kumakawa | May 2011 | B2 |
8179388 | Wyatt et al. | May 2012 | B2 |
8542221 | Wyatt | Sep 2013 | B1 |
20020186213 | Koizumi | Dec 2002 | A1 |
20080055342 | Liao | Mar 2008 | A1 |
20080143729 | Wyatt et al. | Jun 2008 | A1 |
20090327777 | Vasquez | Dec 2009 | A1 |
20100149413 | Kumakawa | Jun 2010 | A1 |
20120075334 | Pourbigharaz et al. | Mar 2012 | A1 |
20120083320 | Hijazi et al. | Apr 2012 | A1 |
20130141642 | Wu | Jun 2013 | A1 |
20130163876 | Silver et al. | Jun 2013 | A1 |
Number | Date | Country | |
---|---|---|---|
20140085275 A1 | Mar 2014 | US |