This application claims priority to Chinese Patent Application No. 200910130039.4, filed on Apr. 3, 2009, which is hereby incorporated by reference in its entirety.
The present invention relates to display technologies, and in particular, to a display method, display controller and display terminal.
Currently, video play and video telephony are used extensively on mobile terminals. To display a high-resolution video source on a low-resolution liquid crystal display (LCD), a process of scaling down the video source is generally required. On the contrary, to display a low-resolution video source on a high-resolution LCD, a process of scaling up the video source is required.
The source video is scaled by a scaling engine integrated in the display controller.
In the prior art, the transient bandwidths required for reading the source video image linearly increase along with the scaling ratio. The transient bandwidths needed by the system memory to read the source video image under scaling conditions=transient bandwidths needed by the system memory to read the source video image in case of no scaling*vertical scaling ratio*horizontal scaling ratio. Table 1 lists maximum input video resolutions that can be supported by the scaling engine of the display controller supplied by a renowned application processor supplier under various LCD resolutions. As shown in Table 1, the vertical and horizontal scaling ratios supported by the display controller are 2 at most.
During the implementation of the present invention, the inventor discovers at least the following weaknesses in the prior art: The source video image cannot be scaled within a high ratio range in online mode.
Embodiments of the present invention provide a display method, display controller and display terminal to increase the scaling ratio of the source video image.
A display method provided in an embodiment of the present invention includes:
judging whether a preset policy is met when the video layer needs to scale a video image; if the preset policy is met, using an offline mode; otherwise, using an online mode; and
processing a video image frame of the video image according to the online mode or the offline mode, and outputting the processed video image, where the online mode is a mode in which the video image frame is scaled in real time and the offline mode is a mode in which the video image frame is scaled asynchronously.
A display controller provided in an embodiment of the present invention includes:
a mode configuring module, when a video layer needs to scale a video image, adapted to: set the offline mode if a preset policy is met; set the online mode if the preset policy is not met; and
a display control processing module, adapted to: control the display controller to process the video image frame according to the online mode or offline mode based on the configuration details of the mode configuring module, and output the processed video image.
A display terminal provided in an embodiment of the present invention includes:
a system memory, adapted to store a video image frame of a video image;
a display controller, when a video layer needs to scale the video image, adapted to: set the offline mode if a preset policy is met; set the online mode if the preset policy is not met, read the video image frame from the system memory according to the online mode or offline mode, process the video image frame, and output the processed video image frame; and
a display, adapted to display the processed video image frame processed by the display controller.
With the display method, device and terminal, the source video image can be scaled in a high ratio range by selecting the online mode or offline mode, thus reducing the display power consumption.
For better description of embodiments of the present invention or technical solution in the prior art, the following briefly describes the required drawings. It is apparent that these drawings are some embodiments of the present invention only, and those skilled in the art may obtain other drawings based on these drawings without creative work.
a and
The following describes the technical solution of the present invention in detail with reference to the accompanying drawings and exemplary embodiments. These embodiments are some embodiments of the present invention only. Other embodiments that those skilled in the art obtain based on embodiments of the present invention without creative work fall into the scope of protection of the present invention.
An embodiment of the present invention provides a display method. As shown in
Step 201: Judge whether the video layer needs to scale the video image; if the video layer needs to scale, go to step 202; otherwise, end the process.
Step 202: Set the video layer to online mode or offline mode according to the preset policy.
The online mode may be a mode in which the scaling engine of the display controller scales the video image in real time. That is, the scaling engine of the display controller sends the processed pixel to the backward module while scaling the video data. The scaling engine and the backward module are streamlined. The offline mode is a mode in which the scaling engine and the backward processing module process the video image asynchronously. That is, the scaling engine writes back the processed data to the scaling buffer of the system memory; after a complete frame is written, a direct memory access (DMA) channel of the display controller reads the frame at the LCD frame synchronization time, and then sends the frame to the backward module of the scaling engine for subsequent processing. In brief, in online mode, the video image frame is scaled in real time; in offline mode, the video image frame is scaled asynchronously.
The preset policy includes a principle of minimizing the data access load of the system memory by the video layer or a principle of minimizing the bus clock frequency of the video layer.
The principle of minimizing the data access load of the system memory by the video layer includes: presetting the display frame rate is M (greater than 1) times the frame rate for writing to the source video image frame buffer and the width and height of the scaled source video image are N times the width and height of the target video image, the ratio of the data access load of the system memory by the video layer in offline mode to the data access load of the system memory by the video layer in online mode is N2+M+1:N2*M. If the video is played and the decoder writes to the source video buffer, the display rate is generally twice the decoding frame rate, that is M=2. According to the foregoing proportion, when N is greater than 1.73, the data access load of the system memory by the video layer in offline mode is smaller than that in online mode, and the offline mode is selected; when N is smaller than 1.73, the data access load of the system memory by the video layer in online mode is smaller than that in offline mode, and the online mode is selected; when N is equal to 1.73, the data access load of the system memory by the video layer in online mode is equal to that in offline mode, and either the online mode or the offline mode may be selected. That is, the offline mode is used when the horizontal and vertical scaling ratio of the source video image is greater than or equal to √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}; the online mode is used when the horizontal and vertical scaling ratio of the source video image is smaller than √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}. The √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))} can be substituted as X*√{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}, wherein the X is naturalness number.
The principle of minimizing the bus clock frequency of the video layer includes: using the offline mode when the source video image is scaled down vertically; and using the online mode when the source video image is scaled up vertically.
Step 203: Process the video image according to the online mode or the offline mode, and output the processed video image.
The process shown in
The step of judging whether the preset policy is met may include judging whether the preset policy is met according to the principle of minimizing the data access load of the system memory by the video layer. The details are as follows: Presetting the display frame rate is M (greater than 1) times the update frame rate of the video source, when the horizontal and vertical scaling ratio of the source video image is greater than √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}, the preset policy is met; when the horizontal and vertical scaling ratio of the source video image is smaller than √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}, the preset policy is not met; when the horizontal and vertical scaling ratio of the source video image is equal to √{square root over ((M+1)/(M−1))}{square root over ((M+1)/(M−1))}, the preset policy may be met.
The step of judging whether the preset policy is met may also include judging whether the preset policy is met according to the principle of minimizing the bus clock frequency of the video layer. The details are as follows:
The preset policy is met when the source video image is scaled down vertically; and the preset policy is not met when the source video image is scaled up vertically.
The flowchart of processing the video image frame according to the online mode and outputting the processed video image is shown in
With the foregoing display method, the source video image is scaled in a high ratio range according to the online mode or offline mode, thus reducing the display power consumption. In addition, the bus clock frequency and the operating clock frequency of the scaling engine are within a range that can be implemented physically. When the mode is switched according to the principle of minimizing the data access load of the system memory, the data access load of the system memory by the display system can be reduced, thus reducing the power consumption of the system memory. When the mode is switched according to the principle of minimizing the bus clock frequency of the video layer, the bus clock frequency of the video layer can be reduced, thus reducing the total power consumption of the display system.
When the video image frame is read by using the policy of skipping the redundant lines, the operating clock frequency may be reduced, and the data access load of the system memory is further reduced.
Optionally, the step of setting the video layer to online mode or offline mode according to the preset policy may include: using the online mode to scale down the source video image; and using the offline mode to scale up the source video image.
Step 301: Read the source video image frame from the source video frame buffer in real time.
Step 302: Rotate the video image frame, scale the video image frame, buffer the video image frame by lines, and convert the format of the video image frame.
The rotation, scaling and format conversion processes are the same as those in the prior art, and are not further described.
The purpose of buffering the video image frame by lines is to solve the problem that the horizontal scaling ratio is limited.
Step 303: Overlay the converted data with other image layers for displaying, and output the processed video image.
The overlay process is the same as that in the prior art, and is not further described.
By processing the video image frame according to the online mode in this embodiment, the video image may be scaled and the scaled video image may be output at the same time. In addition, with the line buffer process, the problem that the horizontal scaling ratio is limited may be solved.
a and
Step 401: Read a source video image frame from the source video frame buffer.
Step 402: Rotate and scale the source video image frame, and buffer the scaled video image frame. That is, write the scaled video image frame to the scaling video buffer.
The rotation and scaling processes are the same as those in the prior art, and are not further described.
Step 403: Judge whether the read source video image frame is already processed and whether new frames are available in the source video frame buffer; if so, return to step 401; otherwise, repeat step 403.
A next source video image frame is read after the previous frame is processed completely.
Step 404: When an LCD frame synchronization signal arrives, read the buffered video image frame from the scaling video buffer, and convert the format of the buffered video image frame.
The format conversion process is the same as that in the prior art, and is not further described.
Step 405: Overlay the converted data with other image layers for displaying, and output the processed video image.
By processing the video image frame according to the offline mode in this embodiment of the present invention, the source video image may be scaled in a high ratio range because the scaling process and subsequent output process are performed asynchronously. In addition, the bus clock frequency and the operating clock frequency of the scaling engine are in a range that can be implemented physically.
In embodiments shown in
Step 501: Initialize the variable values.
Specifically, the following variables are set: N=N−1; M=M−1; m=0; 1=0; and n=0.
N indicates the height of the target image; M indicates the height of the source image; m indicates the current processed line No. of the source image; and 1 indicates the relative distance.
Step 502: Judge whether n is smaller than or equal to N; if so, go to step 503; otherwise, end the process.
Step 503: Set 1=1+M/N, and i=0.
Step 504: Judge whether I is greater than or equal to 1; if so, go to step 505; otherwise, go to step 508.
Step 505: Set m=m+1, 1=1−1, and I=i+1.
Step 506: Judge whether i is greater than 2; if so, go to step 507; otherwise, go to step 504.
Step 507: Determine the (m−1)th line as a redundant line, and return to step 504.
Step 508: Set n=n+1, and return to step 502.
By using the algorithm shown in
The mode needs to be re-selected and switched if one of the following events occurs:
o1o1 {circle around (1)} The first video image frame is already prepared;
o2o2o2 {circle around (2)} The rotation angle of the video image is changed;
o3o3 {circle around (3)} The scaling ratio of the video image is changed;
o4o4o4 {circle around (4)} The overlay priority or overlay specifications (for example, the color key) of the video image layer is changed; or
o5o5 {circle around (5)} Background play is changed to foreground play.
The mode selection and switching processes include the following steps:
Step 601: Judge whether the previous display configuration is already validated; if so, go to step 602; otherwise repeat step 601.
In this embodiment, the step of judging whether the previous display configuration is validated is checking whether the configuration validation flag bit is 0. Certainly, in other embodiments, whether the previous display configuration is validated may also be judged by checking whether the configuration validation flag bit is 1.
It is understandable that all the configurations needed for the purpose of display are collectively called display configurations. For a display process, multiple parameters and/or multiple steps need to be configured. It is necessary to judge whether multiple parameters and/or multiple steps for one-time displaying are already configured by checking the configuration bit.
Step 602: Judge whether the video layer needs to scale the video image; if so, go to step 604; otherwise, go to step 603.
Step 603: Configure the source video address register and other video parameters except the scaling parameter, and close the scaling engine, and then go to step 608.
Step 604: Judge whether the scaling ratio of the source video image is smaller than 1.73 or whether the source video image is scaled up; if so, go to step 605; otherwise go to step 606.
Step 605: Set the processing mode to online mode, and then go to step 607.
Step 606: Set the processing mode to offline mode, and then go to step 607.
Step 607: Configure the parameters of the video layer. The parameters of the video layer include at least relationships between the video layer and other image layers, such as overlay priority and color key, video input format such as line offset, width and height of the source image, and width and height of the target image, video rotation angle, scaling video frame buffer address, and scaling parameter register, for example, horizontal and vertical scaling metrics.
Step 608: Enable the video layer.
Step 609: Set the configuration validation flag bit to 1 and end the process.
After the foregoing new configurations are validated, the hardware automatically sets the configuration validation flag bit to 0
Now the mode selection and switching are implemented according to the principle of minimizing the data access load of the system memory by the video layer.
In an embodiment shown in
The mode selection and switching processes according to the principle of minimizing the bus clock frequency of the video layer are the same as those shown in
When the mode is switched according to the principle of minimizing the data access load of the system memory, the data access load of the system memory by the display system can be reduced, thus reducing the power consumption of the system memory. When the mode is switched according to the principle of minimizing the bus clock frequency of the video layer, the bus clock frequency of the video layer can be reduced, thus reducing the total power consumption of the display system.
An embodiment of the present invention provides a display controller. As shown in
a mode configuring module 701, adapted to: set the offline mode when the preset policy is met and the video layer needs to scale a video image; and set the online mode when the preset policy is not met; or adapted to set the video layer to online mode or offline mode according to the preset policy when determining that the video layer needs to scale the video image; and
a display control processing module 702, adapted to: control the display controller to process the video image frame according to the online mode or offline mode based on the configuration details of the mode configuring module, and output the processed video image.
With the display controller, the source video image can be scaled in a high ratio range by selecting the online mode or offline mode, thus reducing the display power consumption.
As shown in
The configuration register is adapted to notify the mode selecting module when determining that the video layer needs to scale a video image.
The mode selecting module 7012 is adapted to: set the offline mode when the preset policy is met; and set the online mode when the preset policy is not met. It is understandable that the mode selecting module 7012 is adapted to set the video layer to online mode or offline mode. In this embodiment, when the mode selecting module is set to 0, the display controller is in online mode; when the mode selecting module is set to 1, the display controller is in offline mode.
In addition, the configuration register 7011 is further adapted to configure the parameters of the video layer after determining that the previous display configuration is validated and before determining whether the video layer needs to scale the video image; or configure the parameters of the video layer after the video layer is set to online mode or offline mode according to the preset policy.
The foregoing parameters of the video layer include at least: relationship between the video layer and other image layers, video input format, video rotation angle, scaling video frame buffer address, and scaling parameter register.
As shown in
The first video channel 7021 is adapted to read the source video image frame outside the display controller in real time. Specifically, the first video channel 7021 is adapted to read the source video image from the source video image buffer in real time.
The rotating module 7022 is adapted to rotate the source video image frame read by the first video channel.
The scaling module 7023 is adapted to scale the rotated video image.
The line buffering module 7024 is adapted to buffer the scaled video image.
The format converting module 7025 is adapted to: obtain the video image from the line buffering module, and convert the format of the video image.
The overlay processing module 7026 is adapted to: overlay the converted video image with other image layers for displaying, and output the processed video image.
As shown in
a first video channel 7021, adapted to read a source video image frame from the source video frame buffer, and specifically, adapted to read a source video image from the source video image buffer;
a rotating module 7022, adapted to rotate the source video image frame read by the first video channel.
a scaling module 7023, adapted to: scale the rotated video image, and buffer the scaled video image through a second video channel;
the second video channel 7027, adapted to read the buffered video image frame when an LCD frame synchronization signal arrives, and specifically, adapted to read the buffered video image frame from the scaling video buffer when the LCD frame synchronization signal arrives;
a format converting module 7025, adapted to convert the format of the video image frame read from the scaling video buffer; and
an overlay processing module 7026, adapted to: overlay the converted video image with other image layers for displaying, and output the processed video image.
The first video channel shown in
The redundant line judging module is adapted to: identify a redundant line of the read source video image, and notify the reading unit of the identified redundant line.
The reading unit is adapted to: skip the redundant line in the source video image, and read the non-redundant lines of the video image frame.
With the display controller provided in this embodiment, the source video image is scaled in a high ratio range according to the online mode or offline mode, thus reducing the display power consumption. In addition, the bus clock frequency and the operating clock frequency of the scaling engine are within a range that can be implemented physically. When the mode is switched according to the principle of minimizing the data access load of the system memory, the data access load of the system memory by the display system can be reduced, thus reducing the power consumption of the system memory. When the mode is switched according to the principle of minimizing the bus clock frequency of the video layer, the bus clock frequency of the video layer can be reduced, thus reducing the total power consumption of the display system.
Further, the redundant line can be pre judged and skipped directly, and only the valid lines need to be read for subsequent processing. Thus, the operating clock frequency may be reduced, and the data access load of the system memory may also be further reduced.
When the video layer attribute is changed, the software writes the mode configuration to the shadow register in scaling mode, and sets the configuration validation flag bit to 1 after configuring other parameters of the video layer. When an LCD frame synchronization signal arrives, if the operating register is offline but the shadow register is online (that is, switching from the offline mode to the online mode is required), the display controller must copy the value of the shadow register to the operating register and enter the online mode after a complete frame that is being scaled in offline mode is written to the scaling video frame buffer (that is, after the scaled buffered frame 2 is written) and before the next LCD frame synchronization signal arrives. In addition, the hardware sets the configuration validation flag bit to zero. If the operating register is online but the shadow register is offline (that is, switching from the online mode to the offline mode is required), the display controller copies the value of the shadow register to the operating register when the LCD frame synchronization signal arrives and enters the offline mode. In addition, the hardware sets the configuration validation flag bit to zero. It is understandable that the new configuration is validated after the hardware sets the configuration validation flag bit to zero.
Thus, the value of the operating register in scaling mode represents the current operating mode of the display controller. In offline mode, the display controller reads a current decoded frame from the source video frame buffer after the decoder decodes a frame; the display controller rotates and scales the frame, and writes the rotated and scaled frame to the scaling video frame buffer. In addition, after the LCD frame synchronization signal arrives, the display controller reads the current frame from the scaling video frame buffer, converts the format of the frame from YUV to RGB, overlays the converted frame with other image layers, and sends the overlaid frame to the LCD for displaying. In online mode, the display controller reads the current frame from the source video frame buffer; the display controller rotates and scales the current frame in real time, converts the format of the frame from YUV to RGB, overlays the converted frame with other image layers, and sends the overlaid frame to the LCD for displaying.
In offline mode, the display controller reads the source video frame after the decoders decodes a frame and the time stamp of the frame matches the current time or when the mode is changed from the online mode to the offline mode at the LCD frame synchronization time. After scaling the source video frame, the display controller writes the scaled source video frame to the scaling video frame buffer. Thus, the scaling frame rate in offline mode is the same as the frame rate of the decoder. The display controller, however, reads the frame from the scaling frame buffer according to the display frame rate synchronous with the LCD, converts the format of the frame from YUV to RGB, overlays the frame, and sends the overlaid frame to the LCD for displaying. Table 2 summarizes the bus clock frequencies needed by the video layer in offline mode based on the following assumptions: the decoding frame rate is 30 frames per second; the bus read delay is 35 clock periods; and the outstanding depth of the video channel is 1. According to Table 2, the bus clock frequencies needed by the video layer in offline scaling mode are rather low. Thus, any scaling ratio may be implemented physically.
In online mode, only a maximum scaling ratio of 1.73 needs to be implemented according to the principle of minimizing the data access load of the system memory. Thus, the transient bandwidth of the system memory needed by the video layer is only 1.73 times the transient bandwidth when no scaling is performed. This ratio is also in a reasonably implemented range. Table 3 lists the bus clock frequency needed by the video layer when the WXGA is displayed vertically and scaled down by 1.73 times online and the outstanding depth of the video channel is 2. Table 4 lists the bus clock frequency needed by the video layer when the WXGA is displayed horizontally and scaled down by 1.73 times online and the outstanding depth of the video channel is 2. In general, the bus read delay is within 25 clock periods. According to Table 3 and Table 4, the bus clock frequency required by the video layer within 25 clock periods is smaller than 140 MHz.
The online mode and the offline mode may also be selected or switched according to the following principle of minimizing the bus clock frequency needed by the video layer: using the offline mode to scale down the video image; using the online mode to scale up the video image. Table 5 lists the bus clock frequency needed by the video layer when the switching of the WXGA vertical playing mode is based on the principle of minimizing the bus clock frequency of the video layer and when the outstanding depth of the video channel is 2. Table 6 lists the bus clock frequency needed by the video layer when the switching of the WXGA horizontal playing mode is based on the principle of minimizing the bus clock frequency of the video layer and when the outstanding depth of the video channel is 2. In general, the bus read delay is within 25 clock periods. According to Table 5 and Table 6, the bus clock frequency required by the video layer within 25 clock periods is smaller than 81 MHz.
An embodiment of the present invention provides a display terminal. As shown in
a system memory 1101, adapted to store a video image frame;
a display controller 1102, adapted to: set the offline mode when the preset policy is met and the video layer needs to scale the video image; set the online mode when the preset policy is not met, read the video image from the system memory according to the online mode or offline mode, process the video image, and output the processed video image; and
a display 1103, adapted to display the video image processed by the display controller.
The system memory 1101 may include:
a first storing unit 11011, adapted to store decoded or collected source video images; and
a second storing unit 11012, adapted to act as the scaling video buffer used in offline mode.
The display 1103 may be an LCD or other displays.
The structure of the display controller 1102 and specific processes are shown in
With the display terminal provided in this embodiment, the source video image is scaled in a high ratio range by selecting the online mode or offline mode, thus reducing the display power consumption. In addition, the bus clock frequency and the operating clock frequency of the scaling engine are within a range that can be implemented physically.
Those skilled in the art may understand that all or part of the steps in the foregoing embodiments may be performed by hardware instructed by a program. The program may be stored in a computer readable storage medium such as a read-only memory/random access memory (ROM/RAM), a magnetic disk or a compact disk.
Although the present invention has been described through several exemplary embodiments, the invention is not limited to such embodiments. It is apparent that those skilled in the art can make various modifications and variations to the invention without departing from the spirit and scope of the invention. The invention is intended to cover the modifications and variations provided that they fall in the scope of protection defined by the following claims or their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
200910130039.4 | Apr 2009 | CN | national |