A graphics system may include a display pipe with a buffer configured to store pixels to be processed by a display controller for displaying on a display device, with a buffer control circuit coupled to the buffer to supply pixels to the display controller. When the buffer control circuit detects an underrun of the buffer responsive to the display controller attempting to read pixels from the buffer that have not yet been written to the buffer, the buffer control circuit may supply an underrun pixel to the display. The underrun pixel may be selected from a set of previously stored set of underrun pixels, which may include a most recent valid pixel read by the display controller. A read pointer representative of the location in the buffer from where the display controller is currently attempting to read may be advanced even when an underrun condition occurs. The underrun pixel may be supplied to the display controller until the underrun has been resolved, at which point the most recent valid pixel read from the buffer may be supplied to the display controller.
|
15. A system comprising:
a first-in-first-out (FIFO) buffer configured to store pixels to be displayed on a display device by a display controller;
a processing circuit configured to write the pixels into the FIFO buffer at a first clock rate;
a display controller configured to read the pixels from the FIFO buffer at a second clock rate different from the first clock rate;
a register configured to store an underrun pixel; and
selection logic circuitry configured to receive an indication of whether a currently read pixel is an invalid pixel or a valid pixel, and further configured to selectively provide to the display controller, based on the received indication:
the underrun pixel from the register when the indication is that the currently read pixel is an invalid pixel; and
the currently read pixel when the indication is that the currently read pixel is a valid pixel.
1. A display pipe comprising:
a buffer configured to store pixels to be displayed on a display device by a display controller; and
a buffer control circuit coupled to the buffer, and configured to:
detect an underrun of the buffer in response to a position of a read pointer to the buffer overtaking a position of a write pointer to the buffer, wherein the position of the read pointer overtaking the position of the write pointer comprises the read pointer pointing to a location in the buffer that has not yet been written with a new pixel value expected by the display controller, wherein the read pointer points to a location in the buffer from where a pixel is currently being read and the write pointer points to a location in the buffer that is currently being filled; and
supply an underrun pixel to the display controller from a location other than the location in the buffer, in response to detecting the underrun.
8. A method for providing pixels to be displayed on a display device, the method comprising:
writing, into respective locations in a buffer, pixels to be displayed on a display device, comprising writing the pixels in a specified order;
reading pixels from the respective locations in the buffer in the specified order the pixels were written into the respective locations in the buffer; and
supplying to a display controller, from a location other than a respective location in the buffer, a proxy pixel to be displayed on the display device, wherein supplying the proxy pixel is in response to the reading comprising:
a read pointer to the buffer overtaking a position of a write pointer to the buffer, wherein the position of the read pointer overtaking the position of the write pointer comprises the read pointer pointing to a location in the buffer that has not yet been written with a new pixel value expected by the display controller;
wherein the read pointer points to a location in the buffer from where a pixel is currently being read and the write pointer points to a location in the buffer that is currently being filled.
2. The display pipe of
3. The display pipe of
a register configured to store the underrun pixel; and
selection logic coupled the register, and configured to selectively provide to the display controller:
a most recently read pixel from the buffer, except when the underrun is detected; and
the underrun pixel when an underrun is detected.
4. The display pipe of
5. The display pipe of
6. The display pipe of
7. The display pipe of
9. The method of
providing a valid pixel to the display controller for displaying the valid pixel on the display device, responsive to the reading returning the valid pixel.
10. The method of
11. The method of
continuously supplying the proxy pixel to the display controller until the reading returns a valid pixel; and
subsequent to the reading returning the valid pixel, supplying the valid pixel to the display controller.
12. The method of
13. The method of
14. The method of
wherein supplying the proxy pixel from the register comprises supplying the most recently read valid pixel stored in the register.
16. The system of
17. The system of
18. The system of
19. The system of
make a determination whether the currently read pixel is an invalid pixel or a valid pixel based on:
a location of the currently read pixel in the FIFO buffer; and
a location in the FIFO buffer that was most recently written by the processing circuit; and
generate the indication based on the determination.
20. The system of
track:
a read pointer pointing to a current read location in the FIFO buffer from where the display controller is attempting to read; and
a write pointer pointing to a current write location in the FIFO buffer where the processing circuit is attempting to write; and
detect when the display controller is attempting to read from a location in the FIFO buffer that does not contain a valid pixel, wherein to detect when the display controller is attempting to read from a location in the FIFO buffer that does not contain a valid pixel, the control circuitry is further configured to compare a value of the read pointer with a value of the write pointer.
|
This application is a divisional of U.S. patent application Ser. No. 12/685,171, filed Jan. 11, 2010, which is incorporated by reference herein in its entirety.
1. Field of the Invention
This invention is related to the field of graphical information processing, more particularly, to reading and writing registers that store image frame descriptors.
2. Description of the Related Art
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), to display images, video information/streams, and data. Accordingly, these systems typically incorporate functionality for generating images and data, including 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 typically consists of a specified number of pixels according to the resolution of the image/video frame. Most graphics systems use frame buffers to store the pixels for image and video frame information. The term “frame buffer” therefore often denotes the actual memory used to hold picture/video frames. The information in a frame buffer 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 total amount of the memory required for frame buffers to store image/video information depends on the resolution of the output signal, and on the color depth and palette size.
The frame buffers can be situated in memory elements dedicated to store image and video information, or they can be situated in the system memory. Consequently, system memory may be used to store a set of pixel data that defines an image and/or video stream for display on a display device. Applications running in such a system can write the pixel data into the system memory, from where the pixel data may be obtained by a graphics processing system to generate a set of image/video signals for generating the image on the display device. Typically, the image/video signals are generated through a display controller, which can be set up to receive the image/video pixels from the graphics processing system. While under normal circumstances the image/video pixels are provided to the display controller at a sufficiently high rate to continuously display the current (expected) image/video frame, there may be cases when, for a variety of reasons, the pixels expected by the display controller are not yet available to the display controller. It is helpful to have some mechanism in place to handle such cases in order to maintain uninterrupted display of image/video information.
In one set of embodiments, the display pipe in a graphics system may feature an output buffer for storing pixels, which may be continuously read by a display controller for displaying on a display device. If the display controller pops pixels from the output buffer before those pixels are written by the display pipe, then a buffer underrun occurs. The output buffer may increment the read pointer for each underrun pop, so that when the display pipe catches up, the correct pixels will be displayed after the underrun is corrected. Various modes may be supported for the underrun pixels. A first mode may include outputting the most recent valid pixel, which may provide a “closest to correct” solution that may minimize the visual effect of the underrun. A second mode may include outputting a “stuck pixel” (which may be programmed) for the underrun pixels, which may be useful for debug as the underrun pixels may be visually obvious. A third mode may include outputting the stuck pixels for the rest of the current frame, even if the underrun is eventually corrected. A fourth mode may include outputting the stuck pixel for the rest of the frames, even if the underrun is eventually corrected.
In one set of embodiments, a display pipe may include a buffer configured to store pixels to be displayed by a display controller, and a buffer control circuit coupled to the buffer. The buffer control circuit may detect an underrun of the buffer responsive to the display controller attempting to read pixels from the buffer that have not yet been written to the buffer, and supply an underrun pixel to the display controller in response to detecting the underrun. In one embodiment, the underrun pixel is a most recent valid pixel read by the display controller. The buffer control circuit may include a register to store the underrun pixel, and may further include selection logic coupled the register, to selectively provide to the display controller a most recently read pixel from the buffer, except when an underrun is detected, in which case the selection logic may provide the underrun pixel to the display controller. The register may store the most recently read valid pixel as the underrun pixel, or it may store a pixel loaded from memory to serve as the underrun pixel.
In another set of embodiments, a graphics system may include an output buffer configured to store pixels to be displayed on a display device, and a processing unit configured to write the pixels into the output buffer at a first clock rate. The graphics system may also include a display controller to read the pixels from the output buffer at a second clock rate different from the first clock rate, and a control element for detecting when the display controller is attempting to read from a location in the output buffer that does not contain a valid pixel. When that happens, the control element may cause a specified pixel to be supplied to the display controller from a location other than the location in the output buffer from where the display controller was attempting to read. In one embodiment, the processing unit writes the pixels into the output buffer in a specified order, and the display controller reads the pixels from the output buffer in the same specified order in which the pixels were written into the output buffer. A location in the output buffer may be said to not contain a valid pixel, if the display controller is attempting to read from that location before the processing unit has written that location according to the specified order.
In one set of embodiments, the control element may track a read pointer pointing to a current read location in the output buffer from where the display controller is attempting to read, and may also track a write pointer pointing to a current write location of the output buffer that the processing unit is attempting to write. The control element may compare the value of the read pointer with the value of the write pointer to detect when the display controller is attempting to read from a location in the output buffer that does not contain a valid pixel. The graphics system may continue to move the read pointer forward even in the event the control element has detected that the display controller is attempting to read from a location in the output buffer that does not contain a valid pixel. The control element may also cause the specified pixel to be supplied to the display controller until the display controller is attempting to read from a location in the output buffer that contains a valid pixel, at which point the control element may allow the valid pixel to be read and provided to the display controller.
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.
Turning now to
SIU 106 may be an interconnect over which the memory controller 104, peripheral components NIC 110 and VPU 116, processor 114 (through L2 cache 112), L2 cache 112, and CDMA controller 124 may communicate. SIU 106 may implement any type of interconnect (e.g. a bus, a packet interface, point to point links, etc.). SIU 106 may be a hierarchy of interconnects, in some embodiments. CDMA controller 124 may be configured to perform DMA operations between memory 102 and/or various peripheral components 126-132. NIC 110 and VPU 116 may be coupled to SIU 106 directly and may perform their own data transfers to/from memory 102, as needed. NIC 110 and VPU 116 may include their own DMA controllers, for example. In other embodiments, NIC 110 and VPU 116 may also perform transfers through CDMA controller 124. Various embodiments may include any number of peripheral components coupled through the CDMA controller 124 and/or directly to the SIU 106. DCU 118 may include a display control unit (CLDC) 120 and buffers/registers 122. CLDC 120 may provide image/video data to a display, such as a liquid crystal display (LCD), for example. DCU 118 may receive the image/video data from VPU 116, which may obtain image/video frame information from memory 102 as required, to produce the image/video data for display, provided to DCU 118.
Processor 114 (and more particularly, instructions executed by processor 114) may program CDMA controller 124 to perform DMA operations. Various embodiments may program CDMA controller 124 in various ways. For example, DMA descriptors may be written to the memory 102, describing the DMA operations to be performed, and CDMA controller 124 may include registers that are programmable to locate the DMA descriptors in the memory 102. The DMA descriptors may include data indicating the source and target of the DMA operation, where the DMA operation transfers data from the source to the target. The size of the DMA transfer (e.g. number of bytes) may be indicated in the descriptor. Termination handling (e.g. interrupt the processor, write the descriptor to indicate termination, etc.) may be specified in the descriptor. Multiple descriptors may be created for a DMA channel, and the DMA operations described in the descriptors may be performed as specified. Alternatively, the CDMA controller 124 may include registers that are programmable to describe the DMA operations to be performed, and programming the CDMA controller 124 may include writing the registers.
Generally, a DMA operation may be a transfer of data from a source to a target that is performed by hardware separate from a processor that executes instructions. The hardware may be programmed using instructions executed by the processor, but the transfer itself is performed by the hardware independent of instruction execution in the processor. At least one of the source and target may be a memory. The memory may be the system memory (e.g. the memory 102), or may be an internal memory in the integrated circuit 103, in some embodiments. For example, a peripheral component 126-132 may include a memory that may be a source or target. In the illustrated embodiment, peripheral component 132 includes the ROM 142 that may be a source of a DMA operation. Some DMA operations may have memory as a source and a target (e.g. a first memory region in memory 102 may store the data to be transferred and a second memory region may be the target to which the data may be transferred). Such DMA operations may be referred to as “memory-to-memory” DMA operations or copy operations. Other DMA operations may have a peripheral component as a source or target. The peripheral component may be coupled to an external interface on which the DMA data is to be transferred or on which the DMA data is to be received. For example, peripheral components 130 and 132 may be coupled to interfaces onto which DMA data is to be transferred or on which the DMA data is to be received.
CDMA controller 124 may support multiple DMA channels. Each DMA channel may be programmable to perform a DMA via a descriptor, and the DMA operations on the DMA channels may proceed in parallel. Generally, a DMA channel may be a logical transfer path from a source to a target. Each channel may be logically independent of other DMA channels. That is, the transfer of data on one channel may not logically depend on the transfer of data on another channel. If two or more DMA channels are programmed with DMA operations, CDMA controller 124 may be configured to perform the transfers concurrently. For example, CDMA controller 124 may alternate reading portions of the data from the source of each DMA operation and writing the portions to the targets. CDMA controller 124 may transfer a cache block of data at a time, alternating channels between cache blocks, or may transfer other sizes such as a word (e.g. 4 bytes or 8 bytes) at a time and alternate between words. Any mechanism for supporting multiple DMA operations proceeding concurrently may be used.
CDMA controller 124 may include buffers to store data that is being transferred from a source to a destination, although the buffers may only be used for transitory storage. Thus, a DMA operation may include CDMA controller 124 reading data from the source and writing data to the destination. The data may thus flow through the CDMA controller 124 as part of the DMA operation. Particularly, DMA data for a DMA read from memory 124 may flow through memory controller 104, over SIU 106, through CDMA controller 124, to peripheral components 126-132, NIC 110, and VPU 116 (and possibly on the interface to which the peripheral component is coupled, if applicable). Data for a DMA write to memory may flow in the opposite direction. DMA read/write operations to internal memories may flow from peripheral components 126-132, NIC 110, and VPU 116 over SIU 106 as needed, through CDMA controller 124, to the other peripheral components (including NIC 110 and VPU 116) that may be involved in the DMA operation.
In one embodiment, instructions executed by the processor 114 may also communicate with one or more of peripheral components 126-132, NIC 110, VPU 116, and/or the various memories such as memory 102, or ROM 142 using read and/or write operations referred to as programmed input/output (PIO) operations. The PIO operations may have an address that is mapped by integrated circuit 103 to a peripheral component 126-132, NIC 110, or VPU 116 (and more particularly, to a register or other readable/writeable resource, such as ROM 142 or Registers 138 in the component, for example). It should also be noted, that while not explicitly shown in
In one embodiment, PIO operations may use the same interconnect as CDMA controller 124, and may flow through CDMA controller 124, for peripheral components that are coupled to CDMA controller 124. Thus, a PIO operation may be issued by processor 114 onto SIU 106 (through L2 cache 112, in this embodiment), to CDMA controller 124, and to the targeted peripheral component. Alternatively, the peripheral components 126-132 may be coupled to SIU 106 (much like NIC 110 and VPU 116) for PIO communications. PIO operations to peripheral components 126-132 may flow to the components directly from SIU 106 (i.e. not through CDMA controller 124) in one embodiment.
Generally, a peripheral component may comprise any desired circuitry to be included on integrated circuit 103 with the processor. A peripheral component may have a defined functionality and interface by which other components of integrated circuit 103 may communicate with the peripheral component. For example, a peripheral component such as VPU 116 may include video components such as a display pipe, which may include graphics processors, and a peripheral such as DCU 118 may include other video components such as display controller circuitry. NIC 110 may include networking components such as an Ethernet media access controller (MAC) or a wireless fidelity (WiFi) controller. Other peripherals may include audio components such as digital signal processors, mixers, etc., controllers to communicate on various interfaces such as universal serial bus (USB), peripheral component interconnect (PCI) or its variants such as PCI express (PCIe), serial peripheral interface (SPI), flash memory interface, etc.
As mentioned previously, one or more of the peripheral components 126-132, NIC 110 and VPU 116 may include registers (e.g. registers 138-140 as shown, but also registers, not shown, in NIC 110 and/or within VPU 116) that may be addressable via PIO operations. The registers may include configuration registers that configure programmable options of the peripheral components (e.g. programmable options for video and image processing in VPU 116), status registers that may be read to indicate status of the peripheral components, etc. Similarly, peripheral components may include memories such as ROM 142. ROMs may store data used by the peripheral that does not change, code to be executed by an embedded processor within the peripheral component 126-132, etc.
Memory controller 104 may be configured to receive memory requests from system interface unit 106. Memory controller 104 may be configured to access memory to complete the requests (writing received data to the memory for a write request, or providing data from memory 102 in response to a read request) using the interface defined the attached memory 102. Memory controller 104 may be configured to interface with any type of memory 102, such as dynamic random access memory (DRAM), synchronous DRAM (SDRAM), double data rate (DDR, DDR2, DDR3, etc.) SDRAM, Low Power DDR2 (LPDDR2) SDRAM, RAMBUS DRAM (RDRAM), static RAM (SRAM), etc. The memory may be arranged as multiple banks of memory, such as dual inline memory modules (DIMMs), single inline memory modules (SIMMs), etc. In one embodiment, one or more memory chips are attached to the integrated circuit 10 in a package on package (POP) or chip-on-chip (COC) configuration.
It is noted that other embodiments may include other combinations of components, including subsets or supersets of the components shown in
Turning now to
In one set of embodiments, UI 214 and 216 may include one or more registers programmable to define frame parameters such as base address, frame size, active regions of frames, and other parameters for the frames that may be stored in buffers 208 and 210. Active regions may represent those regions within an image frame that contain pixels that are to be displayed, while pixels outside of the active region of the frame are not to be displayed. In order to reduce the number of accesses that may be required to fetch pixels from frame buffers 208 and 210, when fetching frames from memory 202 (more specifically from frame buffers 208 and 210), UI 214 and 216 may fetch only those pixels of any given frame that are within the active regions of the frame, as defined by the contents of the registers within UI 214 and 216. The pixels outside the active regions of the frame may be considered to have an alpha value corresponding to a blend value of zero. In other words, pixels outside the active regions of a frame may automatically be treated as being transparent, or having an opacity of zero, thus having no effect on the resulting display frame. Consequently, the fetched pixels may be blended with pixels from other frames, and/or from processed video frame or frames provided by video pipe 220 to blend unit 218.
Turning now to
Display pipe 300 may be designed to fetch data from memory, process that data, then presents it to an external display controller through an asynchronous FIFO 320. 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 display pipe 300 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 output FIFO 320, the display controller may issue signals (referred to as pop signals) to remove the pixels at the display controller's clock frequency (indicated as vclk in
In the embodiment shown in
Blend unit 310 may be situated at the backend of display pipe 300 as shown in
In one set of embodiments, the buffer underrun may be handled by always capturing a last read valid pixel, (in other words, a most recently read valid pixel), and storing it in a memory module (e.g. a register) 404, from where it may be provided to display controller 402 to be displayed until the next valid pixel is made available to display controller 402. That is, the underrun pixel may be provided to display controller 402 until WP is again ahead of RP, ensuring that display controller has access to a current valid pixel. It should be noted that as used herein, “valid pixel” refers to a pixel at a location in output FIFO 320 that was expected to be written and has been written before the RP points to that location. It should also be noted that in the diagram show in
In some embodiments, register 404 may also be loaded with a specified pixel value from memory, which may be used during certain test cases for example, or possibly during debug. This is indicated 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.
Bratt, Joseph P., Millet, Timothy J., Holland, Peter F., Tripathi, Brijesh, Choo, Shing Horng
Patent | Priority | Assignee | Title |
10095408, | Mar 10 2017 | Microsoft Technology Licensing, LLC | Reducing negative effects of insufficient data throughput for real-time processing |
10410575, | Jul 19 2017 | Apple Inc. | Adjustable underrun outputs |
10789877, | Jul 19 2017 | Apple Inc. | Adjustable underrun outputs |
Patent | Priority | Assignee | Title |
6489956, | Feb 17 1998 | Oracle America, Inc | Graphics system having a super-sampled sample buffer with generation of output pixels using selective adjustment of filtering for implementation of display effects |
6496186, | Feb 17 1998 | Oracle America, Inc | Graphics system having a super-sampled sample buffer with generation of output pixels using selective adjustment of filtering for reduced artifacts |
6525723, | Feb 17 1998 | Oracle America, Inc | Graphics system which renders samples into a sample buffer and generates pixels in response to stored samples at different rates |
7202870, | Apr 01 2002 | MEDIATEK INC | Display controller provided with dynamic output clock |
20080165268, | |||
20100073388, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 24 2014 | Apple Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
May 24 2016 | ASPN: Payor Number Assigned. |
Oct 24 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 01 2024 | REM: Maintenance Fee Reminder Mailed. |
Jun 17 2024 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
May 10 2019 | 4 years fee payment window open |
Nov 10 2019 | 6 months grace period start (w surcharge) |
May 10 2020 | patent expiry (for year 4) |
May 10 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 10 2023 | 8 years fee payment window open |
Nov 10 2023 | 6 months grace period start (w surcharge) |
May 10 2024 | patent expiry (for year 8) |
May 10 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 10 2027 | 12 years fee payment window open |
Nov 10 2027 | 6 months grace period start (w surcharge) |
May 10 2028 | patent expiry (for year 12) |
May 10 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |