WO1998059494A9 - Apparatus and method for controlling transfer of data between processing elements - Google Patents

Apparatus and method for controlling transfer of data between processing elements

Info

Publication number
WO1998059494A9
WO1998059494A9 PCT/US1998/012883 US9812883W WO9859494A9 WO 1998059494 A9 WO1998059494 A9 WO 1998059494A9 US 9812883 W US9812883 W US 9812883W WO 9859494 A9 WO9859494 A9 WO 9859494A9
Authority
WO
WIPO (PCT)
Prior art keywords
data
signal
datum
input
output
Prior art date
Application number
PCT/US1998/012883
Other languages
French (fr)
Other versions
WO1998059494A1 (en
Inventor
Jeffrey D Kurtze
Craig R Frink
James Hamilton
Frank C Sarnowski
Raymond D Cacciatore
Scott A Markinson
Michael F Lamenza
Anthony O'connor
Hamed Eshraghian
Original Assignee
Avid Technology Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Avid Technology Inc filed Critical Avid Technology Inc
Priority to JP50490299A priority Critical patent/JP2002511171A/en
Priority to EP98931437A priority patent/EP0988756B1/en
Priority to AU81572/98A priority patent/AU8157298A/en
Priority to DE69801754T priority patent/DE69801754T2/en
Priority to CA002294153A priority patent/CA2294153A1/en
Publication of WO1998059494A1 publication Critical patent/WO1998059494A1/en
Publication of WO1998059494A9 publication Critical patent/WO1998059494A9/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/42Bus transfer protocol, e.g. handshake; Synchronisation
    • G06F13/4204Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus
    • G06F13/4208Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a system bus, e.g. VME bus, Futurebus, Multibus
    • G06F13/4213Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a system bus, e.g. VME bus, Futurebus, Multibus with asynchronous protocol
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/42Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/61Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/24Systems for the transmission of television signals using pulse code modulation

Definitions

  • the present invention is related to apparatus and methods for controlling transfer and processing of data by interconnected data processing elements.
  • the invention is more particularly related to the processing of temporally continuous media data, including motion video and audio data.
  • Analog motion video signals such as those used in common television sets, video tape recorders and other analog video systems, are temporally continuous and synchronous signals requiring various elements in a video system to be synchronized in order to be used.
  • analog motion video signals have a predetermined and fixed rate to which all of the elements in the video system are synchronized. Any element in the video system is designed with the assumption that there will be a constant rate for input and output of motion video information. More recently, it has been possible to store digital motion video data in data files on a computer. There are several methods for playing back such motion video data. One method is called “pushing" or "streaming" of the motion video data.
  • Streaming is based on an assumption that a system can provide an average data flow rate that is the same as the ultimate data flow rate needed to ensure temporally continuous output of analog motion video images to a viewer. Sufficient buffering is used to account for expected latencies in data transfer between elements. In some cases, both the temporal and spatial resolution of the motion video information may need to be reduced. Such systems typically are designed with the assumption that transfer of audio and video data from a source through several processing elements to its ultimate destination can neither be delayed nor stopped. When a general purpose digital computer is used to process motion video information, a constant rate of flow of data generally cannot be maintained.
  • a data decompressor outputs data into a first buffer, from which it is transferred to a second buffer associated with a special effects processor.
  • the first buffer indicates whether valid data is available.
  • the special effects processor indicates to a controller associated with the decompressor whether it can receive data based on memory in the second buffer.
  • the present invention provides a generic interface which enables asynchronous data processing elements to be interconnected using an interconnection protocol that controls flow of data between the processing elements.
  • the flow control allows the processing elements to be data independent from, i.e., the processing elements need not be designed for a fixed sample rate or resolution, sample format and other data dependent factors.
  • the processing elements may process motion video data at various temporal and spatial resolutions and color formats.
  • Flow of data between processing elements may be controlled by handshake signals indicating whether the sender has valid data and the receiver can receive data. When valid data is available at the sender and is requested by the receiver, a transfer of data occurs.
  • the characteristics of the data, and functions to be performed on the data may be specified using control inputs to the processing elements.
  • a counting circuit may be used to specify the number of the data samples for which the control inputs are valid.
  • the interface allows each processing element to have a small number of storage locations for storing data, such as a pair of registers, which eliminates the need for large buffers and simplifies implementation of the processing element with such flow control as a simple integrated circuit. Accordingly one aspect of the present invention is an output interface for a sender of data.
  • the interface includes an output including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum defines a boundary of a sample of the data.
  • a valid data signal output line carries a valid data signal associated with a datum which indicates whether the associated datum is valid.
  • a request signal input line carries a request signal from a receiver associated with a datum from the sender which indicates a request for transfer of the associated datum.
  • the interface includes a handshake mechanism which is operative on an edge of an interface clock signal to hold a datum at the sender when either of the request signal or valid data signal associated with the datum are not asserted and to permit transfer of the datum to the receiver through the output when both the request signal and the valid data signal associated with the datum are asserted.
  • the handshake mechanism is operative on an edge of the interface clock signal to hold the datum on the output when either of the request signal or valid data signal are not asserted and to permit update of the datum on the output when both the request signal and the valid data signal are asserted.
  • the interface has an input, including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum on the data lines defines a boundary of a sample of the data.
  • a valid data signal input line carries a valid data signal associated with a datum from a sender and indicating whether the associated datum is valid.
  • a request signal output line carries a request signal and associated with a datum from the sender and indicating a request for transfer of the associated datum.
  • Data flow is controlled by a handshake mechanism which is operative on an edge of the interface clock signal to accept a datum received through the input when both the request signal and the valid data signal associated with the datum are asserted and not to accept a datum received through the input when either the request signal or the valid data signal associated with the datum are not asserted.
  • the handshake mechanism does not read the datum on the input when either of the request signal or valid data signal are not asserted and reads the datum on the input when both the request signal and the valid data signal are asserted.
  • Another aspect of the present invention is an integrated circuit with a processing section having an input for receiving data and an output providing processed data.
  • the integrated circuit has an input interface as described above with an output connected to the input of the processing section.
  • the integrated circuit has an output interface with an input connected to the output of the processing section.
  • Input logic is operative on an edge of an interface clock signal to accept a datum received through the input when both the first request signal and the first valid data signal associated with the datum are asserted and for not to accept a datum received through the input when either the first request signal or the first valid data signal associated with the datum are not asserted.
  • Output logic is operative on an edge of a clock signal to hold a datum when either of the second request signal or second valid data signal associated with the datum are not asserted and to permit transfer of the datum to the receiver through the output when both the second request signal and the second valid data signal associated with the datum are asserted.
  • Another aspect of the invention is a circuit for processing data, comprising a processing element having a first input for receiving data comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the processing element and an output providing processed data.
  • a counting circuit has a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid.
  • Control logic tracks a number of samples processed by the processing element and generates the control signal to the processing element after the processing element outputs the last sample for which the control information is valid.
  • the processing element includes a plurality of interconnected processors.
  • Another aspect of the invention is a circuit for processing data, comprising a first processing element having a first input for receiving data comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the first processing element and an output providing processed data.
  • a second processing element has a first input connected to the output of the first processing element and for receiving the processed data comprised of a plurality of samples, a second input which receives control information indicating how the received data is to be processed, a third input for receiving the control signal for starting and stopping processing by the second processing element and an output providing processed data.
  • a counting circuit has a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid.
  • Control logic tracks a number of samples processed by the second processing element and generates the control signal to the first and second processing elements after the second processing element outputs the last sample for which the control information is valid.
  • FIG. 1 is an illustration of the signals connecting two asynchronous video processing elements in an interface according to one embodiment of the present invention
  • Figs. 2A-2E are timing diagrams illustrating the relationship of signals across the interface of Fig. 1 ;
  • Fig. 3 A is a block diagram of a processing element having an input and an output both using the asynchronous digital video interface in accordance with the present invention
  • Fig. 3B is a block diagram of another embodiment of the processing element of Fig. 3A;
  • Fig. 3C is a block diagram of a circuit having two processing elements in a single control domain
  • Figs. 4A and 4B illustrate two embodiments for double buffering control information
  • Fig. 5 is a state diagram for a field advance counter
  • Fig. 6 is a state diagram for a processing element using an interface and field advance counter in one embodiment of the present invention
  • Fig. 7A-E are block diagrams of embodiments of the input and output control logic shown in Figs. 3A and 3B;
  • Fig. 7F-G are a block diagram and timing diagram, respectively, illustrating another embodiment of input interface logic with pipelined handshake signals
  • Fig. 8 is a block diagram illustrating an interface in one embodiment of the invention for digital video input
  • Fig. 9 is a block diagram illustrating an interface in one embodiment of the invention for digital video output
  • Fig. 10 illustrates an embodiment of the present invention where the output of a processing element having an interface in accordance with an embodiment of the present invention is connected to a processing element without such an interface, using a tracking state machine;
  • Fig. 11 illustrates the connection of a processing element to a processing element having an interface in accordance with the present invention using a tracking state machine.
  • the present invention provides an asynchronous data interface for interconnecting processing elements in a manner which allows the processing elements to be data independent.
  • the interconnect allows for format independence, temporal and spatial resolution independence, frame rate independence and variability, and faster than real-time transfer of compressed or uncompressed digital motion video data between processing elements.
  • the interface allows processing elements to treat media as computed data rather than temporally continuous data. Because of the data independence of the interconnect and subsequently the processing performed by interconnected processing elements, different formats of data and different media types may be multiplexed with different bandwidths across the same interconnect.
  • the present invention eliminates an assumption that motion video data and audio data cannot be burst across an interconnect.
  • motion video data can be processed using the present invention with processing elements that allow for multiple temporal and spatial resolutions, color and pixel representations and resolutions, full motion and less than full motion video, broadcast quality and less than broadcast quality video data, and multiplexing of two or more data streams including video data, key data, other kinds of data and control information and data over the same interconnect.
  • Fig. 1 illustrates an interface between a sender and a receiver of data.
  • Each of the sender and the receiver may be implemented as separate integrated circuits.
  • a sender 30 is connected to a receiver 32 through a data interconnect 34 that carries data (VDI(9:0)) between devices. While this embodiment is described in connection with video data it may be applied to other kinds of data.
  • data includes, but is not limited to video data, key data, audio data, control information or other data.
  • the data type may be agreed upon, by convention or by signals labeled in the data stream or specified by control information.
  • the interface is unidirectional, but the direction may be selectable under appropriate software and/or hardware control, as discussed below.
  • Transaction timing on this video data interface is relative to an edge, e.g., the rising edge, the falling edge or both, of the interface clock (CLK), e.g., a twenty- seven megahertz (27 MHZ) clock present or a signal line 42.
  • CLK interface clock
  • the interface clock may be established by either an external source or by the sender, e.g., when source synchronous clocking is used to transmit data over long distances.
  • the width, in bits, of the data interconnect 34 of the interface depends on the application.
  • both 8-bit and 10-bit data paths are suitable.
  • the interface may be a single video component in width, according to an appropriate video format convention.
  • chroma and luma samples alternating on successive clocks following a 4:2:2 convention (CCIR601) may be supported.
  • Other possible formats include, but are not limited to, RGB, 4:4:4, RGBA, 4x4 and 4:2:2:4.
  • the interface is format independent so long as the sender and receiver agree to the selected format.
  • VDI 1 :0 When a 10-bit interface is used for 8-bit only video data, the least significant bits (VDI 1 :0) may be left undefined.
  • the flow of data from the sender 30 to the receiver 32 across the data interconnect 34 is controlled using two handshake signals.
  • the first handshake signal is a request signal (REQ_N) sent across a signal line 38 from the receiver.
  • the request signal is generated by the receiver and is associated with a datum at the sender which the receiver requests to be transferred.
  • the receiver uses the request signal to indicate its ability to accept new data, which also allows the receiver to pace the flow of data.
  • the request signal also may be asserted by the receiver independent of the second handshake signal, called the valid data signal.
  • the valid data signal (VAL_N) is sent across a signal line 40 from the sender.
  • the valid data signal is associated with a datum at the sender and indicates whether the associated datum is available to be transferred.
  • the valid data signal may be asserted by the sender independent of the request signal.
  • the sender uses the valid data signal to control the flow of information to the receiver.
  • the handshake mechanism from the point of view of the sender is
  • the request signal and valid data signal associated with a datum available to be transferred are examined. If either signal is not asserted, the datum is held at the sender. If both handshake signals are asserted, then the transfer of the datum to the receiver through the output is permitted.
  • the handshake mechanism from the point of view of the receiver is the following. Upon each edge of the interface clock signal, the request signal and the valid data signal associated with a particular datum available at the sender to be transferred are examined. If either signal is not asserted, the datum is not accepted to be received through the input. When both the request signal and the valid data signal associated with the datum are asserted the datum is accepted to be received through the input.
  • the valid data signal is used to indicate that valid data is present on the data interface 34.
  • the request signal is used to indicate that the data present on the data inferface 34 is requested by the receiver.
  • a transfer of data across the interconnect 34 occurs if both the request signal and valid data signal are asserted when an edge of the interface clock occurs and the data on the data interface 34 is updated. If either signal is negated, then the data transfer does not occur, the data is stored at the sender and the flow of information between the devices is stalled. Suspending data transfer may be effected by suspending the clock controlling latches on the interface or by appropriate feedback circuitry.
  • the request signal and valid data signals may be pipelined or delayed or may be assumed to be valid for a plurality of data to be transferred.
  • a boundary signal (VSYNC_N), sent by the sender across a signal line 36 with the data to the receiver, represents auxiliary information about the data transferred across the interface. This signal may include one or more bits of information.
  • This boundary signal signifies at least the boundary of data for a given sample. For example, for motion video data the boundary signal may designate an image boundary, or another boundary such as a line or pixel or video datum.
  • this signal When used to designate an image boundary, this signal may be asserted at the same time the data for the last component of either a pixel in the image or a key is on the data interconnect 34 in order to indicate the end of the image.
  • the start of data for a sample, such as an image, could be signaled instead of the end.
  • the boundary signal also may be encoded such that a transition in the signal designates an end of field and the state of the signal on the first component of the field indicates the sense (i.e., odd or even) of the field.
  • the auxiliary information also may indicate the presence of data type or other control information.
  • the boundary signal is asserted with the same timing as the data on the data interconnect 34 and follows the same flow control behavior as the data. It is valid also only when the valid data signal is asserted. If the request signal is negated at the time when the boundary signal is asserted, then the boundary signal remains valid as long as the valid data signal is asserted.
  • the request signal (REQ_N), the valid data signal (VAL_N) and the boundary signal (VSYNC_N) are negative logic signals.
  • the valid data signal 54 when asserted, indicates that the sender has placed either valid video data or valid key data 52 on the data interconnect 34. Data is read from the data interconnect 34 by the receiver when both the request signal 56 and the valid data signal 54 are asserted in the same cycle of the interface clock 50. When the valid data signal 54 is not asserted, no valid data exists on the video data interconnect.
  • the boundary signal 58 is not asserted.
  • the valid data signal for several clock cycles is shown at 54.
  • Valid data is present at the video data interconnect 52 only when the valid data signal is asserted (cycles 53, 55, 59 and 49).
  • the request signal, indicated at 56 is asserted for the second and subsequent clock cycles 53, 55, 57, 59 and 49.
  • data transfer occurs only during clock cycles 53, 55, 59 and 49.
  • the request signal indicates whether the receiver is able to accept data from the data interconnect.
  • Data is read from the data interconnect when both the request signal and valid data signal are asserted in the same cycle of the interface clock.
  • the request signal is not asserted, the receiver is unable to read data from the data interconnect.
  • a clock signal 50 represents the interface clock applied to the clock inputs of the sender and receiver. Data are shown at 60.
  • the boundary signal 66 is not asserted for simplicity.
  • the valid data signal (VAL_N) is shown at 62 and in this example is constantly asserted.
  • Fig. 2C is a timing diagram representing how the boundary signal is used to indicate the last component of a sample.
  • the boundary signal represents a field boundary (called a vertical synchronization signal is a synchronous video system).
  • the data on the data interconnect is illustrated at 72. Both the valid data signal (VAL_N) and the request signal (REQ_N) are asserted as shown at 74 and 76, respectively. As indicated at 78, at the fifth clock cycle 77, the data on the data interconnect is a component "yl,” and is the last pixel component of the last pixel of a field. The assertion of the boundary signal as indicated in 78 is concurrent with the presentation of this last pixel component on the data interconnect.
  • the boundary signals also may be used to designate other boundaries of other kinds of samples, such as a line or pixel, in the data.
  • Timing diagrams Figs. 2D through 2F illustrate some examples of the ordering of some formats of video data and key data in one embodiment of the invention.
  • Video component ordering may follow any standard convention, such as CCIR656
  • Fig. 2D is a timing diagram illustrating video component ordering.
  • the interface clock signal and boundary signal are illustrated at 50 and 58, respectively.
  • the boundary signal is not asserted.
  • the video data illustrated at 80 illustrates components appearing in the sequence according to a 4:2:2 format.
  • the valid data signal 82 and request data signal 84 are both asserted.
  • the interface is generic in nature, it also may be used to transport key data (e.g., alpha data for alpha compositing) separately from the video data.
  • the interconnect may be used full width or half width in a time multiplexed manner, since the key data consumes only half the interconnection bandwidth in most video applications. Key values are ordered according to corresponding video samples, although a fixed timing relationship is not required at the interconnect. Full width key data occupies the full width of the interconnect, but only half its bandwidth, the ordering is shown below.
  • Fig. 2E is a timing diagram illustrating key component ordering.
  • the data output by the element is illustrated at 86. It is assumed that the request signal 90 is asserted. As the valid data signal becomes unasserted in the fourth clock cycle 85 and sixth clock cycle 87, no data is available on the video data interface as indicated at 86. Note that the ordering of the data between the third and fifth clock cycles (85 and 87) does not involve any loss of data.
  • the interface may also be used in a time multiplexed fashion to transfer key data.
  • 10-bit key value may be transferred using half the interconnect width (5 -bits). 10-bit values also can be time-multiplexed onto an 8-bit bus. This reduces the interface pin count by time multiplexing the key data into upper and lower time slices. The upper or most significant data is sent first followed by the lower or least significant data. When an 8-bit key is used the least significant bit (VDIO) is undefined. Key order is defined (left to right, left first) as:
  • Fig. 2F is a timing diagram illustrating multiplexed key component ordering.
  • the key components appear at the video data interconnect as indicated at 92. It is assumed that the request data signal is constantly asserted as shown at 96.
  • the valid data signal controls the output on the video data interface as indicated at 94. For example, in the third clock cycle 93, where the valid data signal is not asserted, the data present on the interface as indicated at 92 is held until the next clock cycle 95.
  • multiple types of data may be multiplexed over the same interconnect, including two or more data streams of video data, key data, and other kinds of data and control information.
  • each type of data may have its own associated handshake signals. These handshake signals also can be multiplexed over the interconnect. Alternatively, separate interface signals may be provided for the two or more data streams which are multiplexed over the interconnect.
  • control information may include, for motion video data, the size of an image, i.e., its spatial resolution; a position of an image, e.g., for a processing element that is a picture-in-picture processor; brightness; contrast; color correction or other processing information; chroma or luma keys; indications of a blend to be performed; and/or possibly an indication of temporal resolution (i.e., frame rate) or color format.
  • control information typically is provided by a host computer or local processor to the processing element so that it is available when the associated video information is available to be processed by the processing element.
  • Control information may be shared by several interconnected processing elements. In order for the processing element to receive correct control information, a control circuit is used to keep track of the number of samples processed by the processing element. The control information may be specified to be valid for a number of samples.
  • Processing elements interconnected in this manner operate in separate time domains since they are not "slaved" to a master clock.
  • Each processing element although closely related in time, provides control and state information to the host computer or other controller, so that the host may control and track progress of the processing element.
  • FIG. 3A illustrates a device with a single processing element, and both an asynchronous input and an asynchronous output using an interface in accordance with the invention.
  • Other embodiments of a device with asynchronous input signals and synchronous output signals, a processing element with synchronous input signals and asynchronous output signals, and a long interconnect between two asynchronous devices, will be described in more detail below.
  • processing element 200 performs most of the processing on the input data.
  • the device receives a boundary signal 202, data 204, a valid data input signal 206 and an interface clock 208, and provides an output signal 209 indicating a request. All of these signals are received by input control logic 210, described in more detail below.
  • the interface clock 208 controls latching of the data performed in the input control logic.
  • the processing element 200 receives data from the input control logic, along with the associated boundary signal as indicated at 217.
  • the processing element also provides an output 218 to be used by the input control logic to generate the request signal.
  • the device On the output side, the device provides as its output a boundary signal 220, data 222 and a valid data signal 228, and receives both an interface clock signal 224, and an input request signal 226.
  • the output interface clock 224 may be different from the input interface clock 208.
  • the data, boundary signal and valid data signal are provided to output control logic 230, described in more detail below.
  • the output control logic also receives, from the processing element 200, a boundary signal 232, data 234, and valid data signal 236.
  • the output control logic 230 passes on the request signal to the processing element 200 as indicated at 238. Loading of latches within the output control logic occurs upon an edge of the interface clock 224 depending on the state of the valid data and request signals.
  • the processing element 200 receives control information from control registers 243.
  • the control registers are loaded via a bus connected to the host computer as indicated at 245.
  • the control registers 243 may be implemented using the register constructions shown below in Fig. 4A and 4B.
  • Control information may be double buffered and thus have two states, an "active" state and a "shadow” state.
  • the active state contains the current state used in processing, while the shadow state is the control information for the next function to be performed.
  • the processing element also has an associated a field advance counter 248 which has a corresponding state diagram described below in connection with Fig. 5. The contents of the field advance counter represent the number of data samples for which the active control information is valid.
  • the FAC may be used to represent a number of frames, lines or pixels or other subset of motion video data.
  • the field advance counter decrements every time the boundary signal 232 is asserted at the output of the processing element 200.
  • One or more processing elements that are interconnected using the interface described above define a single "control domain.” Each control domain has a corresponding field advance counter.
  • the counter has logic which generates interrupt and loading signals to the host processor to inform the host of its state and to processing element to control processing by the processing element.
  • FIG. 3B An alternate embodiment is shown in Fig. 3B.
  • Fig. 3B includes four three-state buffer arrangements 240, 242, 244 and 246, which enable the device and its interfaces to operate in two directions in a selectable manner.
  • each interface has a corresponding identical input and output control logic as indicated at 230 and 210A and 210 and 230A.
  • This embodiment is otherwise the same as that in Fig. 3A, and would also include a control information register and field advance counter.
  • the control information would indicate the direction of flow of information on the input and output interfaces, and the processing element would generate appropriate control signals to control the three-state buffer arrangements 240, 242, 244 and 246.
  • Fig. 3C illustrates an embodiment with two processing elements 250 and 252 interconnected using an interface in accordance with the present invention as indicated at 254 and controlled by a single field advance counter 256. Accordingly, these elements are part of a single control domain.
  • Processing elements 250 and 252 are interconnected by input/output elements 258, 260, 262 and 264.
  • the field advance counter 256 controls the control information in registers 266.
  • the processing elements 250 and 252 may receive different control information or may share control information.
  • the processing elements 250 and 252 receive the same outputs indicating whether the counter 256 is at zero, as indicated at 268. However, the counter 256 decrements according to the boundary signal 270 output by the last processing element in the control domain.
  • FIG. 4A the host computer writes control information into a shadow register 1 14.
  • the shadow register 114 Upon the arrival of the next clock edge when the boundary signal output by the processing element is valid, the contents of the shadow register 114 are loaded into the active register 116.
  • the output of the active register is the control information used by the processing elements within the control domain.
  • a first register 100 and a second register 102 are connected to first and second inputs, respectively, of a multiplexer 104 which is controlled by a double buffered flag bit 106 to select one of the inputs as its output 108.
  • the output of the multiplexer provides the control information used by the processing elements within the domain.
  • the host computer loads the flag bit in a shadow register 110. Upon the arrival of the next clock edge when the boundary signal output by the processing element is valid, the contents of the shadow register 110 are loaded into an active register 112, the output of which controls the multiplexer 104. If the shadow register was not updated since the last boundary signal, the active register would not change.
  • Control information is copied from the shadow registers to the active registers, shown in Figs. 4 A and 4B, when a boundary signal output by the processing element becomes asserted or when the processing element is stalled (due to only the FAC being stalled) and the field advance counter transitions to a non-zero value.
  • the field advance counter (FAC) will now be described in more detail in connection with Fig. 5.
  • the FAC is a counter that has a size corresponding to a maximum number of samples which may be processed by its corresponding processing elements before those elements stop processing.
  • the FAC for example, may be eight (8) bits, which corresponds to an advance load of 255 samples. It should be understood that the system is designed to support any value loaded into the FAC, including only one sample.
  • the FAC decrements immediately when written if it was in a stalled state prior to being written, as well as when a sample boundary is detected.
  • the FAC signals the processing element to stop processing when the counter is exhausted, i.e, is at zero ('0'), and the last sample is processed, which is signaled by a boundary signal output by the last processing element in the control domain. If there are multiple processing elements at the end of a control domain, the FAC is decremented after all of the processing elements indicate a sample boundary.
  • the FAC also is used to signal the host computer, via an interrupt, when a series of operations is about to be completed at the end of the sample when it transitions to a count of '0.' Upon receiving this interrupt, the host computer can update the control information to take effect after the current sample is processed.
  • the FAC state of '0' when the boundary signal at the output of the processing element indicates a sample boundary causes the flow of data through the device to stop or stall, and a second interrupt is generated to the host computer.
  • This stalling prevents the processing element from continuing to operate when its control information is no longer valid. Processing continues when a non-zero value is loaded into the FAC and the data of the next sample is ready at the input of the first processing element in the control domain.
  • the host should not write a value into the FAC when the FAC is at one or zero.
  • the state of the field advance counter transitions from either state 124 or state 120 to the active state 122.
  • the boundary signal output by the processing element signifies an end of a sample has been reached, and the field advance counter is greater than one, the transition returns to the active state.
  • the field advance counter is one and a sample boundary is encountered, a transition occurs to the FAC at zero state 124 with an interrupt signal to the host indicating the field advance counter is at zero. If a sample boundary is encountered when the FAC is at zero, a transition occurs to the stalled state 120 and an appropriate interrupt also is sent to the host.
  • the field advance counter also may include an additional register, herein called a write save register.
  • This write save register captures the current state of the field advance counter when a new value is written to the field advance counter. This register allows processing elements to be cleanly halted by writing a "one" into the field advance counter. To restart, an application may determine a final number of fields to be played by reading the saved value from the write save register.
  • the register may be used, for example, by having the host determine whether the field advance counter value is greater than one, and if greater than one, writing the field advance counter value into the write save register.
  • the write save register also may be implemented directly in hardware.
  • the field advance counter provides the capability for time varying control information to be provided to a processing element.
  • the control information is time-varying since it includes parameters to be applied to one sample and then is updated at the end of each sample for the next sample.
  • Such a capability allows for various data to be multiplexed through the processing element, to allow different kinds of processing to be applied to the same kinds of data through the processing element, and many other features.
  • the processing element changes the form of the incoming data, such as by changing its temporal or spatial resolution or color format, different kinds of conversion can be performed.
  • the processing element is changing the content, for example by performing a keying function or a blend of two video streams or other manipulation, the actual function performed by the processing element can be varied over time through the changing of the control information.
  • Fig. 6 is a state machine diagram for the processing element 200 of Figs. 3 A and 3B.
  • stalled 280 There are two states for a processing element, stalled 280 and active 282.
  • the processing element cannot receive data or output valid data. Accordingly, the request and valid data signals are deasserted.
  • the processing element transitions to the active state 282. In this state, both the request and valid data signals may be asserted. Whether they are asserted depends on the actual processing performed by the processing element. For example, the processing element may immediately request data, but may not output valid data for several clock cycles until the next output sample is completely computed.
  • the active state 282 a transition occurs when a boundary signal is generated by the processing element.
  • the processing element If the field advance counter is non-zero when the boundary signal generated by the processing element indicates a sample boundary, then the processing element remains in the active state. If the field advance counter is already at zero when the boundary signal generated by the processing element indicates a sample boundary, then the processing element transitions from the active state 282 to the stalled state 280.
  • the state diagram for controlling the processing element may be implemented using control logic associated with the hardware which actually performs the processing.
  • the stalled and active states respectively disable ad enable activity of the processing element.
  • active state 282 may include several states in which the processing element may be actively processing data or may be stalled due to flow control effects from the interface with other components. Stalling due to flow control over the interface may occur at any byte of data, even between components of samples in multiplexed data.
  • stalling of a processing element due to a need for control information typically only occurs between samples.
  • Fig. 7A shows one embodiment of the input and output control logic in Fig. 3A.
  • the input control logic shown in Fig. 7A, includes a first register 300. Its output is applied to a second latch 302 and to a multiplexer 304.
  • the multiplexer 304 also receives the output from register 302.
  • the output of multiplexer 304 is supplied to a register 306.
  • a latch 308 receives the input request and valid data signals and uses them to control multiplexer 304.
  • Fig. 7A The signals illustrated in Fig. 7A are defined in the following table and logic equations. All logic equations herein are in VHDL (IEEE standard 1076-1987).
  • I_V0_EN ⁇ DREQI OR NOT I_V0_Q;
  • I_V0_D ⁇ I_V2_QORI_Vl_Q;
  • I_D1_EN ⁇ NOT I_V0_Q OR NOT I_V1_Q.
  • circuit shown in Fig. 7A may be implemented using a programmable logic array or specialized circuit or discrete hardware components.
  • the circuit illustrates in Fig. 7A favors output timing. This circuit may be modified to eliminate register 300 as shown in Fig. 7B.
  • the logic equations representing the output signals provided by the various logic circuits 302 through 308 are represented by the following table.
  • I_VO_EN ⁇ DREQI ORNOT I_V0_Q;
  • I_V1_EN ⁇ DREQI ORNOT I_V1_Q;
  • I_VO_D ⁇ DVLDI OR I_V1_Q;
  • I_V1_D ⁇ DVLDI AND NOT I_V0_EN;
  • FIG. 7C An interface that favors input timing requirements is shown in Fig. 7C.
  • the register 306 of Fig. 7A is deleted.
  • the logic equations representing the output signals provided by the various logic circuits 300 through 306 in Fig. 7C are represented by the following table:
  • I_V0_EN ⁇ NOT I_V0_Q OR NOT I_V1_Q;
  • I_V1_EN ⁇ NOT I_V1_Q OR DREQI;
  • Fig. 7D is a block diagram of an embodiment of the input control logic which optimizes input interface timing parameters. It includes a multiplexer 310, latch 312 connected to the output of multiplexer 310. The output of latch 312 is fed back to an input of the multiplexer 310. The output of latch 312 is also applied to a second multiplexer 314. The output of multiplexer 314 is connected to a data latch 316, whose output is fed back to an input of multiplexer 314. The output data to the interface is provided by the output of the multiplexer 314.
  • Fig. 7E is a block diagram of an embodiment of the output control logic which is optimized for output interface timing parameters.
  • a multiplexer 330 provides an output to a data latch 332, whose output is fed back to an input of a multiplexer 330.
  • the output of multiplexer 330 is fed to an input of multiplexer 334.
  • the output of multiplexer 334 is applied to a data latch 336.
  • the output of the data latch provides the output of the output control logic and is also fed back to an input of multiplexer 334.
  • Two additional latches are provided as indicated at 338 and 340.
  • the sender may need a number of clock cycles to extract the data from an associated data storage memory.
  • timing parameters and protocols for accessing data memories associated with the sender may require that the request signal be asserted from the receiver several clock cycles before the valid data signal may be asserted.
  • the latency between the request signal and valid data signal will be fixed and known.
  • the interface therefore uses a pipelined data request/valid handshake to transfer data.
  • a mechanism which stalls the flow of data with a fine level of granularity is used.
  • One example of an interface which provides this capability is shown in Fig. 7F.
  • This circuit may be used where a pixel component requested by one circuit will not be available from another circuit until four clock cycles later, which can occur, for example, when the depth of the control signal pipeline to the memories is four clock cycles.
  • the input interface of the receiving circuit translates requests between internal logic to the sending circuit, buffering the additional pipelined data.
  • the input interface design shown in figure 7F, contains a data storage buffer 354 whose capacity for data storage is equal to the latency or pipeline delay from data request to data valid for the sender. In the figure, this value is referred to as N.
  • the circuit includes control logic 350 which controls the insertion and removal of data from the buffer. The control logic 350 performs these operations in response to the pipelined valid data signal from the sender and the internal same-cycle request signal from the processing element.
  • a data latch 356 receives the output from multiplexer 352 to provide data to the processing element. In operation, the control logic 350 provides data from the storage buffer 354 to the receiver when the buffer 354 is not empty by controlling the data multiplexer 352 and the buffer 354.
  • This multiplexer 352 can be used to select either data from the storage buffer 354 or the sender for transfer to the receiver. If the buffer 354 is empty, the control logic 350 controls the multiplexer 352 to provide data from the sender. If valid data arrives from the sender while the control logic 350 is providing data to the receiver from the storage buffer 354, the control logic 350 causes the data to be placed into the storage buffer 354. If valid data arrives from the sender when the receiver cannot accept it, the control logic 350 causes the data to be placed in the storage buffer 354. This situation may occur when the processing element deasserts the request signal, but the sender has not completed processing the preceding pipelined data requests.
  • the data source does not assert the data valid signal until after receiver asserts the data request signal.
  • the source asserts the data valid signal N clocks later if it has data to transfer. This handshaking guarantees a gap in the input stream where the receiver can insert any buffer pixels remaining from any previous transfers. Similarly, removing the data request signal for one clock cycle ensures that a one cycle gap will appear in the input data N clocks later, where the interface can insert one buffered pixel.
  • the source may assert valid as data is available. The source may hold data valid asserted after the receiver deasserts its data request, in order to transfer the data corresponding to any pipelined requests.
  • FIG. 7G illustrates the behavior of the interface, configured for a pipeline depth of N equal to four.
  • data requested on clock 362 is not available until clock 366.
  • Data is transferred again on clocks 368 and 369, corresponding to the requests issued on clocks 366 and 367. Data was not available for clock 370, and the request made on clock 366 was not honored. Data again became available and the requests made on clocks 367, 368, and 369 were fulfilled on clocks 371, 372, and 373. Request was deasserted on clock 370, resulting in no transfer on clock 374.
  • the control logic 354 in Fig. 7F accounts for the lack of valid data when a request for data is made.
  • the present invention also may be used to connect synchronous and continuous flow video stream components with an asynchronous processing element as described above.
  • a decoder 400 that receives an input analog signal to provide a continuous flow video stream of digital data as indicated at 402.
  • This digital data may be fed to a first-in/first-out buffer 404.
  • the FIFO 404 is connected to an asynchronous component using an interface in accordance with the present invention as indicated at 406 and 408.
  • the FIFO has status signals which may be used to provide the appropriate interface signals.
  • a "not empty" indication from the FIFO 404 can provide the valid data signal.
  • the contents of the FIFO include the boundary information and video data.
  • a clock signal can be provided to the interface as well. In this embodiment, the clock signal drives the transfer of data from the FIFO to the asynchronous element 406.
  • the FIFO also may be asynchronous with appropriate modifications to the control signals.
  • the asynchronous element 406 provides the request data signal which is applied to the read enable input to the FIFO. Accordingly, when data is available in the FIFO, it will be transferred to the asynchronous element 406 when the request data signal enables read output from the FIFO.
  • the FIFO should be sufficiently large to account for variations in the access to the FIFO 404 by the asynchronous element 406 so that it does not overflow.
  • the capacity of the FIFO is irrelevant if an input control logic block, such as described above in connection with Figs. 7A-7E is inserted between the decoder and the FIFO.
  • a FAC may not be necessary if the input data is such that time-varying controls are not necessary.
  • Fig. 9 shows a similar connection between an asynchronous element and a synchronous element which receives data from the asynchronous element 410.
  • the interface is still used as indicated at 412.
  • the data is applied to one of two field memories 414 and 416.
  • the field memories are typically sequential memories that have read and write pointers that are reset every time a field is read or written.
  • An encoder 418 reads data from either field memory 414 or 416 in order to provide output analog motion video data.
  • the encoder creates a continuous flow of video stream of digital data between the field memories and the encoder.
  • the field memories provide a request signal.
  • This request signal in one embodiment, may be generated when either field memory 414 or 416 is empty. In general, the request signal only deasserts at field boundaries and the request is valid for an entire field. This specification may simplify some processing by the asynchronous element 410 by allowing burst transfers into the field memory.
  • the connection between elements such as those shown in Figs. 8 and 9 is over a long cable, e.g., one hundred feet long or more.
  • the propagation delay of a change in a request signal or valid signal between a sender and a receiver is such that a transition in the request signal may be detected at the sender several clock cycles after the request signal is changed by the receiver.
  • the sender may wait for requests to stabilize by waiting, e.g., for about sixteen clock cycles, after every boundary signal that is transmitted to determine whether the request signal from the receiver remains asserted. This embodiment is useful where it is known that the request signal is only asserted or deasserted at field boundaries and remains in a particular state for an entire field.
  • Fig. 10 illustrates how the present invention can be applied to allow for interconnection between a processing element utilizing the interface described above with another processing element that does not provide such capability.
  • Fig. 10 shows the asynchronous element 500 connected to another processing element 502.
  • the processing element 502 receives the auxiliary information of the boundary signal as well as the data from the asynchronous element 500.
  • the valid data and request signals are passed through a tracking state machine 504.
  • the tracking state machine provides control information to the element 502 and receives status information from the processing element 502.
  • the processing element 502 must be such that it provides adequate status information to determine whether it is ready to accept data and adequate control inputs to allow the tracking state machine to stall processing by the element 502.
  • the tracking state machine receives a "early" valid data signal and outputs a request data signal to the asynchronous element 500.
  • the early valid data signal is not the one actually output by the interface, but one provided as an input to the output control logic of element 500.
  • the tracking state machine is a copy of the output control logic, such as shown above in Fig. 7B, but without latches for capturing the video data.
  • Fig. 10 illustrates a clock signal provided to all three elements 500, 502 and 504 from an external source, the clock signal may be provided by the asynchronous element 500.
  • the request signal from the processing element 502 also may be associated with its own clock signal.
  • FIG. 11 shows a similar construction for connecting an arbitrary processing element 510 to an asynchronous processing element using an interface of the present invention illustrated at 512.
  • this construction also uses a tracking state machine 514 which provides control inputs to and receives status information from the processing element 510. It outputs a valid data signal to the asynchronous element 512 and receives a request signal. The request signal is the input to the input control logic of the asynchronous element 512.
  • the processing element 510 should have the same characteristics as processing element 502, i.e., such that it outputs the video data and boundary signal to the asynchronous element 512 and has appropriate status information to enable determination of whether output data is valid and appropriate control inputs to enable to stopping and starting the processing of the element by the tracking state machine 514.
  • the tracking state machine is a copy of the input control logic, such as shown in Fig. 7C, but without latches for capturing the video data.
  • the clock signal shown in Fig. 11 may be generated by the sender of the data.
  • the request signal also may be accompanied by its own clock signal.

Abstract

The present invention provides a generic interface which enables asynchronous data processing elements to be interconnected using an interconnection protocol that controls flow of data between the processing elements. The flow control allows the processing elements to be data independent from, i.e., the processing elements need not be designed for a fixed sample rate or resolution, sample fromat and other data dependent factors. When used with digital motion video data, the processing elements may process motion video data at various temporal and spatial resolutions and color formats. Flow of data between processing elements may be controlled by handshake signals indicating whether the sender has valid data and the receiver can receive data. When valid data is available at the sender and is requested by the receiver, a transfer of data occurs. The characteristics of the data, and functions to be performed on the data may be specified using control inputs to the processing elements. A counting circuit may be used to specify the number of the data samples for which the control inputs are valid. The interface allows each processing element to have a small number of storage locations for storing data, such as a pair of registers, which eliminates the need for large buffers and simplifies implementation of the processing element with such flow control as a simple integrated circuit.

Description

APPARATUS AND METHOD FOR CONTROLLING TRANSFER OF DATA BETWEEN PROCESSING ELEMENTS
FIELD OF THE INVENTION
The present invention is related to apparatus and methods for controlling transfer and processing of data by interconnected data processing elements. The invention is more particularly related to the processing of temporally continuous media data, including motion video and audio data.
BACKGROUND OF THE INVENTION Analog motion video signals, such as those used in common television sets, video tape recorders and other analog video systems, are temporally continuous and synchronous signals requiring various elements in a video system to be synchronized in order to be used. In other words, analog motion video signals have a predetermined and fixed rate to which all of the elements in the video system are synchronized. Any element in the video system is designed with the assumption that there will be a constant rate for input and output of motion video information. More recently, it has been possible to store digital motion video data in data files on a computer. There are several methods for playing back such motion video data. One method is called "pushing" or "streaming" of the motion video data. Streaming is based on an assumption that a system can provide an average data flow rate that is the same as the ultimate data flow rate needed to ensure temporally continuous output of analog motion video images to a viewer. Sufficient buffering is used to account for expected latencies in data transfer between elements. In some cases, both the temporal and spatial resolution of the motion video information may need to be reduced. Such systems typically are designed with the assumption that transfer of audio and video data from a source through several processing elements to its ultimate destination can neither be delayed nor stopped. When a general purpose digital computer is used to process motion video information, a constant rate of flow of data generally cannot be maintained. There may be variations in data flow rates due to various latencies in the computer system due to, for example, disk or memory read latency, interrupts from other processing elements in the computer, etc. In addition, in some systems, such as editing systems, the ability to stop and restart playback is desirable. In order to overcome such problems, one method which has been used is to provide sufficient buffering in combination with an ability for data transfer to be stalled, such as shown in U.S. Patent No. 5,045,940 (Peters, et al.) which is hereby incorporated by reference. These principles are used in a computer network as described in published European Patent
Application No. 0674414A2. An extension of this combination to special effects processing is disclosed in PCT Publications WO94/24815 and WO95/26100 which are incorporated by reference. In this system, a data decompressor outputs data into a first buffer, from which it is transferred to a second buffer associated with a special effects processor. The first buffer indicates whether valid data is available. In addition, the special effects processor indicates to a controller associated with the decompressor whether it can receive data based on memory in the second buffer. One drawback of all of these systems is that they require a significant amount of buffering to accommodate for delays in data transfer between elements. In addition, they are designed for use with a single predetermined format of media.
SUMMARY OF THE INVENTION The present invention provides a generic interface which enables asynchronous data processing elements to be interconnected using an interconnection protocol that controls flow of data between the processing elements. The flow control allows the processing elements to be data independent from, i.e., the processing elements need not be designed for a fixed sample rate or resolution, sample format and other data dependent factors. When used with digital motion video data, the processing elements may process motion video data at various temporal and spatial resolutions and color formats. Flow of data between processing elements may be controlled by handshake signals indicating whether the sender has valid data and the receiver can receive data. When valid data is available at the sender and is requested by the receiver, a transfer of data occurs. The characteristics of the data, and functions to be performed on the data may be specified using control inputs to the processing elements. A counting circuit may be used to specify the number of the data samples for which the control inputs are valid. The interface allows each processing element to have a small number of storage locations for storing data, such as a pair of registers, which eliminates the need for large buffers and simplifies implementation of the processing element with such flow control as a simple integrated circuit. Accordingly one aspect of the present invention is an output interface for a sender of data. The interface includes an output including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum defines a boundary of a sample of the data. A valid data signal output line carries a valid data signal associated with a datum which indicates whether the associated datum is valid. A request signal input line carries a request signal from a receiver associated with a datum from the sender which indicates a request for transfer of the associated datum. The interface includes a handshake mechanism which is operative on an edge of an interface clock signal to hold a datum at the sender when either of the request signal or valid data signal associated with the datum are not asserted and to permit transfer of the datum to the receiver through the output when both the request signal and the valid data signal associated with the datum are asserted. In one embodiment, the handshake mechanism is operative on an edge of the interface clock signal to hold the datum on the output when either of the request signal or valid data signal are not asserted and to permit update of the datum on the output when both the request signal and the valid data signal are asserted.
Another aspect of the present invention is an input interface for a receiver of data. The interface has an input, including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum on the data lines defines a boundary of a sample of the data. A valid data signal input line carries a valid data signal associated with a datum from a sender and indicating whether the associated datum is valid. A request signal output line carries a request signal and associated with a datum from the sender and indicating a request for transfer of the associated datum. Data flow is controlled by a handshake mechanism which is operative on an edge of the interface clock signal to accept a datum received through the input when both the request signal and the valid data signal associated with the datum are asserted and not to accept a datum received through the input when either the request signal or the valid data signal associated with the datum are not asserted. In one embodiment, the handshake mechanism does not read the datum on the input when either of the request signal or valid data signal are not asserted and reads the datum on the input when both the request signal and the valid data signal are asserted. Another aspect of the present invention is an integrated circuit with a processing section having an input for receiving data and an output providing processed data. The integrated circuit has an input interface as described above with an output connected to the input of the processing section. The integrated circuit has an output interface with an input connected to the output of the processing section. Input logic is operative on an edge of an interface clock signal to accept a datum received through the input when both the first request signal and the first valid data signal associated with the datum are asserted and for not to accept a datum received through the input when either the first request signal or the first valid data signal associated with the datum are not asserted. Output logic is operative on an edge of a clock signal to hold a datum when either of the second request signal or second valid data signal associated with the datum are not asserted and to permit transfer of the datum to the receiver through the output when both the second request signal and the second valid data signal associated with the datum are asserted.
Another aspect of the invention is a circuit for processing data, comprising a processing element having a first input for receiving data comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the processing element and an output providing processed data. A counting circuit has a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid. Control logic tracks a number of samples processed by the processing element and generates the control signal to the processing element after the processing element outputs the last sample for which the control information is valid. In one embodiment, the processing element includes a plurality of interconnected processors.
Another aspect of the invention is a circuit for processing data, comprising a first processing element having a first input for receiving data comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the first processing element and an output providing processed data. A second processing element has a first input connected to the output of the first processing element and for receiving the processed data comprised of a plurality of samples, a second input which receives control information indicating how the received data is to be processed, a third input for receiving the control signal for starting and stopping processing by the second processing element and an output providing processed data. A counting circuit has a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid. Control logic tracks a number of samples processed by the second processing element and generates the control signal to the first and second processing elements after the second processing element outputs the last sample for which the control information is valid.
BRIEF DESCRIPTION OF THE DRAWING In the drawing,
Fig. 1 is an illustration of the signals connecting two asynchronous video processing elements in an interface according to one embodiment of the present invention; Figs. 2A-2E are timing diagrams illustrating the relationship of signals across the interface of Fig. 1 ;
Fig. 3 A is a block diagram of a processing element having an input and an output both using the asynchronous digital video interface in accordance with the present invention;
Fig. 3B is a block diagram of another embodiment of the processing element of Fig. 3A;
Fig. 3C is a block diagram of a circuit having two processing elements in a single control domain;
Figs. 4A and 4B illustrate two embodiments for double buffering control information; Fig. 5 is a state diagram for a field advance counter; Fig. 6 is a state diagram for a processing element using an interface and field advance counter in one embodiment of the present invention;
Fig. 7A-E are block diagrams of embodiments of the input and output control logic shown in Figs. 3A and 3B;
Fig. 7F-G are a block diagram and timing diagram, respectively, illustrating another embodiment of input interface logic with pipelined handshake signals;
Fig. 8 is a block diagram illustrating an interface in one embodiment of the invention for digital video input;
Fig. 9 is a block diagram illustrating an interface in one embodiment of the invention for digital video output;
Fig. 10 illustrates an embodiment of the present invention where the output of a processing element having an interface in accordance with an embodiment of the present invention is connected to a processing element without such an interface, using a tracking state machine; and
Fig. 11 illustrates the connection of a processing element to a processing element having an interface in accordance with the present invention using a tracking state machine.
DETAILED DESCRIPTION The present invention will be more completely understood through the following detailed description which should be read in conjunction with the attached drawing in which similar reference numbers indicate similar structures. The present invention provides an asynchronous data interface for interconnecting processing elements in a manner which allows the processing elements to be data independent. For example, for digital motion video data the interconnect allows for format independence, temporal and spatial resolution independence, frame rate independence and variability, and faster than real-time transfer of compressed or uncompressed digital motion video data between processing elements. In general, the interface allows processing elements to treat media as computed data rather than temporally continuous data. Because of the data independence of the interconnect and subsequently the processing performed by interconnected processing elements, different formats of data and different media types may be multiplexed with different bandwidths across the same interconnect. The present invention eliminates an assumption that motion video data and audio data cannot be burst across an interconnect.
As a result, motion video data can be processed using the present invention with processing elements that allow for multiple temporal and spatial resolutions, color and pixel representations and resolutions, full motion and less than full motion video, broadcast quality and less than broadcast quality video data, and multiplexing of two or more data streams including video data, key data, other kinds of data and control information and data over the same interconnect.
Fig. 1 illustrates an interface between a sender and a receiver of data. Each of the sender and the receiver may be implemented as separate integrated circuits. A sender 30 is connected to a receiver 32 through a data interconnect 34 that carries data (VDI(9:0)) between devices. While this embodiment is described in connection with video data it may be applied to other kinds of data. Such data includes, but is not limited to video data, key data, audio data, control information or other data. The data type may be agreed upon, by convention or by signals labeled in the data stream or specified by control information. The interface is unidirectional, but the direction may be selectable under appropriate software and/or hardware control, as discussed below. Transaction timing on this video data interface is relative to an edge, e.g., the rising edge, the falling edge or both, of the interface clock (CLK), e.g., a twenty- seven megahertz (27 MHZ) clock present or a signal line 42. The interface clock may be established by either an external source or by the sender, e.g., when source synchronous clocking is used to transmit data over long distances.
The width, in bits, of the data interconnect 34 of the interface depends on the application. For motion video data, both 8-bit and 10-bit data paths are suitable. In such an embodiment, the interface may be a single video component in width, according to an appropriate video format convention. For example, chroma and luma samples alternating on successive clocks following a 4:2:2 convention (CCIR601) may be supported. Other possible formats include, but are not limited to, RGB, 4:4:4, RGBA, 4x4 and 4:2:2:4. In general, the interface is format independent so long as the sender and receiver agree to the selected format. When a 10-bit interface is used for 8-bit only video data, the least significant bits (VDI 1 :0) may be left undefined.
The flow of data from the sender 30 to the receiver 32 across the data interconnect 34 is controlled using two handshake signals. The first handshake signal is a request signal (REQ_N) sent across a signal line 38 from the receiver. The request signal is generated by the receiver and is associated with a datum at the sender which the receiver requests to be transferred. The receiver uses the request signal to indicate its ability to accept new data, which also allows the receiver to pace the flow of data. The request signal also may be asserted by the receiver independent of the second handshake signal, called the valid data signal. The valid data signal (VAL_N) is sent across a signal line 40 from the sender. The valid data signal is associated with a datum at the sender and indicates whether the associated datum is available to be transferred. The valid data signal may be asserted by the sender independent of the request signal. The sender uses the valid data signal to control the flow of information to the receiver. The handshake mechanism from the point of view of the sender is the following.
Upon each edge of an interface clock signal, the request signal and valid data signal associated with a datum available to be transferred are examined. If either signal is not asserted, the datum is held at the sender. If both handshake signals are asserted, then the transfer of the datum to the receiver through the output is permitted.
The handshake mechanism from the point of view of the receiver is the following. Upon each edge of the interface clock signal, the request signal and the valid data signal associated with a particular datum available at the sender to be transferred are examined. If either signal is not asserted, the datum is not accepted to be received through the input. When both the request signal and the valid data signal associated with the datum are asserted the datum is accepted to be received through the input.
In one embodiment, the valid data signal is used to indicate that valid data is present on the data interface 34. The request signal is used to indicate that the data present on the data inferface 34 is requested by the receiver. A transfer of data across the interconnect 34 occurs if both the request signal and valid data signal are asserted when an edge of the interface clock occurs and the data on the data interface 34 is updated. If either signal is negated, then the data transfer does not occur, the data is stored at the sender and the flow of information between the devices is stalled. Suspending data transfer may be effected by suspending the clock controlling latches on the interface or by appropriate feedback circuitry. In other embodiments, to be described below, the request signal and valid data signals may be pipelined or delayed or may be assumed to be valid for a plurality of data to be transferred. A boundary signal (VSYNC_N), sent by the sender across a signal line 36 with the data to the receiver, represents auxiliary information about the data transferred across the interface. This signal may include one or more bits of information. This boundary signal signifies at least the boundary of data for a given sample. For example, for motion video data the boundary signal may designate an image boundary, or another boundary such as a line or pixel or video datum. When used to designate an image boundary, this signal may be asserted at the same time the data for the last component of either a pixel in the image or a key is on the data interconnect 34 in order to indicate the end of the image. The start of data for a sample, such as an image, could be signaled instead of the end. The boundary signal also may be encoded such that a transition in the signal designates an end of field and the state of the signal on the first component of the field indicates the sense (i.e., odd or even) of the field. The auxiliary information also may indicate the presence of data type or other control information. The boundary signal is asserted with the same timing as the data on the data interconnect 34 and follows the same flow control behavior as the data. It is valid also only when the valid data signal is asserted. If the request signal is negated at the time when the boundary signal is asserted, then the boundary signal remains valid as long as the valid data signal is asserted.
Referring now to Fig. 2A, a timing diagram illustrating control of flow of data by the sender using the valid data signal in one embodiment of the invention will now be described. In this example and in those to follow, the request signal (REQ_N), the valid data signal (VAL_N) and the boundary signal (VSYNC_N) are negative logic signals. The valid data signal 54, when asserted, indicates that the sender has placed either valid video data or valid key data 52 on the data interconnect 34. Data is read from the data interconnect 34 by the receiver when both the request signal 56 and the valid data signal 54 are asserted in the same cycle of the interface clock 50. When the valid data signal 54 is not asserted, no valid data exists on the video data interconnect. To simplify illustration, the boundary signal 58 is not asserted. The valid data signal for several clock cycles is shown at 54. Valid data is present at the video data interconnect 52 only when the valid data signal is asserted (cycles 53, 55, 59 and 49). In this example, it is assumed that the request signal, indicated at 56, is asserted for the second and subsequent clock cycles 53, 55, 57, 59 and 49. In this example, data transfer occurs only during clock cycles 53, 55, 59 and 49.
A timing diagram illustrating control of flow of data by the receiver using the request signal in one embodiment of the invention will now be described in connection with Fig. 2B. The request signal (REQ N) indicates whether the receiver is able to accept data from the data interconnect. Data is read from the data interconnect when both the request signal and valid data signal are asserted in the same cycle of the interface clock. When the request signal is not asserted, the receiver is unable to read data from the data interconnect. In the timing diagram in Fig. 2B, a clock signal 50 represents the interface clock applied to the clock inputs of the sender and receiver. Data are shown at 60. The boundary signal 66 is not asserted for simplicity. The valid data signal (VAL_N) is shown at 62 and in this example is constantly asserted. Accordingly, valid data is always available on the data interconnect as illustrated at 60 for clock cycles 61, 63, 65, 67 and 69. The request data signal 64 is initially not asserted, then is asserted for one clock cycle 61 , then not asserted for a clock cycle 63, then asserted for three clock cycles. For any clock cycle in which the request signal is not asserted (i.e., cycle 63), in the subsequent clock cycle (i.e., cycle 65), the data 60 available on the data interconnect does not change. Fig. 2C is a timing diagram representing how the boundary signal is used to indicate the last component of a sample. In this example, the boundary signal represents a field boundary (called a vertical synchronization signal is a synchronous video system). The data on the data interconnect is illustrated at 72. Both the valid data signal (VAL_N) and the request signal (REQ_N) are asserted as shown at 74 and 76, respectively. As indicated at 78, at the fifth clock cycle 77, the data on the data interconnect is a component "yl," and is the last pixel component of the last pixel of a field. The assertion of the boundary signal as indicated in 78 is concurrent with the presentation of this last pixel component on the data interconnect. The boundary signals also may be used to designate other boundaries of other kinds of samples, such as a line or pixel, in the data.
This interface and these handshake signals allow transfer of a variety of types of data between processing elements in a time multiplexed manner. Timing diagrams Figs. 2D through 2F illustrate some examples of the ordering of some formats of video data and key data in one embodiment of the invention. Video component ordering may follow any standard convention, such as CCIR656
4:2:2, as follows (time advances left to right, left component first):
CbO, Y0, CrO, Yl, Cb2, Y2, Cr2, Y3, >
Fig. 2D is a timing diagram illustrating video component ordering. The interface clock signal and boundary signal are illustrated at 50 and 58, respectively. The boundary signal is not asserted. The video data illustrated at 80 illustrates components appearing in the sequence according to a 4:2:2 format. The valid data signal 82 and request data signal 84 are both asserted.
Since the interface is generic in nature, it also may be used to transport key data (e.g., alpha data for alpha compositing) separately from the video data. The interconnect may be used full width or half width in a time multiplexed manner, since the key data consumes only half the interconnection bandwidth in most video applications. Key values are ordered according to corresponding video samples, although a fixed timing relationship is not required at the interconnect. Full width key data occupies the full width of the interconnect, but only half its bandwidth, the ordering is shown below.
KeyO, Keyl, Key2, > Fig. 2E is a timing diagram illustrating key component ordering. The data output by the element is illustrated at 86. It is assumed that the request signal 90 is asserted. As the valid data signal becomes unasserted in the fourth clock cycle 85 and sixth clock cycle 87, no data is available on the video data interface as indicated at 86. Note that the ordering of the data between the third and fifth clock cycles (85 and 87) does not involve any loss of data.
The interface may also be used in a time multiplexed fashion to transfer key data. A
10-bit key value may be transferred using half the interconnect width (5 -bits). 10-bit values also can be time-multiplexed onto an 8-bit bus. This reduces the interface pin count by time multiplexing the key data into upper and lower time slices. The upper or most significant data is sent first followed by the lower or least significant data. When an 8-bit key is used the least significant bit (VDIO) is undefined. Key order is defined (left to right, left first) as:
KeyO(high), KeyO(low), Keyl(high), Key 1 (low), >
Fig. 2F is a timing diagram illustrating multiplexed key component ordering. The key components appear at the video data interconnect as indicated at 92. It is assumed that the request data signal is constantly asserted as shown at 96. The valid data signal controls the output on the video data interface as indicated at 94. For example, in the third clock cycle 93, where the valid data signal is not asserted, the data present on the interface as indicated at 92 is held until the next clock cycle 95. As stated above, multiple types of data may be multiplexed over the same interconnect, including two or more data streams of video data, key data, and other kinds of data and control information. When multiplexing two types of data, each type of data may have its own associated handshake signals. These handshake signals also can be multiplexed over the interconnect. Alternatively, separate interface signals may be provided for the two or more data streams which are multiplexed over the interconnect.
Having now described how transfer of data between processing elements is controlled and how various data types may be multiplexed across a data interconnect, control of processing performed by interconnected processing elements will now be described.
Since there are many possible types and formats of data that can be received by a processing element using this information, and since various functions can be performed on the data, a processing element receives control information about the data and the function to be performed. This control information should change only on sample boundaries. Such control information may include, for motion video data, the size of an image, i.e., its spatial resolution; a position of an image, e.g., for a processing element that is a picture-in-picture processor; brightness; contrast; color correction or other processing information; chroma or luma keys; indications of a blend to be performed; and/or possibly an indication of temporal resolution (i.e., frame rate) or color format. Such control information typically is provided by a host computer or local processor to the processing element so that it is available when the associated video information is available to be processed by the processing element. Control information may be shared by several interconnected processing elements. In order for the processing element to receive correct control information, a control circuit is used to keep track of the number of samples processed by the processing element. The control information may be specified to be valid for a number of samples.
Processing elements interconnected in this manner operate in separate time domains since they are not "slaved" to a master clock. Each processing element, although closely related in time, provides control and state information to the host computer or other controller, so that the host may control and track progress of the processing element.
A device using an interface and control information as described above will now be described in connection with Fig. 3A. Fig. 3A illustrates a device with a single processing element, and both an asynchronous input and an asynchronous output using an interface in accordance with the invention. Other embodiments of a device with asynchronous input signals and synchronous output signals, a processing element with synchronous input signals and asynchronous output signals, and a long interconnect between two asynchronous devices, will be described in more detail below.
In Fig. 3 A, processing element 200 performs most of the processing on the input data. On the input side, the device receives a boundary signal 202, data 204, a valid data input signal 206 and an interface clock 208, and provides an output signal 209 indicating a request. All of these signals are received by input control logic 210, described in more detail below. The interface clock 208 controls latching of the data performed in the input control logic. The processing element 200 receives data from the input control logic, along with the associated boundary signal as indicated at 217. The processing element also provides an output 218 to be used by the input control logic to generate the request signal.
On the output side, the device provides as its output a boundary signal 220, data 222 and a valid data signal 228, and receives both an interface clock signal 224, and an input request signal 226. The output interface clock 224 may be different from the input interface clock 208. The data, boundary signal and valid data signal are provided to output control logic 230, described in more detail below. The output control logic also receives, from the processing element 200, a boundary signal 232, data 234, and valid data signal 236. The output control logic 230 passes on the request signal to the processing element 200 as indicated at 238. Loading of latches within the output control logic occurs upon an edge of the interface clock 224 depending on the state of the valid data and request signals.
The processing element 200 receives control information from control registers 243. The control registers are loaded via a bus connected to the host computer as indicated at 245. The control registers 243 may be implemented using the register constructions shown below in Fig. 4A and 4B. Control information may be double buffered and thus have two states, an "active" state and a "shadow" state. The active state contains the current state used in processing, while the shadow state is the control information for the next function to be performed. The processing element also has an associated a field advance counter 248 which has a corresponding state diagram described below in connection with Fig. 5. The contents of the field advance counter represent the number of data samples for which the active control information is valid. For processing of motion video data, the FAC may be used to represent a number of frames, lines or pixels or other subset of motion video data. The field advance counter decrements every time the boundary signal 232 is asserted at the output of the processing element 200. One or more processing elements that are interconnected using the interface described above define a single "control domain." Each control domain has a corresponding field advance counter. The counter has logic which generates interrupt and loading signals to the host processor to inform the host of its state and to processing element to control processing by the processing element.
An alternate embodiment is shown in Fig. 3B. Fig. 3B includes four three-state buffer arrangements 240, 242, 244 and 246, which enable the device and its interfaces to operate in two directions in a selectable manner. In this embodiment, each interface has a corresponding identical input and output control logic as indicated at 230 and 210A and 210 and 230A. This embodiment is otherwise the same as that in Fig. 3A, and would also include a control information register and field advance counter. In this embodiment, the control information would indicate the direction of flow of information on the input and output interfaces, and the processing element would generate appropriate control signals to control the three-state buffer arrangements 240, 242, 244 and 246.
Fig. 3C illustrates an embodiment with two processing elements 250 and 252 interconnected using an interface in accordance with the present invention as indicated at 254 and controlled by a single field advance counter 256. Accordingly, these elements are part of a single control domain. Processing elements 250 and 252 are interconnected by input/output elements 258, 260, 262 and 264. The field advance counter 256 controls the control information in registers 266. The processing elements 250 and 252 may receive different control information or may share control information. In this embodiment, the processing elements 250 and 252 receive the same outputs indicating whether the counter 256 is at zero, as indicated at 268. However, the counter 256 decrements according to the boundary signal 270 output by the last processing element in the control domain.
Having now described several embodiments of devices incorporating a field advance counter and associated control information for controlling processing of the processing elements, more details of the field advance counter and control information registers will now be described. Two embodiments for performing double buffering of control information will now be described in connection with Figs. 4A and 4B. As shown in Fig. 4A, the host computer writes control information into a shadow register 1 14. Upon the arrival of the next clock edge when the boundary signal output by the processing element is valid, the contents of the shadow register 114 are loaded into the active register 116. The output of the active register is the control information used by the processing elements within the control domain. In another embodiment shown in Fig. 4B, a first register 100 and a second register 102 are connected to first and second inputs, respectively, of a multiplexer 104 which is controlled by a double buffered flag bit 106 to select one of the inputs as its output 108. The output of the multiplexer provides the control information used by the processing elements within the domain. The host computer loads the flag bit in a shadow register 110. Upon the arrival of the next clock edge when the boundary signal output by the processing element is valid, the contents of the shadow register 110 are loaded into an active register 112, the output of which controls the multiplexer 104. If the shadow register was not updated since the last boundary signal, the active register would not change.
Control information is copied from the shadow registers to the active registers, shown in Figs. 4 A and 4B, when a boundary signal output by the processing element becomes asserted or when the processing element is stalled (due to only the FAC being stalled) and the field advance counter transitions to a non-zero value.
The field advance counter (FAC) will now be described in more detail in connection with Fig. 5. The FAC is a counter that has a size corresponding to a maximum number of samples which may be processed by its corresponding processing elements before those elements stop processing. The FAC, for example, may be eight (8) bits, which corresponds to an advance load of 255 samples. It should be understood that the system is designed to support any value loaded into the FAC, including only one sample. The FAC decrements immediately when written if it was in a stalled state prior to being written, as well as when a sample boundary is detected. The FAC signals the processing element to stop processing when the counter is exhausted, i.e, is at zero ('0'), and the last sample is processed, which is signaled by a boundary signal output by the last processing element in the control domain. If there are multiple processing elements at the end of a control domain, the FAC is decremented after all of the processing elements indicate a sample boundary. The FAC also is used to signal the host computer, via an interrupt, when a series of operations is about to be completed at the end of the sample when it transitions to a count of '0.' Upon receiving this interrupt, the host computer can update the control information to take effect after the current sample is processed. If the host computer is unable to respond to the interrupt before the end of the sample, the FAC state of '0' when the boundary signal at the output of the processing element indicates a sample boundary causes the flow of data through the device to stop or stall, and a second interrupt is generated to the host computer. This stalling prevents the processing element from continuing to operate when its control information is no longer valid. Processing continues when a non-zero value is loaded into the FAC and the data of the next sample is ready at the input of the first processing element in the control domain. The host should not write a value into the FAC when the FAC is at one or zero.
During reset the FAC is cleared to a '0' value and no processing occurs by the processing element. After reset, a status bit provides the interrupt to the host to indicate that the FAC has reached '0.' When a non '0' value is loaded into the FAC, control information for the next field becomes immediately available to the associated processing elements in the control domain, and processing by the processing elements in the control domain begins on the new data of the next field as the data become available at the device interface. A state diagram for the field advance counter will now be described in connection with Fig. 5. There are three states: stalled 120, active 122 and FAC at zero 124. When a field advance counter transitions to a non-zero value, the state of the field advance counter transitions from either state 124 or state 120 to the active state 122. When the boundary signal output by the processing element signifies an end of a sample has been reached, and the field advance counter is greater than one, the transition returns to the active state. When the field advance counter is one and a sample boundary is encountered, a transition occurs to the FAC at zero state 124 with an interrupt signal to the host indicating the field advance counter is at zero. If a sample boundary is encountered when the FAC is at zero, a transition occurs to the stalled state 120 and an appropriate interrupt also is sent to the host.
The field advance counter also may include an additional register, herein called a write save register. This write save register captures the current state of the field advance counter when a new value is written to the field advance counter. This register allows processing elements to be cleanly halted by writing a "one" into the field advance counter. To restart, an application may determine a final number of fields to be played by reading the saved value from the write save register. The register may be used, for example, by having the host determine whether the field advance counter value is greater than one, and if greater than one, writing the field advance counter value into the write save register. The write save register also may be implemented directly in hardware. The field advance counter provides the capability for time varying control information to be provided to a processing element. The control information is time-varying since it includes parameters to be applied to one sample and then is updated at the end of each sample for the next sample. Such a capability allows for various data to be multiplexed through the processing element, to allow different kinds of processing to be applied to the same kinds of data through the processing element, and many other features. Where the processing element changes the form of the incoming data, such as by changing its temporal or spatial resolution or color format, different kinds of conversion can be performed. Where the processing element is changing the content, for example by performing a keying function or a blend of two video streams or other manipulation, the actual function performed by the processing element can be varied over time through the changing of the control information.
In order to effectively use the interface and field advance counter as described above, the processing element must be able to start and stop processing based on the information provided by the field advance counter. This restriction is imposed because the control information is only valid for the number of data samples specified by the field advance counter. If the field advance counter is stalled, then the active control information received by the processing element is no longer valid. Fig. 6 is a state machine diagram for the processing element 200 of Figs. 3 A and 3B.
There are two states for a processing element, stalled 280 and active 282. In the stalled state 280, the processing element cannot receive data or output valid data. Accordingly, the request and valid data signals are deasserted. When the field advance counter associated with the processing element transitions to a non-zero value, the processing element transitions to the active state 282. In this state, both the request and valid data signals may be asserted. Whether they are asserted depends on the actual processing performed by the processing element. For example, the processing element may immediately request data, but may not output valid data for several clock cycles until the next output sample is completely computed. In the active state 282 a transition occurs when a boundary signal is generated by the processing element. If the field advance counter is non-zero when the boundary signal generated by the processing element indicates a sample boundary, then the processing element remains in the active state. If the field advance counter is already at zero when the boundary signal generated by the processing element indicates a sample boundary, then the processing element transitions from the active state 282 to the stalled state 280. The state diagram for controlling the processing element may be implemented using control logic associated with the hardware which actually performs the processing. The stalled and active states respectively disable ad enable activity of the processing element.
It should be understood that the stalling occurring in step 280 of Fig. 6 is different from other stalling that may occur due to flow control of data through the data interface that connects interconnected processing elements. In other words, active state 282 may include several states in which the processing element may be actively processing data or may be stalled due to flow control effects from the interface with other components. Stalling due to flow control over the interface may occur at any byte of data, even between components of samples in multiplexed data. On the other hand, stalling of a processing element due to a need for control information typically only occurs between samples. Having now described the processing element field advance counter and control information in a device in accordance with one embodiment of the invention, the input and output control logic will now be described in connection with Fig. 7.
Fig. 7A shows one embodiment of the input and output control logic in Fig. 3A. In this embodiment, the output logic is in essence the same as the input logic; therefore only the input logic will be described. The input control logic, shown in Fig. 7A, includes a first register 300. Its output is applied to a second latch 302 and to a multiplexer 304. The multiplexer 304 also receives the output from register 302. The output of multiplexer 304 is supplied to a register 306. A latch 308 receives the input request and valid data signals and uses them to control multiplexer 304.
The signals illustrated in Fig. 7A are defined in the following table and logic equations. All logic equations herein are in VHDL (IEEE standard 1076-1987).
Figure imgf000020_0001
The logic equations representing the output signals provided by the various logic circuits 300 through 308 in Fig. 7A are represented by the following table:
DVLDO <= I_V2_Q;
DREQO <= NOT I_V2_Q ORNOT V1 Q OR NOT I_V0_Q;
I_V0_EN <= DREQI OR NOT I_V0_Q;
I_V1_EN <= DREQI ORNOT I_V0_Q ORNOT I_V1_Q; I I_VV22_EENN < <== NOTI_V2_QORNOTI_V1_QORNOTI_VO_Q;
I_V0_D <= I_V2_QORI_Vl_Q;
I VI D <= I_V2_Q AND NOT I_V0_EN; I_V2_D <= DVLDI; and
I_D1_EN <= NOT I_V0_Q OR NOT I_V1_Q.
The circuit shown in Fig. 7A may be implemented using a programmable logic array or specialized circuit or discrete hardware components.
The circuit illustrates in Fig. 7A favors output timing. This circuit may be modified to eliminate register 300 as shown in Fig. 7B. The logic equations representing the output signals provided by the various logic circuits 302 through 308 are represented by the following table.
I_VO_EN <= DREQI ORNOT I_V0_Q;
I_V1_EN <= DREQI ORNOT I_V1_Q;
I_D1_EN <= NOTIV1 Q;
I_VO_D <= DVLDI OR I_V1_Q;
I_V1_D <= DVLDI AND NOT I_V0_EN;
DVLDO <= I_V0_Q;
DREQO <= NOT I_V1_Q;
An interface that favors input timing requirements is shown in Fig. 7C. In this figure, the register 306 of Fig. 7A is deleted. The logic equations representing the output signals provided by the various logic circuits 300 through 306 in Fig. 7C are represented by the following table:
I_V0_EN <= NOT I_V0_Q OR NOT I_V1_Q;
I_V1_EN <= NOT I_V1_Q OR DREQI;
I_D1_EN <= NOT I V1 Q; I I__VV00__DD < <== DVLDI;
I_V1_D <= I_V0_Q AND NOT DREQI;
DVLDO <= I_V0_Q OR I_V1_Q;
DREQO <= NOT I_V0_Q OR NOT I_V1_Q; Fig. 7D is a block diagram of an embodiment of the input control logic which optimizes input interface timing parameters. It includes a multiplexer 310, latch 312 connected to the output of multiplexer 310. The output of latch 312 is fed back to an input of the multiplexer 310. The output of latch 312 is also applied to a second multiplexer 314. The output of multiplexer 314 is connected to a data latch 316, whose output is fed back to an input of multiplexer 314. The output data to the interface is provided by the output of the multiplexer 314. The circuit also includes latches 318 and 320 whose signals are described by the logic equations which represent the control equations for the various logic circuits in Fig. 7D: i_m0_en <= i_v0_q AND i_vl_q; i_ml_en <= i_vl_q; i i_ vvO0_ dd < <== dvldi OR (i_v0_q AND i_vl_q); i_vl d <= NOT dreqi AND (i_v0_q OR i_vl_q); dreqo <= NOT i_v0_q OR NOT i_vl_q; dvldo <= i_vO_q OR i_vl_q;
Fig. 7E is a block diagram of an embodiment of the output control logic which is optimized for output interface timing parameters. In this circuit, a multiplexer 330 provides an output to a data latch 332, whose output is fed back to an input of a multiplexer 330. The output of multiplexer 330 is fed to an input of multiplexer 334. The output of multiplexer 334 is applied to a data latch 336. The output of the data latch provides the output of the output control logic and is also fed back to an input of multiplexer 334. Two additional latches are provided as indicated at 338 and 340. The logic equations representing the control of the circuit of Fig. 7E are represented by the following table: ii__mmO0__eenn <<== dreqi OR NOT i_v0_q; i_ml_en <= i_vl_q; i_vO_d <= (i_v0_q AND NOT dreqi) OR i_vl_q OR dvldi; i_vl_d <= NOT dreqi AND (i_vl_q OR (dvldi AND i_v0_q)); dreqo <= NOT i_vl_q; ddvvllddoo <<== i_v0_q;
For some input and output interfaces, it may not be possible to provide the data request/valid handshake described above. For example, the sender may need a number of clock cycles to extract the data from an associated data storage memory. In other words, timing parameters and protocols for accessing data memories associated with the sender may require that the request signal be asserted from the receiver several clock cycles before the valid data signal may be asserted. In general, the latency between the request signal and valid data signal will be fixed and known. The interface therefore uses a pipelined data request/valid handshake to transfer data.
In such a system, a mechanism which stalls the flow of data with a fine level of granularity is used. One example of an interface which provides this capability is shown in Fig. 7F. This circuit may be used where a pixel component requested by one circuit will not be available from another circuit until four clock cycles later, which can occur, for example, when the depth of the control signal pipeline to the memories is four clock cycles. The input interface of the receiving circuit translates requests between internal logic to the sending circuit, buffering the additional pipelined data.
The input interface design, shown in figure 7F, contains a data storage buffer 354 whose capacity for data storage is equal to the latency or pipeline delay from data request to data valid for the sender. In the figure, this value is referred to as N. The circuit includes control logic 350 which controls the insertion and removal of data from the buffer. The control logic 350 performs these operations in response to the pipelined valid data signal from the sender and the internal same-cycle request signal from the processing element. A data latch 356 receives the output from multiplexer 352 to provide data to the processing element. In operation, the control logic 350 provides data from the storage buffer 354 to the receiver when the buffer 354 is not empty by controlling the data multiplexer 352 and the buffer 354. This multiplexer 352 can be used to select either data from the storage buffer 354 or the sender for transfer to the receiver. If the buffer 354 is empty, the control logic 350 controls the multiplexer 352 to provide data from the sender. If valid data arrives from the sender while the control logic 350 is providing data to the receiver from the storage buffer 354, the control logic 350 causes the data to be placed into the storage buffer 354. If valid data arrives from the sender when the receiver cannot accept it, the control logic 350 causes the data to be placed in the storage buffer 354. This situation may occur when the processing element deasserts the request signal, but the sender has not completed processing the preceding pipelined data requests.
In the data transfer protocol for the circuit of Fig. 7F, the data source does not assert the data valid signal until after receiver asserts the data request signal. The source asserts the data valid signal N clocks later if it has data to transfer. This handshaking guarantees a gap in the input stream where the receiver can insert any buffer pixels remaining from any previous transfers. Similarly, removing the data request signal for one clock cycle ensures that a one cycle gap will appear in the input data N clocks later, where the interface can insert one buffered pixel. While the data request signal remains asserted, the source may assert valid as data is available. The source may hold data valid asserted after the receiver deasserts its data request, in order to transfer the data corresponding to any pipelined requests. The timing diagram in Fig. 7G illustrates the behavior of the interface, configured for a pipeline depth of N equal to four. In this example, data requested on clock 362 is not available until clock 366. Note that the deassertion of this request signal on clock 363 causes a corresponding deassertion of the valid data signal on clock 367. Data is transferred again on clocks 368 and 369, corresponding to the requests issued on clocks 366 and 367. Data was not available for clock 370, and the request made on clock 366 was not honored. Data again became available and the requests made on clocks 367, 368, and 369 were fulfilled on clocks 371, 372, and 373. Request was deasserted on clock 370, resulting in no transfer on clock 374. The control logic 354 in Fig. 7F accounts for the lack of valid data when a request for data is made.
Having now described a general embodiment of the present invention, some additional embodiments for use in more specialized circuits will now be described. The present invention also may be used to connect synchronous and continuous flow video stream components with an asynchronous processing element as described above. For example, when inputting digital video information into a computer as shown in Fig. 8, there typically is a decoder 400 that receives an input analog signal to provide a continuous flow video stream of digital data as indicated at 402. This digital data may be fed to a first-in/first-out buffer 404. The FIFO 404 is connected to an asynchronous component using an interface in accordance with the present invention as indicated at 406 and 408. The FIFO has status signals which may be used to provide the appropriate interface signals. For example, a "not empty" indication from the FIFO 404 can provide the valid data signal. The contents of the FIFO include the boundary information and video data. A clock signal can be provided to the interface as well. In this embodiment, the clock signal drives the transfer of data from the FIFO to the asynchronous element 406. The FIFO also may be asynchronous with appropriate modifications to the control signals. The asynchronous element 406 provides the request data signal which is applied to the read enable input to the FIFO. Accordingly, when data is available in the FIFO, it will be transferred to the asynchronous element 406 when the request data signal enables read output from the FIFO. The FIFO should be sufficiently large to account for variations in the access to the FIFO 404 by the asynchronous element 406 so that it does not overflow. In one embodiment, the capacity of the FIFO is irrelevant if an input control logic block, such as described above in connection with Figs. 7A-7E is inserted between the decoder and the FIFO. In this embodiment, a FAC may not be necessary if the input data is such that time-varying controls are not necessary.
Fig. 9 shows a similar connection between an asynchronous element and a synchronous element which receives data from the asynchronous element 410. The interface is still used as indicated at 412. The data is applied to one of two field memories 414 and 416. The field memories are typically sequential memories that have read and write pointers that are reset every time a field is read or written. An encoder 418 reads data from either field memory 414 or 416 in order to provide output analog motion video data. The encoder creates a continuous flow of video stream of digital data between the field memories and the encoder. In order to connect with an asynchronous element 410 over an interface 412, the field memories provide a request signal. This request signal, in one embodiment, may be generated when either field memory 414 or 416 is empty. In general, the request signal only deasserts at field boundaries and the request is valid for an entire field. This specification may simplify some processing by the asynchronous element 410 by allowing burst transfers into the field memory.
In some embodiments, the connection between elements such as those shown in Figs. 8 and 9 is over a long cable, e.g., one hundred feet long or more. In such a circumstance, the propagation delay of a change in a request signal or valid signal between a sender and a receiver is such that a transition in the request signal may be detected at the sender several clock cycles after the request signal is changed by the receiver. To account for such a case, the sender may wait for requests to stabilize by waiting, e.g., for about sixteen clock cycles, after every boundary signal that is transmitted to determine whether the request signal from the receiver remains asserted. This embodiment is useful where it is known that the request signal is only asserted or deasserted at field boundaries and remains in a particular state for an entire field. Fig. 10 illustrates how the present invention can be applied to allow for interconnection between a processing element utilizing the interface described above with another processing element that does not provide such capability. Fig. 10 shows the asynchronous element 500 connected to another processing element 502. The processing element 502 receives the auxiliary information of the boundary signal as well as the data from the asynchronous element 500. The valid data and request signals are passed through a tracking state machine 504. The tracking state machine provides control information to the element 502 and receives status information from the processing element 502. The processing element 502 must be such that it provides adequate status information to determine whether it is ready to accept data and adequate control inputs to allow the tracking state machine to stall processing by the element 502. The tracking state machine receives a "early" valid data signal and outputs a request data signal to the asynchronous element 500. The early valid data signal is not the one actually output by the interface, but one provided as an input to the output control logic of element 500. The tracking state machine is a copy of the output control logic, such as shown above in Fig. 7B, but without latches for capturing the video data. While Fig. 10 illustrates a clock signal provided to all three elements 500, 502 and 504 from an external source, the clock signal may be provided by the asynchronous element 500. The request signal from the processing element 502 also may be associated with its own clock signal. Fig. 11 shows a similar construction for connecting an arbitrary processing element 510 to an asynchronous processing element using an interface of the present invention illustrated at 512. Similarly, this construction also uses a tracking state machine 514 which provides control inputs to and receives status information from the processing element 510. It outputs a valid data signal to the asynchronous element 512 and receives a request signal. The request signal is the input to the input control logic of the asynchronous element 512. The processing element 510 should have the same characteristics as processing element 502, i.e., such that it outputs the video data and boundary signal to the asynchronous element 512 and has appropriate status information to enable determination of whether output data is valid and appropriate control inputs to enable to stopping and starting the processing of the element by the tracking state machine 514. The tracking state machine is a copy of the input control logic, such as shown in Fig. 7C, but without latches for capturing the video data. The clock signal shown in Fig. 11 may be generated by the sender of the data. The request signal also may be accompanied by its own clock signal.
Having now described a few embodiments of the invention, it should be apparent to those skilled in the art that the foregoing is merely illustrative and not limiting, having been presented by way of example only. Numerous modifications and other embodiments are within the scope of one of ordinary skill in the art and are contemplated as falling within the scope of the invention as defined by the appended claims and equivalent thereto. What is claimed is:

Claims

1. An output interface for a sender of data, comprising: an output, including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum defines a boundary of a sample of the data; a valid data signal output line for carrying a valid data signal and associated with a datum and indicating whether the associated datum is valid; a request signal input line for carrying a request signal from a receiver and associated with a datum from the sender and indicating a request for transfer of the associated datum; and means, operative on an edge of an interface clock signal, for holding a datum at the sender when either of the request signal or valid data signal associated with the datum are not asserted and for permitting transfer of the datum to the receiver through the output when both the request signal and the valid data signal associated with the datum are asserted.
2. The output interface of claim 1, wherein the means for holding and permitting transfer includes means, operative on an edge of the interface clock signal, for holding the datum on the output when either of the request signal or valid data signal are not asserted and for permitting update of the datum on the output when both the request signal and the valid data signal are asserted.
3. An input interface for a receiver of data, comprising: an input, including data lines for carrying a datum and a boundary signal line for carrying a signal indicating whether the datum on the data lines defines a boundary of a sample of the data; a valid data signal input line for carrying a valid data signal associated with a datum from a sender and indicating whether the associated datum is valid; a request signal output line for carrying a request signal and associated with a datum from the sender and indicating a request for transfer of the associated datum; and means, operative on an edge of the interface clock signal, for accepting a datum received through the input when both the request signal and the valid data signal associated with the datum are asserted and for not accepting a datum received through the input when either the request signal or the valid data signal associated with the datum are not asserted.
4. The input interface of claim 3, wherein the means for accepting and not accepting a datum includes means, operative on an edge of the interface clock signal, for not reading the datum on the input when either of the request signal or valid data signal are not asserted and for reading the datum on the input when both the request signal and the valid data signal are asserted.
5. An integrated circuit, comprising: (a) processing section having an input for receiving data and an output providing processed data;
(b) an input interface having:
(i) an input, including data lines for carrying a datum and a boundary signal line for carrying a first boundary signal indicating whether the datum on the data lines defines a boundary of a sample of the data;
(ii) a valid data signal input line for carrying a first valid data signal associated with a datum from a sender and indicating whether the associated datum is valid; (iii) a request signal output line for carrying a first request signal and associated with a datum from the sender and indicating a request for transfer of the associated datum; and
(iv) an output connected to the input of the processing section;
(c) input logic, operative on an edge of an interface clock signal, for accepting a datum received through the input when both the first request signal and the first valid data signal associated with the datum are asserted and for not accepting a datum received through the input when either the request signal or the valid data signal associated with the datum are not asserted; and
(d) an output interface having:
(i) an output, including data lines for carrying a datum and a boundary signal line for carrying a second boundary signal indicating whether the datum defines a boundary of a sample of the data;
(ii) a valid data signal output line for carrying a second valid data signal and associated with a datum and indicating whether the associated datum is valid; (iii) a request signal input line for carrying a second request signal from a receiver and associated with a datum from the sender and indicating a request for transfer of the associated datum; and
(iv) an input connected to the output of the processing section; and (e) output logic operative on an edge of a clock signal, for holding a datum when either of the second request signal or second valid data signal associated with the datum are not asserted and for permitting transfer of the datum to the receiver through the output when both the second request signal and the second valid data signal associated with the datum are asserted.
6. A circuit for processing data, comprising: a processing element having a first input for receiving data, comprised of a plurality of samples, a second input for receiving control information, indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the processing element and an output providing processed data; a counting circuit having a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid, and control logic for tracking a number of samples processed by the processing element and for generating the control signal to the processing element after the processing element outputs the last sample for which the control information is valid.
7. The circuit of claim 6, wherein the processing element includes a plurality of interconnected processors.
8. A circuit for processing data, comprising: a first processing element having a first input for receiving data, comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving a control signal for starting and stopping processing by the first processing element and an output providing processed data; a second processing element having a first input connected to the output of the first processing element and for receiving the processed data comprised of a plurality of samples, a second input for receiving control information indicating how the received data is to be processed, a third input for receiving the control signal for starting and stopping processing by the second processing element and an output providing processed data; and a counting circuit having a first input for receiving a value to be loaded to provide an output, wherein the output indicates a number of samples of the processed data for which the control information is valid, and control logic for tracking a number of samples processed by the second processing element and for generating the control signal to the first and second processing elements after the second processing element outputs the last sample for which the control information is valid.
PCT/US1998/012883 1997-06-20 1998-06-19 Apparatus and method for controlling transfer of data between processing elements WO1998059494A1 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
JP50490299A JP2002511171A (en) 1997-06-20 1998-06-19 Apparatus and method for controlling data transfer between processing elements
EP98931437A EP0988756B1 (en) 1997-06-20 1998-06-19 Apparatus and method for controlling transfer of data between processing elements
AU81572/98A AU8157298A (en) 1997-06-20 1998-06-19 Apparatus and method for controlling transfer of data between processing elements
DE69801754T DE69801754T2 (en) 1997-06-20 1998-06-19 METHOD AND DEVICE FOR CONTROLLING THE TRANSFER OF DATA BETWEEN PROCESSING ELEMENTS
CA002294153A CA2294153A1 (en) 1997-06-20 1998-06-19 Apparatus and method for controlling transfer of data between processing elements

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/879,981 1997-06-20
US08/879,981 US6105083A (en) 1997-06-20 1997-06-20 Apparatus and method for controlling transfer of data between and processing of data by interconnected data processing elements

Publications (2)

Publication Number Publication Date
WO1998059494A1 WO1998059494A1 (en) 1998-12-30
WO1998059494A9 true WO1998059494A9 (en) 1999-05-06

Family

ID=25375278

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1998/012883 WO1998059494A1 (en) 1997-06-20 1998-06-19 Apparatus and method for controlling transfer of data between processing elements

Country Status (7)

Country Link
US (1) US6105083A (en)
EP (1) EP0988756B1 (en)
JP (1) JP2002511171A (en)
AU (1) AU8157298A (en)
CA (1) CA2294153A1 (en)
DE (1) DE69801754T2 (en)
WO (1) WO1998059494A1 (en)

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4197755B2 (en) * 1997-11-19 2008-12-17 富士通株式会社 Signal transmission system, receiver circuit of the signal transmission system, and semiconductor memory device to which the signal transmission system is applied
US6141691A (en) * 1998-04-03 2000-10-31 Avid Technology, Inc. Apparatus and method for controlling transfer of data between and processing of data by interconnected data processing elements
US6327253B1 (en) 1998-04-03 2001-12-04 Avid Technology, Inc. Method and apparatus for controlling switching of connections among data processing devices
US6961801B1 (en) 1998-04-03 2005-11-01 Avid Technology, Inc. Method and apparatus for accessing video data in memory across flow-controlled interconnects
WO1999052277A1 (en) * 1998-04-03 1999-10-14 Avid Technology, Inc. A multi stream video editing system using uncompressed video data for real-time rendering performance, and for non real-time rendering acceleration
US6198477B1 (en) 1998-04-03 2001-03-06 Avid Technology, Inc. Multistream switch-based video editing architecture
US20030133448A1 (en) * 1998-04-03 2003-07-17 Craig R. Frink Packet protocol for encoding and decoding video data and data flow signals and devices for implementing the packet protocol
US6163819A (en) * 1998-07-21 2000-12-19 Micron Technology, Inc. Sequential data transfer circuit
US6732210B1 (en) * 2000-01-03 2004-05-04 Genesis Microchip Inc Communication bus for a multi-processor system
US6651116B1 (en) * 2000-05-15 2003-11-18 International Business Machines Corporation Output interface for a raster object memory in a method, system and program
US7000044B2 (en) * 2000-09-25 2006-02-14 Olympus Corporation Electronic camera and data transmission system
US20020108115A1 (en) * 2000-12-11 2002-08-08 The Associated Press News and other information delivery system and method
KR100903905B1 (en) 2001-09-19 2009-06-19 톰슨 라이센싱 Apparatus and process for limiting a data transfer bandwidth through handshake suppression
WO2003038641A1 (en) * 2001-10-31 2003-05-08 Thomson Licensing S.A. Admission control system for home video servers
US7949777B2 (en) * 2002-11-01 2011-05-24 Avid Technology, Inc. Communication protocol for controlling transfer of temporal data over a bus between devices in synchronization with a periodic reference signal
US20070186076A1 (en) * 2003-06-18 2007-08-09 Jones Anthony M Data pipeline transport system
JP2007526539A (en) * 2003-06-18 2007-09-13 アンブリック, インコーポレイテッド Integrated circuit development system
US7426578B2 (en) 2003-12-12 2008-09-16 Intercall, Inc. Systems and methods for synchronizing data between communication devices in a networked environment
US7624209B1 (en) * 2004-09-15 2009-11-24 Xilinx, Inc. Method of and circuit for enabling variable latency data transfers
JP5052220B2 (en) * 2007-06-19 2012-10-17 パナソニック株式会社 Video encoding device
JP4674614B2 (en) * 2008-04-18 2011-04-20 ソニー株式会社 Signal processing apparatus and control method, signal processing method, program, and signal processing system
WO2009147566A1 (en) * 2008-06-02 2009-12-10 Koninklijke Philips Electronics N.V. Asynchronous communication
KR101706181B1 (en) 2011-06-29 2017-02-13 삼성전자주식회사 Broadcast receiving device and Method for receiving broadcast thereof
US9928190B2 (en) * 2015-06-15 2018-03-27 International Business Machines Corporation High bandwidth low latency data exchange between processing elements

Family Cites Families (127)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US2927154A (en) * 1960-03-01 Jtweattotis
US3123668A (en) * 1964-03-03 Video
US3925815A (en) * 1955-06-14 1975-12-09 Jerome H Lemelson Video transducing apparatus and method for editing
NL283442A (en) * 1961-10-02
BE630758A (en) * 1962-04-09
US4209843A (en) * 1975-02-14 1980-06-24 Hyatt Gilbert P Method and apparatus for signal enhancement with improved digital filtering
US3721757A (en) * 1971-02-08 1973-03-20 Columbia Broadcasting Syst Inc Method and apparatus for automatically editing television information
US3740463A (en) * 1971-02-16 1973-06-19 Memorex Corp Improved editing system
US3748381A (en) * 1971-02-16 1973-07-24 Memorex Corp Improved editing system
US3824336A (en) * 1972-03-17 1974-07-16 Teletronics Int Inc Editing system and method
US3787617A (en) * 1972-05-15 1974-01-22 Spectra Vision Corp Magnetic tape editing method and system
US4001882A (en) * 1975-03-12 1977-01-04 Spectra-Vision Corporation Magnetic tape editing, previewing and animating method and system
GB1578433A (en) * 1976-07-19 1980-11-05 Rca Corp Special video effect generator
US4100607A (en) * 1977-02-07 1978-07-11 Convergence Corporation Computer for video tape editing system
US4149242A (en) * 1977-05-06 1979-04-10 Bell Telephone Laboratories, Incorporated Data interface apparatus for multiple sequential processors
FR2426296A1 (en) * 1978-05-18 1979-12-14 Thomson Csf VECTOR GENERATOR FOR GRAPHIC CONSOLE
US4205346A (en) * 1978-06-09 1980-05-27 Ross Video Limited Video transition circuitry including transition previewing means
US4272790A (en) * 1979-03-26 1981-06-09 Convergence Corporation Video tape editing system
SE451513B (en) * 1979-05-31 1987-10-12 Sony Corp SET AND DEVICE FOR EDITING DIGITAL SIGNALS
US4375083A (en) * 1980-01-31 1983-02-22 Bell Telephone Laboratories, Incorporated Signal sequence editing method and apparatus with automatic time fitting of edited segments
US4283745A (en) * 1980-04-11 1981-08-11 Sony Corporation Editing apparatus
US5216755A (en) * 1980-12-04 1993-06-01 Quantel Limited Video image creation system which proportionally mixes previously created image pixel data with currently created data
JPS57191703A (en) * 1981-05-20 1982-11-25 Fanuc Ltd Sequence controller
JPS6053349B2 (en) * 1981-06-19 1985-11-25 株式会社日立製作所 image processing processor
US4602286A (en) * 1982-01-15 1986-07-22 Quantel Limited Video processing for composite images
US4538188A (en) * 1982-12-22 1985-08-27 Montage Computer Corporation Video composition method and apparatus
US4937685A (en) * 1983-12-02 1990-06-26 Lex Computer And Management Corporation Method of display presentation for video editing
US4685003A (en) * 1983-12-02 1987-08-04 Lex Computing & Management Corporation Video composition method and apparatus for providing simultaneous inputting and sorting of video source material
US4979050A (en) * 1983-12-02 1990-12-18 Lex Computer And Management Corporation Video composition method for assembling video segments
US4541008A (en) * 1982-12-27 1985-09-10 Jones Futura Foundation, Ltd. Television signal bandwidth reduction using variable rate transmission
US5459529A (en) * 1983-01-10 1995-10-17 Quantel, Ltd. Video processing for composite images
JPS59135680A (en) * 1983-01-24 1984-08-03 Asaka:Kk Viewer for video edition
US4558302A (en) * 1983-06-20 1985-12-10 Sperry Corporation High speed data compression and decompression apparatus and method
US4964004A (en) * 1983-12-02 1990-10-16 Lex Computer And Management Corporation Video composition method and apparatus employing visual and tactile feedback
US4717971A (en) * 1984-08-24 1988-01-05 Eastman Kodak Company Partitioned editing method for a collection of video still pictures
US4698664A (en) * 1985-03-04 1987-10-06 Apert-Herzog Corporation Audio-visual monitoring system
US4746994A (en) * 1985-08-22 1988-05-24 Cinedco, California Limited Partnership Computer-based video editing system
US4750050A (en) * 1985-12-11 1988-06-07 Corporate Communications Consultants, Inc. Editing system and method
US4698682A (en) * 1986-03-05 1987-10-06 Rca Corporation Video apparatus and method for producing the illusion of motion from a sequence of still images
US4694343A (en) * 1986-03-28 1987-09-15 Ampex Corporation Digital effects device integrally combined within a video switcher
US4956725A (en) * 1986-08-29 1990-09-11 Canon Kabushiki Kaisha Image signal reproducing apparatus
JP2504018B2 (en) * 1987-01-25 1996-06-05 日本電気株式会社 Input circuit
US5048012A (en) * 1987-04-03 1991-09-10 Advanced Micro Devices, Inc. Data link controller with flexible multiplexer
US5081701A (en) * 1987-04-20 1992-01-14 Tandem Computers Incorporated System for controlling data transfer using transfer handshake protocol using transfer complete and transfer inhibit signals
US5126851A (en) * 1987-06-16 1992-06-30 Canon Kabushiki Kaisha Video system using two different kinds of recording media
US4785349A (en) * 1987-10-05 1988-11-15 Technology Inc. 64 Digital video decompression system
US4972274A (en) * 1988-03-04 1990-11-20 Chyron Corporation Synchronizing video edits with film edits
US4858011A (en) * 1988-04-04 1989-08-15 Jackson Richard A Video switcher system with modular architecture
JP2555141B2 (en) * 1988-04-15 1996-11-20 株式会社日立製作所 Image processing device
JPH077375B2 (en) * 1988-06-17 1995-01-30 日本電気株式会社 Bus control method
US4994914A (en) * 1988-06-21 1991-02-19 Digital Equipment Corporation Composite video image device and related method
JPH0268644A (en) * 1988-09-02 1990-03-08 Matsushita Electric Ind Co Ltd Data transfer control circuit
US5050066A (en) * 1988-10-14 1991-09-17 Intel Corporation Apparatus with a single memory and a plurality of queue counters for queuing requests and replies on a pipelined packet bus
US5222219A (en) * 1988-10-25 1993-06-22 Hewlett-Packard Company Pipeline computer system having write order preservation
US5164839A (en) * 1988-12-27 1992-11-17 Explore Technology, Inc. Method for handling audio/video source information
DE3900489C2 (en) * 1989-01-10 1996-04-04 Broadcast Television Syst Device for generating control signals for a video mixing device
US5109482A (en) * 1989-01-11 1992-04-28 David Bohrman Interactive video control system for displaying user-selectable clips
US5119441A (en) * 1989-03-28 1992-06-02 Ricoh Company, Ltd. Optical character recognition apparatus and method using masks operation
US4970663A (en) * 1989-04-28 1990-11-13 Avid Technology, Inc. Method and apparatus for manipulating digital video data
GB8913638D0 (en) * 1989-06-14 1989-08-02 Quantel Ltd Electronic image composition systems
US5111409A (en) * 1989-07-21 1992-05-05 Elon Gasper Authoring and use systems for sound synchronized animation
GB2235815A (en) 1989-09-01 1991-03-13 Compact Video Group Inc Digital dialog editor
JPH03205976A (en) * 1989-10-27 1991-09-09 Nec Corp Picture synthesizing system using special effector
US5227863A (en) * 1989-11-14 1993-07-13 Intelligent Resources Integrated Systems, Inc. Programmable digital video processing system
US5045940A (en) * 1989-12-22 1991-09-03 Avid Technology, Inc. Video/audio transmission systsem and method
US5267351A (en) * 1989-12-22 1993-11-30 Avid Technology, Inc. Media storage and retrieval system
US5218672A (en) * 1990-01-19 1993-06-08 Sony Corporation Of America Offline editing system with user interface for controlling edit list generation
JP2796160B2 (en) * 1990-02-21 1998-09-10 株式会社日立製作所 Industrial robot teaching device
US5260695A (en) * 1990-03-14 1993-11-09 Hewlett-Packard Company Color map image fader for graphics window subsystem
JP2984311B2 (en) * 1990-04-04 1999-11-29 キヤノン株式会社 Still image playback device
US5189516A (en) * 1990-04-23 1993-02-23 The Grass Valley Group, Inc. Video preview system for allowing multiple outputs to be viewed simultaneously on the same monitor
US5237648A (en) * 1990-06-08 1993-08-17 Apple Computer, Inc. Apparatus and method for editing a video recording by selecting and displaying video clips
US5161019A (en) 1990-06-29 1992-11-03 Rca Thomson Licensing Corporation "channel guide" automatically activated by the absence of program information
US5237567A (en) * 1990-10-31 1993-08-17 Control Data Systems, Inc. Processor communication bus
JP2964631B2 (en) * 1990-11-30 1999-10-18 ソニー株式会社 Special effects device
US5191645A (en) * 1991-02-28 1993-03-02 Sony Corporation Of America Digital signal processing system employing icon displays
US5194952A (en) * 1991-03-28 1993-03-16 Abekas Video Systems, Inc. Video processing system having improved transition control and display
US5192999A (en) * 1991-04-25 1993-03-09 Compuadd Corporation Multipurpose computerized television
JP2581341B2 (en) * 1991-04-26 1997-02-12 日本ビクター株式会社 High efficiency encoding device and decoding device
US5353391A (en) * 1991-05-06 1994-10-04 Apple Computer, Inc. Method apparatus for transitioning between sequences of images
US5646750A (en) 1991-06-05 1997-07-08 Sony Corporation Method and apparatus for compressing video in a manner characteristic of photographic film
US5241389A (en) * 1991-07-29 1993-08-31 Intelligent Resources Integrated Systems, Inc. Video display system providing for synchronization of multiple video data streams
EP0526064B1 (en) * 1991-08-02 1997-09-10 The Grass Valley Group, Inc. Video editing system operator interface for visualization and interactive control of video material
US5321500A (en) * 1991-08-07 1994-06-14 Sony Electronics Inc. Non-real-time film scanning system
US5255373A (en) * 1991-08-07 1993-10-19 Hewlett-Packard Company Decreasing average time to access a computer bus by eliminating arbitration delay when the bus is idle
US5257113A (en) * 1991-09-20 1993-10-26 International Business Machines Corporation Video mixing technique using JPEG compressed data
GB2260458B (en) 1991-10-04 1995-03-22 Sony Broadcast & Communication Data decoder
US5412773A (en) * 1991-11-19 1995-05-02 Sony Electronics Inc. Computerized interactive menu-driven video signal processing apparatus and method
US5355450A (en) 1992-04-10 1994-10-11 Avid Technology, Inc. Media composer with adjustable source material compression
US5274760A (en) * 1991-12-24 1993-12-28 International Business Machines Corporation Extendable multiple image-buffer for graphics systems
US5255375A (en) * 1992-01-10 1993-10-19 Digital Equipment Corporation High performance interface between an asynchronous bus and one or more processors or the like
DE4201335A1 (en) 1992-01-20 1993-07-22 Philips Patentverwaltung Mixing method for interlaced and progressive video signals - using time-compressing circuit consisting of RAMs, switches and controller to store alternate lines of interlaced video signal
US5287420A (en) * 1992-04-08 1994-02-15 Supermac Technology Method for image compression on a personal computer
US5305438A (en) * 1992-05-19 1994-04-19 Sony Electronics Inc. Video storage, processing, and distribution system using recording format independent hierarchical storages and processors
US5432900A (en) * 1992-06-19 1995-07-11 Intel Corporation Integrated graphics and video computer display system
US5243447A (en) * 1992-06-19 1993-09-07 Intel Corporation Enhanced single frame buffer display system
DE69229338T2 (en) 1992-06-30 1999-12-16 Discovision Ass Data pipeline system
US5682326A (en) 1992-08-03 1997-10-28 Radius Inc. Desktop digital video processing system
DE4229394A1 (en) 1992-09-03 1994-03-10 Ingolf Dipl Ing Menzel Adaptive quantisation method for colour-images - performing separate quantisation of brightness and colour components of input image values for each image element
JP2548497B2 (en) 1992-10-09 1996-10-30 松下電器産業株式会社 Video editing equipment
US5581784A (en) 1992-11-17 1996-12-03 Starlight Networks Method for performing I/O's in a storage system to maintain the continuity of a plurality of video streams
JPH06205292A (en) * 1992-11-27 1994-07-22 Matsushita Electric Ind Co Ltd Edit device
JP3036287B2 (en) * 1992-12-15 2000-04-24 富士ゼロックス株式会社 Video scene detector
CA2115976C (en) 1993-02-23 2002-08-06 Saiprasad V. Naimpally Digital high definition television video recorder with trick-play features
US5373327A (en) * 1993-02-25 1994-12-13 Hewlett-Packard Company Detection, correction and display of illegal color information in a digital video signal
US5315390A (en) * 1993-04-02 1994-05-24 The Grass Valley Group, Inc. Simple compositing system which processes one frame of each sequence of frames in turn and combines them in parallel to create the final composite sequence
US5440348A (en) * 1993-04-16 1995-08-08 Avid Technology, Inc. Method and user interface for creating, specifying and adjusting motion picture transitions
US5644364A (en) 1993-04-16 1997-07-01 Avid Technology, Inc. Media pipeline with multichannel video processing and playback
US5754186A (en) 1993-05-10 1998-05-19 Apple Computer, Inc. Method and apparatus for blending images
US5638501A (en) 1993-05-10 1997-06-10 Apple Computer, Inc. Method and apparatus for displaying an overlay image
US5329365A (en) * 1993-07-07 1994-07-12 Rca Thomson Licensing Corporation Method and apparatus for providing compressed non-interlaced scanned video signal
US5499050A (en) * 1993-11-01 1996-03-12 Intel Corporation Method and apparatus for monitoring video compression processing
EP0657887B1 (en) 1993-12-13 2001-09-05 Sony Corporation Editing systems and methods
US5508940A (en) * 1994-02-14 1996-04-16 Sony Corporation Of Japan And Sony Electronics, Inc. Random access audio/video processor with multiple outputs
EP0752184B1 (en) 1994-03-18 2002-12-04 Avid Technology, Inc. Pipeline processing of still images adapted for real time execution of digital video effects
JP3501301B2 (en) 1994-03-18 2004-03-02 ソニー株式会社 I / O signal switching device
US5732239A (en) 1994-05-19 1998-03-24 Starlight Networks Method for operating a disk storage system which stores video data so as to maintain the continuity of a plurality of video streams
US5495291A (en) * 1994-07-22 1996-02-27 Hewlett-Packard Company Decompression system for compressed video data for providing uninterrupted decompressed video data output
US5559562A (en) 1994-11-01 1996-09-24 Ferster; William MPEG editor method and apparatus
WO1996017313A1 (en) 1994-11-18 1996-06-06 Oracle Corporation Method and apparatus for indexing multimedia information streams
US5528301A (en) * 1995-03-31 1996-06-18 Panasonic Technologies, Inc. Universal video format sample size converter
US5623308A (en) 1995-07-07 1997-04-22 Lucent Technologies Inc. Multiple resolution, multi-stream video system using a single standard coder
US5659539A (en) 1995-07-14 1997-08-19 Oracle Corporation Method and apparatus for frame accurate access of digital audio-visual information
US5949948A (en) 1995-11-20 1999-09-07 Imedia Corporation Method and apparatus for implementing playback features for compressed video data
JPH09261648A (en) 1996-03-21 1997-10-03 Fujitsu Ltd Scene change detector
US5768447A (en) 1996-06-14 1998-06-16 David Sarnoff Research Center, Inc. Method for indexing image information using a reference model
US5883670A (en) 1996-08-02 1999-03-16 Avid Technology, Inc. Motion video processing circuit for capture playback and manipulation of digital motion video information on a computer

Also Published As

Publication number Publication date
DE69801754T2 (en) 2002-07-04
US6105083A (en) 2000-08-15
CA2294153A1 (en) 1998-12-30
WO1998059494A1 (en) 1998-12-30
EP0988756B1 (en) 2001-09-19
DE69801754D1 (en) 2001-10-25
JP2002511171A (en) 2002-04-09
AU8157298A (en) 1999-01-04
EP0988756A1 (en) 2000-03-29

Similar Documents

Publication Publication Date Title
EP0988756B1 (en) Apparatus and method for controlling transfer of data between processing elements
US6141691A (en) Apparatus and method for controlling transfer of data between and processing of data by interconnected data processing elements
US6297794B1 (en) Method of switching video sources and computer system employing this method
US6091778A (en) Motion video processing circuit for capture, playback and manipulation of digital motion video information on a computer
EP1068734B1 (en) Method and apparatus for controlling data flow between devices connected by a memory
US6327253B1 (en) Method and apparatus for controlling switching of connections among data processing devices
US6118835A (en) Apparatus and method of synchronizing two logic blocks operating at different rates
EP0916225B1 (en) Motion video processing circuit for capture, playback and manipulation of digital motion video information on a computer
EP1414015B1 (en) Video bus for a video decoding system
JPH0814983B2 (en) Compatible FIFO memory controller
JP3639580B2 (en) Cascade output of encoder system with multiple encoders
US6961801B1 (en) Method and apparatus for accessing video data in memory across flow-controlled interconnects
US6865654B2 (en) Device for interfacing asynchronous data using first-in-first-out
JP2567428B2 (en) Data transfer rate converter
KR100242308B1 (en) Sharing apparatus of mpeg in personal computer and cdi

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AU CA CN DE GB JP

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: C2

Designated state(s): AU CA CN DE GB JP

AL Designated countries for regional patents

Kind code of ref document: C2

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

COP Corrected version of pamphlet

Free format text: PAGES 1/13-4/13 AND 6/13-13/13, DRAWINGS, REPLACED BY NEW PAGES 1/18-5/18 AND 7/18-18/18; PAGE 5/13RENUMBERED AS PAGE 6/18; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

ENP Entry into the national phase

Ref document number: 2294153

Country of ref document: CA

Ref country code: CA

Ref document number: 2294153

Kind code of ref document: A

Format of ref document f/p: F

WWE Wipo information: entry into national phase

Ref document number: 81572/98

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 1998931437

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1998931437

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWG Wipo information: grant in national office

Ref document number: 1998931437

Country of ref document: EP