The present invention relates to graphics display systems, and more particularly to a graphics controller, for use in a graphics display system, having a single display interface for supporting two or more display devices.
Graphics display systems typically employ a graphics controller as an interface between a graphics display device and one or more providers of image data. Commonly, in a graphics display system the providers of image data are a host and a camera. The host and camera each transmit image data to the graphics controller, and the graphics controller then transmits image data to the display device.
Generally, the graphics controller includes an internal memory for storing the image data it receives. Before transmitting image data to the display device, the graphics controller processes the image data. For example, the graphics controller may compress or decompress image data. In addition, the graphics controller may crop, resize, scale, and color convert the image data according to one of a number of alternative color conversion schemes.
Mobile telephones and other portable graphics display systems may have two or more display devices, such as, for example, a main display and an auxiliary display. The main display is used for displaying image data from the camera, the host, or both. The auxiliary panel is used for displaying image data provided by the host. The main display has a display screen that is typically larger than the display screen of the auxiliary display. Camera images and video game graphics are displayed, for example, on the main display while the auxiliary panel is used for displaying image data, such as time, date, and the telephone number of an incoming caller.
In graphics display systems which have two or more display devices, it is generally a requirement for the graphics controller to have a display interface for each display. The reason for this requirement is to prevents conflicts between the sources. For example, the host can transmit image data to the auxiliary panel using one display interface while the camera can simultaneously transmit image data to the main panel using the other display interface without there ever being a conflict over the use of a single display interface.
In battery-powered portable graphics display systems, however, there is an ever present need to minimize power consumption. Further, there is a need to minimize the size of the graphics controller integrated circuit (“IC”). A graphics controller that could use a single display interface to support two or more display panels would be desirable to help achieve these goals.
One method for preventing conflicts when two sources of image data simultaneously want to transfer data over a single display interface is to add a memory to the graphics controller for temporarily buffering the data of one of the sources. However, the advantage of not having to use two display interfaces tends to be offset by the disadvantage of increasing memory requirements.
Accordingly, a graphics controller that uses a single display interface to support two or more display devices is needed.
The invention, in one preferred embodiment, is directed to a method for fetching image data from a memory for transmission on a data bus to at least two display devices. First portions of a first frame are fetched at a non-interleaving fetch rate in response to receiving a first signal. Second portions of a second frame are fetched at the non-interleaving fetch rate in response to receiving a second signal. The timing of the first and second signals are asynchronous to one another. The non-interleaving fetch rate is adjusted to an interleaving fetch rate in response to performing fetching the second portions.
In another preferred embodiment, the invention is directed to a graphics controller for fetching image data for transmission on a data bus to at least two display devices in response to receiving respective signals for each of the display devices. At least one of the signals is generated asynchronously to the other signals. The graphics controller comprises a memory for storing first and second frames of image data, a display interface for fetching first portions of a first frame at a non-interleaving fetch rate in response to detection a first signal, and fetching second portions of a second frame at the non-interleaving fetch rate in response to detection of a second signal, and a rate controller for adjusting the non-interleaving fetch rate to an interleaving fetch rate in response to detection of the second signal while fetching first portions.
The invention is also directed, in another preferred embodiment, to a graphics display system for transmitting image data from at least two image sources to at least two display devices. The system comprises a first data source for generating a first frame of image data, a second data source for generating a second frame of image data. The second data source generates image data asynchronously to the first data source. In addition, the system includes a first display device, a second display device, and a graphics controller coupled with the first and second data sources, and with the first and second display devices. The graphics controller includes a memory for storing the first and second frames, a display interface for fetching from the memory first portions of the first frame at a non-interleaving fetch rate upon the completion of storing of the first frame in the memory, and fetching second portions of the second frame at the non-interleaving fetch rate upon the completion of storing of the second frame in the memory, and a rate controller for adjusting the non-interleaving fetch rate to an interleaving fetch rate upon the completion of storing of the second frame while fetching first portions.
In yet another embodiment, the invention is directed to a medium readable by a machine embodying a program of instructions executable by the machine for performing a method for fetching image data from a memory for transmission on a data bus to at least two display devices. First portions of a first frame are fetched at a non-interleaving fetch rate in response to receiving a first signal. Second portions of a second frame are fetched at the non-interleaving fetch rate in response to receiving a second signal. The timing of the first and second signals are asynchronous to one another. The non-interleaving fetch rate is adjusted to an interleaving fetch rate in response to performing fetching the second portions.
The invention is directed to a graphics controller for use in a graphics display system, the graphics controller having a single display interface to support two or more display devices. The invention is also directed to a system and a method for supporting two or more display devices with a single display interface. Reference will now be made in detail to preferred embodiments of the invention, examples of which are illustrated in the accompanying drawings. Wherever possible, the same reference numbers are used in the drawings and the description to refer to the same or like parts.
The host 28 is preferably a CPU or DSP, and the image capture device 30 is preferably a camera. However, the invention is not limited to devices of these specific types. Any types of providers of image data are contemplated as being within the scope of the invention.
The graphics controller 26 provides a mechanism for the host 28 to control the camera 30. The camera may be programmed, for example, to send display frames of image data in different resolutions to the graphics controller. The camera is programmed via a serial control bus 32. The host specifies parameters, such as camera resolution, by transmitting control data over a parallel bus 33 to the graphics controller, which the graphics controller then uses to program the camera over the serial bus 32.
The graphics controller 26 includes an internal memory 34 for storing image data. Image data for display on the main display device 22 is designated by reference number 36. The image data 36 are created by the camera (also referred to herein as “camera image data”). Image data for display on the an auxiliary display device 24 is designated by reference number 38. The image data 38 are created by the host (also referred to herein as “host image data”).
The host image data 38 are stored in the memory 34 as a result of the host issuing a command (or commands) and transferring the data to the graphics controller on the bus 33. In a similar fashion, the camera image data 36 are stored in the memory 34 as a result of the host first programming (via the graphics controller) the camera to generate a stream of display frames of image data, and then programming the graphics controller to store the camera image data.
Whether provided by the host 28 or the camera 30, the image data 36, 38 are typically presented to the graphics controller in a raster order. “Raster order” refers to a scan pattern in which an area is scanned from side to side in rows from top to bottom. The graphics controller stores the image data 36, 38 in the internal memory in the same raster order in which the data are presented.
The graphics controller provides a camera clock signal 44 (“CAM CLK”) to the camera. In addition, the camera 30 generates a VSYNC signal on a line 45, which is provided to the graphics controller.
The main display device 22 has a display screen 46 and an internal memory 48 for storing a display frame of image data. Similarly, the auxiliary display device 24 has a display screen 50 and an internal memory 52 for storing a display frame of image data. While the display devices 22, 24 are typically liquid crystal displays (“LCD”), they may be any device capable of rendering image data, including CRT and OLED display devices, as well as hard copy rendering devices, such as printers.
In this description, preferred embodiments and examples described are described with reference to two display devices, 22 and 24. The display devices 22 and 24 provide context and help illustrate the principles of the invention. However, it should be understood that the principles of the invention is not limited to two display devices and may be applied for use with 3 or more display devices.
The graphics controller 26 includes a display interface (“I/F”) 40 for fetching image data from memory and transmitting it to the display devices according to the invention. The graphics controller 26 transmits image data to the display panels 22, 24 on a data bus 54, as shown in
The host image data 38 are fetched from memory and transmitted to display panel 24 on the bus 54 as a result of a command (or commands) by the host 28. The camera image data 36 are also fetched from memory and transmitted to display panel 22 on the bus 54 on as a result of a command (or commands) by the host 28.
The display interface 40 transmits image data by placing image data 36 or 38 on the bus 54, selecting display 22 or 24, and issuing a write command. In a preferred embodiment, a particular display device is selected by asserting the chip select signal (CS#) on either line 56 or 60. The line 56 runs between the graphics controller and the auxiliary display device 24, and the line 60 runs between the graphics controller and the main display device 22. In an alternative embodiment, the chip select signal is provided by the graphics controller on a single line that is coupled to both panels, and inverter is placed in series before one of the display devices so that when the chip select signal is asserted, one panel is selected while the other is de-selected. The write command (WR#) is issued using a line 58, which runs between the graphics controller and the two display devices.
The camera 30 provides the camera image data 36 in a stream of display frames. The host 28 may monitor the generation of display frames by the camera 30, and after each frame has been generated and stored in memory, request that the graphics controller 26 fetch the camera image data 36 from the internal memory and transmit it to the display panel 22. However, this is a burden on the host.
Alternatively, the graphics controller 26 includes an auto-frame transfer module 43 (“A/F”). The host 28 programs auto-frame transfer module so that the camera image data 36 is automatically fetched from memory 34 and transmitted to the display 22. After generating each display frame, the camera generates the VSYNC signal on line 45. Under this alternative, the auto-frame transfer module 43 monitors VSYNC and triggers the display interface 40 to fetch and transfer image data when the signal is detected. This relieves the host of the burden of having to monitor the transmission of each camera display frame, as well as the need to repeatedly request the graphics controller to transmit display frames to the display panel.
In general, graphics controllers transmit image data to display devices in conformity with a timing protocol required by the device. Traditionally, the display timing protocol is relatively strict. However, some display devices are provided with an internal memory for storing a display frame of image data, and these devices are capable of receiving data under a more relaxed timing protocol. Display devices with internal memory also include circuitry for refreshing the device's display screen from the on-board memory.
As mentioned, the display devices are provided with internal memory. The display devices 22 and 24 are capable of receiving data under a timing protocol which is more relaxed than that required for traditional display devices. In addition, the display devices 22, 24 include circuitry (not shown) for refreshing the display screen from the on-board memory. When the image data 36, 38 are fetched from the internal memory 34 and written to the display devices, the image data 36 are stored in the internal memory 48 for display on the display screen 46, and the image data 38 are stored in the internal memory 52 for display on the display screen 50.
The amount of the memory 36 for storing camera image data 36 is limited to the size of a single camera display frame in the graphics controller 26. In other words, the same portion (or address space) of memory is used for storing each frame in the sequence of frames generated by the camera.
The size of the internal memory 34 in the graphics controller provided for the camera image data 36 is preferably limited to the size of a single camera display frame. This can be done provided: (a) the fetching of a first frame begins before the storing of a subsequent frame; and, generally speaking, (b) the first frame is fetched at a rate greater than or equal to the rate at which the subsequent frame is stored. Under these conditions, the storing of a subsequent frame will not overtake the fetching of the first frame, and a memory the size of a single frame may be used both for storing a first frame and a subsequent frame. As described below with reference to
In the example, the time required to store a display frame of camera image data is 30 periods of CAM CLK 44. At the end of each frame, the camera asserts VSYNC. The camera provides a vertical non-display period of 3 clock periods between successive frames. In addition, 20 periods of CAM CLK 44 are required to fetch each frame. The fetching of each frame begins immediately after the storing of the frame is complete. Because (a) the fetching of each frame begins before the storing of a subsequent frame, and (b) the frames are fetched at a rate greater than CAM CLK 44 rate, the amount of memory for storing the camera image data 36 may be limited to the size of a single camera frame.
Generally, camera image data must be stored as it is received. The camera outputs image data in a stream synchronized with the camera clock signal 44, and the image data is stored in the internal memory 34. If, while capturing a continuous stream of image data, the graphics controller were to program the camera to speed up, slow down, or pause the camera output, undesirable visual artifacts would generally result. The reason is that the camera needs time to adjust and compensate the gain and balance of an internal image sensor. So reprogramming the camera while capturing a stream of image data may cause several seconds of unstable frames. Further, there can be a significant time lag between when the graphics controller sends a command to the camera and when the camera begins to respond to the command. The lag is due to the fact that the camera is programmed over the relatively slow serial bus 32. Thus, speeding up, slowing down, or pausing the camera output is generally impractical during the capture of a continuous stream of image data. Accordingly, in order to prevent artifacts, the image data from the camera generally must be stored as it is received or it will be lost.
The camera 30 operates asynchronously to the host 28. The image data 36 from the camera is stored in the internal memory 34 at the same speed as the camera clock signal 40. The host communicates with the graphics controller over the bus 33, which operates under a clock speed different from camera clock signal 40. The host is unaware of the camera clock signal 40, as well as the time periods when the camera is transmitting image data. In order to learn whether camera data is being transferred at a particular point in time, the host must poll the graphics controller or the graphics controller must provide the information on its own initiative.
As mentioned, the auxiliary panel 24 may be used for displaying time, date, and the telephone number of an incoming caller. This type of information does not need to be updated as often as successive camera images or video. For example, the host 28 may wish to update the auxiliary panel 24 only when the time to be displayed changes, e.g., once a minute or when an incoming call is received. Accordingly, the host will present the host image data 38 to the graphics controller only when one of these events occur, which could be at any time. After the image data 38 are stored in the internal memory 34, the host 28 will then request that the host image data be fetched from the memory and written to panel 24.
From the foregoing, it is apparent that requests by the host to fetch and transmit host image data 38 are a certainty. However, the times when these requests will be made are uncertain. The unpredictability of these requests makes the flexibility to handle such requests at any time a desirable feature of a display interface adapted for supporting a plurality of display devices. As will be seen below, a display interface 40 according to the invention provides this flexibility.
As mentioned, speeding up, slowing down, or pausing the camera output is generally impractical and results in visual artifacts. Therefore, accommodating the timing of host requests that host image data be fetched from the memory and written to panel 24 by speeding up, slowing down, or pausing the camera output is not practical.
Requests for transfer of host image data 38 at two different points in time are shown in
In these examples, a frame 304 of host image data 38 is assumed to be 5 pixels in size. The figures also show the same storing and fetching from the memory 34 of the camera image data 36 that is shown in
It should be understood that the frames of camera image data 36 are typically display frames. That is, they comprise all of the pixels in a display screen arranged in raster sequence. Often the frames of host image data 38 are also display frames. However, this is not a requirement. For example, a frame host image data 38 may comprise only the subset of pixels in a display screen which have changed from a previous frame. The use of the word “frame” herein is intended to refer to either all or a subset of the pixels of a display frame.
Referring first to
Before describing the problem, notice that a “latency” period is shown in
The host may monitor generation camera frames, and after a frame has been generated, request that the graphics controller fetch the camera data 36. Alternately, the host may program the auto-frame transfer module 43 to automatically perform the fetching. The latency period represents the time required for the host to perform either of these alternative tasks. Depending on a number of factors, the latency period will vary in different embodiments and may vary within a particular embodiment. For instance, the host may be idle at one time and busy at another time.
A significant problem occurs if the display interface 40 begins fetching camera frame 302b after the graphics controller has begun storing camera frame 300c at time T1 as shown in
Referring now to
Referring still to
In known systems, a prior art display interface writes image data at the pixel clock speed, as required by a traditional display panel. It is not possible to transmit image data to a traditional display panel at a rate faster than the pixel clock. In contrast, in the system 20, the display devices 22 and 24 have an internal memory and are capable of receiving data at clock speeds which are faster than the pixel clock speed. It might be thought that the timing of host requests for fetching and writing host image data from the memory to panel could be accommodated without creating image tearing or frame dropping artifacts simply by transmitting data on the data bus 54 at a higher rate.
However, transmitting image data at a higher speed is not a viable solution. As the speed of the bus between the graphics controller and the panel increases, electromagnetic interference (“EMI”) with other components of the graphics display system is generated. In particular, a mobile telephone includes a radio (not shown), that is susceptible to EMI. Further, power consumption increases with bus speed. Thus, it is generally desired to transfer image data to the panels at the lowest clock speed possible.
The display interface 40 advantageously transmits image data to the display devices at the minimally sufficient clock speed. In particular, the display interface 40 preferably writes image data at the pixel clock speed on the data bus 54 between the graphics controller 26 and the display panels 22 and 24. Other clock speeds are of course possible, and in some embodiments, may be preferred. However, other preferred clock speeds are sufficiently slow so that they do not create EMI. As one example of an alternative, the display interface 40 write image data on the data bus 54 at 1.25 times the pixel clock speed.
According to one preferred embodiment of the invention, the novel display interface 40 supports two display panels without creating image tearing, frame dropping, or other undesirable artifacts, and without increasing the data transmission rate and thereby creating undesirable EMI. The display interface 40 makes advantageous use of all of the available bandwidth of data bus 42 despite the fact that the timing of host requests to fetch host image data are uncertain, or that the latency period may vary.
In the examples of
The display interface 40 fetches camera image data 302 at a standard rate at times when the host or A/F module 43 have not made a request for the transfer of a host frame. The “standard” rate is preferably a rate typically required by a traditional display device. As shown in the examples, the standard rate is preferably the pixel clock rate. For example, the entirety of the camera frame 2 (302b) is fetched at the pixel clock rate. In addition, the un-shaded portions of the camera frames 1, 3, and 4 are also fetched at the standard rate. The un-shaded portions represent periods when no fetching of host image data is taking place.
Similarly, the display interface 40 fetches host image data 304 at the standard rate at times when camera image data 302 is not being fetched, that is, during the available bandwidth periods shown in
At times when the host or the auto-frame transfer module 43 have made a request for the transfer of a host frame, the display interface 40 fetches camera image data at a rate slower than the standard rate. In one preferred embodiment, the slower rate is equal to ½ the pixel clock rate. In other words, the display interface 40 dynamically slows the fetching and transmitting of frames of camera image data 36 when a request for the transfer of a host frame occurs. The display interface 40 reduces the camera data fetch rate at substantially the same time that the host data transfer is made. In addition, the display interface 40 substantially concurrently begins fetching and transmitting of frames of host image data 38. Preferably, the display interface 40 fetches the host image data at the same slower rate, e.g., ½ the pixel clock rate.
During periods when both camera and host image data are being fetched, the display interface 40 alternates between fetching and transmitting portions of the camera image data 36 and host image data 38. (Periods when both camera and host image data are being fetched are shaded in
The display interface 40 preferably includes logic for detecting a request for fetching and transmitting host image data to a display, for alternately fetching one pixel of camera image data 36 and one pixel of host image data 38, and alternately transmitting the fetched pixels to the display devices. Further, the rate controller 41 is either included in the display interface 40 or coupled to it. The rate controller 41 is adapted to adjust the rate at which the display interface 40 fetching and transmitting host and camera image data. The rate controller 41 may adjust the rate in response to detecting VSYNC while host image data is being fetched, to the host requests a transfer of host image data while host image data is being fetched, or to substitute signals provides by counting image data as it is being stored. It will be appreciated by one skilled in the art that this logic may be implemented in a variety of different ways. In one preferred embodiment, the “logic” is embodied as a program of instructions for performing a method according to the invention, which is executable by a machine, such as a microprocessor.
It can be seen from
It will be recalled that the second of the requirements described above for limiting the size of the camera frame memory is that, generally speaking, the camera image data must be stored at a rate slower than the rate at which the camera image data is fetched. The invention does not necessarily satisfy this second general requirement. However, this does not prevent a problem. Provided that the fetching begins sufficiently prior to the storing of subsequent data (providing a “head start”) so that, even though a new frame is being written faster than the previous frame is being fetched, the head start will be large enough that the writing will not over take the reading before the fetching of the host image data is complete. When the fetching of the host image data is complete, the display interface 40 reverts to fetching camera data at the standard clock rate.
While it is preferably to use the VSYNC signal trigger camera frame transfers, this is not required. It should be understood that in an alternative preferred embodiment, image data may be counted as it is stored thereby providing a measure of storing progress. The counter may be adapted to generate a suitable substitute signal after a predetermined or programmable percent of the camera frame is stored. In one preferred embodiment, the fetching of camera frames from memory is begun once 80 of the frame has been stored. Similarly, the signal which triggers the transfer of host frames may be an explicit signal from the host or a signal produced as the result of a measure of storage progress, and such signal need not be asserted only upon completion of storing.
Another advantage is that when the host 26 requests a transfer of host image data, the transfer begins substantially immediately. The graphics controller can acknowledge the host's request and the host can terminate its involvement knowing that the transfer is in process.
The invention is not limited to the exemplary transfers of (a) camera image data 36 to the main display 22; and (b) host image data 38 to auxiliary display 24. In one alternative embodiment, (a) camera image data 36 is transferred to the auxiliary display 24; and (b) host image data 38 to the main display 22. Moreover, the camera image data 36 may be comprised of image data of image data provided by two or more sources, such as by both the host and the camera. Similarly, the host image data 38 may originate from two or more sources.
In yet another alternative embodiment, the same image data, for example, camera image data 36, may be transferred to a plurality of display devices, for instance, to both displays 22 and 24. This provides, for such transfers, the advantage of increasing the timing margin and thereby eliminating the possibility of undesirable image tearing artifacts.
The buses described herein are preferably fixed electrically conductive traces known in the art of IC design. However, it should be appreciated that the described buses, such as the data bus 54, may also be wireless or optical.
The terms and expressions that have been employed in the foregoing specification are used as terms of description and not of limitation, and are not intended to exclude equivalents of the features shown and described or portions of them. The scope of the invention is defined and limited only by the claims that follow.