[Not Applicable]
[Not Applicable]
[Not Applicable]
A display device usually receives video frames from another device that is attached to, but was manufactured separately from the display device. The device providing the frames and the display device are synchronized by means of a vertical synchronization pulses Vsynch and horizontal synchronization pulses Hsynch. The display device signifies the beginning of a time period for the display of a frame by transmitting a vertical synchronization pulse (Vsynch).
Between the vertical synchronization pulse and the first horizontal synchronization pulse, there is a period of time known as the vertical blanking interval VBI. During the VBI, preparations are made for displaying the next frame. The preparation can include receiving information regarding the next frame for display and an address in a buffer storing the first pixel of the next frame for display.
Ideally, the foregoing information is received before or during the VBI. However, if the foregoing is not received, the device providing the frames may not be able to provide the next frame for display. The foregoing can potentially result in a noticeable degradation of quality in the display of the video.
Further limitations and disadvantages of conventional and traditional approaches will become apparent to one of skill in the art, through comparison of such systems with embodiments presented in the remainder of the present application with references to the drawings.
Described herein is a system and method for repeating a last frame.
In one embodiment, there is presented a method for displaying frames. The method comprises providing a first frame, waiting to receive information about a second frame to display, after displaying the first frame, and providing the first frame, if the information regarding the second frame is not received before a predetermined time.
In another embodiment, there is presented a system for displaying frames. The system comprises a display engine, and a host processor. The display engine provides a first frame. The host processor provides information about a second frame to the display engine, after the display engine provides the first frame. The display engine provides the first frame, if the host processor does not provide the information regarding the second frame to the display engine before a predetermined time.
In another embodiment, there is presented a feeder for providing a frame. The feeder comprises a first one or more registers, a circuit, and a host processor. The first one or more registers stores one or more starting address for a first frame. The circuit calculates starting addresses for one or more rows of the first frame following a vertical synchronization pulse associated with the first frame. The host processor writes one or more starting address for a second frame to the first one or more registers. The first one or more registers stores the one or more starting address for the first frame until the host processor writes the one or more starting address for the second frame to the first one or more registers.
These and other advantages and novel features of the present invention, as well as details of an illustrated embodiment thereof, will be more fully understood from the following description and drawings.
Referring now to
The frames 100 further comprise any number of lines 0 . . . N of pixels. The display device displays the lines 0 . . . N at a particular time interval within the time interval for displaying the frame. In the case of a progressive display, the lines 0 . . . N are displayed in consecutive order, line 0, line 1, line 2, . . . line N.
The display device usually receives the frames from another device that is attached to, but was manufactured separately from the display device. The device providing the frames and the display device are synchronized by means of a vertical synchronization pulses Vsynch and horizontal synchronization pulses Hsynch. The display device signifies the beginning of a time period for the display of a frame by transmitting a vertical synchronization pulse (Vsynch). The display device signifies the time period for displaying a new line in a frame 100 (x) by transmitting a horizontal synchronization pulse Hsynch. The device providing the frames uses the foregoing vertical/horizontal synchronization pulses to follow the timing of the display device, and provides the appropriate line 100 (x) of the appropriate frame 100 for display at the appropriate time.
For a progressive display, each vertical synchronization pulse Vsynch is followed by horizontal synchronization pulses Hsynch0, Hsynch1, Hsynch2 , . . . HsynchN, associated with each line 100(0), 100(1), 100(2), . . . 100(N) in the frame 100. Responsive to the horizontal synchronization pulses Hsynchx, the display device receives and displays the horizontal line 100(x) associated with the horizontal synchronization pulse.
Between each consecutive Hsynch, there is a time period to allow for preparation to display the next line. The preparations can include, for example, determining a memory address in a buffer that stores the pixels of the next line.
Additionally, between the vertical synchronization pulse Vsynch and the first horizontal synchronization pulse Hsynch0, there is a period of time known as the vertical blanking interval VBI. During the VBI preparations are made for displaying the next frame. The preparation can include receiving information regarding the next frame for display and an address in a buffer storing the first pixel of the next frame for display.
Ideally, the foregoing information is received before or during the VBI. However, if the foregoing is not received, the device providing the frames may not be able to provide the next frame for display. The foregoing can potentially result in a noticeable degradation of quality in the display of the video. To reduce the degradation in the quality of the display of the video caused by the foregoing, where the device does not receive the information regarding the next frame, e.g., 1001 for display by a predetermined time, such as the first Hsynch0 following Vsynch1, the device provides the previous frame 1000 for display during the display time (the time period between Vsynch1 and the following Vsynch) for frame 1001.
Referring now to
Referring now to
The data is output from the transport bitstream buffer 32 and is then passed to a data transport processor 35. The data transport processor 35 then demultiplexes the transport bitstream 65 into constituent transport bitstreams. The constituent packetized elementary bitstream can include for example, video transport bitstreams, and audio transport bitstreams. The data transport processor 35 passes an audio transport bitstream to an audio decoder 60 and a video transport bitstream to a video transport processor 40.
The video transport processor 40 converts the video transport bitstream into a video elementary bitstream and provides the video elementary bitstream to a video decoder 45. The video decoder 45 decodes the video elementary bitstream, resulting in a sequence of decoded video frames. The decoding can include decompressing the video elementary bitstream. The decoded video data includes a series of frames. The frames are stored in a frame buffer 48.
The display engine 50 is responsible for providing a bitstream to a display device, such as a monitor or a television. The display device and the decoder system are synchronized by horizontal and vertical synchronization pulses. Between the vertical synchronization pulse Vsynch and the first horizontal synchronization pulse Hsynch0, there is a period of time known as the vertical blanking interval VBI. During the VBI, preparations are made for displaying the next frame. The preparation can include the host processor 90 determining the frame for display and providing an address in the frame buffer storing the first pixel of the frame for display to the display engine 50.
Ideally, the display engine 50 receives foregoing information before or during the VBI. However, if the foregoing is not received, the display engine 50 may not be able to provide the next frame, frame 1001, for display. The foregoing can potentially result in a noticeable degradation of quality in the display of the video. To reduce the degradation in the quality of the display of the video caused by the foregoing, where the display engine 50 does not receive the information regarding the next frame, e.g., 1001 for display by a predetermined time, such as the first Hsynch0 following Vsynch1, the display engine 50 provides the previous frame 1000 for display during the display time (the time period between Vsynch1 and the following Vsynch) for frame 1001.
Referring now to
The feeder 715 and the display device are synchronized by horizontal and vertical synchronization pulses. During the VBI, preparations are made for displaying the next frame. The preparations can include the host processor 90 determining the frame for display and providing an address in the frame buffer storing the first pixel of the frame for display to the feeder 715.
Ideally, the feeder 715 receives foregoing information before or during the VBI. However, if the foregoing is not received, the feeder 715 may not be able to rasterize and provide the next frame, frame 1001, for display. The foregoing can potentially result in a noticeable degradation of quality in the display of the video. To reduce the degradation in the quality of the display of the video caused by the foregoing, where the pixel feeder 715 does not receive the information regarding the next frame, e.g., 1001 for display by a predetermined time, such as the first Hsynch0 following Vsynch1, the pixel feeder 715 rasterizes and provides the previous frame 1000 for display during the display time (the time period between Vsynch1 and the following Vsynch) for frame 1001.
Referring now to
The host processor 90 programs the feeder 715 during the VBI with the addresses in the frame buffer 48 storing the starting chroma and luma pixels of the frame. The starting addresses are provided to the feeder 715 via a luma starting address register 805Y and a chroma starting address register 805C in the RBUS interface 805. After providing the parameters to the RBUS interface 805, the host 90 sets a start parameter in the RBUS interface 805.
The feeder 715 fetches each pixel line in a series of bursts and stores the pixels in the buffer 840. The initial starting luma and chroma addresses are provided to the BRM 815. When the BRM 815 receives the starting luma and chroma addresses, the start parameter in the RBUS Interface 805 is deasserted.
The BRM 815 issues the commands for fetching the luma and chroma pixels in the first line of the frame/field. The IDWU 820 effectuates the, commands. The pixel feeder 835 retrieves the pixels from the buffer 840, and outputs a rasterized stream formatted in accordance with the display format. The output rasterized stream is provided to the output buffer, via the BVB protocol generator.
After the BRM 815 receives the starting addresses of the frame, the LAC 810 detects deassertion of the start parameter and calculates the starting address of the next line and stores the addresses in the RBUS Interface 805 and reasserts the start parameter. The starting addresses of the next line are determined by appropriately incrementing the starting address of the current line.
The LAC 810 includes a last luma line start register 810Y and a last chroma line start register 810C. Initially, the address write to the registers 805Y and 805C are transferred to the registers 810Y and 810C. The LAC 810 calculates the starting addresses for a line 100(x) by incrementing the registers 810Y and 810C. The registers 810Y, 810C then store the starting address for the line 100(x). To calculate the starting addresses for a line 100(x+1), the LAC 810 increments the registers 810Y and 810C.
When the BRM 815 and IDWU 820 finish transferring the current line to the buffer 840, the BRM 815 receives the starting addresses for the next line from the RBUS Interface 805. When the BRM 815 receives the starting addresses for the next line, the start parameter is deasserted. The foregoing process is repeated until the end of the picture.
The operation of the LAC 810 is described in greater detail in 60/495,695, that is incorporated herein by reference.
The RBUS Interface 805 is programmed with the starting addresses of the previous frame 1000 following the previous Vsynch, Vsynch0, in registers 805Y, 805C. Ideally, the RBUS Interface 805 receives starting addresses of frame 1001 in registers 805Y, 805C before or during the VBI following Vsynch1. Where the RBUS Interface 805 receives the starting addresses of frame 1001 prior to a predetermined time, such as Hsynch0 following Vsynch1, the starting addresses of frame 1001 overwrite the starting addresses of frame 1000
If the addresses are not received, the feeder 715 may not be able to rasterize and provide the next frame, frame 1001, for display. The foregoing can potentially result in a noticeable degradation of quality in the display of the video. However, the RBUS interface 805 maintains the starting addresses for the previous frame 1000. To reduce the degradation in the quality of the display of the video caused by the foregoing, where the RBUS interface 805 does not receive the starting addresses for the next frame, e.g., 1001 for display by a predetermined time, such as the first Hsynch0 following Vsynch1, the pixel feeder 715 rasterizes and provides the previous frame 1000 for display during the display time (the time period between Vsynch, and the following Vsynch) for frame 1001 . The feeder 715 rasterized the previous frame 1000 based on the starting addresses programmed into the registers 805Y, 805C following Vsynch0.
One embodiment of the present invention may be implemented as a board level product, as a single chip, application specific integrated circuit (ASIC), or with varying levels integrated on a single chip with other portions of the system as separate components. The degree of integration of the system will primarily be determined by speed and cost considerations. Because of the sophisticated nature of modern processors, it is possible to utilize a commercially available processor, which may be implemented external to an ASIC implementation of the present system. Alternatively, if the processor is available as an ASIC core or logic block, then the commercially available processor can be implemented as part of an ASIC device with various functions implemented as firmware.
While the invention has been described with reference to certain embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the invention. In addition, many modifications may be made to adapt particular situation or material to the teachings of the invention without departing from its scope. Therefore; it is intended that the invention not be limited to the particular embodiment(s) disclosed, but that the invention will include all embodiments falling within the scope of the appended claims.