A display system typically includes a screen that displays video rendered by a processor such as a graphics processing unit (GPU) and provided to the screen in a stream of frames. The display video timing is determined by a frame rate (or refresh rate), a number of pixels per line in the frame (HTotal), a number of lines per frame (VTotal), and a pixel clock rate (PClk) that is equal to the product of the refresh rate, the number of pixels per line, and the number of lines per frame. The number of pixels per line includes a horizontal active region that includes pixel values used to generate images and a horizontal blanking region that conveys other information such as digital audio or metadata. Thus, the total number of pixels per line is equal to a sum of the pixels in the horizontal active region and the pixels in the horizontal blanking region. The number of lines per frame includes a vertical active region that includes pixel values and a vertical blanking region that conveys other information such as digital audio or metadata. Thus, the total number of lines per frame is equal to a sum of the lines in the vertical active region and the lines in the vertical blanking region. For example, a high definition frame can represent an image using 1080 active vertical lines that include values of the pixels and 45 vertical blanking lines. A line rate for the frame is defined as the pixel clock rate divided by the number of pixels per line or, equivalently, as the product of the refresh rate and the number of lines per frame.
The present disclosure is better understood, and its numerous features and advantages made apparent to those skilled in the art by referencing the accompanying drawings. The use of the same reference symbols in different drawings indicates similar or identical items.
A source (e.g., a GPU or other processor) provides frames at a refresh rate that is determined by source timing. The timing of the display system is synchronized to the source timing. For example, the source can provide frames at 60 Hertz (Hz) and the display system can read/display the frames at 60 Hz at times that are synchronized to the GPU. However, video is captured or generated at different refresh rates by different sources. For example, video is typically rendered at 50 Hz in some geographical regions such as Europe and Japan, while video is rendered at 60 Hz in another geographical region such as North America. Display systems therefore implement variable refresh rates to allow the refresh rate to change from, for example, 50 Hz to 60 Hz and vice versa. The source and display systems that implement variable refresh rates typically use the same pixel clock rate and the same number of pixels per line for the different refresh rates. The number of lines per frame therefore changes in response to the changing refresh rate to preserve the fixed pixel clock rate and number of pixels per line, that is, to maintain a constant line rate. The change in the number of lines per frame is determined by the ratio of the refresh rates and so the change in the refresh rate from a first refresh rate to a second refresh rate typically leads to a fractional number of lines per frame at the second refresh rate. Display systems account for the fractional line rate using techniques including rounding the fractional number of lines per frame up or down (corresponding to a refresh rate that is higher or lower than the target refresh rate) or dithering between integer values of the number of lines per frame for even/odd frames. Furthermore, display systems perform a mode reset in response to detecting a change in the refresh rate or number of lines per frame, which causes display interruptions of up to a few seconds.
The processing system 100 includes at least one central processing unit (CPU) 115. Some embodiments of the CPU 115 include multiple processing elements (not shown in
An input/output (I/O) engine 125 handles input or output operations associated with a display system 130, as well as other elements of the processing system 100 such as keyboards, mice, printers, external disks, and the like. The display system 130 supports a variable refresh rate so that the display system 130 can present frames at refresh rates within a range up to a maximum refresh rate. For example, the display system 130 can support refresh rates of 24 Hz, 25 Hz, 30 Hz, 50 Hz, 60 Hz, 100 Hz, and 120 Hz. The variable refresh rate corresponds to a variable vertical blanking region, which is within a range beginning at a minimum vertical blanking region that corresponds to the maximum refresh rate of the display system 130. In some embodiments, the refresh rates are determined by querying the display system 130 its Enhanced Extended Display Identification Data (E-EDID) and determining the refresh rates from the EDID reply. The I/O engine 125 is coupled to the bus 110 so that the I/O engine 125 communicates with the memory 105, the CPU 115, or other entities that are connected to the bus 110. In the illustrated embodiment, the I/O engine 125 reads information stored on an external storage component 135, which is implemented using a non-transitory computer readable medium such as a compact disk (CD), a digital video disc (DVD), and the like. The I/O engine 125 also writes information to the external storage component 135, such as the results of processing by the CPU 115.
The processing system 100 includes at least one GPU 140 that renders images for presentation by the display system 130. For example, the GPU 140 renders objects to produce values of pixels that are provided to the display system 130, which uses the pixel values to display an image that represents the rendered objects. The GPU 140 includes one or more processing elements such as an array 142 of compute units that execute instructions concurrently or in parallel. Some embodiments of the GPU 140 are used for general purpose computing. In the illustrated embodiment, the GPU 140 communicates with the memory 105 (and other entities that are connected to the bus 110) over the bus 110. However, some embodiments of the GPU 140 communicate with the memory 105 over a direct connection or via other buses, bridges, switches, routers, and the like. The GPU 140 executes instructions stored in the memory 105 and the GPU 140 stores information in the memory 105 such as the results of the executed instructions. For example, the memory 105 stores a copy 145 of instructions that represent a program code that is to be executed by the GPU 140. The GPU 140 also includes a timing reference 144.
The GPU 140 generates a stream of frames that is provided to the display system 130. Some embodiments of the display system 130 include a buffer 150 that stores the frames in the stream received from the GPU 140. The display system 130 also includes a display controller 152 that reads out the pixel values in the frames from the buffer 150 and uses the values to display an image on (or present an image to) a screen 154. The display controller 152 provides the frames via a display interface 153 (such as an HDMI or DisplayPort interface) configured to couple to the screen 154. The display system 130 also includes a timing reference 156, which is synchronized to the GPU timing reference 144 during normal operation. For example, the GPU 140 can generate frames at 60 Hz and provide the frames to the display system 130, which displays or presents the frames on the screen 154 at 60 Hz. Some embodiments of the timing reference 156 are implemented in a timing controller (TCON) chip 157, e.g., as an application-specific integrated circuit (ASIC) or other circuit, which also performs timing and synchronization operations for the display system 130, as discussed herein. The display system 130 also includes a monitor scaler 158 that scales information in the frames received from the GPU 140 to the pixel density of the screen 154.
The frames generated by the GPU 140 and displayed by the display system 130 are characterized by a number of pixels per line in the frame (HTotal), a number of lines per frame (VTotal), and a pixel clock rate (PClk) that is equal to the product of the refresh rate, the number of pixels per line, and the number of lines per frame. A line rate for the frame is defined as the pixel clock rate divided by the number of pixels per line or, equivalently, as the product of the refresh rate and the number of lines per frame. The refresh rates used by the GPU 140 and the display system 130 are factored into a corresponding plurality of prime factors. For example, a frame rate of 50 Hz has the prime factors (5, 2) and a frame rate of 60 Hz as the prime factors (2, 3, 5). Numbers of lines per frame in the frames provided by the GPU 140 at the multiple refresh rates is determined based on ratios of the refresh rates, the prime factors of the refresh rates, and a common line rate for providing frames to the display system at the different refresh rates. The GPU 140 provides frames to the display system 130 at a selected one of the refresh rates using the same line rate regardless of which refresh rate is chosen. Furthermore, the line rate is an integer for frames provided at the refresh rates.
The frame 200 is partitioned into lines 201 (only one indicated by a reference numeral in the interest of clarity) of pixels 202 (only one indicated by a reference numeral in the interest of clarity). Each line 201 includes a number 205 of pixels per line (HTotal). The number 205 of pixels per line includes a horizontal active region 210 that includes pixel values used to generate images (as indicated by the open boxes) and a horizontal blanking region 215 that conveys other information such as digital audio or metadata (as indicated by the hatched boxes). The frame 200 also includes a number 220 of lines per frame (VTotal). The number 220 of lines per frame includes a vertical active region 225 that includes pixel values (as indicated by the open boxes) and a vertical blanking region 230 that conveys other information such as digital audio or metadata (as indicated by the hatched boxes). Thus, the total number 220 of lines per frame is equal to a sum of the lines in the vertical active region 225 and the lines in the vertical blanking region 230. For example, a high definition frame can represent an image using 1080 active vertical lines that include values of the pixels and 45 vertical blanking lines.
The GPU provides the frame 200 (and the display system presents the frame 200) at a refresh rate. The frame 200 is therefore characterized by a pixel clock rate (PClk) that is equal to the product of the refresh rate, the number 205 of pixels per line, and the number 220 of lines per frame. A line rate for the frame 200 is defined as the pixel clock rate divided by the number 205 of pixels per line or, equivalently, as the product of the refresh rate and the number 220 of lines per frame.
The display system that presents the frame 200 supports variable refresh rates. The GPU therefore renders the frame 200 at different refresh rates corresponding to the variable refresh rates supported by the display system. The characteristics of the frame 200 are modified based on the variable refresh rate used to render the frame 200 and presented the frame 200 at the display system. The number 220 of lines per frame that are included in the frame 200 for the different refresh rates is determined based on ratios of the refresh rates, the prime factors of the refresh rates, and a common line rate for providing frames to the display system at the different refresh rates. For example, if the display system supports refresh rates of 50 Hz and 60 Hz, the ratio of the supported refresh rates is 5/6. The numbers 220 of lines per frame used at the different refresh rates are therefore chosen to have prime factors corresponding to the ratio of the supported refresh rates. For example, the number 220 for the frame 200 is chosen to be:
2250=21*32*53 at 60 Hz
and the number 220 for the frame 200 is chosen to be:
Thus, the number 220 is a whole number for both refresh rates and the frame 200 has a common line rate for both refresh rates:
2250*60=2700*50=135 kHz
In some embodiments, the parameters of the frame 200 are chosen to provide a common line rate over a larger range of refresh rates. For example, if a frame rate set supported by the display system includes the refresh rates 24 Hz, 25 Hz, and 30 Hz, the ratios of the refresh rates are:
The number 220 of lines in the frame 200 for the refresh rate of 30 Hz is chosen to have prime factors (5, 4=22) so that the frame 200 is generated at 24 Hz and 25 Hz using the same line rate and pixel clock as the frame 200 at 30 Hz. In that case, the numbers 220 of lines for the different refresh rates is:
The numbers 220 of lines in the frame 200 at the different refresh rates (VTotal24, VTotal25, VTotal30) are all whole numbers because the values of the refresh rates have prime factors (5, 4=22). For example, the numbers 220 can have the values:
VTotal30=2200=23*52*111
The frames 200 having the above numbers 220 of lines also have the same line rates:
2200*30=2640*25=2750*24=66 kHz
Although the examples discussed above include two and three different refresh rates, some embodiments of these techniques are applied to larger sets of refresh rates. Moreover, other prime factors can also be used, including, but not limited to, the prime factors 7, 11, and 13.
In some embodiments, the number 220 of lines is constrained to be above a minimum number of lines. For example, the pixels in the vertical blanking region 230 can be used to convey audio information. The minimum number of lines can therefore be set based on a required (or minimum) audio bandwidth per line or per frame. In some embodiments, the number 205 of pixels per line is constrained by the required audio bandwidth or other overhead requirements. In some embodiments, the pixel rate for the frame 200 is constrained based on parameters defined in a timing descriptor. For example, an 18-byte detailed timing descriptor (DTD) structure defined in Enhanced Extended Display Identification Data (E-EDID) allows pixel rates to be specified in terms of 10 kilo-pixels per second (kPix/s), e.g., within a range of 0.01 MPix/s to 655.35 MPix/s. For another example, a 20-byte DTD structure defined in E-EDID allows pixel rates to be specified in terms of 1 kPix/s, e.g., within a range of 0.001 MPix/s to 16777.216 MPix/s.
At block 310, the processing system determines a ratio between a first refresh rate and a second refresh rate supported by the display system. For example, as discussed herein, the ratio between a 50 Hz refresh rate and a 60 Hz refresh rate is 5/6.
At block 315, the processing system determines prime factors of the refresh rates. For example, the prime factors of the 50 Hz refresh rate are (5, 2) and the prime factors of the 60 Hz refresh rate are (5, 3, 2).
At block 320, the processing system determines a first number of lines per frame for frames provided at the first refresh rate and a second number of lines per frame for frames provided at the second refresh rate. The first and second numbers of lines per frame are determined based on the ratio of refresh rates and the prime factors. For example, the first number of lines per frame is selected to have a value that shares one or more prime factors with the second refresh rate and the second number of lines per frame is selected to have a value that shares one or more prime factors with the first refresh rate. Thus, the first and second numbers of lines per frame are whole numbers and produce the same line rate. The first and second numbers of lines per frame are also determined so that the line rates of the frames having the first and second numbers of lines per frames are both equal to the common line rate.
At block 405, a processing unit such as a GPU is rendering frames at a first refresh rate and providing the frames to a display system. The display system is a variable refresh rate system and the first refresh rate is one of a set of refresh rates that is supported by the display system. As discussed herein, the frames initially include a first number of lines per frame that is determined based on one or more ratios of the refresh rates in the set supported by the display system, prime factors of the refresh rates, and a common line rate for providing frames to the display system at all the refresh rates in the set.
At decision block 410, the processing unit and the display system determine whether there is been a change in refresh rate. If not, the method 400 continues to monitor for changes in the refresh rate. If a change in the refresh rate is detected, the method 400 flows to block 415.
At block 415, the processing unit provides frames having a second number of lines per frame. The processing unit renders the frames at a second refresh rate that differs from the first refresh rate. The second number of lines per frame is determined based on the second refresh rate and the line rate, as discussed herein.
At block 420, the processing unit provides the frames to the display unit, which presents or displays the frames at the second refresh rate. The first and second numbers of lines per frame in the frames transmitted at the first and second refresh rates are determined based on one or more ratios of the refresh rates, the prime factors of the refresh rates, and the common line rate. The line rates are therefore whole numbers and the display system does not need to account for fractional line rates. Furthermore, the display system does not perform a mode reset in response to detecting a change in the refresh rate or number of lines per frame.
A computer readable storage medium may include any non-transitory storage medium, or combination of non-transitory storage media, accessible by a computer system during use to provide instructions and/or data to the computer system. Such storage media can include, but is not limited to, optical media (e.g., compact disc (CD), digital versatile disc (DVD), Blu-Ray disc), magnetic media (e.g., floppy disc, magnetic tape, or magnetic hard drive), volatile memory (e.g., random access memory (RAM) or cache), non-volatile memory (e.g., read-only memory (ROM) or Flash memory), or microelectromechanical systems (MEMS)-based storage media. The computer readable storage medium may be embedded in the computing system (e.g., system RAM or ROM), fixedly attached to the computing system (e.g., a magnetic hard drive), removably attached to the computing system (e.g., an optical disc or Universal Serial Bus (USB)-based Flash memory), or coupled to the computer system via a wired or wireless network (e.g., network accessible storage (NAS)).
In some embodiments, certain aspects of the techniques described above may implemented by one or more processors of a processing system executing software. The software includes one or more sets of executable instructions stored or otherwise tangibly embodied on a non-transitory computer readable storage medium. The software can include the instructions and certain data that, when executed by the one or more processors, manipulate the one or more processors to perform one or more aspects of the techniques described above. The non-transitory computer readable storage medium can include, for example, a magnetic or optical disk storage device, solid state storage devices such as Flash memory, a cache, random access memory (RAM) or other non-volatile memory device or devices, and the like. The executable instructions stored on the non-transitory computer readable storage medium may be in source code, assembly language code, object code, or other instruction format that is interpreted or otherwise executable by one or more processors.
Note that not all of the activities or elements described above in the general description are required, that a portion of a specific activity or device may not be required, and that one or more further activities may be performed, or elements included, in addition to those described. Still further, the order in which activities are listed are not necessarily the order in which they are performed. Also, the concepts have been described with reference to specific embodiments. However, one of ordinary skill in the art appreciates that various modifications and changes can be made without departing from the scope of the present disclosure as set forth in the claims below. Accordingly, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of the present disclosure.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any feature(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature of any or all the claims. Moreover, the particular embodiments disclosed above are illustrative only, as the disclosed subject matter may be modified and practiced in different but equivalent manners apparent to those skilled in the art having the benefit of the teachings herein. No limitations are intended to the details of construction or design herein shown, other than as described in the claims below. It is therefore evident that the particular embodiments disclosed above may be altered or modified and all such variations are considered within the scope of the disclosed subject matter. Accordingly, the protection sought herein is as set forth in the claims below.
Number | Date | Country | |
---|---|---|---|
Parent | 17030659 | Sep 2020 | US |
Child | 18108251 | US |