The technology of the disclosure relates generally to video-mode display panels on computing devices.
Computing devices have become common in almost every facet of everyday activity. Commonly, computing devices have some form of user interface. Many such user interfaces include some way a user can provide input to the computing device as well as a display through which the user can view output from the computing device. A relatively recent trend is the incorporation of a touch screen display panels that allows the input and the output functions to be combined in a single device.
Various specifications define and control how data is sent from a control system (sometimes referred to as a host or host processor) to a display device such as a display panel. The MIPI® Alliance has provided the Display Serial Interface (DSI) specification as one specification for data transfer between host processors and display panel. DSI-compatible display panels can be generally classified in two categories:
A. Command-mode display panels, where the display panel is self-refreshed from internal panel RAM. The DSI host processor transfers updated portion of the frame buffer at the rate of content refresh rate to the panel.
B. Video-mode display panels, where the display panel is refreshed by the DSI host processor. The host processor transfers an entire framebuffer at a constant refresh rate. The refresh rate may range from, for example, 30-60 Hz depending on the display panel's capacitor discharge rate. The display panel is refreshed at one of the refresh rates in this range based on various runtime parameters. Video-mode panels are widely used in the communication devices due to lower price in comparison to command mode panels.
In one embodiment, a system for displaying image data is discussed. The system may include a host processor configured to provide a frame of image data to a bus, the frame including a first frame region and a second frame region, wherein the first frame region is provided at a first refresh rate and the second frame region is provided at a second refresh rate, wherein the first refresh rate is faster than the second refresh rate. The system may include a video-mode display panel. The video-mode display panel may include a bus interface coupled to the bus and configured to receive the frame. The video-mode display panel may include a display screen including a plurality of pixel elements for displaying the frame, wherein the first frame region is displayed at the first refresh rate and the second frame region is displayed at the second refresh rate. The first refresh rate may be an integer multiple of the second refresh rate. The second refresh rate may exceed a display screen minimum refresh rate. The second refresh rate may exceed a content refresh rate associated with the second frame region. The first frame region may include faster-changing image data displayed at the first refresh rate and the second frame region may include slower-changing image data displayed at the second refresh rate. The system may include a timing controller, the timing controller configured to provide a first clock signal driving the first refresh rate and a second clock signal driving the second refresh rate, wherein the first refresh rate is independent of the second refresh rate. The host processor may be further configured to communicate a first offset associated with the first frame region and a second offset associated with the second frame region to the video-mode display panel before providing the stored frame to the bus. The first offset and the second offset may be communicated via a DSI protocol extension command. The video-mode display panel may receive the frame, the first offset, and the second offset via the bus, wherein the bus may be a DSI bus.
In another embodiment, a method for displaying image data is discussed. The method may include providing, by a host processor, a frame of image data to a bus, the frame including a first frame region and a second frame region, wherein the first frame region is provided at a first refresh rate and the second frame region is provided at a second refresh rate, wherein the first refresh rate is faster than the second refresh rate. The method may include receiving, by a bus interface coupled to the bus, the frame. The method may include displaying the frame, at a display screen including a plurality of pixel elements, wherein the first frame region is displayed at the first refresh rate and the second frame region is displayed at the second refresh rate, wherein the bus interface and the display screen are components in a video-mode display panel. The first refresh rate may be an integer multiple of the second refresh rate. The second refresh rate may exceed a display screen minimum refresh rate. The second refresh rate may exceed a content refresh rate associated with the second frame region. The first frame region may include faster-changing image data displayed at the first refresh rate and the second frame region may include slower-changing image data displayed at the second refresh rate. The method may include providing a first clock signal driving the first refresh rate and a second clock signal driving the second refresh rate by a timing controller, wherein the first refresh rate is independent of the second refresh rate. The host processor may be further configured to communicate a first offset associated with the first frame region and a second offset associated with the second frame region to the video-mode display panel before providing the stored frame to the bus. The first offset and the second offset may be communicated via a DSI protocol extension command. The video-mode display panel may receive the frame, the first offset, and the second offset via the bus, wherein the bus may be a DSI bus.
In another embodiment, a system for displaying image data is discussed. The system may include a host processor means configured to provide a frame of image data to a bus, the frame including a first frame region and a second frame region, wherein the first frame region is provided at a first refresh rate and the second frame region is provided at a second refresh rate, wherein the first refresh rate is faster than the second refresh rate. The system may include a video-mode display panel means. The video-mode display panel means may include a bus interface means coupled to the bus and configured to receive the frame. The video-mode display panel means may include a display screen means including a plurality of pixel elements for displaying the frame, wherein the first frame region is displayed at the first refresh rate and the second frame region is displayed at the second refresh rate. The first refresh rate may be an integer multiple of the second refresh rate. The second refresh rate may exceed a display screen minimum refresh rate. The second refresh rate may exceed a content refresh rate associated with the second frame region. The first frame region may include faster-changing image data displayed at the first refresh rate and the second frame region may include slower-changing image data displayed at the second refresh rate. The system may include a timing controller means, the timing controller means configured to provide a first clock signal driving the first refresh rate and a second clock signal driving the second refresh rate, wherein the first refresh rate is independent of the second refresh rate. The host processor means may be further configured to communicate a first offset associated with the first frame region and a second offset associated with the second frame region to the video-mode display panel before providing the stored frame to the bus. The first offset and the second offset may be communicated via a DSI protocol extension command The video-mode display panel means may receive the frame, the first offset, and the second offset via the bus, wherein the bus may be a DSI bus.
In another embodiment, a non-transient computer-readable storage medium containing program instructions for causing a computer to perform a method is discussed. The method may include providing, by a host processor, a frame of image data to a bus, the frame including a first frame region and a second frame region, wherein the first frame region is provided at a first refresh rate and the second frame region is provided at a second refresh rate, wherein the first refresh rate is faster than the second refresh rate. The method may include receiving, by a bus interface coupled to the bus, the frame. The method may include displaying the frame, at a display screen including a plurality of pixel elements, wherein the first frame region is displayed at the first refresh rate and the second frame region is displayed at the second refresh rate, wherein the bus interface and the display screen are components in a video-mode display panel. The first refresh rate may be an integer multiple of the second refresh rate. The second refresh rate may exceed a display screen minimum refresh rate. The second refresh rate may exceed a content refresh rate associated with the second frame region. The first frame region may include faster-changing image data displayed at the first refresh rate and the second frame region may include slower-changing image data displayed at the second refresh rate. The method may include providing a first clock signal driving the first refresh rate and a second clock signal driving the second refresh rate by a timing controller, wherein the first refresh rate is independent of the second refresh rate. The host processor may be further configured to communicate a first offset associated with the first frame region and a second offset associated with the second frame region to the video-mode display panel before providing the stored frame to the bus. The first offset and the second offset may be communicated via a DSI protocol extension command. The video-mode display panel may receive the frame, the first offset, and the second offset via the bus, wherein the bus may be a DSI bus.
With reference now to the drawing, several exemplary aspects of the present disclosure are described. The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any aspect described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects.
In video-mode display panels, the DSI specification expects data transfer of an entire frame buffer for every refresh. Thus, the entire display is refreshed continuously even if only a small region is refreshing at a relatively high frame rate. This leads to higher power consumption. To reduce power consumption, the display panel may be divided into a first frame region and a second frame region, where each frame region is associated with its own refresh rate. A higher refresh rate can be provided to content such as video playback and scrolling where a higher refresh rate is required for improved user experience and reduce visual artifacts. A lower refresh rate can be provided to other content, thus saving power where higher refresh rate is not required.
Video-mode display panels are frequently used in value tier segment smartphones. Power savings in this segment will enhance battery life and improve performance in this product segment. [to background]
With continued reference to
With continued reference to
Other master and slave devices can be connected to the system bus 308. As illustrated in
The CPU(s) 302 may also be configured to access the display controller(s) 320 over the system bus 308 to control information sent to one or more displays 326. The display controller(s) 320 sends information to the display(s) 326 to be displayed via one or more video processors 328, which process the information to be displayed into a format suitable for the display(s) 326. The display(s) 326 can include any type of display, including, but not limited to, a cathode ray tube (CRT), an LCD, a plasma display, a light emitting diode (LED) display, etc.
The video-mode display panel 410 includes the bus interface 470 which is coupled to the bus 450 and configured to receive image data from the host processor 405. The video-mode display panel 410 also includes a display panel 490 comprising a plurality of pixel elements for displaying the image data. The video-mode display panel 410 also includes a display driver 480 that is coupled to the bus interface 470 and the display panel 490. The host processor 405 transfers image data that includes a series of frames of pixel information (such as “video data”) from the frame buffer 430 over bus interface 440 and bus 450 at a video rate, such as sixty (60) frames per second. The display driver 480 reads the series of frames of image data from the bus interface 470 and writes the frames to the display screen 490.
In this exemplary solution, the first frame rate can be a multiple of the second frame rate. This allows the solution to be implemented in the computing systems illustrated above driven by a single timing engine.
In the example screenshot of
In some situations, it may be difficult to set the first frame rate as a multiple of the second frame rate. For example, the desired multiple may exceed a maximum frame rate for the display panel. A minimum frame rate associated with the video for display, the video-mode display panel, and other factors can be determined as discussed below. In such situations, better performance may be obtained by setting the second frame rate approximately equal to the minimum frame rate. This may require additional host processor enhancements such as additional timing controllers to allow independent refresh rates between the different frame regions.
In 610, the process may initiate video-mode transfer parameters associated with multiple refresh rate regions. For example, the host processor may determine a panel operating frequency range, including a minimum refresh rate and a maximum refresh rate. This can be based on the hardware specification of the display panel. For example, the minimum refresh rate can based on how long display panel capacitors can retain a charge between refreshing without producing visual artifacts or blank spaces. The minimum refresh rate can be set to exceed this period to ensure the display panel is refreshed before the charge dissipates. The maximum refresh rate can be determined by how fast pixel elements of the display panel can change in response to refreshing.
The host processor can analyze a video including a series of frames to be displayed at the display panel. The video can be divided into a first region and a second region. The first region and the second region may include different content for display at different refresh rates. For example, the first region can include faster-changing content and the second region can include slower-changing content, as discussed above. In this example, the second region does not need to be refreshed by the host processor as often as the first region.
In one example, the first region and the second region can each be mapped to a different application layer by the host processor. To initiate the transfer, the host processor can transfer a first frame of the video to be displayed.
In 612, the host processor can receive a subsequent frame to be displayed. In one example, this can be a stored frame to be displayed. The subsequent frame can be divided into first region and second region as discussed. The host processor refreshes first region.
In 614, the host processor checks whether the second region needs to be refreshed. The second region, including slower-changing video content, can be refreshed at a lesser rate than the first region. For example, the second region may be refreshed every second, third, or other integer multiple cycle. The host processor can access or update a counter to determine how many first region refreshes have occurred. If no refresh of the second region is required, the process returns to 612 where the first region is refreshed with a subsequent frame. If a refresh is required, the process continues to 616. It will be appreciated that the process can be extended to any number of regions, each region associated with its own refresh rate.
In 616, host processor refreshes the second region of the subsequent frame. The process returns to 612 and continues until refreshing is no longer required, for example, when the video content has completed playback.
In 662, the host processor may transmit a MIPI DSI protocol extension command, initiating a state to communicate a horizontal offset, for example, a first offset, and a vertical offset, for example, a second offset, for each virtual channels to be used. For example, each region of the video can be associated with a virtual channel and defined by the associated offsets. In one example, up to four virtual channels can be supported by the MIPI DSI protocol.
In this example, the host processor may support independent timing engines for each channel For example, this may be implemented with timing controllers capable of driving different refresh rates for each region. In this example, the controllers may provide a first clock signal and a second clock signal. Thus, the refresh rates of the regions do not depend on each other, unlike the process illustrated in
In one example, the host processor may identify and cluster frame buffer regions with similar refresh rate requirements. Furthermore, the host processor may limit the number of unique refresh regions to a maximum number of virtual channels, as defined in the MIPI DSI protocol. In a further example, each region may be associated with a region of interest, as defined in the MIPI DSI protocol.
For example, a porch may be a non-active region of a virtual channel, or anything outside a region of interest. In one example, the host processor may compute a horizontal porch and a vertical porch of each virtual channel for every refresh rate to ensure that there is no overlap and timing collision with data transfers of other regions. The host processor may further transmit the porches along with the horizontal and vertical panel offsets at beginning of data transfer to the display panel.
The host process may then transfer a first frame of the video to be displayed to the display panel.
In 664, the host processor can receive a subsequent frame to be displayed. In one example, this can be a stored frame to be displayed. The subsequent frame can be divided into first region and second region as discussed above. The host processor refreshes first region of the display panel.
In 666, the host processor checks whether the second region needs to be refreshed. The second region, including slower-changing video content, can be refreshed at a lesser rate than the first region. It will be appreciated that the process can be extended to any number of regions, each region associated with its own refresh rate.
If no refresh of the second region is required, the process returns to 664 where the first region is refreshed with a subsequent frame. If a refresh is required, the process continues to 668.
In 668, host processor refreshes the second region of the subsequent frame. The process returns to 664 and continues until refreshing is no longer required, for example, the video content has completed playback.
As defined in the MIPI DSI specifications, the bus may have four data lanes and one clock lane. In one example, each virtual channel discussed above can be assigned to one data lane. If there are less than four virtual channels, one or more virtual channels can be assigned multiple data lanes for improved throughput. The host processor may ensure the total aggregated bandwidth required by the virtual channels does not exceed the available bandwidth or throughput of the bus. For example, the host processor may reduce the refresh rate in one or more regions where the displayed content is more static and less dynamic, and such a lower refresh rate does not impact user experience or create visual artifacts.
In one example, the MIPI DSI protocol and the associated hardware may be further extended to provide a faster clock in the clock lane. This will provide more granular refresh rates in the example process illustrated in
Area 706 illustrates a data transfer over a bus for a first region at 60 fps. Area 708 illustrates a data transfer over the bus for a second region at 48 fps. It can be seen that the data transfer over the bus for the first region is idle in graph areas 710A, 710B, and 710C and in high speed transfer of pixel data in areas 714A, 714B, and 714C. Similarly, the data transfer over the bus for the second region is in high speed transfer of pixel data in areas 712A, 712B, and 712C, while idle in areas 716A, 716B, and 716C. As can be seen, the second region 708 has shorter data transfer periods and longer idle times compared to the data transfer for the first region 706 as it is transferring less pixel data required a lower frame rate of the second region.
Power savings from implementing the above processes can be computed. For example, almost 16 mA of SoC power savings can be expected based on simulation where a video-mode display panel is refreshed at 48 Hz as compared to 60 Hz. Additional power will be saved by the display panel as capacitors charging rate will be reduced. This power saving is subjective to panel fabrication.
Those of skill in the art will further appreciate that the various illustrative logical blocks, modules, circuits, and algorithms described in connection with the aspects disclosed herein may be implemented as electronic hardware, instructions stored in memory or in another computer readable medium and executed by a processor or other processing device, or combinations of both. The devices described herein may be employed in any circuit, hardware component, integrated circuit (IC), or IC chip, as examples. Memory disclosed herein may be any type and size of memory and may be configured to store any type of information desired. To clearly illustrate this interchangeability, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. How such functionality is implemented depends upon the particular application, design choices, and/or design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The various illustrative logical blocks, modules, and circuits described in connection with the aspects disclosed herein may be implemented or performed with a processor, a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), a Field Programmable Gate Array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices (e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration).
It is also noted that the operational steps described in any of the exemplary aspects herein are described to provide examples and discussion. The operations described may be performed in numerous different sequences other than the illustrated sequences. Furthermore, operations described in a single operational step may actually be performed in a number of different steps. Additionally, one or more operational steps discussed in the exemplary aspects may be combined. It is to be understood that the operational steps illustrated in the flowchart diagrams may be subject to numerous different modifications as will be readily apparent to one of skill in the art. Those of skill in the art will also understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
The previous description of the disclosure is provided to enable any person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the spirit or scope of the disclosure. Thus, the disclosure is not intended to be limited to the examples and designs described herein, but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.