+

WO1998013767A1 - Multimedia data controller - Google Patents

Multimedia data controller Download PDF

Info

Publication number
WO1998013767A1
WO1998013767A1 PCT/US1997/017197 US9717197W WO9813767A1 WO 1998013767 A1 WO1998013767 A1 WO 1998013767A1 US 9717197 W US9717197 W US 9717197W WO 9813767 A1 WO9813767 A1 WO 9813767A1
Authority
WO
WIPO (PCT)
Prior art keywords
cpu
data
die
buffer
bus
Prior art date
Application number
PCT/US1997/017197
Other languages
French (fr)
Other versions
WO1998013767A9 (en
Inventor
Dale Gulick
Original Assignee
Advanced Micro Devices, 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 Advanced Micro Devices, Inc. filed Critical Advanced Micro Devices, Inc.
Priority to EP97943566A priority Critical patent/EP0928452A1/en
Publication of WO1998013767A1 publication Critical patent/WO1998013767A1/en
Publication of WO1998013767A9 publication Critical patent/WO1998013767A9/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/10Program control for peripheral devices
    • G06F13/12Program control for peripheral devices using hardware independent of the central processor, e.g. channel or peripheral processor
    • G06F13/122Program control for peripheral devices using hardware independent of the central processor, e.g. channel or peripheral processor where hardware performs an I/O function other than control of data transfer
    • 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/40Bus structure
    • G06F13/4004Coupling between buses
    • G06F13/4027Coupling between buses using bus bridges
    • G06F13/405Coupling between buses using bus bridges where the bridge performs a synchronising function
    • G06F13/4059Coupling between buses using bus bridges where the bridge performs a synchronising function where the synchronisation uses buffers, e.g. for speed matching between buses

Definitions

  • the present invention relates generally to the design and development of microprocessor and memory systems within computers. More particularly, the present invention relates to transmission of data between a CPU and devices external to the CPU. Still more particularly, the present invention relates to data transmission between a CPU and a multimedia device using receive and transmit FTFO buffers.
  • multimedia computers may present video images and/or audio tracks from a medium such as a CD-ROM.
  • FIG. 1 shows a typical prior art computer system depicting the elements relevant to the present discussion.
  • a central processing unit (CPU) core 10 is coupled to an LI cache system 15 and a bus Input/Output (I O) device 16 over a CPU local bus 8.
  • the LI cache system 15 typically includes a cache controller and a cache SRAM (not shown).
  • the CPU core 10, LI cache system 15, and bus I/O 16 may be implemented as separate discrete components but preferably are integrated onto a single chip processor as indicated by dashed box 9.
  • the bus I/O device 16 couples the CPU local bus 8 to a memory bus 11.
  • a memory control unit or memory controller 12 also couples to the memory bus 11.
  • a second level cache, referred to as an L2 cache 7, couples to the memory bus 11 and also couples to the memory control unit 12.
  • the memory control unit 12 couples to a memory device 13.
  • the memory device 13 typically is dynamic random access memory (DRAM).
  • DRAM dynamic random access memory
  • a bus bridge 17 couples the memory bus 11 to a peripheral bus 18.
  • Peripheral devices 19 are coupled to the peripheral bus.
  • a multimedia device 190 represents one type of peripheral device which is coupled to the peripheral bus 18. Examples of multimedia devices are CD-ROM drives, graphics cards, video recorders, sound cards, modems, and the like.
  • a simple communication scheme allows data from the CPU core 10 to be placed on the CPU local bus 11 and tr.ansferred through the bus I/O device 16, memory bus 11, bus bridge 17, peripheral bus 18, and to a peripheral device/ multimedia device.
  • Data communication from the peripheral devices 19 and 190 to the CPU core 10 follows the same path, albeit in the reverse order.
  • the CPU core 10 typically engages in multiple activities such as access cycles to the memory device 13 through memory control unit 12, accesses to the LI cache SRAM 15, as well as receiving and transmitting data to a variety of peripheral devices 19/190.
  • the CPU core 10 often performs digital signal processing (DSP) operations on video and audio data to and from the multimedia device 190.
  • DSP digital signal processing
  • Multimedia data often comprises real-time, isochronous data (i.e., video and audio data metered out in regular time periods).
  • Buffering the multimedia data directly in the LI cache system instead of main memory might be beneficial as cache memory accesses are faster and more efficient than accesses to system memory.
  • direcdy buffering the multimedia data in the LI cache system 15 and bypassing main memory storage is impractical because cache memories cannot be used direcdy by peripheral devices to store data.
  • FIFO first-in-first-out
  • data stored in the respective transmit and receive buffers is transferred direcdy to/from the peripheral devices.
  • There data stored in the tr.ansmit FIFO buffer is read by the periphery or multimedia devices without passing through the bus bridge .and periphery bus.
  • Data written into the receive FIFO buffer also is communicated direcdy between the peripheral device and FIFO buffer without passing through d e peripheral bus and bus brid ⁇ e.
  • the FIFO buffer produces interrupt signals which reflect the amount of the FIFO buffer currendy in use for storing data. These interrupt signals are used by the CPU and the peripheral device as an indication of when to retrieve data from the FIFO buffers.
  • Figure 2 is an exemplary block diagram of the parallel implementation of the preferred embodiment.
  • Figure 3A is a block diagram of die receive FIFO contained in d e parallel implementation.
  • Figure 5A is a block diagram of the receive FIFO contained in the serial implementation.
  • Figure 5B is a block diagram of the transmit FIFO contained in die serial implementation.
  • a central processing unit (CPU) core 100 is coupled to an LI cache system 150 and bus I/O device 160 over a CPU local bus 80. Also attached to die CPU local bus is a transmit first-in-first-out buffer (TX FIFO) 300 and receive FIFO buffer (RX FIFO) 200 according to the present invention.
  • TX FIFO transmit first-in-first-out buffer
  • RX FIFO receive FIFO buffer
  • a parallel bus structure 175 couples the RX and TX FIFOs to die bus I/O 160.
  • these components are integrated into a single processor chip, as indicated by the dashed box 20.
  • the bus I/O 160 connects die CPU local bus 80 to a system bus or memory bus 110.
  • a memory control unit 120 also couples to the system bus 110.
  • the memory control unit 120 couples to a memory device 130 which preferably includes dynamic random access memory (DRAM).
  • L2 cache 70 couples to the memory control unit 120 and to the system bus 110.
  • data from the multimedia device 190 may flow over the peripheral bus 180, through the bus bridge 170 to die system bus 110, through the bus I/O 160, and over the bus structure 175 to the RX FIFO 200.
  • the CPU retrieves the data over CPU local bus 80.
  • Data to be transmitted to die multimedia device from the CPU core flows over the CPU local bus 80 to the TX FIFO 300.
  • the multimedia device retrieves the data from die TX FIFO 300 via die bus structure 175, bus I/O 160, system bus 110, bus bridge 170, and peripheral bus 180.
  • the RX and TX FIFOs appear to d e CPU 100 as if diey are LI cache units.
  • the FIFO's have the same access rights as cache memory and generally are as fast as or faster than cache memory. Accesses to the FIFO's tirus is faster dian DRAM memory accesses with little of die latency problems inherent to DRAM memory accesses. In other words, FIFO accesses by the CPU 100 are similar to cache hits, and thus have reduced latency compared to main memory accesses.
  • Multimedia devices typically have real time processing requirements and data rates. This is generally not true for other tasks handled by the CPU. Processing rate also varies among different multimedia devices. Differences in these real time dependencies make data communication problematic. For example, data in the FIFO buffers may be overwritten if the CPU stores data in the buffer faster than the multimedia device can retrieve it. Thus, in one embodiment die processor is programmed witii die isochronous rate of the multimedia device. Synchronizing processing rates between the CPU and die multimedia device efficiently enables data to be written into a FIFO buffer at the same rate the data is retrieved. Thus, valid data in the buffers will not be overwritten.
  • die preferred embodiment includes several ways to overcome this problem including the use of interrupt signals, adjusting in real-time die effective data rate of the CPU, and adjusting the clock rate of the FIFO buffers.
  • the RX FIFO 200 and TX FIFO 300 preferably contain logic circuitry to generate interrupt signals.
  • the RX FIFO 200 includes a FIFO buffer 202 and a logic circuit 204.
  • the FIFO buffer 202 is coupled to the CPU local bus 80 and die bus structure 175.
  • Logic circuit 204 generates a plurality of signals shown collectively as signal 205. These signals preferably represent interrupt signals which ⁇ ue either received by die system interrupt controller or provided to a pin, such as die NMI pin, of the CPU core 100 as described below.
  • the logic circuit 204 generates one or more of the interrupt signals in response to the excess capacity signal 203.
  • Excess capacity signal 203 monitors me excess storage capacity of the FIFO buffer 202 to indicate the amount of me FIFO buffer available for storage of new data. Specifically, excess capacity signal 203 indicates whether only one memory position in FIFO buffer 202 contains valid data, whedier the FIFO buffer is half-full of data, whedier the FIFO buffer is completely full of data, or whedier some other number of memory locations contains valid data. This predetermined number of locations may be programmable or fixed (i.e. , hardwired).
  • logic circuit 304 generates a plurality of signals shown collectively as signal 305. These signals preferably represent interrupt signals which are either received by the system interrupt controller or provided to a pin, such as die NMI pin, of the CPU core 100.
  • the CPU core first fills the FIFO buffer 302.
  • the multimedia device then begins retrieving the data from the buffer.
  • Buffer level signal 303 indicates d e amount of data stored in die buffer that has yet to be retrieved by the multimedia device. Based on d e status of buffer level signal 303, logic circuit 304 generates one or more of die interrupt signals 310, 320, 330, and 340.
  • Interrupt signal 310 is generated when d e buffer level signal 303 indicates only one position in the FIFO buffer 302 contains valid data; that is, all but one memory positions of the buffer have been retrieved by d e multimedia device.
  • Interrupt signal 320 is generated when die buffer level signal 303 indicates that one-half of die FIFO's memory have yet to be read by die multimedia device.
  • interrupt signal 330 is generated when die multimedia device has retrieved enough data from the buffer so that only a predetermined number of memory locations in the buffer have yet to be retrieved.
  • the corresponding interrupt is generated and used by die CPU 100 as an indication of when to store more data in die buffer.
  • interrupt signal 220 may be implemented exclusievely to indicate to die CPU core when the multimedia device has retrieved all but one memory positions, thereby signalling the CPU to store new data in the TX FIFO.
  • Factors such as the data rate, type of data, and processing power of the CPU relative to die multimedia device influence the designer ' s choice of interrupt protocol.
  • the multimedia data received on bus structure 175 from die system bus 110 is stored in FIFO buffer 202.
  • some preferred level of capacity i.e. , only 1 position filled, half filled, completely filled, or X number of positions filled as described above
  • excess capacity signal 203 signals the logic circuit 204 of this capacity condition.
  • die logic circuit generates die corresponding interrupt signal 305 which is received by die CPU core 100. This interrupt signal triggers the CPU to retrieve multimedia data from the RX FIFO 200 over the CPU local 80.
  • FIGS 2 and 3B illustrate the preferred embodiment for communicating data from the CPU core 100 to the multimedia device 190 and follows a similar scheme to that for multimedia device-to-CPU communication described above.
  • the CPU core 100 begins filling die TX FIFO buffer 302 with data targeted for d e multimedia device.
  • the multimedia device retrieves some or all of the data from the buffer through the bus I/O 160. system bus 110, bus bridge 170 and peripheral bus 180.
  • buffer level signal 303 directs the logic circuit 304 to generate an interrupt signal reflective of die buffer's data level (i.e. , only 1 position filled, half filled, or X number of positions filled). This interrupt signal is received preferably by die CPU core 100 indicating a need for the CPU core to write more data to die transmit FIFO buffer 304.
  • multimedia data may be communicated between multimedia device 190 and CPU core 100 through an RX FIFO 400 and TX FIFO 500 without passing through die bus I/O, system bus, and bus bridge 170.
  • This architecture is beneficial when the data to an from the multimedia device constitutes a serial stream of data, and not parallel as in the embodiment described above.
  • Serial data from the multimedia device can be written direcdy into the RX FIFO 400 over signal line 192 and ultimately retrieved by CPU core 100 via d e CPU local bus 80.
  • Data from the CPU core 100 can be written into die TX FIFO 500 and retrieved by die multimedia device 190 over serial signal line 194.
  • the parallel nature of the CPU local bus 80 necessitates the conversion of serial multimedia data received over signal line 192 to parallel form. Further, parallel data from the CPU core to be transmitted to the multimedia device 190 must be converted to serial form for transmission over serial signal line 194.
  • the RX FIFO 400 and TX FIFO 500 preferably incorporate logic to convert data between serial and parallel forms. Parallel-to-serial and serial- to-parallel conversion blocks are shown in Figure 5A and 5B.
  • a serial-to-parallel converter 401 converts serial data received from multimedia device 190 over signal line 192.
  • the data is dien placed on a bus 406.
  • die RX FIFO 400 performs identically to RX FIFO 200 with data being read from the FIFO buffer 402 over the CPU local bus 80.
  • E-xcess capacity signal 403 is similar to excess capacity signal 203 in Figure 3A. Specifically, signal 403 reflects the excess capacity level of the FIFO buffer 402.
  • Logic circuit 404 uses excess capacity signal 403 to generate one or more of the interrupts 410. 420, 430, and 440 shown collectively as signal 405.
  • the interrupt signals are used by the CPU core 100 to indicate when to retrieve data from the FIFO buffer.
  • TX FIFO 500 performs identically to TX FIFO 300 ejXcept that the parallel data read from a FIFO buffer 502 is placed on a parallel bus 507 and convened to a serial stream of data by parallel-to-serial convener 506.
  • the functions of buffer level signal 503 and interrupt signal 505 comprising signals 510, 520, and 530 correspond to buffer signal 303 and interrupt signals 305 in Figure 3B.
  • Figures 6A-6D show an alternative to the embodiment of Figures 3 A, 3B, 5 A, and 5B in which registers .are used instead of interrupt signals to overcome the problems of mismatched data rates, diereby ensuring the efficient flow of data between die CPU core 100 and multimedia device 190.
  • registers instead of interrupt signals
  • the CPU writes to and reads from die FIFO buffers at a predetermined nominal rate approximating the multimedia data rate.
  • die RX FIFO's logic circuit 204 periodically updates a register 250 to indicate how full the FIFO buffer 202 is with data from the multimedia device.
  • the logic circuit 204 may store in the register a number indicating the percentage of die total buffer space free for the multimedia device to store more data.
  • the number stored in die register might reflect the percentage of the buffer space presently containing data to be read by die CPU.
  • die register provides a way for die CPU to infer how full the buffer has become so that the CPU CM adjust its effective data rate if necessary.
  • the CPU will increase temporarily its effective data retrieval rate.
  • a faster effective rate can be achieved eidier by retrieving the same quantity of data more often man die nominal rate or retrieving less data at die same rate.
  • the buffer is only 5% full, it may be desired for die CPU to slow down its effective retrieval rate to let the multimedia device 190 temporarily fill the buffer faster than die CPU 100 retrieves the data. Slower effective retrieval rates are achieved eidier by reading die same quantity of data less often tiian the nominal rate or reading more data at die same nominal rate.
  • Figure 6B ejXempiifies die TX FIFO using a register 350 instead of interrupts.
  • the CPU 100 writes data to d e TX FIFO buffer 302 at a nominal rate approximating the isochronous rate of the multimedia device.
  • the CPU periodically checks the status of register 350.
  • Register 350 is updated by logic circuit 304 to reflect die level of data in the FTFO buffer.
  • registers 450 in Figure 6C and 550 in Figure 6D parallels that of registers 250 and 350, respectively, for die serial embodiment of d e present invention.
  • An alternative embodiment to the use of interrupt signals or changing the effective data rate of the CPU is to dynamically change me TX or RX FIFO clock rate as needed to output more or less data depending on die amount of data stored in die FIFO.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Communication Control (AREA)
  • Information Transfer Systems (AREA)

Abstract

The present invention discloses a system and method for communicating real-time, multimedia data between a host CPU and an external multimedia device using a pair of first-in-first-out (FIFO) buffers. Data from the CPU is stored in a first FIFO buffer and subsequently retrieved by the multimedia device. Data from the multimedia device is stored in a second FIFO buffer and subsequently retrieved by the CPU for processing. The FIFO buffers provide indications to the CPU for the CPU to store more data in the first FIFO buffer and for the CPU to retrieve data from the second FIFO buffer.

Description

MULTIMEDIA DATA CONTROLLER
BACKGROUND
1. Field of the Invention
The present invention relates generally to the design and development of microprocessor and memory systems within computers. More particularly, the present invention relates to transmission of data between a CPU and devices external to the CPU. Still more particularly, the present invention relates to data transmission between a CPU and a multimedia device using receive and transmit FTFO buffers. 2. Description of the Relevant An
The continuing proliferation of computer development and applications has lead to computer systems that incorporate "multimedia" capability. That is, present computer technology allows for the processing of audio and video information as such information is generated by devices external to the central processing unit (CPU) or computer. For example, multimedia computers may present video images and/or audio tracks from a medium such as a CD-ROM.
Figure 1 shows a typical prior art computer system depicting the elements relevant to the present discussion. A central processing unit (CPU) core 10 is coupled to an LI cache system 15 and a bus Input/Output (I O) device 16 over a CPU local bus 8. The LI cache system 15 typically includes a cache controller and a cache SRAM (not shown). The CPU core 10, LI cache system 15, and bus I/O 16 may be implemented as separate discrete components but preferably are integrated onto a single chip processor as indicated by dashed box 9.
The bus I/O device 16 couples the CPU local bus 8 to a memory bus 11. A memory control unit or memory controller 12 also couples to the memory bus 11. A second level cache, referred to as an L2 cache 7, couples to the memory bus 11 and also couples to the memory control unit 12. The memory control unit 12 couples to a memory device 13. The memory device 13 typically is dynamic random access memory (DRAM).
A bus bridge 17 couples the memory bus 11 to a peripheral bus 18. Peripheral devices 19 are coupled to the peripheral bus. A multimedia device 190 represents one type of peripheral device which is coupled to the peripheral bus 18. Examples of multimedia devices are CD-ROM drives, graphics cards, video recorders, sound cards, modems, and the like.
The CPU core 10 and peripheral devices 19 and 190 communicate through the bus bridge 17 in different ways. A simple communication scheme allows data from the CPU core 10 to be placed on the CPU local bus 11 and tr.ansferred through the bus I/O device 16, memory bus 11, bus bridge 17, peripheral bus 18, and to a peripheral device/ multimedia device. Data communication from the peripheral devices 19 and 190 to the CPU core 10 follows the same path, albeit in the reverse order.
The CPU core 10 typically engages in multiple activities such as access cycles to the memory device 13 through memory control unit 12, accesses to the LI cache SRAM 15, as well as receiving and transmitting data to a variety of peripheral devices 19/190. The CPU core 10 often performs digital signal processing (DSP) operations on video and audio data to and from the multimedia device 190. Digital signal processing is a time-consuming, iterative process often involving vast amounts of data and requiring a large portion of the CPU's computing resources. Multimedia data often comprises real-time, isochronous data (i.e., video and audio data metered out in regular time periods). For real-time data, such as video and audio, to be effectively observed by the human user, it must be performed (e.g., video data displayed on a monitor or sound data provided to speakers) at the same rate at which the data was acquired originally. Any delays in processing will render music or motion pictures, for e.xample, unintelligible .and useless. As such, multimedia data often requires processing by die CPU "on the fly" or "in real time."
These demands on the CPU's processing power often renders direct communication between a multimedia device 190 and me CPU core 10 impractical because the CPU generally can receive, transmit, and process data much faster than the multimedia device 190. Direct data transmission between CPU and multimedia device, consequently, may not be the most efficient transmission scheme in light of other processing demands on the CPU. Consequently, data from me multimedia device may be stored or buffered in the memory 13. Once in the memory, the CPU core 10 can retrieve the multimedia data more efficiently as larger blocks of data can be retrieved with less access overhead d an with datum by datum transfers directly between multimedia device and CPU.
However, latency effects renders memory structures incapable of allowing real-time blocks of data to be stored, retrieved, and processed wid out detrimentally effecting me data's real-time nature. Further, latency in accessing DRAM often is unpredictable. For example, video data that is stored in die memory device 13 and periodically processed by the CPU core 10 with the latency inherent to the system may result in dropped frames or missed audio data, thereby resulting in jerky video and poor audio quality .
Buffering the multimedia data directly in the LI cache system instead of main memory might be beneficial as cache memory accesses are faster and more efficient than accesses to system memory. However, direcdy buffering the multimedia data in the LI cache system 15 and bypassing main memory storage is impractical because cache memories cannot be used direcdy by peripheral devices to store data.
Therefore, it would be desirable to have a multimedia data controller capable of allowing real-time CPU processing of multimedia data while accomplishing other CPU-related tasks. Such a controller would be able to effectively process and display video images and broadcast audio signals without losing the quality or usefulness inherent to the information. SUMMARY OF THE INVENTION
The problems oudined above are in large pan solved by the teachings of the present invention. The present invention incorporates a system and method for communication of data between a central processing unit (CPU) and one or more peripheral devices attached to a peripheral bus. The system comprises a CPU coupled to a system or memory bus. The system bus in turn couples to a peripheral bus through a bus bridge. One or more peripheral devices are coupled to the peripheral bus. The present invention comprises one or more memory buffers coupled to the CPU which stores peripheral and/or multimedia data tr.ansferred to or from the one or more peripheral devices.
Data to and from the peripheral device is stored temporarily in a first-in-first-out (FIFO) buffer. Bodi the CPU and peripheral device receive interrupt signals when retrieval of the data from the FIFO buffer is preferred. The retrieving device then obtains the stored data from me FIFO buffer.
In one embodiment, the memory buffer includes separate transmit and receive buffers. Data from the CPU is first stored in the transmit FIFO buffer, and once the transmit FIFO buffer becomes sufficiendy full, the peripheral device requests control over the peripheral bus to retrieve data from the FIFO buffer. The peripheral bus writes data to the receive FIFO buffer via the peripheral bus and bus bridge for subsequent retrieval by the CPU.
In another embodiment, data stored in the respective transmit and receive buffers is transferred direcdy to/from the peripheral devices. There data stored in the tr.ansmit FIFO buffer is read by the periphery or multimedia devices without passing through the bus bridge .and periphery bus. Data written into the receive FIFO buffer also is communicated direcdy between the peripheral device and FIFO buffer without passing through d e peripheral bus and bus bridεe. The FIFO buffer produces interrupt signals which reflect the amount of the FIFO buffer currendy in use for storing data. These interrupt signals are used by the CPU and the peripheral device as an indication of when to retrieve data from the FIFO buffers. Instead of using interrupts to indicate when the FIFO buffer contains data to be retrieved for processing, the CPU may monitor the level of data in the FIFO. In response, the CPU may adjust the effective processing rate so as to ensure the FIFO maintains an optimal level of data. Finally, the CPU may adjust the clock rate of the F FO buffer to maintain an optimal data level.
BRIEF DESCRIPTION OF THE DRAWINGS
Other objects and advantages of die invention will become apparent upon reading the following detailed description and upon reference to the accompanying drawings in which:
Figure 1 is a block diagram representation of a typical prior an computer system.
Figure 2 is an exemplary block diagram of the parallel implementation of the preferred embodiment.
Figure 3A is a block diagram of die receive FIFO contained in d e parallel implementation.
Figure 3B is a block diagram of the transmit FIFO contained in the psLraliel implementation.
Figure 4 is an exemplary block diagram of the serial data implementation of the preferred embodiment.
Figure 5A is a block diagram of the receive FIFO contained in the serial implementation.
Figure 5B is a block diagram of the transmit FIFO contained in die serial implementation.
Figures 6A-6D are exemplary block diagrams including registers for correcting mismatched data rates.
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawing and detailed description thereto are not intended to limit the invention to d e particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of die present invention as defined by the appended claims. DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
Referring now to Figure 2, a multimedia data controller is shown consistent with the preferred embodiment. A central processing unit (CPU) core 100 is coupled to an LI cache system 150 and bus I/O device 160 over a CPU local bus 80. Also attached to die CPU local bus is a transmit first-in-first-out buffer (TX FIFO) 300 and receive FIFO buffer (RX FIFO) 200 according to the present invention. A parallel bus structure 175 couples the RX and TX FIFOs to die bus I/O 160. Preferably, these components are integrated into a single processor chip, as indicated by the dashed box 20.
The bus I/O 160 connects die CPU local bus 80 to a system bus or memory bus 110. A memory control unit 120 also couples to the system bus 110. The memory control unit 120 couples to a memory device 130 which preferably includes dynamic random access memory (DRAM). L2 cache 70 couples to the memory control unit 120 and to the system bus 110.
A bus bridge 170 provides connectivity between the system bus 110 and a peripheral bus 180. External devices 19 and multimedia devices 190 couple to die peripheral bus 180. The peripheral bus 180 preferably comprises a PCI (Peripheral Component Interconnect) bus, but may comprise other bus types such those complying widi the ISA and EISA standards. Thus, the peripheral bus 180 is not limited to any panicular bus architecture. Multimedia device 190 represents such media devices as graphics/video cars or systems, audio cards or systems, MPEG decoders/encoders, CD ROM systems, video cassette recorders, video cameras, and the like. Data to and from the peripheral devices 19 and multimedia device 190 may flow along d e path including the CPU core 100, CPU local bus 80, bus I/O 160, system bus 110, bus bridge 170, peripheral bus 180, and peripheral device 19 or multimedia device 190. Data may flow in either direction-from the CPU core to die peripheral device and vice versa. Data may also be stored in and retrieved from the memory subsystem comprising the memory controller 120 and memory device 130. Thus, data from the multimedia device 190 may be provided to d e memory 130, and die CPU 100 reads from the memory to obtain the data.
According to the present invention, data from the multimedia device 190 may flow over the peripheral bus 180, through the bus bridge 170 to die system bus 110, through the bus I/O 160, and over the bus structure 175 to the RX FIFO 200. Once in the RX FIFO 200, the CPU retrieves the data over CPU local bus 80. Data to be transmitted to die multimedia device from the CPU core flows over the CPU local bus 80 to the TX FIFO 300. Subsequently, the multimedia device retrieves the data from die TX FIFO 300 via die bus structure 175, bus I/O 160, system bus 110, bus bridge 170, and peripheral bus 180.
The RX and TX FIFOs appear to d e CPU 100 as if diey are LI cache units. For example, the FIFO's have the same access rights as cache memory and generally are as fast as or faster than cache memory. Accesses to the FIFO's tirus is faster dian DRAM memory accesses with little of die latency problems inherent to DRAM memory accesses. In other words, FIFO accesses by the CPU 100 are similar to cache hits, and thus have reduced latency compared to main memory accesses.
Multimedia devices typically have real time processing requirements and data rates. This is generally not true for other tasks handled by the CPU. Processing rate also varies among different multimedia devices. Differences in these real time dependencies make data communication problematic. For example, data in the FIFO buffers may be overwritten if the CPU stores data in the buffer faster than the multimedia device can retrieve it. Thus, in one embodiment die processor is programmed witii die isochronous rate of the multimedia device. Synchronizing processing rates between the CPU and die multimedia device efficiently enables data to be written into a FIFO buffer at the same rate the data is retrieved. Thus, valid data in the buffers will not be overwritten. This approach, however, places generally unacceptable limitations on the operating system and is further limited because die data rate may change for a multimedia device during different modes of operation and certainly different multimedia devices have different data rates. Accordingly, die preferred embodiment includes several ways to overcome this problem including the use of interrupt signals, adjusting in real-time die effective data rate of the CPU, and adjusting the clock rate of the FIFO buffers.
The embodiment including interrupt signals will now be described. Referring now to Figures 2, 3A, and 3B, the RX FIFO 200 and TX FIFO 300 preferably contain logic circuitry to generate interrupt signals. In Figure 3A, an embodiment of die RX FIFO 200 is shown. As shown, the RX FIFO 200 includes a FIFO buffer 202 and a logic circuit 204. The FIFO buffer 202 is coupled to the CPU local bus 80 and die bus structure 175. Logic circuit 204 generates a plurality of signals shown collectively as signal 205. These signals preferably represent interrupt signals which ∑ue either received by die system interrupt controller or provided to a pin, such as die NMI pin, of the CPU core 100 as described below. The logic circuit 204 generates one or more of the interrupt signals in response to the excess capacity signal 203. Excess capacity signal 203 monitors me excess storage capacity of the FIFO buffer 202 to indicate the amount of me FIFO buffer available for storage of new data. Specifically, excess capacity signal 203 indicates whether only one memory position in FIFO buffer 202 contains valid data, whedier the FIFO buffer is half-full of data, whedier the FIFO buffer is completely full of data, or whedier some other number of memory locations contains valid data. This predetermined number of locations may be programmable or fixed (i.e. , hardwired).
Based on the status of excess capacity signal 203, logic circuit 204 generates an appropriate interrupt. Interrupt signal 210 is generated when the excess capacity signal 203 indicates only one position in the FIFO buffer 202 contains valid data. Interrupt signal 220 is generated when die signal 203 indicates diat one-half of die FIFO's memory locations are full. Interrupt signal 230 is generated when d e excess capacity signal indicates all of d e FIFO is full of data. Finally, interrupt signal 240 is generated upon a predetermined number of locations in FIFO buffer 202 becoming full.
Similarly, in Figure 3B, logic circuit 304 generates a plurality of signals shown collectively as signal 305. These signals preferably represent interrupt signals which are either received by the system interrupt controller or provided to a pin, such as die NMI pin, of the CPU core 100. The CPU core first fills the FIFO buffer 302. The multimedia device then begins retrieving the data from the buffer. Buffer level signal 303 indicates d e amount of data stored in die buffer that has yet to be retrieved by the multimedia device. Based on d e status of buffer level signal 303, logic circuit 304 generates one or more of die interrupt signals 310, 320, 330, and 340. Interrupt signal 310 is generated when d e buffer level signal 303 indicates only one position in the FIFO buffer 302 contains valid data; that is, all but one memory positions of the buffer have been retrieved by d e multimedia device. Interrupt signal 320 is generated when die buffer level signal 303 indicates that one-half of die FIFO's memory have yet to be read by die multimedia device. Finally, interrupt signal 330 is generated when die multimedia device has retrieved enough data from the buffer so that only a predetermined number of memory locations in the buffer have yet to be retrieved. Moreover, once the multimedia device has retrieved enough data from the FIFO buffer so as to create one of these buffer level condidons, the corresponding interrupt is generated and used by die CPU 100 as an indication of when to store more data in die buffer.
One or more of the interrupt signals may be used in a given implementation. For example, me system designer may desire to implement interrupt signal 220 to trigger the CPU core 100 to retrieve data from the receive FIFO buffer 202 once the buffer becomes half-full of data from the multimedia device. The data can be retrieved and processed while the buffer is filling up with new data. On die transmit side, interrupt signal 310 may be implemented exclusievely to indicate to die CPU core when the multimedia device has retrieved all but one memory positions, thereby signalling the CPU to store new data in the TX FIFO. Factors such as the data rate, type of data, and processing power of the CPU relative to die multimedia device influence the designer's choice of interrupt protocol.
The operation of the present invention will now be described widi reference to d e preferred embodiment shown in Figures 2, 3A, and 3B. Multimedia data communication generally is bi-direcdonal-from die multimedia device 190 to the CPU core 100, and vice versa. When the mulάmedia device contains data to be processed by the CPU, die multimedia device requests control of the peripheral bus 180 from the bus bridge 170. According to predetermined and commonly .known bus conϋrol schemes, the bus bridge 170 grants control of the peripheral bus to the multimedia device 190. The multimedia device dien places its data (including address, data, and control bits) on the peripheral bus and the bus bridge then tr.ansmits that data to die RX FIFO 200 via the system bus 110, bus I/O 160, .and bus structure 175. The multimedia data preferably comprises addresses which are mapped to die RX FIFO 200
In Figure 3A, the multimedia data received on bus structure 175 from die system bus 110 is stored in FIFO buffer 202. When the FIFO buffer reaches some preferred level of capacity (i.e. , only 1 position filled, half filled, completely filled, or X number of positions filled as described above), excess capacity signal 203 signals the logic circuit 204 of this capacity condition. In response, die logic circuit generates die corresponding interrupt signal 305 which is received by die CPU core 100. This interrupt signal triggers the CPU to retrieve multimedia data from the RX FIFO 200 over the CPU local 80.
Figures 2 and 3B illustrate the preferred embodiment for communicating data from the CPU core 100 to the multimedia device 190 and follows a similar scheme to that for multimedia device-to-CPU communication described above. The CPU core 100 begins filling die TX FIFO buffer 302 with data targeted for d e multimedia device. The multimedia device retrieves some or all of the data from the buffer through the bus I/O 160. system bus 110, bus bridge 170 and peripheral bus 180. When the level of data in the buffer drops to a predetermined level, buffer level signal 303 directs the logic circuit 304 to generate an interrupt signal reflective of die buffer's data level (i.e. , only 1 position filled, half filled, or X number of positions filled). This interrupt signal is received preferably by die CPU core 100 indicating a need for the CPU core to write more data to die transmit FIFO buffer 304.
In an alternative embodiment as shown in Figures 4, 5A, and 5B, multimedia data may be communicated between multimedia device 190 and CPU core 100 through an RX FIFO 400 and TX FIFO 500 without passing through die bus I/O, system bus, and bus bridge 170. This architecture is beneficial when the data to an from the multimedia device constitutes a serial stream of data, and not parallel as in the embodiment described above.
Serial data from the multimedia device can be written direcdy into the RX FIFO 400 over signal line 192 and ultimately retrieved by CPU core 100 via d e CPU local bus 80. Data from the CPU core 100 can be written into die TX FIFO 500 and retrieved by die multimedia device 190 over serial signal line 194.
The parallel nature of the CPU local bus 80 necessitates the conversion of serial multimedia data received over signal line 192 to parallel form. Further, parallel data from the CPU core to be transmitted to the multimedia device 190 must be converted to serial form for transmission over serial signal line 194. The RX FIFO 400 and TX FIFO 500 preferably incorporate logic to convert data between serial and parallel forms. Parallel-to-serial and serial- to-parallel conversion blocks are shown in Figure 5A and 5B.
In Figure 5 A serial-to-parallel converter 401 converts serial data received from multimedia device 190 over signal line 192. The data is dien placed on a bus 406. From this point on, die RX FIFO 400 performs identically to RX FIFO 200 with data being read from the FIFO buffer 402 over the CPU local bus 80. E-xcess capacity signal 403 is similar to excess capacity signal 203 in Figure 3A. Specifically, signal 403 reflects the excess capacity level of the FIFO buffer 402. Logic circuit 404 uses excess capacity signal 403 to generate one or more of the interrupts 410. 420, 430, and 440 shown collectively as signal 405. The interrupt signals are used by the CPU core 100 to indicate when to retrieve data from the FIFO buffer. Interrupt signal 410 represents die condition in which only one FIFO buffer position contains data. Signal 420 represents the condition in which die buffer is half-full. Signals 420 represents the condition in which die buffer completely full. Finally, signal 440 represents the condition when X positions contain data.
In Figure 5B TX FIFO 500 performs identically to TX FIFO 300 ejXcept that the parallel data read from a FIFO buffer 502 is placed on a parallel bus 507 and convened to a serial stream of data by parallel-to-serial convener 506. Parallel-to-serial converter 506, in turn, outputs the serial data stre.am on line 194 for tr.ansmission to the multimedia device 190. The functions of buffer level signal 503 and interrupt signal 505 comprising signals 510, 520, and 530 correspond to buffer signal 303 and interrupt signals 305 in Figure 3B.
Figures 6A-6D show an alternative to the embodiment of Figures 3 A, 3B, 5 A, and 5B in which registers .are used instead of interrupt signals to overcome the problems of mismatched data rates, diereby ensuring the efficient flow of data between die CPU core 100 and multimedia device 190. When using a register instead of interrupt signals, the CPU writes to and reads from die FIFO buffers at a predetermined nominal rate approximating the multimedia data rate.
In Figure 6A, die RX FIFO's logic circuit 204 periodically updates a register 250 to indicate how full the FIFO buffer 202 is with data from the multimedia device. For example, the logic circuit 204 may store in the register a number indicating the percentage of die total buffer space free for the multimedia device to store more data. Alternatively, the number stored in die register might reflect the percentage of the buffer space presently containing data to be read by die CPU. In eidier case, die register provides a way for die CPU to infer how full the buffer has become so that the CPU CM adjust its effective data rate if necessary. For instance, if it is desired for the CPU to retrieve data from the RX FIFO so that d e buffer never becomes more than 50% full and if the register 250, in fact, indicates the buffer is 70% full, the CPU will increase temporarily its effective data retrieval rate. A faster effective rate can be achieved eidier by retrieving the same quantity of data more often man die nominal rate or retrieving less data at die same rate. Alternatively, if the buffer is only 5% full, it may be desired for die CPU to slow down its effective retrieval rate to let the multimedia device 190 temporarily fill the buffer faster than die CPU 100 retrieves the data. Slower effective retrieval rates are achieved eidier by reading die same quantity of data less often tiian the nominal rate or reading more data at die same nominal rate.
Figure 6B ejXempiifies die TX FIFO using a register 350 instead of interrupts. The CPU 100 writes data to d e TX FIFO buffer 302 at a nominal rate approximating the isochronous rate of the multimedia device. To prevent die CPU 100 from overwriting data in d e FIFO buffer when the multimedia does not retrieve data as fast as die CPU stores data in the buffer, the CPU periodically checks the status of register 350. Register 350 is updated by logic circuit 304 to reflect die level of data in the FTFO buffer. From the status of register 350, the CPU core 100 can determine how much of die data has been retrieved by the multimedia device 190 and thus, whedier d e multimedia device is able to retrieve data from the FTFO buffer at d e same rate at which the CPU stores data. If, for example, register 350 indicates the FTFO buffer is almost filled, die CPU can use diat information to slow down its effective rate of storing data in the buffer. Slowing die effective rate is accomplished similar to diat described above for slowing die retrieval rate with respect to d e RX FIFO. That is, the CPU core 100 can store the same quantity of data less often than the nominal rate or storing more data at d e nominal rate. The function of registers 450 in Figure 6C and 550 in Figure 6D parallels that of registers 250 and 350, respectively, for die serial embodiment of d e present invention. An alternative embodiment to the use of interrupt signals or changing the effective data rate of the CPU is to dynamically change me TX or RX FIFO clock rate as needed to output more or less data depending on die amount of data stored in die FIFO.
Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended diat die following claims be interpreted to embrace all such variations and modifications.

Claims

WHAT IS CLAIMED IS:
1. A system for processing data from a peripheral device comprising: a central processing unit (CPU); a bus input/output device coupled to said CPU; a system bus coupled to said bus input/output device; a peripheral bus coupled to said system bus; a peripheral device coupled to said peripheral bus; and a memory buffer coupled to said CPU and coupled to said bus input/output device, wherein said memory buffer is adapted for only storing data to be tr-ansferred to said peripheral device and data received from said peripheral device; wherein said peripheral device and said CPU exchange information through said memory buffer.
2. The system of claim 1, wherein information is stored in said memory buffer by s d periphery device, wherein said information stored in said memory buffer by said peripheral device is retrieved by said CPU.
3. The system of claim 1, wherein information is stored in said memory buffer by said CPU, wherein said information stored in said memory buffer by said CPU is retrieved by said peripheral device.
4. The system of claiml , further comprising: a main memory coupled to said system bus for storing code .and data; and a cache system coupled to said CPU for storing a portion of said code and data stored in said main memory.
5. The system of claim 1, wherein said memory buffer produces a first signal indicative of die amount of data stored in said memory buffer by the peripheral device that has not been retrieved by the CPU.
6. The system of claim 5, wherein the first signal indicative of die amount of data stored in said memory buffer by the peripheral device comprises a first interrupt signal, and wherein said CPU uses said first interrupt signal to initiate retrieving data from said memory buffer stored in said memory buffer by said peripheral device.
7. The system of claim 5, wherein said memory buffer produces a second signal indicative of die amount of data stored in said memory buffer by the CPU diat has not been retrieved by die peripheral device.
8. The system of claim 7, wherein the second signal indicative of die amount of data stored in said memory buffer by the CPU comprises a second interrupt signal, and wherein said CPU uses said second interrupt signal to initiate storing more data in said memory buffer for retrieval by said peripheral device.
9. The system of claim 1, wherein said memory buffer comprises a receive buffer and a transmit buffer, wherein die receive buffer stores information received from the peripheral device and destined for the CPU, and the transmit FTFO buffer stores information received from the CPU and destined for the peripheral device.
10. The system of claim 1, wherein said peripheral device comprises a multimedia device, and wherein said information comprises real-time data.
11. The system of claim 1, wherein said memory buffer is a FIFO memory buffer.
12. A computer system comprising; a CPU; a memory buffer coupled to said CPU; a peripheral bus; an external device coupled to said memory buffer; a peripheral device coupled to said peripheral bus, wherein said peripheral device includes a serial input/output port; a serial data line coupled to said serial input/output port .and to said CPU; wherein serial data from die peripheral device is stored in the memory buffer for retrieval by said CPU; and wherein data stored in the memory buffer by the CPU is transmitted to die peripheral device in serial form.
13. The computer system of claim 12 wherein said memory buffer converts the serial data received from the external device to parallel form for transmission to die CPU.
14. The system of claim 12, wherein said memory buffer produces a first signal indicative of the amount of data stored in said memory buffer by the external device that has not been retrieved by die CPU.
15. The system of claim 14, wherein die first signal indicative of die amount of data stored in said memory buffer by the external device comprises an interrupt signal.
16. The system of claim 15, wherein said CPU uses said interrupt signal to initiate retrieving data from said memory buffer stored in said buffer by said external device.
17. The system of claim 12, wherein said memory buffer produces a second signal indicative of die amount of data stored in said memory buffer by die CPU diat has not been retrieved by die external device.
18. The system of claim 17, wherein the second signal indicative of die amount of data stored in said memory buffer by the CPU comprises an interrupt signal.
19. The system of claim 18, wherein said CPU uses said interrupt signal to initiate storing more data in said memory buffer for retrieval by said external device.
20. The computer system of claim 12 wherein the memory buffer comprises a receive buffer and a transmit buffer wherein the receive buffer stores the information received from the external device and die transmit buffer stores information received from die CPU.
21. The computer system of claim 20, wherein the transmit buffer converts the data stored in the memory buffer by said CPU to a serial string of data for retrieval by the external device.
22. The computer system of claim 12, wherein said external device comprises a multimedia device.
23. The computer system of claim 22, wherein said information comprises real-time data.
24. The computer system of claim 12, wherein the memory buffer is a FIFO memory buffer.
25. A system for processing data from a peripheral device comprising: a central processing unit (CPU); a CPU local bus coupled to said CPU; a bus input/out device coupled to said CPU local bus; a system bus coupled to said bus input/output device; a peripheral device coupled to a peripheral bus; a bus bridge device for coupling said system bus to said peripheral bus; and a FTFO memory buffer coupled to said CPU and coupled to said bus input/output device, wherein said FTFO memory buffer comprises a tr∑uismit FIFO buffer for storing data from die CPU to be retrieved by the peripheral device and said FIFO memory buffer comprises a receive FIFO buffer for storing data received from the peripheral device to be retrieved by the CPU.
26. The system of claim 25, wherein said data first stored in said receive FIFO buffer by said peripheral device is retrieved by said CPU before other data stored in said receive F FO buffer is retrieved.
27. The system of claim 26, wherein said data first stored in said transmit FIFO buffer by said CPU is retrieved by said peripheral device before other data stored in said transmit FIFO buffer is retrieved.
28. The system of claim 27, wherein the receive FTFO buffer comprises a register that is updated by die receive FTFO buffer to indicate die amount of die FIFO buffer containing data from the peripheral device yet to be retrieved by die CPU.
29. The system of claim 27, wherein die transmit FIFO buffer comprises a register diat is updated by die transmit FIFO buffer to indicate d e amount of data stored in the transmit FIFO buffer by the CPU that has yet to be retrieved by the peripheral device.
30. The system of claim 28, wherein die transmit F FO buffer comprises a register diat is updated by d e transmit FIFO buffer to indicate die amount of data stored in the transmit FIFO buffer by the CPU diat has yet to be retrieved by d e periphery device.
31. The system of claim 30, wherein data is communicated between the FTFO memory buffer .and the peripheral device through a bus input/output device, a system bus wherein the bus input/output device couples die CPU local bus to die system bus, a peripheral bus, and a bus bridge device d at couples the system bus to me peripheral bus.
32. The system of claim 30, wherein data is communicated in serial form between the FTFO memory buffer and die peripheral device over serial signal lines coupled between the FTFO memory buffer and die peripheral device.
33. The system of claim 28, wherein said peripheral device comprises a multimedia device.
34. The system of claim 33, wherein said information comprises real-time data.
PCT/US1997/017197 1996-09-25 1997-09-25 Multimedia data controller WO1998013767A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP97943566A EP0928452A1 (en) 1996-09-25 1997-09-25 Multimedia data controller

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US71980196A 1996-09-25 1996-09-25
US08/719,801 1996-09-25

Publications (2)

Publication Number Publication Date
WO1998013767A1 true WO1998013767A1 (en) 1998-04-02
WO1998013767A9 WO1998013767A9 (en) 1998-07-09

Family

ID=24891419

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1997/017197 WO1998013767A1 (en) 1996-09-25 1997-09-25 Multimedia data controller

Country Status (2)

Country Link
EP (1) EP0928452A1 (en)
WO (1) WO1998013767A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1999052293A1 (en) * 1998-04-03 1999-10-14 Avid Technology, Inc. Method and apparatus for controlling data flow between devices connected by a memory
EP1187031A3 (en) * 2000-09-08 2007-04-25 Texas Instruments Inc. Bus bridge interface system

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0166341A2 (en) * 1984-06-27 1986-01-02 International Business Machines Corporation Multiprocessor system with fast path means for storage accesses
WO1992001987A1 (en) * 1990-07-16 1992-02-06 Tekstar Systems Corporation Interface system for data transfer with remote peripheral independently of host processor backplane

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0166341A2 (en) * 1984-06-27 1986-01-02 International Business Machines Corporation Multiprocessor system with fast path means for storage accesses
WO1992001987A1 (en) * 1990-07-16 1992-02-06 Tekstar Systems Corporation Interface system for data transfer with remote peripheral independently of host processor backplane

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
ANDREWS: "PCI promises solution to local-bus bottleneck", COMPUTER DESIGN., vol. 31, no. 8, August 1992 (1992-08-01), LITTLETON, MASSACHUSETTS US, pages 36 - 40, XP000307561 *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1999052293A1 (en) * 1998-04-03 1999-10-14 Avid Technology, Inc. Method and apparatus for controlling data flow between devices connected by a memory
US6134607A (en) * 1998-04-03 2000-10-17 Avid Technology, Inc. Method and apparatus for controlling data flow between devices connected by a memory
EP1187031A3 (en) * 2000-09-08 2007-04-25 Texas Instruments Inc. Bus bridge interface system

Also Published As

Publication number Publication date
EP0928452A1 (en) 1999-07-14

Similar Documents

Publication Publication Date Title
US6032211A (en) Method of mode control in a bus optimized for personal computer data traffic
US6192428B1 (en) Method/apparatus for dynamically changing FIFO draining priority through asynchronous or isochronous DMA engines in response to packet type and predetermined high watermark being reached
US5430847A (en) Method and system for extending system buses to external devices
US7457892B2 (en) Data communication flow control device and methods thereof
US5918073A (en) System and method for equalizing data buffer storage and fetch rates of peripheral devices
US5870627A (en) System for managing direct memory access transfer in a multi-channel system using circular descriptor queue, descriptor FIFO, and receive status queue
US6115761A (en) First-In-First-Out (FIFO) memories having dual descriptors and credit passing for efficient access in a multi-processor system environment
US6151651A (en) Communication link with isochronous and asynchronous priority modes coupling bridge circuits in a computer system
EP1068734B1 (en) Method and apparatus for controlling data flow between devices connected by a memory
US6148357A (en) Integrated CPU and memory controller utilizing a communication link having isochronous and asynchronous priority modes
EP1318457B1 (en) Bus bridge with a burst transfer mode bus and a single transfer mode bus
WO1999022302A1 (en) Buffering data that flows between buses operating at different frequencies
EP1820309B1 (en) Streaming memory controller
US5859649A (en) Data processing system having display controller with bursting direct memory access
US5983299A (en) Priority request and bypass bus
US5790811A (en) System and method for performing data transfers during PCI idle clock cycles
US6199132B1 (en) Communication link with isochronous and asynchronous priority modes
US8037254B2 (en) Memory controller and method for coupling a network and a memory
US6425071B1 (en) Subsystem bridge of AMBA's ASB bus to peripheral component interconnect (PCI) bus
WO2006134550A2 (en) Memory controller
EP0928452A1 (en) Multimedia data controller
US6134609A (en) Method for using computer system memory as a modem data buffer by transferring modem I/O data directly to system controller and transferring corresponding system controller data directly to main memory
WO1998013767A9 (en) Multimedia data controller
US6078973A (en) System controller interfacing a main memory and a modem and transferring data directly between dedicated region of the memory and the modem I/O circuitry
JP4514411B2 (en) Inter-bus communication interface device

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): JP KR

AL Designated countries for regional patents

Kind code of ref document: A1

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

WWE Wipo information: entry into national phase

Ref document number: 1997943566

Country of ref document: EP

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
COP Corrected version of pamphlet

Free format text: PAGES 1-15, DESCRIPTION, REPLACED BY NEW PAGES 1-7; PAGES 16-22, CLAIMS, REPLACED BY NEW PAGES 8-11; PAGES 1/11-11/11, DRAWINGS, REPLACED BY NEW PAGES 1/11-11/11; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

121 Ep: the epo has been informed by wipo that ep was designated in this application
NENP Non-entry into the national phase

Ref country code: JP

Ref document number: 1998515891

Format of ref document f/p: F

WWP Wipo information: published in national office

Ref document number: 1997943566

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 1997943566

Country of ref document: EP

点击 这是indexloc提供的php浏览器服务,不要输入任何密码和下载