|Publication number||US5471638 A|
|Application number||US 08/263,987|
|Publication date||Nov 28, 1995|
|Filing date||Jun 22, 1994|
|Priority date||Oct 4, 1991|
|Publication number||08263987, 263987, US 5471638 A, US 5471638A, US-A-5471638, US5471638 A, US5471638A|
|Inventors||James W. Keeley|
|Original Assignee||Bull Hn Inforamtion Systems Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (13), Referenced by (16), Classifications (10), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This is a continuation of application Ser. No. 07/771,712, filed on Oct. 4, 1991, now abandoned.
1. The patent application of James W. Keeley and Thomas F. Joyce entitled, "High Performance Tightly Coupled Multiple Synchronous State Machine Based Processing Unit," filed on Oct. 4, 1991, bearing Ser. No. 07/771,289, which is assigned to the same assignee as this patent application now U.S. Pat. No. 5,341,508.
2. The patent application of Thomas F. Joyce and James W. Keeley entitled, "Method and Apparatus for Avoiding Processor Deadly Embrace in a Multiprocessor System," filed on Oct. 4, 1991, bearing Ser. No. 07/771,296, which is assigned to the same assignee as this patent application now U.S. Pat. No. 5,283,870.
3. The patent application of Thomas F. Joyce and James W. Keeley entitled, "Programmable Bus State Machine," filed on Oct. 4, 1991, bearing Ser. No. 07/771,297, which is assigned to the same assignee as this patent application now U.S. Pat. No. 5,341,495.
1. Field of Use
The present invention relates to data processing systems and, more particularly, to systems for processing different types of requests.
2. Prior Art
One system includes a plurality of units which are tightly coupled to an asynchronous system bus network. Different types of requests, including processor and input/output commands are issued by peer and maintenance processors. This type of system is generally described in greater detail in U.S. Pat. No. 4,992,930.
While the peer processor in the above system can process different types of system bus requests, they cannot be processed simultaneously and require that the processor operation be stalled in order to process properly certain types of requests, such as I/O requests.
Accordingly, it is a primary object of the present invention to provide a system which has improved performance.
It is a more specific object of the present invention to provide a system which is capable of handling requests from a plurality of requestors having different types of requirements.
The above objects are achieved in a high performance processor which has a tightly coupled (on-board) local memory and includes a plurality of areas or interface sections for processing different types of transactions or requests. In the preferred embodiment, these interface sections include a first interface section for processing processor generated read/write requests to the system bus, a second interface section for processing externally received read commands to be directed to the processor's local on-board memory and a third interface section for processing externally received I/O register commands. Means are included for coupling all of externally addressable registers in common to one of the interface sections, enabling the simultaneous processing of the different types of requests.
In the preferred embodiment, each type of transaction or request is queued up and the transaction or request is completed by the appropriate one of the interface sections under the control of an independently operated state machine. Each state machine is uniquely programmed to complete the transaction under all possible circumstances, including the handling of retry or bus wait or other response situations. This enables several system bus transaction sequences to take place simultaneously requiring different retry procedures.
The above and other objects and advantages of the present invention will be better understood from the following detailed description taken in conjunction with the accompanying drawings.
FIG. 1 is a block diagram of a multiprocessor system which incorporates the interface system of the present invention.
FIG. 2 shows in greater detail, a processing unit of FIG. 1 which incorporates the interface system of the present invention.
FIGS. 3a through 3d show in greater detail, the state machines and register control circuits of FIG. 2.
FIGS. 4a through 4c are state diagrams used in explaining the operation of the state machines of FIG. 2.
FIG. 5 is a diagram used to illustrate how the interface system of the present invention processes different types of transactions.
Description of FIG. 1
FIG. 1 shows a multiprocessor system 10 which includes a plurality of central processing units 10-2 through 10-6 and peer processors 12-2 and 12-4 which tightly couple in common to a system bus 16 and to a main memory or system memory 14. Each processor, as shown, includes a bus interface area which enables the unit to transmit or receive requests in the form of commands, interrupts, data or responses/status to another unit on system bus 16. In the preferred embodiment, the system bus 16 operates asynchronously and uses a split bus cycle protocol which provides higher performance by granting other units bus cycles during the period of time a unit is waiting for main memory to furnish data in response to an earlier request made by that unit. For further information regarding this type of bus interface and operation, reference may be made to U.S. Pat. No. 3,997,896.
Referring to FIG. 1, it is seen that each peer processor 12-2 and 12-4 includes a microprocessor 12-20, a local memory 12-30 and interface buses which couple to the bus interface circuits of block 12-40 as shown. The microprocessor 12-20 and local memory 12-30 are tightly coupled through a local processor bus 12-25. The clock generator circuits 12-22 generate a single frequency clock signal CLKREF of 33 MHz which provides the fundamental timing and internal operating frequency for microprocessor 12-20, in addition to all of the other circuits which make up processor 12-2. The microprocessor 12-20 is a high performance 32-bit processor which operates at clock speeds of up to 33 MHz and in the preferred embodiment corresponds to an Intel 80486 chip. The Intel 80486 chip includes a microprocessor, a floating point math coprocessor, a memory cache controller and an 8K RAM cache unit. The principal processing function is performed by the microprocessor while complex processing functions, such as floating operations, are performed by the math coprocessor. The internal cache unit provides fast access to the data required for processing. In the preferred embodiment, peer processors 12-2 and 12-4 operate under the control of a UNIX® (UNIX is a registered trademark of X/Open Company Limited) operating system.
In FIG. 1, the processors 10-2 through 10-6 function as host processors. In the preferred embodiment, each processor takes the form of a Bull DPS6000 system which operates under the control of the Bull HVS proprietary operating system. In the system of FIG. 1, each of the processors are organized to operate in an independent manner and have access to the full complement of system resources, such as input/output units, main memory and the like.
Description of FIG. 2
FIG. 2 shows in greater detail, a portion of the on-board processor 12-2 of FIG. 1. In the preferred embodiment, the microprocessor 12-20 and local memory 12-30, along with associated control circuits, in addition to clock generation circuits of block 12-22, are contained on a single daughter board which couples to the interface circuits of block 12-900. The bus interface circuits, sets of command, address and data registers and state control circuits are contained on the mother board. These two boards make up the entire processor.
Each external request received from system bus 16 to access local memory 12-30 which has been acknowledged by the system bus response logic circuits, not shown, is loaded into the corresponding receive data, address and command registers 12-42 through 12-46 in response to an enable signal CYCREQ generated by clock logic circuits of block 12-92. The address and command signals are converted into the appropriate form by address and command converter circuits of blocks 12-52 and 12-54 and stored in available registers of the two sets of queue registers of blocks 12-62 and 12-64, in response to signal CYFIFO. Thereafter, the stored address and command signals are applied to the processor bus via the interface circuits of block 12-900, in response to an enabling signal EADQTP. Additionally, the bus command signals are applied to the system bus response logic circuits of block 12-91.
Any data associated with a request loaded into register 12-42 is reordered as required by the programmable array logic (PALs) of block 12-50 and stored into the appropriate one of the register of block 12-60. The different bytes of the data words are swapped from the so-called big endian format of the system bus to the little endian format utilized by microprocessor 12-20. This is accomplished by the byte swap circuits included in block 12-900 which is implemented by the proper reordering of connector pin connections.
The XSM state machine 12-66 generates the required control signals for executing external memory read and write requests. In response to an input signal RXHAVE received from the circuits of block 12-90, which indicates the receipt of a memory request, the XSM state machine 12-66 loads the request into one of the sets of registers of the two level queue. It also enables transfer of the memory request via signal EADQTP to local memory 12-30 via the local bus in the same form as those memory requests made by microprocessor 12-20. Also, the XSM state machine 12-66 generates the required signals for transferring local memory data to system bus 16 via data swap circuits 12-56 and a set of registers of an array 12-58.
A processor state machine control block 12-80 controls the processing of transactions or requests initiated by microprocessor 12-20. As shown, commands generated by microprocessor 12-20 are applied to a microprocessor to bus command generator of block 12-82 which, in turn, generates the appropriate system bus command. The bus command is loaded into a processor command register 12-84, along with the appropriate address and data. The address and data are loaded into registers 12-86 and 12-88, respectively. This is all done in response to an enabling load signal PTDTLD generated by state machine 12-80.
The processing unit 12-2 further includes a plurality of system visible registers which are accessible via system bus 16 by microprocessor 12-20 or by any other system bus unit. A number of these registers connect in common to a receive bus (R Bus), as shown, for receiving input data from the RX DATA IN register 12-42.
These registers include a processor control command register (PCC) which comprises a plurality of flip-flop register stages, an EEPROM address register (EAR), a memory module register (MMR), a software message register (SMR), a pair of interrupt pending registers (IPR0 and IPR1) which serve as the output registers of an interrupt store (IPS) random access memory (RAM) 12-76 loadable from the R Bus by an interrupt register (ITR). As shown, the SMR, MMR, IPR0 and IPR1 registers also connect in common to a send bus (S Bus) for reading out of their contents to system bus 16 via a receive transfer second half bus cycle register (RTSHBC) 12-70.
Other system visible registers whose contents are only read, also connect in common to the S Bus. These registers include a syndrome register (SYN), a resource identification register (ID) and a revision number register (REV). The ID and REV registers which store constant values in addition to the MMR register are implemented in a programmable array logic (PAL) circuit while the other registers are implemented using standard register circuits.
The system visible registers are accessed in response to I/O commands applied to system bus 16 which results in the storing of address and command signals in registers 12-44 and 12-46. The address and command signals are decoded by the decode circuits of the RTR Control block 12-90. The system visible registers are described in greater detail in the Appendix.
As seen from FIG. 2, the processing unit 12-2 in accordance with the present invention includes three independently operated state machines 12-400, 12-420 and 12-440 which enable the simultaneous execution of different types of transactions. Each state machine connects to system bus 16 via receive command register 12-46 and is responsible for completing all aspects of a specific type of transaction (e.g. wait, retry conditions). Also PTR state machine 12-400 connects to the system bus circuits of block 12-91.
Also, each state machine connects to the system bus priority request circuits of block 12-460 which grants each state machine access to system bus 16 in response to request signals PTREQP, XTREQP, and RTREQP on a priority basis defined by the states of signals RXPTWON, RXXTWON, and RXRTWON, in addition to signal RXANYR.
Additionally, state machines 12-400, 12-420, and 12-440 receive input control signals from the processor state machine (PSM) state machine 12-80, external state machine (XSM) 12-66 and the RTR control circuits of block 12-90 respectively. These signals initiate the processing of the different types of transactions following the loading of the pertinent registers with command, address and data as appropriate.
Description of FIGS. 3a through 3d
FIG. 3a shows in block form, the processor transfer state machine (PTR) 12-400 which controls the transfer of microprocessor generated commands to system bus 16. The PTR state machine 12-400 includes a pair of clocked programmable array logic (PAL) circuits 12-400a and 12-400b. As shown, PTR state machine circuit 12-400a receives as inputs, a clock signal REFCLK from clock generator circuits 12-22, a processor transfer load signal PTDTLD- from PSM state machine 12-80, a RXHAVE+ signal from RTR control circuits 12-90, system bus response signals RXNAKR, and RXWAIT in addition to a system bus time-out signal RXTMOT and system bus clear signal MBMCLR, system bus command/control signals RXWRIT, RXMREF, RXLOCK, RXSHBC, and RXMCLR from RXCMDIN register 12-46. Additionally, PTR state machine circuit 12-400a receives an any request signal RXANYR and system bus cycle won signal from register 12-46 generated by the system bus priority circuits of block 12-460. The PTR state machine circuit 12-400a generates as outputs, a request pending signal PTREQP applied to priority circuits of block 12-460, a retry signal PTRETRY, a lock NAK signal PTNKFLP, and lock output signals PTLOCKN and PTLOKFF. The equations for generating these output signals are set forth in the Appendix.
The PAL circuit 12-400b receives lock NAK response signal PTNKFLP from PAL circuit 12-400a, and second half bus cycle acknowledge signal RXSHBA from system bus 16. The PAL circuit 12-400b generates as outputs, a PT cycle over signal which is forwarded to PSM state machine 12-80, an I/O NAK signal IONAKR, and an unusual event signal PTRUAR which is forwarded to the syndrome register error circuits.
FIG. 3b shows in block form, the external state machine (XTR) 12-420 which controls the transfer and processing of external system bus requests to local memory 12-30. The XTR state machine 12-32 includes a clocked programmable array logic (PAL) circuit 12-420a which receives clock signal REFCLK from clock generator circuits 12-22. As shown, XTR state machine 12-420a also receives as inputs, an ask signal XSMASK, a syndrome register clear signal SYNCLR, burst address signals BURSTA1 and BURSTA2, and idle state signal XINIDLE from XSM state machine 12-66, signals RXHAVE+ and RXHAVED+ from the RTR control circuits 12-90, system bus response signals RXNAKR, and RXWAIT in addition to a system bus clear signal MBMCLR. Additionally, XTR state machine 12-420a receives an any request signal RXANYR and system bus cycle won signal RXXTWON from register 12-46 generated by the system bus priority circuits of block 12-460. The XTR state machine circuit 12-420a generates as outputs, retry signal XTRETRY, XSM time-out signal XSMTMOT, XSM cycle over signal XSMCOVR, and external command load signal XTCMDLD. Additionally, the XTR state machine circuit 12-420a generates a request pulse signal XTREQP which it applies to priority circuits of block 12-460 and an unusual event signal XTRUAR which it applies to the syndrome register error circuits. The equations for generating these output signals are set forth in the Appendix.
FIG. 3c shows in block form, the receive state machine (RTR) 12-440 which controls the processing of read/write register requests received from system bus 16. The RTR state machine includes a clocked programmable array logic (PAL) circuit 12-440a which receives clock signal REFCLK from clock generator circuits 12-22. As shown, RTR state machine circuit 12-440a also receives as inputs, signals RXHAVE+ and RXHAVED+ from the RTR control circuits 12-90, system bus response signals RXACKR, RXNAKR, and RXWAIT in addition to system bus clear signal MBMCLR and syndrome register clear signal SYNCLR. Additionally, circuit 12-440a receives an I/O read command signal from the decoder circuits of block 12-90. Additionally, RTR state machine circuit 12-440a receives any request signal RXANYR and system bus cycle won signal RXRTWON from register 12-46 generated by the system bus priority circuits of block 12-460.
The RTR state machine circuit 12-440a generates as outputs, retry signal RTRETRY, NAK signals RTNKFLS and RTNKFLP, and busy signal RTRBSY. Additionally, the RTR state machine 12-440a generates a request pulse signal RTREQP which it applies to the priority circuits of block 12-460 and an usual event signal RTRUAR which it applied to the syndrome register circuits. The equations for generating these output signals are set forth in the Appendix.
FIG. 3d shows in greater detail, the RTR control circuits of block 12-90. As shown, these circuits include the decoder circuits of block 12-900 and the timing circuits of block 12-920. The block 12-900 includes two PAL circuits 12-900a and 12-900b, each of which receive a clock input signal, CYFIFO from the timing circuits of block 12-920. Additionally, each circuit receives I/O read/write acknowledge signal RXIORWA+, in addition to input external command address signals RXAD18+ through RXAD23+ from RXADDRIN register 12-44. The PAL circuit 12-900b also receives an interrupt acknowledge signal RXINTA+.
The PAL circuit 12-900a generates as outputs, read enable interrupt register signals IPRORD and IPRlRD, software message read register enable signal SMREAD-, syndrome register enable signal SYNDRD-, register selection signals RTSEL0 through RTSEL2, IOREAD and I/O read signal IOREAD. The PAL circuit 12-900b generates as outputs, write IPS memory signal WRTIPS-, write software message register SMWRIT-, write interrupt register signals IPROWR- and IPRlWR- and EEPROM address register write signal EARWRIT. These signals are applied to the appropriate registers as read and write enable signals. The register select signals RTSELO+ through RTSEL2 are further decoded and used to generate the constant values from other PAL circuits, not shown, for the resource ID and revision number registers of block 12-72 of FIG. 2, in addition to reading out the contents of the memory module register from such other PAL circuits. The equations for generating these signals are set forth in the Appendix.
The timing circuits of block 12-920 include a pair of series connected D flip-flops 12-920b and 12-920c, each of which receives clock signal REFCLK. Flip-flop 12-920b receives as a data input, cycle request signal CYREQ+ which is generated by an OR gate 12-920a in response to a NAK, ACK, or WAIT cycle response received from system bus 16. Flip-flop 12-920b generates output signal RXHAVE+ which is in turn applied as a data input to flip-flop 12-920c as shown. This flip-flop generates a clock time later, signal RXHAVD which is applied to an output register 12-920d. This register, in response to a further clock signal, generates cycle FIFO signal CYFIFO. AS seen from FIG. 2, the signals RXHAVE+, RXHAVED+, CYCREQ and CYFIFO are distributed to the different ones of the control and register circuits of the mother board.
With reference to FIGS. 1 through 3d and the diagrams of FIGS. 4a through 5, the operation of the system interface circuits of the present invention will now be described. FIGS. 4a through 4c are flow diagrams which illustrate the independent operations of the PTR, XTR and RTR state machines in processing different types of transactions.
PTR State Machine Operation
Referring to FIG. 4a, it is seen that the PTR state machine 12-400 starts in the idle state and remains in that state until it receives a PT load signal PTDTLD from PSM state machine 12-80. At that time, the PTR state machine sequences to a PTR request state which results in the generation of signal PTREQP. This signal is sent to the system bus 16 via the priority request circuits 12-446. Next the PTR state machine 12-400 sequences to a second idle state (idle2) and waits for a response to come back from system bus 16.
There are several things that could take place as a result of the command issued by processing unit 12-2. If the command specified a memory lock operation, the PTR state machine 12-400 will sequence to path c if a negative acknowledgement was received as a response (bus NAK). This would occur if the area of memory being accessed was already being accessed by another unit on system bus 16. For further information about this type of operation, reference may be made to the copending related patent application entitled, "Method and Apparatus for Avoiding Processor Deadly Embrace in a Multiprocessor System."
In this situation, the PTR state machine 12-400 sequences to a PTLOCKN state via path c. It stays in that state until it receives an indication of a bus unlock operation having occurred on bus 16. This causes the PTR state machine 12-400 to return to the PT request state via path d. When in this state, the PTR state machine 12-400 initiates a lock retry procedure wherein the command is reissued to system bus 16 according to standard bus procedure. The other situation that can occur is that none of the conditions (i.e., a,b,c,d,e) occur, causing the PTR state machine 12-400 to remain in the idle2 state.
If the PTR state machine 12-400 received a WAIT response from system bus 16, it will again sequence to the PT request state. Also, if the PTR state machine 12-400 received a system bus time-out or an illegal response (i.e., it was doing a memory reference command and received a NAK response), it will return to the PT request state. Normally, the memory will never generate a NAK response to a memory request unless the request is for a lock operation. Accordingly, the PTR state machine 12-400 performs one more retry and if the condition occurs again, the PTR state machine 12-400 sequences to the cycle over state via path e. This state corresponds to an end state which is entered if an ACK response is received to a command, or a bus NAK response is received to an I/O command, or a second time-out or illegal response is received. At that time, the PTR state machine sets the NAK indicator (PTNKFLP).
It is seen that the retry sequence is programmable based upon whatever bus operation is being performed. In this way, the PTR state machine 12-400 is able to handle the lock NAK responses, bus WAIT responses, the retry conditions, not only in the case of bus errors or time-outs, but also in the case of illegal bus responses. In the case of processor issued commands, a wait response is a legal response. The same is true of a NAK response to an I/O command. However, the PTR state machine does not retry such I/O commands, but instead concludes the operation by sequencing to the cycle over state. In the case of retry, if a NAK response is received as a result of memory lock command, the PTR state machine waits for a memory unlock operation to occur on system bus 16 in which case the operation is retried.
RTR State Machine Operation
FIG. 4b illustrates the operation of the RTR state machine 12-420 of FIG. 3c. This state machine responds to I/O commands received from system bus 16 specifying either reading or writing the contents of a system visible register and, in the case of a read operation, returns the contents back to the requesting unit, such as a memory controller or another on-board memory processing unit.
As seen from FIG. 4b, the RTR state machine 12-420 starts in the idle state waiting for the receipt of an I/O read operation. Upon receipt of an I/O read command, it sequences to the RT request state. When in this state, the RTR state machine 12-400 generates signal RTREQP to the priority request circuits of block 12-460. It then sequences to the idle2 state.
As shown in FIG. 4b, the RTR state machine can terminate it operation in a number of ways. If it receives a bus WAIT response, it remains in the idle2 state until it receives data back during a second half bus cycle. Here, the only legal response in the case of a second half bus cycle is a bus ACK response. Therefore, if the RTR state machine receives a NAK or WAIT response, it returns back to the RT request state via path a and retries the operation. Also, in the case of a NAK or WAIT response, it sets the NAK indicator (i.e. RTNKFLP). If, as a result of the first retry operation, the RTR state machine receives another or second NAK response or receives an ACK response, it returns to the idle state. Here, in the case of the RTR state machine, a NAK or WAIT response is deemed illegal.
XTR State Machine Operation
Referring to FIG. 4c, it is seen that the XTR state machine 12-440 starts in the idle state and remains in that state until it receives a request from the XSM state machine 12-66 (i.e., signal XSMASK) as for example to send data out of the burst array registers loaded from local memory 12-30 of block 12-58 to complete the execution of a read burst command received from system bus 16. At that time, the XTR state machine 12-440 sequences to the XT request state which results in the generation of signal XTREQP. This signal is sent to the system bus 16 via the priority request circuits 12-460. Next, the XTR state machine 12-440 sequences to the idle2 state. It will do a retry in the following situations. If it received a NAK or WAIT response, it will retry that operation once and if unsuccessful, it will terminate by entering a cycle over state via path c. This results in the generation of signal XSMCOVR. If it received a NAK response when doing the burst operation and the burst count was not equal to three, indicating the transfer of four words was not completed, then a retry is performed in order to send out the contents of the last burst register (fourth word) to system bus 16. Following that, the XTR state machine 12-440 again sequences to the cycle over state.
If the NAK indicator was set which means that the XTR state machine 12-440 did a retry operation but received a NAK or WAIT response or received a bus ACK response and was not doing a burst (single word) or doing a burst operation and the count was equal to three, this indicates that the operation was completed but an error was detected. This results in the setting of an unusual response indication (XTUAR) in the syndrome register error circuits which indicates that the XTR state machine received an illegal response after having already retried the operation. This enables the XSM state machine 12-66 to take whatever further action may be necessary, such as rereading local memory 12-30.
From the above, it is seen how the state machines are able to handle system bus responses differently. As mentioned, each of the state machines can be simultaneously processing a different transaction or request queued up in the different registers of the processing unit. For example, the microprocessor 12-20 could have made a request to the system bus 16. Simultaneously, the processing unit 12-2 could be processing a memory request received from system bus 16, in addition to processing an I/O command specifying the reading or writing of a system visible register. Once the transaction or request has been queued up, control is turned over to the appropriate state machine for completion. As described above, each state machine monitors the system bus 16 and is responsible for completing the transaction no matter what conditions happen to occur in the process of completion.
FIG. 5 illustrates how the state machines of the present invention is able to provide the simultaneous processing of transactions. Referring to the Figure, it is seen that the first transaction is an I/O command issued by the PSM state machine 12-80. In response to the Pt data load signal, the PTR state machine 12-400 operates to transfer the command to system bus 16 in the manner described above. While that operation is in process, the XSM state machine 12-66 issues request for transferring data in response to a burst read operation received from an I/O controller connected to system bus 16. In response to the burst request, the XSM state machine 12-66 initiates the read out of the requested four data words from local memory 12-30 and their loading into the burst array registers of block 12-58. Upon completion of the loading of the burst array registers, it generates signal XSMASK.
Upon receipt of signal XSMASK, the XTR state machine 12-420 will begin the transfer of data during subsequent second half bus cycles. As seen from FIG. 5, the first transfer occurs during a fourth cycle of operation.
While both operations are in process, a host processor of FIG. 1 issues an I/O request specifying the reading of the system message register. In response to the request, the RTR control circuits 12-90 generate the appropriate signals which cause the RTR state machine 12-440 to begin its processing of the request. The RTR state machine 12-440 delivers the contents of the software message register during the eighth cycle.
The data requested by the PSM state machine 12-80 on behalf of microprocessor 12-20 is delivered during the last cycle of FIG. 5. During the transaction sequence, burst data is being delivered to system bus 16 under the control of the XTR state machine 12-420 as shown in FIG. 5.
It will be appreciated by those skilled in the art that many changes may be made without departing from the teachings of the present invention. For example, the invention may be used in conjunction with different types of protocols and commands. Also, while the preferred embodiment utilizes different PAL circuits to perform certain functions that such functions can be combined in certain instances and performed within a single circuit. Also, the invention is not limited to any specific type of circuit. ##SPC1##
While in accordance with the provisions and statutes there has been illustrated and described the best form of the invention, certain changes may be made without departing from the spirit of the invention as set forth in the appended claims and that in some cases, certain features of the invention may be used to advantage without a corresponding use of other features.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4099236 *||May 20, 1977||Jul 4, 1978||Intel Corporation||Slave microprocessor for operation with a master microprocessor and a direct memory access controller|
|US4247893 *||Jan 3, 1977||Jan 27, 1981||Motorola, Inc.||Memory interface device with processing capability|
|US4415971 *||Mar 31, 1981||Nov 15, 1983||Cii Honeywell Bull||Apparatus for managing the data transfers between a memory unit and the different processing units of a digital data processing system|
|US4433378 *||Sep 28, 1981||Feb 21, 1984||Western Digital||Chip topography for MOS packet network interface circuit|
|US4698753 *||Nov 9, 1982||Oct 6, 1987||Texas Instruments Incorporated||Multiprocessor interface device|
|US4797853 *||Nov 15, 1985||Jan 10, 1989||Unisys Corporation||Direct memory access controller for improved system security, memory to memory transfers, and interrupt processing|
|US4831520 *||Feb 24, 1987||May 16, 1989||Digital Equipment Corporation||Bus interface circuit for digital data processor|
|US4992930 *||May 9, 1988||Feb 12, 1991||Bull Hn Information Systems Inc.||Synchronous cache memory system incorporating tie-breaker apparatus for maintaining cache coherency using a duplicate directory|
|US5003465 *||Jun 27, 1988||Mar 26, 1991||International Business Machines Corp.||Method and apparatus for increasing system throughput via an input/output bus and enhancing address capability of a computer system during DMA read/write operations between a common memory and an input/output device|
|US5077664 *||Mar 3, 1989||Dec 31, 1991||Fujitsu Limited||Direct memory access controller|
|US5111425 *||Jan 16, 1990||May 5, 1992||Hitachi Ltd.||Single chip communication data processor with direct memory access controller having a channel control circuit|
|US5123092 *||Oct 21, 1988||Jun 16, 1992||Zenith Data Systems Corporation||External expansion bus interface|
|US5235685 *||May 11, 1989||Aug 10, 1993||Data General Corp.||Interface bus with independent data, command and direct control sections for parallel transfer of information between host and intelligent storage|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US5603042 *||Dec 15, 1994||Feb 11, 1997||Ast Research, Inc.||Pipelined data ordering system utilizing state machines to data requests|
|US5615382 *||Jun 6, 1995||Mar 25, 1997||Digital Equipment Corporation||Data transfer system for buffering and selectively manipulating the size of data blocks being transferred between a processor and a system bus of a computer system|
|US5701422 *||Dec 13, 1995||Dec 23, 1997||Ncr Corporation||Method for ensuring cycle ordering requirements within a hierarchical bus system including split-transaction buses|
|US5710939 *||May 26, 1995||Jan 20, 1998||National Semiconductor Corporation||Bidirectional parallel data port having multiple data transfer rates, master, and slave operation modes, and selective data transfer termination|
|US5737627 *||Feb 7, 1997||Apr 7, 1998||Ast Research, Inc.||Pipelined data ordering system utilizing state machines to order data requests|
|US6038667 *||Oct 14, 1998||Mar 14, 2000||Helbig, Sr.; Walter A.||Method and apparatus enhancing computer system security|
|US6058439 *||Mar 31, 1997||May 2, 2000||Arm Limited||Asynchronous first-in-first-out buffer circuit burst mode control|
|US6173374 *||Feb 11, 1998||Jan 9, 2001||Lsi Logic Corporation||System and method for peer-to-peer accelerated I/O shipping between host bus adapters in clustered computer network|
|US6195593 *||Jul 22, 1998||Feb 27, 2001||Seiko Epson Corporation||Reusable modules for complex integrated circuit devices|
|US6785743 *||Mar 22, 2000||Aug 31, 2004||University Of Washington||Template data transfer coprocessor|
|US7054971||Mar 19, 2003||May 30, 2006||Seiko Epson Corporation||Interface between a host and a slave device having a latency greater than the latency of the host|
|US7730274||Dec 31, 2007||Jun 1, 2010||Symantec Operating Corporation||Preventing undesired trespass in storage arrays|
|US8060775||Jun 14, 2007||Nov 15, 2011||Symantec Corporation||Method and apparatus for providing dynamic multi-pathing (DMP) for an asymmetric logical unit access (ALUA) based storage system|
|US20040044814 *||Mar 19, 2003||Mar 4, 2004||Denis Beaudoin||Interface between a host and a slave device having a latency greater than the latency of the host|
|US20050223010 *||Mar 28, 2005||Oct 6, 2005||Paul Murray||Coordination of lifecycle changes of system components|
|WO1999012112A1 *||Aug 27, 1998||Mar 11, 1999||Seiko Epson Corporation||Reusable modules for complex integrated circuit devices|
|U.S. Classification||710/7, 711/100, 710/1, 710/113|
|International Classification||G06F15/78, G06F13/36|
|Cooperative Classification||G06F13/36, G06F15/78|
|European Classification||G06F13/36, G06F15/78|
|May 27, 1999||FPAY||Fee payment|
Year of fee payment: 4
|Apr 29, 2003||FPAY||Fee payment|
Year of fee payment: 8
|Jun 18, 2003||REMI||Maintenance fee reminder mailed|
|May 4, 2007||FPAY||Fee payment|
Year of fee payment: 12