CA2503335C - Method and apparatus for pre-emptively arbitrating on an acyclic directed graph - Google Patents

Method and apparatus for pre-emptively arbitrating on an acyclic directed graph Download PDF

Info

Publication number
CA2503335C
CA2503335C CA2503335A CA2503335A CA2503335C CA 2503335 C CA2503335 C CA 2503335C CA 2503335 A CA2503335 A CA 2503335A CA 2503335 A CA2503335 A CA 2503335A CA 2503335 C CA2503335 C CA 2503335C
Authority
CA
Canada
Prior art keywords
node
nodes
adjacent
signal
bus
Prior art date
Legal status (The legal status 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 status listed.)
Expired - Lifetime
Application number
CA2503335A
Other languages
French (fr)
Other versions
CA2503335A1 (en
Inventor
Florin Oprescu
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple 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 Apple Inc filed Critical Apple Inc
Priority to CA2698356A priority Critical patent/CA2698356C/en
Publication of CA2503335A1 publication Critical patent/CA2503335A1/en
Application granted granted Critical
Publication of CA2503335C publication Critical patent/CA2503335C/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40052High-speed IEEE 1394 serial bus
    • H04L12/40078Bus configuration
    • 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/14Handling requests for interconnection or transfer
    • G06F13/36Handling requests for interconnection or transfer for access to common bus or bus system
    • 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/14Handling requests for interconnection or transfer
    • G06F13/36Handling requests for interconnection or transfer for access to common bus or bus system
    • G06F13/368Handling requests for interconnection or transfer for access to common bus or bus system with decentralised access control
    • G06F13/37Handling requests for interconnection or transfer for access to common bus or bus system with decentralised access control using a physical-position-dependent priority, e.g. daisy chain, round robin or token passing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/173Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
    • G06F15/17337Direct connection machines, e.g. completely connected computers, point to point communication networks
    • G06F15/17343Direct connection machines, e.g. completely connected computers, point to point communication networks wherein the interconnection is dynamically configurable, e.g. having loosely coupled nearest neighbor architecture
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40052High-speed IEEE 1394 serial bus
    • H04L12/40084Bus arbitration
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/48Routing tree calculation

Abstract

A bus arbitration scheme is implemented in a system where an arbitrary assembly of nodes on a system bus have been resolved into an acyclic directed graph. The hierarchical arrangement of nodes has one node designated a root while all other nodes have established parent-child relationships with the nodes to which they are linked. Each node may have a plurality of connected child ports with a predetermined acknowledgment priority scheme established. Fair bus access arbitration provides for bus granting in a sequence corresponding to the predetermined port priorities allowing all nodes a turn on the bus. The root node may always assert its priority access status to gain bus access which is useful for accommodating a root node which requires isochronous data transfer. Alternatively, a token passing arbitration scheme may be implemented where the token for bus access is passed around the nodes according to the above-described predetermined port priority scheme. Preemptive bus initialization may be triggered by any node upon detection of a necessitating error or addition or removal of a connection to an existing node.

Description

i METHOD AND APPARATUS FOR PRE-EMPTIVELY ARBITRATING
ON AN ACYCLIC DIRECTED GRAPH
This is a divisional application of Canadian patent application serial number 2,408,252, which is turn is a divisional application of Canadian Patent No. 2,151,369 which issued to patent on February 10, 2004 and was the national phase application of PCT International application PCT/US93/12311 filed December 16, 1993 (12.16.93) and published July 7, 1994 (07.07.94) under International publication no. WO 94/15302.
BACKGROUND OF THE INVENTION
I. Field of the Invention The present invention relates to computer systems.
More particularly, the present invention relates to a method and apparatus for establishing and utilizing a communications scheme between a plurality of arbitrarily assembled elements of a computer system.
Components within a given computer system need the ability to convey signals amongst themselves. In very simple systems, it is possible to have each element of the system directly wired to all of the other parts of the system. However, in reality, in order to make computers expandable and to accommodate an unknown number of system parts, computer architects long ago developed the concept of a communications bus.
A bus is a communications path, such as a wire or wires, running throughout the computer system. Each component of the system need only plug into the bus to be theoretically connected to each of the other components in the system. Of course, each component cannot simultaneously communicate with other components because there may be only a single communications channel between the components. It is necessary when utilizing a communications bus to establish some form a sharing arrangement so that each component may use the bus to .
communicate with other components in an efficient manner WO l4/1530Z PCTIUS93112311 that does not leave critical pieces of information from one component hanging, waiting for bus access. The method by which components on the bus share the bus is generally . referred to as a bus arbitration scheme.
In addition to the critical need to optimize the bus arbitration scheme so as to maximize the flow of important information, the physical (and logical/electrical) configuration of the bus itself can and should be optimized to minimize system delays while remaining as flexible as possible.
In order to communicate with other components attached to a bus, each component must be equipped with hardware such as transmitting and receiving circuitry compatible with the communications protocol implemented for the bus.
One such communications standard is described in IEEE
Standards Document P1394 entitled ~Xigh Performance Serial Xus~, said document attached as Appendix A to this document. The standard described in P1394 is intended to provide a low cost interconnect between cards on the same backplane, cards on other backplanes, and external peripherals.
Prior art buses or networks required knowing what was being plugged in where. For example, the back of many WO 94/15302 PCTIUS93/1?311 _q_ computers have specified ports for specific peripherals.
Some computers implement several buses, such as the Macintosh which uses a bus referred to as ADB for components like a mouse and keyboard and SCSI bus for other , peripherals. These types of buses provide for daisy chaining elements together but connections are of limited topology. Other known buses/networks require that the nodes of the network be arranged in a ring, a loop which must be closed in order to operate. Finally, star, or hub-and-spoke arrangements required that each node be directly linked to a central master. Each of the prior art systems lacks a desirable measure of flexibility.
It would be desirable, and is therefore and object of the present invention, to be able to arbitrarily assemble elements of a computer system onto a bus where the arbitrary topology can be resolved by the system into a functioning system without requiring a predetermined arrangement of components.

It is an object of the present invention to provide a fair bus access arbitration scheme for a computer system bus or network in which the connections of nodes have been resolved into an acyclic directed graph.
It is also an object of the present invention to provide a priority bus access arbitration scheme for a computer system bus or network in which the connections of nodes have been resolved into an acyclic directed graph.
It is another object of the present invention to provide a method of token passing bus arbitration for a computer system bus or network in which the connections of nodes have been resolved into an acyclic directed graph.
It is yet another object of the present invention to provide a mechanism whereby a preemptive bus initialization may be triggered by any node in a network of nodes which are resolved into an acyclic directed graph when errors are detected or nodes are added or subtracted during operation.
These and other objects of the present invention are implemented in a system where an arbitrary assembly of nodes on a system bus have been resolved into an acyclic directed graph. The hierarchical arrangement of nodes has one node designated a root while all other nodes have established parent/child relationships with the nodes to which they are linked. Each node may have a plurality of connected child ports with a predetermined acknowledgment priority scheme established. Fair bus access arbitration provides for bus granting in a sequence corresponding to the predetermined port priorities allowing all nodes a turn on the bus. The root node may always assert its priority access status to gain bus access which is useful for accommodating a root node which requires isochronous data transfer. Alternatively, a token passing arbitration scheme may be implemented where the token for bus access is passed around the nodes according to the above-described predetermined port priority scheme. Preemptive bus initialization may be triggered by any node upon detection of a necessitating error or addition or removal of a connection to an existing node.
Accordingly, in one aspect, the present invention provides in a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed -6a-acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a method of preemptive bus initialization comprising: propagating a "Bus Initialization" (BI) signal from any node determining that bus initialization is necessary; sustaining the BI
signal for a predetermined period of time; and propagating that signal throughout the directed acyclic graph to all nodes in the directed acyclic graph.
In a further aspect, the present invention provides in a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed -6b-acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relations ships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a method of preemptive bus initialization comprising: propagating a "Bus Initialization" (BI) signal from any node determining that bus initialization is necessary; sustaining the BI
signal for a predetermined period of time; and propagating that signal throughout the directed acyclic graph to all nodes in the directed acyclic graph.
In a still further aspect, the present invention provides a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising:
determining an error condition in communication through -6c-the at least one links; sustaining a "Bus Initialization"
(BI) signal for a period of time to propagate the BI
signal from the first node to the at least one adjacent node in response to the error condition; and performing bus initialization in communication with the at least one adjacent node.
In a still further aspect, the present invention provides in a method for a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality of adjacent nodes respectively, the method comprising: receiving a "Bus Initialization" (BI) signal from a second node of the plurality of adjacent nodes;
sustaining the BI signal for a period of time to propagate the BI signal from the first node to the plurality of adjacent nodes except the second node in response to said receiving the BI signal; and performing bus initialization in communication with the plurality of adjacent nodes.
In a further aspect, the present invention provides a computer system comprising a plurality of components, said plurality of components each having at least one communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the -6d-root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, to arbitrate access to the bus the computer system further comprising: means for transmitting a " Bus Request " (BR) signal from a requesting node to a parent node, said requesting node having a packet of information to propagate on said bus; means for, each node that receives the BR signal, forwarding the BR signal to a parent node;
means for the root node, upon receiving the BR signal from one adjacent node, responding to said adjacent node with a " Bus Grant " (BG) signal; means for, each node that receives the BG signal from a parent node, propagating the BG signal to a child node which previously forwarded the BR signal, except the requesting node; and means for the requesting node, upon receiving the BG signal, propagating said packet of information on the bus, wherein after the requesting node has propagated said packet of information, the requesting node waits for a gap period before again requesting access to said bus, said gap period being greater than a worst case signal propagation delay through the bus.
In a still further aspect, the present invention provides a computer system comprising a plurality of components, said plurality of components each having at least one communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed -6e-acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, to arbitrate access to the bus the computer system further comprising: means for transmitting a " Bus Denied " (BD) signal from a requesting node to all adjacent child nodes, said requesting node having a packet of information to propagate on said bus; means for transmitting a " Bus Request " (BR) signal from the requesting node to a parent node; means for, each node that receives the BR signal, forwarding the BR signal to a parent node and propagating a BD signal to all child nodes that were not the source of the BR signal; means for the root node, upon receiving the BR signal from one adjacent node, responding to said adjacent node with a " Bus Grant " (BG) signal, said root node propagating a BD signal to alI other adjacent nodes;
means for, each node that receives the BG signal from a parent node, propagating the BG signal to a child node which had previously forwarded the BR signal, except the requesting node; means for the requesting node, upon receiving the BG signal, acknowledging receipt of said BG
signal and propagating said packet of information; and means for the root node, upon determining that the root node requires access to the bus, propagating a BD signal to all adjacent nodes and granting access to the bus to the root node.
In a further aspect, the present invention provides a computer system comprising a plurality of components, said plurality of components each having at least one -6f-communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a metaphorical token passed from node to node in a cycle through the directed acyclic graph for token passing bus access arbitration, the node having the token being the node with bus access, the computer system further comprising: means for passing the token through the directed acyclic graph in an order determined by a predetermined selection criterion each node has established for selecting adjacent nodes.
In a still further aspect, the present invention provides in a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed -6g-acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a requesting node to access the bus, the requesting node comprising: means for generating a first " Bus Request "
(BR) signal when the requesting node has information to propagate onto the bus; means for forwarding the first BR
signal from the requesting node to an adjacent parent node; means for propagating information onto the bus upon receiving a " Bus Grant " (BG) signal; and means for waiting, after the propagating, for a gap period before generating a second BR signal, the gap period being greater than a worst case signal propagation delay through the bus; wherein the first BR signal is forwarded by any receiving node to a respective adjacent parent node;
wherein the BG signal is generated at a root node upon receiving the first BR signal forwarded from one adjacent node of the root node; and wherein the BG signal is forwarded by any node having the BG signal to an adjacent child node which previously forwarded the first BR signal.
In a further aspect, the present invention provides in a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, -6h-all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a first node connected to at least one adjacent node on the bus, the first node being capable of having at least one child node, the first node comprising: when the first node has at least one adjacent child node: means for receiving a first " Bus Request " (BR) signal from a second node, the second node being one of the at least one adjacent child node of the first node; when the first node has a parent node: means for forwarding the first BR signal to the parent node of the first node after receiving the first BR
signal; means for forwarding a first " Bus Grant " (BG) signal for the first BR signal from the parent node of the first node to the second node; means for transmitting a second BR signal to the parent node of the first node when the first node requires access to the bus to propagate information; and means for receiving a second BG signal for the second BR signal from the parent node of the first node: when the first node has no parent node: means for transmitting a third BG signal for the first BR signal to the second node; and means for granting the first node access to the bus when the first node requires access to the bus to propagate information.
In a still further aspect, the present invention provides a first node to communicate with at least one -6i-adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent node respectively, the first node comprising: means for counting, since a starting point of a node identification process, a number of announcements received by the first node; means for passing a token from the first node to one of the at Least one adjacent node according to a predetermined selection criterion for selecting a node from the at least one adjacent node; means for broadcasting an announcement from the first node when the first node is in possession of the token for data transmission; and means for setting a unique address for the first node based on the number of announcements received by the first node since the starting point to when the first node is in possession of the token for data transmission.
In a further aspect, the present invention provides a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relations ships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the -6j-root node being defined as having no parent node, the computer system further comprising: means for propagating a " Bus Initialization " (BI) signal from any node determining that bus initialization is necessary; means for sustaining the BI signal for a predetermined period of time; and means for propagating that signal throughout the directed acyclic graph to all nodes in the directed acyclic graph.
In a still further aspect, the present invention provides a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising: means for determining a first determination that a parent-child relationship between the first node and one of the at least one adjacent node is to be changed; means for sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the first determination; and means for communicating with the at least one adjacent node to perform bus initialization.
In a further aspect, the present invention provides a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising: means for determining a change in status of a second node in communication with the first node through a point-to-point link; means for sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the change; and means for performing bus -6k-initialization in communication with the at least one adjacent node.
In a still further aspect, the present invention provides a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising: means for determining an error condition in communication through the at least one links; means for sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the error condition; and means for performing bus initialization in communication with the at least one adjacent node.
In a further aspect, the present invention provides a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the first node comprising: means for receiving a " Bus Initialization " (BI) signal from a second node of the plurality of adjacent nodes; means for sustaining the BI signal for a period of time to propagate the BI signal from the first node to the plurality of adjacent nodes except the second node in response to receiving the BI signal; and means for performing bus initialization in communication with the plurality of adjacent nodes.
In a still further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method on a requesting node to access a bus of a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising the bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, the method comprising:
generating a first " Bus Request " (BR) signal when the requesting node has information to propagate onto the bus;
forwarding the first BR signal from the requesting node to an adjacent parent node; propagating information onto the bus upon receiving a " Bus Grant " (BG) signal; and waiting, after the propagating, for a gap period before generating a second BR signal, the gap period being greater than a worst case signal propagation delay through the bus; wherein the first BR signal is forwarded by any receiving node to a respective adjacent parent node;
wherein the BG signal is generated at a root node upon receiving the first BR signal forwarded from one adjacent node of the root node; and wherein the BG signal is forwarded by any node having the BG signal to an adjacent child node which previously forwarded the first BR signal.
In a further aspect, the present invention provides a machine readable medium containing executable computer -6m-program instructions which when executed by a data processing system cause said system to perform a method on a first node to access a bus of a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising the bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, the first node connected to at least one adjacent node on the bus, the first node being capable of having at least one child node, the method comprising: when the first node has at least one adjacent child node: receiving a first " Bus Request "
(BR) signal from a second node, the second node being one of the at least one adjacent child node of the first node;
when the first node has a parent node: forwarding the first BR signal to the parent node of the first node after receiving the first BR signal; forwarding a first " Bus Grant " (BG) signal for the first BR signal from the parent node of the first node to the second node;
transmitting a second BR signal to the parent node of the first node when the first node requires access to the bus -6n-to propagate information; and receiving a second BG signal for the second BR signal from the parent node of the first node; when the first node has no parent node: transmitting a third BG signal for the first BR signal to the second node; and granting the first node access to the bus when the first node requires access to the bus to propagate information.
In a still further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the method comprising: passing a token from the first node to one of the plurality of adjacent nodes according to a predetermined selection criterion for selecting a node from the plurality of adjacent nodes.
In a further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent node respectively, the method comprising: counting, since a starting point of a node identification process, a number of announcements received by the first node; passing a token from the first node to one of the at least one adjacent node according to a predetermined selection criterion for selecting a node from the at least one adjacent node; broadcasting an announcement from the first node when the first node is in possession of the token for data transmission; and setting a unique address for the first node based on the number of announcements received by the first node since the starting point to when the first node is in possession of the token for data transmission.
In a still further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising: determining a first determination that a parent-child relationship between the first node and one of the at least one adjacent node is to be changed; sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the first determination; and communicating with the at least one adjacent node to perform bus initialization.
In a further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising: determining a change in status of a second node in communication with the first node through a point-to-point link; sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at -6p-least one adjacent node in response to the change; and performing bus initialization in communication with the at least one adjacent node.
In a still further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising: determining an error condition in communication through the at least one links; sustaining a " Bus Initialization " (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the error condition; and performing bus initialization in communication with the at least one adjacent node.
In a further aspect, the present invention provides a machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the method comprising: receiving a " Bus Initialization " (BI) signal from a second node of the plurality of adjacent nodes; sustaining the BI signal for a period of time to propagate the BI signal from the first node to the plurality of adjacent nodes except the second node in response to said receiving the BI signal;
and performing bus initialization in communication with the plurality of adjacent nodes.

The objects, features and advantages of the present . invention will be apparent from the following detailed description in which:
Figure 1 illustrates a block diagram of the hardware layer implementation utilized in accordance with the present invention.
Figures 2(a)-2(b) illustrate arbitrarily assembled collection of nodes, one being acyclic and the other including multiple cycles.
Figure 3(a) is the arbitrarily assembled collection of nodes of Figure 2(a) undergoing the graph transformation process in accordance with the present invention.
Figures 3(b)-3(d) illustrate alternative communications exchanges between nodes in implementing the present invention.
Figure 3(e) graphically illustrates the directed graph resulting from the arbitrarily assembled network of nodes of Figure 2(a).
Figures 4 illustrates a symmetrical graph arrangement which requires resolving a root contention.

_8_ Figure 5 illustrates a directed acyclic graph with a possible unique address assignment order indicated.
Figures 6(a)-6(f) illustrate the process flow for carrying out the graph transformation procedure in accordance with the preferred embodiment of the present invention.

_g_ A method and apparatus for utilizing a bus having an arbitrary topology are described. In the following description, many specific details are set forth such as various computer components in order to provide a thorough understanding of the present invention. It will be obvious, however, to one skilled in the art that the present invention may be practiced without such specific details. In other instances, well-known control structures and coding techniques have not been described in detail in order not to obscure unnecessarily the present invention.
Throughout this detailed description, numerous descriptive terms are introduced to provide metaphorical clarity to the description. For example, frequent references will be made to parent-child relationships between nodes in a given topology. The purpose of this is to provide the concept of "direction" to the finally resolved graph. As will be described, once an arbitrary topology has been reduced to an acyclic directed graph, there will be one node identified as the "root" node. The root node will not have a parent node, all nodes logically immediately adjacent to the root node are the child nodes WO 94115302 PCT/US9311?311 of the root. The "tree" metaphor is completed by the inclusion of nodes referred to as "branches" and "leaves".
The bus architecture described herein, though described with reference to components for a single computer, in general has a broader scope. The present invention for defining the bus topology may be applied to any arbitrarily assembled collection of nodes linked together as in a network of devices. One point that must be noted is that it is necessary to distinguish a node from a physical computer component. Each component to reside on the bus will have associated with it at least one node physical layer controller. In certain circumstance, a given component may advantageously be associated with multiple nodes but in the usual case there will be a one-to-one correspondence between devices or components on the bus and nodes.
Referring now to 8'igure 1 a block diagram of a node is illustrated. The physical implementation of a node is somewhat arbitrary. In the preferred embodiment implementation of the present invention, the nodes are designed to comply with the IEEE P1394 Hiqh Performance Serial Hus communications protocol. The node 10 includes arbitration state machine logic 11. This arbitration state machine logic WO 94/I5302 PC'TNS9311?3I1 incorporates all the logic circuitry for carrying out the methodologies and algorithms to be described herein. The circuitry may comprise a programmable logic array tPLA) or be uniquely designed to carry out the functions described herein. Those skilled in the art, once described the functions to be carried out by the node logic will be able to implement the present invention without undue experimentation. The node, by means of its logic, shall implement the minimum arbitration protocol including the bus initialization, tree identification, self identification, and the bus arbitration functions, all to be described in detail further herein.
The node 10 shown in Figuro 1 also includes transmission multiplexers 12 and 13 and data transmitter, receiver and resynchronizer 19. The node illustrated in Figure 1 is coupled to local host 15. Local host 15 may be any device one wishes to attach to the bus such as a disk drive, CPU, keyboard or any other component which needs to communicate with other components in the system.
The node 10 communicates With other nodes through communications links. A link is a connection between two ports and in immediate practical terms is a cable segment but in general it may be implemented as any physical communication channel. A link shall be able, at minimum, wo 9an53oZ Pcrrus93n~m to provide a half duplex communication channel between the two ports which it connects. A port is the interface between a node and a link. In accordance with the present invention, a port must have the ability to transmit and receive data and arbitration signaling. A port needs to be able to determine whether or not it is connected to another port through a link. One method of facilitating this is by having connected ports apply a biasing voltage through the link which is detectable by the port at the other end of the link. Thus, if a port has a link attached which is not connected to a port at the other end, a naked link, the port will determine that it is not a connected port. In Figure 1, the illustrated node 10 has three external ports 21, 22 and 23 with connecting links 17, 18 and 19, respectively.
Some of the rules of implementation for nodes in order to implement the present invention are that a node may have one or more ports. A node shall be able to transmit and receive data on any one of its ports. A node shall be able to receive data on one and only one of its enabled ports at a time and be able to retransmit this data on all remaining enabled ports. A node shall be able to receive and transmit signaling messages through all of its ports simultaneously and independently. Separate signaling WO l4I15301 PCT/US93/1I311 transceivers, encoders and decoders are required for each port of a node. A minimum implementation node does not require a local host device. For example, such a node may function as a cable extension. From hereon devices and local hosts will be ignored and all references to bus topology will refer to nodes and node connections through various ports.
lignrss 2(s) aad 2(b) illustrate arbitrarily assembled collections of nodes. From hereon, nodes will be illustrated merely as circles, but are deemed to each incorporate elements equivalent to those described with respect to Figure 1. Note, however, that each node may have more or less than the three external ports shown in that figure. The lines illustrated connecting each of the nodes are the method by which links are shown. Ports are not illustrated, but are impliedly the interface where a link and a node connect.
The bus arbitration methodology to be described herein requires that the arbitrary topology be resolved into an acyclic directed graph. In an arbitrary topology graph a collection of nodes and links may form a cycle. A cycle WO !4/15302 PCTIUS93/IZ311 exists if starting from a specific node in the graph it is possible to return to the same node by traversing links and nodes without any link being traversed twice. ~ignre 2(a) illustrates an acyclic graph because none of the nodes illustrated are connected within a loop. !'igur~
2(b), however, is not an acyclic graph because the region in bounding box 25 contains a collection of nodes, 40-47 which form multiple cycles. The bus arbitration methodology to be described requires that there be no cycles, so a method of user intervention to resolve cycles will also be described further herein.
In addition to the requirement that a graph be acyclic, it must also be directed. A directed graph is one in which a hierarchical arrangement has been established between adjacent nodes. Initially, there are no established parent-child relationships between nodes. That is, for example, node 31 may be the "parent node" for node 34, or be the "child node".for node 34. Thus, it is necessary to take a given arbitrary topology graph and transform it into an acyclic and directed graph. The methods described herein will work to perform this transformation for any give arbitrary topology, regardless of the number of nodes or how they are physically linked and regardless of the signaling propagation time along the links.
Initially, the process of transforming an acyclic arbitrary topology graph into a directed graph will be described. The case where cycle resolution is required will follow. Figure 3(a) shows the arbitrary graph of Figurs 2(a) wherein the nodes and links have status labels and communicated signals are indicated for the graph transformation process for directing a graph. It is instructive at this point to describe signal communications between nodes. Figure 3(b) illustrates two nodes 50 and 51 (hereinafter node A and node 8, respectively) coupled by link 52. As described, the link is the communications channel coupling transceiver ports of the respective nodes as described above with reference to Figure 1. During the graph transformation process, it becomes necessary for nodes to establish parent-child relationships with adjacent nodes. Two nodes are said to be adjacent nodes if there is at least one link connected between a port of the first node and a port of the second node. In Figures 3(b)-3(d) it will be assumed that the relationship to be resolved is that node B is the parent of node A and that it is appropriate for the nodes to establish that relationship.
Prior to a direction being established, when it become appropriate for node A to establish node B as its parent, node A will transmit from its port to which link 52 is coupled the signal "You Are My Parent" (YAMP). This message content may take any form, so long as node A knows that it is signaling YAMP and node B is capable of understanding that the received message is YAMP. When YAMP
signal 53 is received by node B, node B will respond to node A by sending "You Are My Child" (YAMC) through link 52 to node A. The arbitration state machine logic 11 of node A will keep track of the time delay between sending YAMP
signal 53 and receiving YAMC signal 59. The time measured signifies twice the propagation delay between nodes A and B. Upon receiving the YAMC signal, node A will respond with a "You Are My Child Acknowledged" (YAMCA) signal 55.
This provides node B with the ability to also determine the propagation time delay between the nodes equal to the time delay between sending YAMC and receiving YAMCA. For half duplex communication links, the YAMCA message also has the effect of properly orienting the communication channel.

WO 94/15302 PCTNS93I1?311 For full duplex communications channels the three logical messages, YA1~, YAMC and YAMCA can alternatively be relayed by only two signal transmissions. In !'figure 3(c) this situation is illustrated where node A asserts the YAI~
signal 56 continuously until it receives the return YAMC
signal 57. The YAMCA signal is logically transmitted to node B when the YAI~ signal is detected as no longer arriving.
The use of this described triple asynchronous message exchange provides a mechani$m by which both nodes involved in the message exchange can determine the propagation time delay through the link. This delay value is used in resolving contention events to be described further herein as well as during normal bus arbitration to optimize bus performance. The dynamic extraction of this parameter is not mandatory. As an alternative a maximum propagation time delay can be apriory defined at the expense of optimum bus performance.
Once nodes A and B have exchanged messages signifying that node H is the parent of node A, the link can be said to be directed. Node A within its logic labels its port to which link 52 is coupled as a parent port (it talks to a . parent node) and node H labels its port to which link 52 is coupled a child port (it talks to a child node). It is important to maintain the labels that ports achieve because the methods to be described below will be in terms of the labels assigned to nodes and ports at a given time. A
short hand graphical notation is illustrated in Figure 3(d) where the direction arrow 58 indicates that node B is established as the parent of node A and the link is directed.
Direction Determination Referring back now to Figure 3(a) and to process Figures 6(a)-6(f), the process of directing the overall arbitrary topology will now be described. It is necessary to introduce a few more colorful definitions to aid in explaining the topology transformation process. First, a "leaf" node is defined as a node with only one connected port. A node recognizes its status as a leaf node as soon as it is initialized after power-up or other bus initialization. A "branch" node is a node which has at least two connected ports. Though all but one of the connected ports a branch node will have received the YAMP
signal and have acknowledged it. Through its remaining port, a branch node has sent the YAMP signal thus establishing that it has a parent node. A node does not wo ~ens~oz Pcrrus93nz~m _19_ achieve branch status until it has established that it has one parent (a node can have only one parent node) and all its other ports are connected to child nodes. Prior to achieving branch status, a node is considered a "cycle"
node because until it is determined to be a branch the possibility exists that the node is part of a cycle which makes establishing direction impossible.
The graph transformation procedure begins at step 60 upon bus initialization (power-up or instigated) at which time the leaf nodes in the arbitrary topology recognize at step 61 and label themselves at step 68 as leaf nodes by determining that they have only one connected port at decision box 66. In the graph depicted in Pi.gnre 3(a), nodes 33, 35, 36 and 37 are leaf nodes which, once initialized, at step 69 each transmits the YAMP signal through its only connected port to its adjacent node. The nodes receiving these signals will then propagate the YAMC
signals back to the leaf nodes at step 70, thus establishing a direction for the given link between respective parent-child pairs when the YAMCA communication is completed. At step 71 each leaf node labels its one connected port as a parent port and each receiving port on the parent node is labeled a child port.

The nodes on the graph which are not initially leaf nodes are initially considered "cycle nodes" for the reason described above and proceed according to the Cycle Node Procedure 63. Any cycle node which has labeled all but one of its connected ports as child ports then propagates the YA1~ signal from its remaining unlabeled port at step 85.
When that direction is established for the link, the cycle node then becomes labeled a branch node. Thus, after leaf node 37 establishes that node 34 is its parent, node 39 has only one unlabeled port shaving labeled the link connection to node 37 as being through a child port) so node 39 broadcasts the YAI9p signal to node 31, resulting in node 34 becoming a branch node. Likewise, once node 31 has identified that nodes 33 and 39 are its children, node 31 broadcasts the YAI~ signal to node 30. When one node has received through all of its ports the YAI~ signal at decision box 75, that node becomes the root node. In Figure 3(a) after node 30 has received the YA1~ signals from nodes 31 and 32, its label changes from being a cycle node to being the root node. In the graph of Figure 3(a), it is not necessarily the case that node 30 Would become the root. If some of the links in the tree provided long propagation delays, node 30 might have received a YAI~
signal on one port and then transmitted a YAMP signal through its other port. Any of the nodes may become the WO !4/15301 PCTNS93I1Z311 root, even a leaf, the root property taking precedence.
Figure 3 (e) shows the resulting directed graph in response to the communicated signals shown in Figure 3(a) ~ with each node labeled and the directions indicated by dark arrows.
In certain circumstances a root contention situation may arise. This may happen. for example in the case where the arbitrary topology has a symmetrical arrangement to a.t such as that shown in Figure d. In the arbitrary graph illustrated in Figure 4, nodes 160 and 161 have each established that it is a parent to the two leaf nodes to which it is coupled. Then, each has propagated the YANG
signal to the other at nearly the same time. The root contention situation is recognized by both nodes involved at decision box 86. Eaeh node is receiving a signal which designates it as a parent while it has sent the same signal out through the same port. Each of the contending nodes responds to the other with the YAMC signal at step 91 which allows each to determine the "decision time period" which is equal to twice the propagation time between the nodes.

WO X4/15301 PCTNS93I1?311 The root contention situation is resolved by utilizing a random decision mechanism incorporated on each ' arbitration state machine logic unit 11 of each node. For every "decision time period" that elapses, each node will randomly decide at step 92 (with a 50% probability) whether to again transmit the YAMP signal to the other. Almost certainly within a finite number of the cycles, one node will decide to designate the other its parent without that one reciprocating. The one that is designated the parent becomes the root at step 95. Alternatively, predetermined selection criteria values may be assigned to nodes, the larger or smaller determining which dominates in a contention event. The dynamic determination of the "decision time period", while it offers optimum performance is not essential in implementing the present invention. As an alternative an apriory defined "decision time,period"
may be used as long as it is greater than the worst case link propagation that can be encountered in any bus using this algorithm. The same method used to resolve root contentions will also be used to resolve other contention events to be described further herein.

WO 94115301 PCTlUS9311?311 As described above, the result of the graph . transformation process is the assignment of the root attribute to one and only one node in the graph. The root node will have the ultimate decision in the bus arbitration scheme to be described and therefore can access the bus with maximum priority without the use of special priority time gaps. It is often desirable to be able to assign the root property to a predetermined node either when it is manufactured or dynamioally~(during run time) to optimize a given system. A given bus may include a node which requires isochronous data transfer. Isochronous data is data that must be transmitted at a given time to be of any value. For example, music from a compact disk needs to be transferred and output in the order in which it is to be heard and with no significant delays, unlike data files which may be transferred piecemeal and not necessarily in order.
Nodes can be classified into three categories with respect to root designations. These designations may be applied during manufacturing by hard-wiring the designation into the device, programming the arbitration state machine logic or by higher level software making the decision then WO 94/1902 PCTlUS9311?311 initiating a reboot while preserving that decision. The three designations that a node may be assigned with respect to being designated a root are: nodes that do not want to be root, nodes that may (should) be root and nodes that shall be root. These designations are tested for at steps 81 and 83. A node designated in the first category will begin the graph transformation procedure as soon as it is directed to do so. This will usually be immediately following the completion of the bus initialization procedure. A node from the~second category will delay the beginning of the graph transformation procedure for a predetermined amount of time after it is directed to begin the procedure at step 84. Hy this delay, the node increases its chance of becoming the root. (The YA1~
signals are more likely to propagate to it due to the delay.) Despite the added delay, it is still possible that a "may be root" node will not wind up being designated the root. This will depend on the given topology and message propagation delays. The amount of delay can be defined during design to be greater than a reasonable worst case propagation delay through a fairly complex graph.
A node from the third category of root designation possibilities may only recognize the fact that it must be the root after the graph has already been transformed and _ all nodes have identified themselves. The arbitration state machine logic may make this determination or software running on the host system. When this occurs, the node that has to be root agrees with all other nodes on the bus that it is going to be the one and only root and restarts the graph transformation process by signaling a preemptive bus initialization signal which is described further herein. The node then waits at step 82 to become the root and does not participate in the graph transformation until it has received. the YAI~ signal on all of its ports, thus forcing it to be designated the root.
Once the root has been determined, the graph can be said to be directed. There is a defined relationship existing between all adjacent nodes on the graph.
The procedures described above for directing a graph will only work for an acyclic graph. If there are cycles in the arbitrary topology, they must be broken by the procedure beginning at step 80. The existence of a cycle is detected at step 79 when, after a predetermined time-out period has elapsed, a node is still labeled a cycle node rather than a leaf, branch or root. The "cycle detect"

WO 94115302 PCTlUS9311T311 timing starts immediately after the end of the bus initialization function. The time-out period need be no longer than the worst case duration of the graph transformation process (adding in delay time for a "may be root" node and a possible root contention event).
The "cycle detect" time-out event does not have to occur synchronous for all nodes of a graph as all message exchanges are asynchronous events. As such, it is possible for a node which has not yet reached its "cycle detect"
time-out event to receive a message indicating that cycle resolution is ongoing. Such a node will terminate its cycle detect time-out interval and begin the appropriate cycle resolution process.
The method of cycle resolution in accordance with the present invention requires the user of the assembled collection of nodes to intervene. When a node encounters the "cycle detect" time out the system user may be notified at step 100 of 8igura 6(a) through an output device that a cycle exists and which nodes are then involved. The user will then be instructed to disconnect links to eliminate whatever cycles are present. The user will then return control to the graph transformation procedure.

WO 94115302 PCT/US93/1?311 Once each of the loops is broken, and no cycles remain, the procedure for transforming the graph as described in the earlier sections may proceed until the entire graph is both acyclic and directed.
Once a directed acyclic graph has been established from the original arbitrary topology, it is then possible to assign unique physical addresses to each node on the graph. This process begins with all leaf nodes requesting the bus by transmitting through their single connected ports the Bus Request (BR) signal. The parent node receiving the signal will wait until it has received the BR
signal from all of its child ports and then will propagate the BR signal to its parent. The BR signals will propagate through the graph until the root has received the HR signal from all of its children. Once the root has received a bus request through all of its child ports, it will make a decision for granting the bus through one port and propagating a Bus Denial (BD) signal through its remaining child ports. The method for selecting which bus request to grant may be an apriory decision such as. that described above where, for example, ports are selected from left to WO !4!15302 PC'TJUS93l17311 right or based on port numbering, etc. The Bus Grant (BG) signal will be transmitted from the root to its requesting child. If that requesting child is itself a parent node Which has propagated the bus request from one of its .
children, it will send the bus denial signal through all but one of its child ports in the same predetermined fashion as described above. Eventually one leaf node will receive the bus grant signal to which it will reply with a Bus Grant Acknowledged (BGA) signal which will be propagated back to the root node. The propagation of the BD and BGA signals serve to~orient the communication links which may be necessary for the case of half duplex communications channels. All of the denied nodes will then wait for activity by the node which finally receives the HG
signal.
The node which is finally granted access to the bus will transmit an address assignment packet. The node will transmit this packet on the bus and it will be received by all other nodes, each of which will count the number of address packets they receive. The transmitted address packet may have any arbitrary information. A node's unique physical address will be based an the number of address packets a node has counted before it transmits an address packet. Thus, no two nodes will acquire the same physical WO 94115302 PCTlU593II13I1 address despite not having address information assigned in advance. The actual composition of the address packet is arbitrary and may be any bit stream efficiently utilizable by the system. After transmitting the physical address assignment packet, a node will transmit a ~Child ID
Completed" signal (CIC) signal. The parent node receiving this on its child port will then transmit the "Child Identification Completed Acknowledgment~ tCICA) signal and label the port as an identified child part. In response to the next BR signal propagation, the parent of the node which has just identified itself will then select its next child to transmit the physical address packet. Once all the child nodes of a parent node have identified themselves, the parent node will request the bus and, when granted the bus, will propagate its physical address assignment packet. This procedure will continue following the predetermined selection criteria until all nodes determine a unique physical address assignment by counting.
!'igur~ 5 illustrates the graph of Figure 3 (e) in which a left-to-right predefined selection criteria is implemented.
The nodes are uniquely assigned addresses where node 33 receives the first and as described, the root node 30 receives the eighth and last address.

When this procedure is completed, each node in the graph will have a unique physical address, which need not have been determined in advance and which may be utilized for system management or other purposes.
The process of node self identification essentially follows the same routine as the physical address assignment procedure described above. ,As each node transmits its physical address assignment packet, that packet may include further information such as identification of the physical device comprising the identification of the local host related to the node, how much power it requires, and, for example, whether it supports a "soft power-on" attribute, etc. In fact, the node self-identification information may serve as the physical address assignment packet because the practice of sending any information at all provides the basis for counting to yield unique physical addresses.
With respect to the node self-identification packet, the particular information concerning the node need only be "listened" to by those nodes affected by the nature of the announcing node. This procedure, as with the above, WO 94!15302 PCTNS93111311 proceeds until all nodes have transmitted their node self identification information.
The method of topology mapping follows along the same lines as physical address assignment and node self-identification. This procedure thus has each node, when it is going through the address assignment or node self-identification process, further transmit information concerning all of its ports such as the number of child ports it has and whether or not it has any disabled ports.
With respect to disabled ports, it may be desirable to implement a communication protocol between ports that are disabling so that they can identify from whom they are disabled. Thus, when a port identifies a disabled port it will give an identifier indicating its own ID as well as the port ID from which it has become disabled.
By assembling all the topology information about all the ports received during the topology mapping procedure, the bus server, host or any software level application may logically reconstruct the resolved bus topology. This is useful for many purposes including implementing redundancy where if a link unexpectedly goes down, previously disabled wo mssoz pcrms93mi links may serve to prevent the loss of communication channels to any nodes.
Once the topology mapping, node self identification or physical address assignment routines have completed, the bus can be considered up and running. One arbitration scheme implemented in accordance with the present invention is that of fair bus access., When a node desires access to the bus, it sends through its parent port (unless it is the root) a bus request (BR) signal. The parent, upon receiving the BR signal from one child sends a bus denied signal (BD) through all its other child ports. The parent then propagates the BR signal upward through its parent until the signal reaches the root. The root issues a bus grant signal (BG) responsive to the first BR signal it receives and sends the BD signal through all of its other child ports which propagate downward thereby orienting the links. The HG signal propagates downward through the graph until it reaches the requesting node which then sends Bus Acknowledge (BA) signal followed by the packet of information that the node needed to send on the bus. When the packet is completed, all nodes return or enter into an idle state.
In the case where the root receives nearly simultaneous requests for the bus, the predetermined selection criteria for the root node will be used for granting to one of the nodes bus access. This may be the same predetermined priority selecting criteria as described above.
A further aspect of fair bus access arbitration is that a parent node has priority over its children. Thus, when a parent node wants the bus, it sends the BD signal through all of its child ports, then propagates the HR
signal up toward the root. One potential problem with this mechanism is that if the parent has a large quantity of information to transmit on the bus a child node may have trouble getting adequate bus access. There is therefore introduced a gap system which is widely used and well-known in the art. After a node has utilized the bus, the node must wait for one gap period before it can again request the bus. This gives equal chance of being granted the bus to every node on the bus independent of its topological placement on the bus. In order to guarantee a fair arbitration protocol the length of the gap has to be greater than the worst case signal propagation delay WO 94Il5302 PCTIUS93/1Z311 _34-through the bus. The gap value can be predetermined and hard-wired into the node logic but such an approach will result in all but the most extreme case in a sub optimal utilization of the bus. The topology mapping capability together with the measurement of the propagation delay between adjacent nodes performed during the graph transformation phase enables the calculation of an optimal fair gap that will maximize the bus performance for any specific implementation.
In the bus arbitration scheme implemented in accordance with the above fair bus access arbitration, it may be desirable that the root always have bus priority.
When this is implemented, the root node may grant the bus to itself at any time. This is done by first sending the HD signal down through all of the nodes in the graph.
Priority bus access for the root is very useful for the case where the root node is required to perform isochronous data transfer.

WO 94/15302 PCTlUS93l12311 As an alternative to the fair and priority bus access arbitrations schemes described above, the present invention may be utilized in implementing a token gassing bus arbitration scheme. Metaphorically speaking, token passing bus access refers to the notion that a node may communicate on a bus when it is in possession of a token that is passed between nodes. The token is passed from node to node in a cyclic fashion so that each node receives the bus in a predetermined point in the cycle. Token passing is implemented in the present invention in following the same manner as the physical address assignment routine described above. The predetermined selection mechanisms implemented are used to select the order in which the token will be passed from node to node. This order resembles the order as shown in Bigure 5 which dictates the order of unique address assignment. Each node, when it is assigned the token will propagate its information packet on the bus while the remaining nodes listen. The node will then pass the token to the next logical node based on the predetermined sequencing method as described above.

WO 94/15302 PCTlUS93I1131I

An important feature that may be implemented in accordance with the present invention is the notion of preemptive bus initialization. The state machine logic incorporated on each node is capable of triggering a bus initialization (BI) signal to be propagated from the node through all of its ports upon certain conditions. When a node has determined it is necessary to signal a bus initialization condition, it will propagate the BI signal out through all of its ports for a length of time sufficient to guarantee that all adjacent nodes have received it and then released. A node will then go into the initiating procedures which then lead to the graph transformation process in the above described procedures.
There are a number of situations which may make it necessary or desirable to trigger a preemptive bus initialization. First, this may be a node response to an unforeseen error. Additionally, at the host level, it may be determined that a different node should acquire the root attribute, for example, an isochronous data transfer node.
This assignment will be preserved throughout the bus initialization routine thereby causing the desired node to wait during the transform procedure until it receives the WO 94!15302 PCT/US93/I2311 root designation. Another condition leading to a preemptive bus initialization may be the breakage of a link, in which case it may be necessary to calculate a new acyclic directed graph for the attached nodes. Finally, an important situation in which a preemptive bus initialization should occur is when a device is added to the network, referred to as "hot addition" of pezipherals.
The port to which a new device is connected will detect the presence of a new node and trigger a bus initialization which will be transparent to the user of the system but which allows the addition and subtraction of peripherals, for example, without having to shut down and repower. A
new acyclic directed graph is calculated which includes the presence of the added node. It is possible that upon removing certain nodes, it will not be necessary to trigger a bus initialization, for example, when a leaf node is removed, there is no harm to the network. However, if a branch node is disengaged from an operating bus, it is likely to be necessary to reconfigure the graph.
Although the present invention has been described in terms of preferred embodiments, it will be appreciated that various modifications and alterations might be made by those skilled in the art without departing from the spirit and scope of the invention. The invention should, therefore, be measured in terms of the claims which follow.

Claims (102)

1. A computer system comprising a plurality of components, said plurality of components each having at least one communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, to arbitrate access to the bus the computer system further comprising:
means for transmitting a " Bus Request " (BR) signal from a requesting node to a parent node, said requesting node having a packet of information to propagate on said bus;
means for, each node that receives the BR signal, forwarding the BR signal to a parent node;
means for the root node, upon receiving the BR signal from one adjacent node, responding to said adjacent node with a " Bus Grant " (BG) signal;

means for, each node that receives the BG signal from a parent node, propagating the BG signal to a child node which previously forwarded the BR signal, except the requesting node; and means for the requesting node, upon receiving the BG
signal, propagating said packet of information on the bus, wherein after the requesting node has propagated said packet of information, the requesting node waits for a gap period before again requesting access to said bus, said gap period being greater than a worst case signal propagation delay through the bus.
2. The computer system of claim 1, further comprising:
means for, before transmitting the BR signal, transmitting a first " Bus Denied " (BD) signal from said requesting node to any child nodes said requesting node has.
3. The computer system of claim 2, further comprising:
means for propagating a BD signal from each node that forwards the BR signal to a parent node to all child nodes that were not the source of the BR signal.
4. The computer system of claim 3, further comprising:
means for said root node, after responding to the adjacent node with a BG signal, propagating a second BD
signal to all other adjacent nodes.
5. The computer system of claim 4, further comprising:
means for, all nodes receiving the second BD signal, propagating said second BD signal to all adjacent child nodes.
6. The computer system of claim 5, further comprising:
means for said requesting node, before propagating said packet of information, transmitting a "Bus Acknowledge" (BA) signal to acknowledge receipt of the BG
signal.
7. The computer system of claim 6, further comprising:
means for, each node that receives the BA signal, forwarding the BA signal to a parent node.
8. The computer system of claim 1, further comprising:
means for the root node, upon determining that the root node requires access to the bus, propagating a BD
signal to all adjacent nodes and granting access to the bus to the root node.
9. The computer system of claim 7, further comprising:
means for the root node, upon determining that the root node requires access to the bus, propagating a BD
signal to all adjacent nodes and granting access to the bus to the root node.
10. The computer system of claim 1, wherein the root node solves conflicting simultaneous requests for the bus by granting the bus based on a predetermined adjacent node selection criterion.
11. A computer system comprising a plurality of components, said plurality of components each having at least one communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, to arbitrate access to the bus the computer system further comprising:
means for transmitting a "Bus Denied" (BD) signal from a requesting node to all adjacent child nodes, said requesting node having a packet of information to propagate on said bus;
means for transmitting a "Bus Request" (BR) signal from the requesting node to a parent node;
means for, each node that receives the BR signal, forwarding the BR signal to a parent node and propagating a BD signal to all child nodes that were not the source of the BR signal;
means for the root node, upon receiving the BR signal from one adjacent node, responding to said adjacent node with a "Bus Grant" (BG) signal, said root node propagating a BD signal to all other adjacent nodes;
means for, each node that receives the BG signal from a parent node, propagating the BG signal to a child node which had previously forwarded the BR signal, except the requesting node;

means for the requesting node, upon receiving the BG
signal, acknowledging receipt of said BG signal and propagating said packet of information; and means for the root node, upon determining that the root node requires access to the bus, propagating a BD
signal to all adjacent nodes and granting access to the bus to the root node.
12. The computer system of claim 11, wherein the root node solves conflicting simultaneous requests for the bus by granting the bus based on a predetermined adjacent node selection criterion.
13. A computer system comprising a plurality of components, said plurality of components each having at least one communications node wherein said communications nodes of said plurality of components are interconnected by communications links, said communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, said directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a metaphorical token passed from node to node in a cycle through the directed acyclic graph for token passing bus access arbitration, the node having the token being the node with bus access, the computer system further comprising:
means far passing the token through the directed acyclic graph in an order determined by a predetermined selection criterion each node has established for selecting adjacent nodes.
14. In a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a requesting node to access the bus, the requesting node comprising:
means for generating a first "Bus Request" (BR) signal when the requesting node has information to propagate onto the bus;
means for forwarding the first BR signal from the requesting node to an adjacent parent node;

means for propagating information onto the bus upon receiving a "Bus Grant" (BG) signal; and means for waiting, after the propagating, for a gap period before generating a second BR signal, the gap period being greater than a worst case signal propagation delay through the bus;
wherein the first BR signal is forwarded by any receiving node to a respective adjacent parent node;
wherein the BG signal is generated at a root node upon receiving the first BR signal forwarded from one adjacent node of the root node; and wherein the BG signal is forwarded by any node having the BG signal to an adjacent child node which previously forwarded the first BR signal.
15. The requesting node of claim 14, further comprising:
means for transmitting a "Bus Denied" (BD) signal from the requesting node to any child nodes the requesting node has when the requesting node requests access to the bus to propagate information.
16. The requesting node of claim 15, wherein any receiving node of the first BR signal propagates a BD
signal to all adjacent child nodes which did not forward the BR signal.
17. The requesting node of claim 16, wherein any receiving node of a BD signal propagates the corresponding BD signal to all adjacent child nodes.
18. The requesting node of claim 14, further comprising:

means for transmitting a "Bus Acknowledge" (BA) signal before the propagating.
19. The requesting node of claim 18, wherein the BA
signal is transmitted to the adjacent parent node of the requesting node; and the BA signal is forwarded by any receiving node to a respective adjacent parent node.
20. The requesting node of claim 14, wherein a node solves conflicting simultaneous BR signals from adjacent child nodes by selecting a BR signal from the conflicting BR signals based on a predetermined adjacent node selection criterion.
21. In a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, a first node connected to at least one adjacent node on the bus, the first node being capable of having at least one child node, the first node comprising:
when the first node has at least one adjacent child node:
means for receiving a first "Bus Request" (BR) signal from a second node, the second node being one of the at least one adjacent child node of the first node;
when the first node has a parent node:
means for forwarding the first BR signal to the parent node of the first node after receiving the first BR
signal;
means for forwarding a first "Bus Grant" (BG) signal for the first BR signal from the parent node of the first node to the second node;
means for transmitting a second BR signal to the parent node of the first node when the first node requires access to the bus to propagate information; and means for receiving a second BG signal for the second BR signal from the parent node of the first node;
when the first node has no parent node:
means for transmitting a third BG signal for the first BR signal to the second node; and means for granting the first node access to the bus when the first node requires access to the bus to propagate information.
22. The first node of claim 21, further comprising:
when the first node has at least one adjacent child node:
means for transmitting a first "Bus Denied" (BD) signal to all of the at least one adjacent child node when the first node requires access to the bus to propagate information; and means for transmitting a second BD signal to all of the at least one adjacent child node except the second node in response to receiving the first BR signal;
when the first node has a parent node:
means for forwarding a third BD signal from the parent node of the first node to all of the at least one adjacent child node except the second node.
23. The first node of claim 22, further comprising:
means for acknowledging receiving the second BG
signal when the first node has a parent node.
24. The first node of claim 22, further comprising:
means for receiving a "Bus Acknowledge" (BA) signal from the second node.
25. The first node of claim 24, further comprising:
means for forwarding the BA signal to the parent node of the first node.
26. The first node of claim 21, wherein the first node solves conflicting simultaneous BR signals from the at least one adjacent child node by selecting a BR signal from the conflicting BR signals based on a predetermined adjacent node selection criterion.
27. The first node of claim 26, wherein the first node solves conflicting requests for accessing the bus from any adjacent nodes bases on a predetermined selection criterion.
28. The first node of claim 21, further comprises:
means for waiting for a gap period before again requesting access to the bus after successfully obtaining access to the bus, the gap period being greater than a worst case signal propagation delay through the bus.
29. The first node of claim 21, wherein the first node is a root node.
30. A first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the first node comprising:
means for passing a token from the first node to one of the plurality of adjacent nodes according to a predetermined selection criterion for selecting a node from the plurality of adjacent nodes.
31. A first node as in claim 30, further comprising:
means for receiving, at the first node, the token from one of the plurality of adjacent nodes; and means for transmitting data from the first node when the first node is in possession of the token for data transmission.
32. A first node as in claim 31, wherein the plurality of adjacent nodes comprises child nodes of the first node;
and, the token is passed from the first node to the child nodes in an order according to the predetermined selection criterion.
33. A first node as in claim 32, wherein the first node is in possession of the token for data transmission after the first node passes the token to each of the child nodes once.
34. A first node as in claim 33, wherein the plurality of adjacent nodes comprises a parent node of the first node;
the token is received at the first node from the parent node before the token is passed to the child nodes; and, the token is passed from the first node to the parent node after the first node is in possession of the token.
35. A first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent node respectively, the first node comprising:
means for counting, since a starting point of a node identification process, a number of announcements received by the first node;
means for passing a token from the first node to one of the at least one adjacent node according to a predetermined selection criterion for selecting a node from the at least one adjacent node;
means for broadcasting an announcement from the first node when the first node is in possession of the token for data transmission; and means for setting a unique address for the first node based on the number of announcements received by the first node since the starting point to when the first node is in possession of the token for data transmission.
36. A first node as in claim 35, wherein the token is a "Bus Grant" (BG) signal.
37. A first node as in claim 36, wherein the at least one adjacent node comprises child nodes of the first node;
and, the token is passed from the first node to the child nodes in an order according to the predetermined selection criterion.
38. A first node as in claim 37, wherein the first node is in possession of the token for data transmission after the first node passes the token to each of the child nodes once.
39. A first node as in claim 38, wherein the at least one adjacent node comprises a parent node of the first node;
the token is received at the first node from the parent node before the token is passed to the child nodes; and, the token is passed from the first node to the parent node after the first node is in possession of the token.
40. A first node as in claim 35, wherein the announcement comprises topology information concerning the first node.
41. A first node as in claim 40, wherein the topology information includes information about at least one adjacent node and link status.
42. A computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising a bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relations ships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, the computer system further comprising:
means for propagating a "Bus Initialization" (BI) signal from any node determining that bus initialization is necessary;
means for sustaining the BI signal for a predetermined period of time; and means for propagating that signal throughout the directed acyclic graph to all nodes in the directed acyclic graph.
43. A first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising:
means for determining a first determination that a parent-child relationship between the first node and one of the at least one adjacent node is to be changed;
means for sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the first determination; and means for communicating with the at least one adjacent node to perform bus initialization.
44. A first node as in claim 43, wherein said means for communicating comprises:
means for delaying for a period before propagating a "You Are My Parent" (YAMP) signal from the first node to any of the at least one adjacent node to increase a chance of the first node to become a parent of the at least one adjacent node.
45. A first node as in claim 44, wherein the period is sufficient long such that the first node receives a "You Are My Parent" (YAMP) signal from each of the at least one adjacent node to become a parent of the at least one adjacent node.
46. A first node as in claim 43, wherein said means for communicating comprises:
means for determining an unique address of the first node for communication with the at least one adjacent node.
47. A first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising:
means for determining a change in status of a second node in communication with the first node through a point-to-point link;

means for sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the change; and means for performing bus initialization in communication with the at least one adjacent node.
48. A first node as in claim 47, wherein the change in status comprises one of:
a) addition of the second node in communication with the first node; and b) removal of the second node in communication with the first node.
49. A first node as in claim 47, wherein said means for performing bus initialization comprises:
means for determining a parent-child relationship between the first node and each of the at least one adjacent node.
50. A first node as in claim 49, wherein said means for performing bus initialization comprises:
means for determining an unique address of the first node for communication with the at least one adjacent node.
51. A first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the first node comprising:
means for determining an error condition in communication through the at least one links;

means for sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the error condition; and means for performing bus initialization in communication with the at least one adjacent node.
52. A first node as in claim 51, wherein said means for performing bus initialization comprises:
means for determining a parent-child relationship between the first node and each of the at least one adjacent node.
53. A first node as in claim 52, wherein said means for performing bus initialization comprises:
means for determining an unique address of the first node for communication with the at least one adjacent node.
54. A first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the first node comprising:
means for receiving a "Bus Initialization" (BI) signal from a second node of the plurality of adjacent nodes;
means for sustaining the BI signal for a period of time to propagate the BI signal from the first node to the plurality of adjacent nodes except the second node in response to receiving the BI signal; and means for performing bus initialization in communication with the plurality of adjacent nodes.
55. A first node as in claim 54, wherein said means for performing bus initialization comprises:
means for determining a parent-child relationship between the first node and each of the plurality of adjacent nodes.
56. A first node as in claim 54, wherein said means for performing bus initialization comprises:
means for determining an unique address of the first node for communication with the plurality of adjacent nodes.
57. A first node as in claim 54, further comprising:
means for determining a first determination that bus initialization is necessary; and means for sustaining a BI signal for a period of time to propagate the BI signal to the plurality of adjacent nodes in response to the first determination.
58. A first node as in claim 57, wherein the first determination is in response to one of:
a) a determination that a parent-child relationship between the first node and one of the plurality of adjacent nodes is to be changed;
b) a determination that an adjacent node becomes engaged to the first node for communication;
c) a determination that an adjacent node becomes disengaged from the first node for communication;
and d) a determination of an error condition in communication through the plurality of links.
59. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method on a requesting node to access a bus of a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising the bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, the method comprising:
generating a first "Bus Request" (BR) signal when the requesting node has information to propagate onto the bus;
forwarding the first BR signal from the requesting node to an adjacent parent node;
propagating information onto the bus upon receiving a "Bus Grant" (BG) signal; and waiting, after the propagating, for a gap period before generating a second BR signal, the gap period being greater than a worst case signal propagation delay through the bus;
wherein the first BR signal is forwarded by any receiving node to a respective adjacent parent node;
wherein the BG signal is generated at a root node upon receiving the first BR signal forwarded from one adjacent node of the root node; and wherein the BG signal is forwarded by any node having the BG signal to an adjacent child node which previously forwarded the first BR signal.
60. The medium of claim 59, wherein the method further comprises:
transmitting a "Bus Denied" (BD) signal from the requesting node to any child nodes the requesting node has when the requesting node requests access to the bus to propagate information.
61. The medium of claim 60, wherein any receiving node of the first BR signal propagates a BD signal to all adjacent child nodes which did not forward the BR signal.
62. The medium of claim 61, wherein any receiving node of a BD signal propagates the corresponding BD signal to all adjacent child nodes.
63. The medium of claim 59, wherein the method further comprises:
transmitting a "Bus Acknowledge" (BA) signal before the propagating.
64. The medium of claim 63, wherein the BA signal is transmitted to the adjacent parent node of the requesting node; and the BA signal is forwarded by any receiving node to a respective adjacent parent node.
65. The medium of claim 59, wherein a node solves conflicting simultaneous BR signals from adjacent child nodes by selecting a BR signal from the conflicting BR
signals based on a predetermined adjacent node selection criterion.
66. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method on a first node to access a bus of a computer system comprising a plurality of components, the plurality of components each having at least one communications node wherein the communications nodes of the plurality of components are interconnected by communications links, the communications nodes and communications links comprising the bus of a directed acyclic graph wherein one node is designated a root node, all nodes coupled to only one adjacent node being designated leaf nodes, all other nodes in the directed acyclic graph being designated branch nodes, the directed acyclic graph having established hierarchical parent-child relationships between all adjacent nodes proceeding from the root node down to any leaf nodes wherein a leaf node has only one parent node and all nodes adjacent to the root node are child nodes with respect to the root node but parent nodes with respect to other adjacent nodes, the root node being defined as having no parent node, the first node connected to at least one adjacent node on the bus, the first node being capable of having at least one child node, the method comprising:
when the first node has at least one adjacent child node:
receiving a first "Bus Request" (BR) signal from a second node, the second node being one of the at least one adjacent child node of the first node;
when the first node has a parent node:
forwarding the first BR signal to the parent node of the first node after receiving the first BR signal;
forwarding a first "Bus Grant" (BG) signal for the first BR signal from the parent node of the first node to the second node;
transmitting a second BR signal to the parent node of the first node when the first node requires access to the bus to propagate information and receiving a second BG signal for the second BR signal from the parent node of the first node;
when the first node has no parent node:
transmitting a third BG signal for the first BR
signal to the second node; and granting the first node access to the bus when the first node requires access to the bus to propagate information.
67. The medium of claim 66, wherein the method further comprises:
when the first node has at least one adjacent child node:
transmitting a first "Bus Denied" (BD) signal to all of the at least one adjacent child node when the first node requires access to the bus to propagate information;
and transmitting a second BD signal to all of the at least one adjacent child node except the second node in response to receiving the first BR signal;
when the first node has a parent node:
forwarding a third BD signal from the parent node of the first node to all of the at least one adjacent child node except the second node.
68. The medium of claim 67, wherein the method further comprises:
acknowledging receiving the second BG signal when the first node has a parent node.
69. The medium of claim 67, wherein the method further comprises:
receiving a "Bus Acknowledge" (BA) signal from the second node.
70. The medium of claim 69, wherein the method further comprises:
forwarding the BA signal to the parent node of the first node.
71. The medium of claim 66, wherein the first node solves conflicting simultaneous BR signals from the at least one adjacent child node by selecting a BR signal from the conflicting BR signals based on a predetermined adjacent node selection criterion.
72. The medium of claim 71, wherein the first node solves conflicting requests for accessing the bus from any adjacent nodes bases on a predetermined selection criterion.
73. The medium of claim 66, further comprises:
waiting for a gap period before again requesting access to the bus after successfully obtaining access to the bus, the gap period being greater than a worst case signal propagation delay through the bus.
74. The medium of claim 66, wherein the first node is a root node.
75. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the method comprising:
passing a token from the first node to one of the plurality of adjacent nodes according to a predetermined selection criterion for selecting a node from the plurality of adjacent nodes.
76. A medium as in claim 75, wherein the method further comprises:
receiving, at the first node, the token from one of the plurality of adjacent nodes; and transmitting data from the first node when the first node is in possession of the token for data transmission.
77. A medium as in claim 76, wherein the plurality of adjacent nodes comprises child nodes of the first node;
and, the token is passed from the first node to the child nodes in an order according to the predetermined selection criterion.
78. A medium as in claim 77, wherein the first node is in possession of the token for data transmission after the first node passes the token to each of the child nodes once.
79. A medium as in claim 78, wherein the plurality of adjacent nodes comprises a parent node of the first node;
the token is received at the first node from the parent node before the token is passed to the child nodes; and, the token is passed from the first node to the parent node after the first node is in possession of the token.
80. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent node respectively, the method comprising:
counting, since a starting point of a node identification process, a number of announcements received by the first node;
passing a token from the first node to one of the at least one adjacent node according to a predetermined selection criterion for selecting a node from the at least one adjacent node;

broadcasting an announcement from the first node when the first node is in possession of the token for data transmission; and setting a unique address for the first node based on the number of announcements received by the first node since the starting point to when the first node is in possession of the token for data transmission.
81. A medium as in claim 80, wherein the token is a "Bus Grant" (BG) signal.
82. A medium as in claim 81, wherein the at least one adjacent node comprises child nodes of the first node;
and, the token is passed from the first node to the child nodes in an order according to the predetermined selection criterion.
83. A medium as in claim 82, wherein the first node is in possession of the token for data transmission after the first node passes the token to each of the child nodes once.
84. A medium as in claim 83, wherein the at least one adjacent node comprises a parent node of the first node;
the token is received at the first node from the parent node before the token is passed to the child nodes; and, the token is passed from the first node to the parent node after the first node is in possession of the token.
85. A medium as in claim 80, wherein the announcement comprises topology information concerning the first node.
86. A medium as in claim 85, wherein the topology information includes information about at least one adjacent node and link status.
87. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising:
determining a first determination that a parent-child relationship between the first node and one of the at least one adjacent node is to be changed;
sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the first determination; and communicating with the at least one adjacent node to perform bus initialization.
88. A medium as in claim 87, wherein said communicating comprises:
delaying for a period before propagating a "You Are My Parent" (YAMP) signal from the first node to any of the at least one adjacent node to increase a chance of the first node to become a parent of the at least one adjacent node.
89. A medium as in claim 88, wherein the period is sufficient long such that the first node receives a "You Are My Parent" (YAMP) signal from each of the at least one adjacent node to become a parent of the at least one adjacent node.
90. A medium as in claim 87, wherein said communicating comprises:
determining an unique address of the first node for communication with the at least one adjacent node.
91. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising:
determining a change in status of a second node in communication with the first node through a point-to-point link;
sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the change; and performing bus initialization in communication with the at least one adjacent node.
92. A medium as in claim 91, wherein the change in status comprises one of:
a) addition of the second node in communication with the first node; and b) removal of the second node in communication with the first node.
93. A medium as in claim 91, wherein said performing bus initialization comprises:
determining a parent-child relationship between the first node and each of the at least one adjacent node.
94. A medium as in claim 93, wherein said performing bus initialization comprises:
determining an unique address of the first node for communication with the at least one adjacent node.
95. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with at least one adjacent node through at least one point-to-point link connected from the first node to the at least one adjacent nodes respectively, the method comprising:
determining an error condition in communication through the at least one links;
sustaining a "Bus Initialization" (BI) signal for a period of time to propagate the BI signal from the first node to the at least one adjacent node in response to the error condition; and performing bus initialization in communication with the at least one adjacent node.
96. A medium as in claim 95, wherein said performing bus initialization comprises:
determining a parent-child relationship between the first node and each of the at least one adjacent node.
97. A medium as in claim 96, wherein said performing bus initialization comprises:
determining an unique address of the first node for communication with the at least one adjacent node.
98. A machine readable medium containing executable computer program instructions which when executed by a data processing system cause said system to perform a method for a first node to communicate with a plurality of adjacent nodes through a plurality of point-to-point links connected from the first node to the plurality adjacent nodes respectively, the method comprising:
receiving a "Bus Initialization" (BI) signal from a second node of the plurality of adjacent nodes;
sustaining the BI signal for a period of time to propagate the BI signal from the first node to the plurality of adjacent nodes except the second node in response to said receiving the BI signal; and performing bus initialization in communication with the plurality of adjacent nodes.
99. A medium as in claim 98, wherein said performing bus initialization comprises:
determining a parent-child relationship between the first node and each of the plurality of adjacent nodes.
100. A medium as in claim 98, wherein said performing bus initialization comprises:
determining an unique address of the first node for communication with the plurality of adjacent nodes.
101. A medium as in claim 98, wherein the method further comprises:
determining a first determination that bus initialization is necessary; and sustaining a BI signal for a period of time to propagate the BI signal to the plurality of adjacent nodes in response to the first determination.
102. A medium as in claim 101, wherein the first determination is in response to one of:
a) determining that a parent-child relationship between the first node and one of the plurality of adjacent nodes is to be changed;
b) determining a adjacent node becoming engaged to the first node for communication;
c) determining a adjacent node becoming disengaged from the first node for communication; and d) determining an error condition in communication through the plurality of links.
CA2503335A 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph Expired - Lifetime CA2503335C (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CA2698356A CA2698356C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US07/994,983 1992-12-21
US07/994,983 US5630173A (en) 1992-12-21 1992-12-21 Methods and apparatus for bus access arbitration of nodes organized into acyclic directed graph by cyclic token passing and alternatively propagating request to root node and grant signal to the child node
CA002408252A CA2408252C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
CA002408252A Division CA2408252C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CA2698356A Division CA2698356C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Publications (2)

Publication Number Publication Date
CA2503335A1 CA2503335A1 (en) 1994-07-07
CA2503335C true CA2503335C (en) 2010-06-29

Family

ID=25541282

Family Applications (4)

Application Number Title Priority Date Filing Date
CA2503335A Expired - Lifetime CA2503335C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph
CA002151369A Expired - Lifetime CA2151369C (en) 1992-12-21 1993-12-16 Method and apparatus for bus access arbitration of nodes organized into acyclic token passing and alternatively propagating request to root node and grant signal to the child node
CA2698356A Expired - Lifetime CA2698356C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph
CA002408252A Expired - Lifetime CA2408252C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Family Applications After (3)

Application Number Title Priority Date Filing Date
CA002151369A Expired - Lifetime CA2151369C (en) 1992-12-21 1993-12-16 Method and apparatus for bus access arbitration of nodes organized into acyclic token passing and alternatively propagating request to root node and grant signal to the child node
CA2698356A Expired - Lifetime CA2698356C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph
CA002408252A Expired - Lifetime CA2408252C (en) 1992-12-21 1993-12-16 Method and apparatus for pre-emptively arbitrating on an acyclic directed graph

Country Status (9)

Country Link
US (2) US5630173A (en)
EP (4) EP1094394B1 (en)
JP (7) JP3638949B2 (en)
KR (1) KR100290517B1 (en)
AU (1) AU5953994A (en)
CA (4) CA2503335C (en)
DE (4) DE69333798T2 (en)
HK (3) HK1037037A1 (en)
WO (1) WO1994015302A1 (en)

Families Citing this family (116)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7334030B2 (en) * 1994-12-19 2008-02-19 Apple Inc. Method and apparatus for the addition and removal of nodes from a common interconnect
US5875301A (en) * 1994-12-19 1999-02-23 Apple Computer, Inc. Method and apparatus for the addition and removal of nodes from a common interconnect
US5784648A (en) * 1995-12-01 1998-07-21 Apple Computer, Inc. Token style arbitration on a serial bus by passing an unrequested bus grand signal and returning the token by a token refusal signal
US5758105A (en) * 1995-12-04 1998-05-26 International Business Machines Corporation Method and apparatus for bus arbitration between isochronous and non-isochronous devices
US7388092B2 (en) * 1996-05-03 2008-06-17 Applera Corporation Oligonucleotides and analogs labeled with energy transfer dyes
US6131119A (en) * 1997-04-01 2000-10-10 Sony Corporation Automatic configuration system for mapping node addresses within a bus structure to their physical location
JP3222086B2 (en) * 1997-04-07 2001-10-22 矢崎総業株式会社 Tree structure address setting method and system
US6145018A (en) * 1997-11-24 2000-11-07 Intel Corporation Method for hindering some types of nodes from becoming a bus arbitration controller
US6041348A (en) * 1997-12-01 2000-03-21 Lsi Logic Corporation N-port algorithm for disabling a node within a network during reset
US6411628B1 (en) * 1998-02-02 2002-06-25 Intel Corporation Distributed arbitration on a full duplex bus
US6393557B1 (en) 1998-05-08 2002-05-21 International Business Machines Corporation Dynamic method for configuring a computer system
US6434656B1 (en) * 1998-05-08 2002-08-13 International Business Machines Corporation Method for routing I/O data in a multiprocessor system having a non-uniform memory access architecture
JP3277887B2 (en) * 1998-06-19 2002-04-22 日本電気株式会社 Transmission / reception method, transmission / reception circuit and method for controlling transmission / reception circuit
US6122723A (en) * 1998-08-20 2000-09-19 International Business Machines Corporation Switching multi-initiator SCSI devices to a singular target bus
US6438604B1 (en) 1998-10-05 2002-08-20 Canon Kabushiki Kaisha Digital video network interface
US7013354B1 (en) 1998-10-05 2006-03-14 Canon Kabushiki Kaisha Channel protocol for IEEE 1394 data transmission
US6657973B1 (en) * 1998-10-27 2003-12-02 Matsushita Electric Industrial Co., Ltd. Communications node, network system and method of controlling network system
JP3326399B2 (en) 1998-12-17 2002-09-24 松下電器産業株式会社 Communication node, information device having the same, and network system
US6256698B1 (en) 1999-01-11 2001-07-03 Sony Corporation Method of and apparatus for providing self-sustained even arbitration within an IEEE 1394 serial bus network of devices
US7062456B1 (en) 1999-02-09 2006-06-13 The Chase Manhattan Bank System and method for back office processing of banking transactions using electronic files
US6810452B1 (en) 1999-03-19 2004-10-26 Sony Corporation Method and system for quarantine during bus topology configuration
US6374319B1 (en) * 1999-06-22 2002-04-16 Philips Electronics North America Corporation Flag-controlled arbitration of requesting agents
US6628607B1 (en) 1999-07-09 2003-09-30 Apple Computer, Inc. Method and apparatus for loop breaking on a serial bus
US6910090B1 (en) 1999-09-21 2005-06-21 Sony Corporation Maintaining communications in a bus bridge interconnect
EP1090856A1 (en) * 1999-10-04 2001-04-11 LAB Industrie Misch- und Wiegetechnik GmbH System and method for unloading of bulk material from a container, especially from a box-shaped transport container
US6691096B1 (en) 1999-10-28 2004-02-10 Apple Computer, Inc. General purpose data container method and apparatus for implementing AV/C descriptors
US6671768B1 (en) 1999-11-01 2003-12-30 Apple Computer, Inc. System and method for providing dynamic configuration ROM using double image buffers for use with serial bus devices
US6959343B1 (en) 1999-11-01 2005-10-25 Apple Computer, Inc. Method and apparatus for dynamic link driver configuration
US8762446B1 (en) 1999-11-02 2014-06-24 Apple Inc. Bridged distributed device control over multiple transports method and apparatus
US6631426B1 (en) 1999-11-02 2003-10-07 Apple Computer, Inc. Automatic ID allocation for AV/C entities
US6813663B1 (en) 1999-11-02 2004-11-02 Apple Computer, Inc. Method and apparatus for supporting and presenting multiple serial bus nodes using distinct configuration ROM images
US6618750B1 (en) 1999-11-02 2003-09-09 Apple Computer, Inc. Method and apparatus for determining communication paths
US8185549B1 (en) * 1999-11-03 2012-05-22 A9.Com, Inc. Method and system for navigating within a body of data using one of a number of alternative browse graphs
US6636914B1 (en) * 1999-11-05 2003-10-21 Apple Computer, Inc. Method and apparatus for arbitration and fairness on a full-duplex bus using dual phases
US6587904B1 (en) 1999-11-05 2003-07-01 Apple Computer, Inc. Method and apparatus for preventing loops in a full-duplex bus
TW448365B (en) * 1999-11-15 2001-08-01 Via Tech Inc Bus arbitration method providing preemption function between control chip sets
US6457086B1 (en) * 1999-11-16 2002-09-24 Apple Computers, Inc. Method and apparatus for accelerating detection of serial bus device speed signals
US6728821B1 (en) 1999-11-29 2004-04-27 Sony Corporation Method and system for adjusting isochronous bandwidths on a bus
US6751697B1 (en) * 1999-11-29 2004-06-15 Sony Corporation Method and system for a multi-phase net refresh on a bus bridge interconnect
US6639918B1 (en) 2000-01-18 2003-10-28 Apple Computer, Inc. Method and apparatus for border node behavior on a full-duplex bus
US7266617B1 (en) 2000-01-18 2007-09-04 Apple Inc. Method and apparatus for border node behavior on a full-duplex bus
US7421507B2 (en) * 2000-02-16 2008-09-02 Apple Inc. Transmission of AV/C transactions over multiple transports method and apparatus
US7050453B1 (en) * 2000-02-17 2006-05-23 Apple Computer, Inc. Method and apparatus for ensuring compatibility on a high performance serial bus
US6831928B1 (en) 2000-02-17 2004-12-14 Apple Computer, Inc. Method and apparatus for ensuring compatibility on a high performance serial bus
US6484171B1 (en) 2000-03-31 2002-11-19 International Business Machines Corporation System method and computer program for prioritizing filter rules
US6718497B1 (en) 2000-04-21 2004-04-06 Apple Computer, Inc. Method and apparatus for generating jitter test patterns on a high performance serial bus
US6618785B1 (en) 2000-04-21 2003-09-09 Apple Computer, Inc. Method and apparatus for automatic detection and healing of signal pair crossover on a high performance serial bus
JP2001313646A (en) * 2000-04-27 2001-11-09 Sony Corp Electronic device and method for controlling state of its physical layer circuit
US6757773B1 (en) 2000-06-30 2004-06-29 Sony Corporation System and method for determining support capability of a device coupled to a bus system
US7328211B2 (en) 2000-09-21 2008-02-05 Jpmorgan Chase Bank, N.A. System and methods for improved linguistic pattern matching
JP4097891B2 (en) * 2000-11-27 2008-06-11 三菱電機株式会社 Synchronization system using IEEE 1394
US6891805B2 (en) * 2001-02-06 2005-05-10 Telephonics Corporation Communications system
US7024505B2 (en) * 2002-03-28 2006-04-04 Seagate Technology Llc Fair arbitration method in a distributed arbitration system
US6886051B2 (en) * 2002-03-28 2005-04-26 Seagate Technology Llc Device discovery method and apparatus
US7007123B2 (en) * 2002-03-28 2006-02-28 Alcatel Binary tree arbitration system and method using embedded logic structure for controlling flag direction in multi-level arbiter node
US7987246B2 (en) 2002-05-23 2011-07-26 Jpmorgan Chase Bank Method and system for client browser update
US7340650B2 (en) * 2002-10-30 2008-03-04 Jp Morgan Chase & Co. Method to measure stored procedure execution statistics
US20040103199A1 (en) * 2002-11-22 2004-05-27 Anthony Chao Method and system for client browser update from a lite cache
US7149752B2 (en) * 2002-12-03 2006-12-12 Jp Morgan Chase Bank Method for simplifying databinding in application programs
US7085759B2 (en) 2002-12-06 2006-08-01 Jpmorgan Chase Bank System and method for communicating data to a process
US7457302B1 (en) 2002-12-31 2008-11-25 Apple Inc. Enhancement to loop healing for malconfigured bus prevention
US7417973B1 (en) 2002-12-31 2008-08-26 Apple Inc. Method, apparatus and computer program product for ensuring node participation in a network bus
US8032439B2 (en) * 2003-01-07 2011-10-04 Jpmorgan Chase Bank, N.A. System and method for process scheduling
US7401156B2 (en) * 2003-02-03 2008-07-15 Jp Morgan Chase Bank Method using control interface to suspend software network environment running on network devices for loading and executing another software network environment
US7379998B2 (en) * 2003-03-31 2008-05-27 Jp Morgan Chase Bank System and method for multi-platform queue queries
US20040210696A1 (en) * 2003-04-18 2004-10-21 Meyer Michael J. Method and apparatus for round robin resource arbitration
US20040230602A1 (en) * 2003-05-14 2004-11-18 Andrew Doddington System and method for decoupling data presentation layer and data gathering and storage layer in a distributed data processing system
US7366722B2 (en) * 2003-05-15 2008-04-29 Jp Morgan Chase Bank System and method for specifying application services and distributing them across multiple processors using XML
US7509641B2 (en) * 2003-05-16 2009-03-24 Jp Morgan Chase Bank Job processing framework
US7668099B2 (en) * 2003-06-13 2010-02-23 Apple Inc. Synthesis of vertical blanking signal
US7353284B2 (en) 2003-06-13 2008-04-01 Apple Inc. Synchronized transmission of audio and video data from a computer to a client via an interface
US20040255338A1 (en) * 2003-06-13 2004-12-16 Apple Computer, Inc. Interface for sending synchronized audio and video data
US8275910B1 (en) 2003-07-02 2012-09-25 Apple Inc. Source packet bridge
WO2005015361A2 (en) 2003-08-08 2005-02-17 Jp Morgan Chase Bank System for archive integrity management and related methods
US20050065964A1 (en) 2003-09-19 2005-03-24 Ziemann David M. Update of a tree-based database
US7270227B2 (en) 2003-10-29 2007-09-18 Lockheed Martin Corporation Material handling system and method of use
US7788567B1 (en) * 2003-11-18 2010-08-31 Apple Inc. Symbol encoding for tolerance to single byte errors
US7995606B1 (en) 2003-12-03 2011-08-09 Apple Inc. Fly-by and ack-accelerated arbitration for broadcast packets
US7502338B1 (en) 2003-12-19 2009-03-10 Apple Inc. De-emphasis training on a point-to-point connection
US7421696B2 (en) * 2003-12-22 2008-09-02 Jp Morgan Chase Bank Methods and systems for managing successful completion of a network of processes
US7237135B1 (en) 2003-12-29 2007-06-26 Apple Inc. Cyclemaster synchronization in a distributed bridge
US7308517B1 (en) * 2003-12-29 2007-12-11 Apple Inc. Gap count analysis for a high speed serialized bus
US20050144174A1 (en) * 2003-12-31 2005-06-30 Leonid Pesenson Framework for providing remote processing of a graphical user interface
US20050175027A1 (en) * 2004-02-09 2005-08-11 Phonex Broadband Corporation System and method for requesting and granting access to a network channel
US7183906B2 (en) * 2004-03-19 2007-02-27 Lockheed Martin Corporation Threat scanning machine management system
US20050222990A1 (en) * 2004-04-06 2005-10-06 Milne Kenneth T Methods and systems for using script files to obtain, format and disseminate database information
US20050231358A1 (en) * 2004-04-19 2005-10-20 Company Steven L Search engine for singles with (GPS) position data
US7376830B2 (en) 2004-04-26 2008-05-20 Jp Morgan Chase Bank System and method for routing messages
US20050251398A1 (en) * 2004-05-04 2005-11-10 Lockheed Martin Corporation Threat scanning with pooled operators
US20050251397A1 (en) * 2004-05-04 2005-11-10 Lockheed Martin Corporation Passenger and item tracking with predictive analysis
US7212113B2 (en) * 2004-05-04 2007-05-01 Lockheed Martin Corporation Passenger and item tracking with system alerts
US7392471B1 (en) 2004-07-28 2008-06-24 Jp Morgan Chase Bank System and method for comparing extensible markup language (XML) documents
US7366974B2 (en) * 2004-09-03 2008-04-29 Jp Morgan Chase Bank System and method for managing template attributes
US20060059210A1 (en) * 2004-09-16 2006-03-16 Macdonald Glynne Generic database structure and related systems and methods for storing data independent of data type
US20090132466A1 (en) * 2004-10-13 2009-05-21 Jp Morgan Chase Bank System and method for archiving data
US7739436B2 (en) * 2004-11-01 2010-06-15 Sonics, Inc. Method and apparatus for round robin resource arbitration with a fast request to grant response
US7684421B2 (en) * 2005-06-09 2010-03-23 Lockheed Martin Corporation Information routing in a distributed environment
US20060282886A1 (en) * 2005-06-09 2006-12-14 Lockheed Martin Corporation Service oriented security device management network
US8223666B2 (en) * 2005-08-23 2012-07-17 Cisco Technology, Inc. Method of constructing a forwarding database for a data communications network
US7969995B2 (en) * 2005-08-23 2011-06-28 Cisco Technology, Inc. Method and apparatus for constructing a forwarding database for a data communications network
US8065606B1 (en) 2005-09-16 2011-11-22 Jpmorgan Chase Bank, N.A. System and method for automating document generation
US7499933B1 (en) 2005-11-12 2009-03-03 Jpmorgan Chase Bank, N.A. System and method for managing enterprise application configuration
US7610172B2 (en) * 2006-06-16 2009-10-27 Jpmorgan Chase Bank, N.A. Method and system for monitoring non-occurring events
US8483108B2 (en) * 2006-07-24 2013-07-09 Apple Inc. Apparatus and methods for de-emphasis training on a point-to-point connection
US20080060910A1 (en) * 2006-09-08 2008-03-13 Shawn Younkin Passenger carry-on bagging system for security checkpoints
CN101179516B (en) * 2006-11-10 2010-06-09 北京航空航天大学 Digraph based data distributing method
US8104076B1 (en) 2006-11-13 2012-01-24 Jpmorgan Chase Bank, N.A. Application access control system
US7610429B2 (en) * 2007-01-30 2009-10-27 Hewlett-Packard Development Company, L.P. Method and system for determining device criticality in a computer configuration
JP5654983B2 (en) 2008-06-17 2015-01-14 アティヴィオ,インコーポレイテッド Sequence message processing
US8312088B2 (en) * 2009-07-27 2012-11-13 Sandisk Il Ltd. Device identifier selection
US8392614B2 (en) 2009-07-27 2013-03-05 Sandisk Il Ltd. Device identifier selection
FR2951290B1 (en) * 2009-10-08 2011-12-09 Commissariat Energie Atomique MULTI-SOURCE MEMORY DIRECT ACCESS CONTROLLER, CORRESPONDING COMPUTER PROGRAM AND PROGRAM
US8495656B2 (en) 2010-10-15 2013-07-23 Attivio, Inc. Ordered processing of groups of messages
US9038177B1 (en) 2010-11-30 2015-05-19 Jpmorgan Chase Bank, N.A. Method and system for implementing multi-level data fusion
US9292588B1 (en) 2011-07-20 2016-03-22 Jpmorgan Chase Bank, N.A. Safe storing data for disaster recovery
US10540373B1 (en) 2013-03-04 2020-01-21 Jpmorgan Chase Bank, N.A. Clause library manager

Family Cites Families (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2443101A1 (en) * 1978-11-30 1980-06-27 Ibm France IMPROVEMENT IN PRIORITY INTERFACE SELECTION SYSTEMS
US4344134A (en) * 1980-06-30 1982-08-10 Burroughs Corporation Partitionable parallel processor
US4412285A (en) * 1981-04-01 1983-10-25 Teradata Corporation Multiprocessor intercommunication system and method
US4698752A (en) * 1982-11-15 1987-10-06 American Telephone And Telegraph Company At&T Bell Laboratories Data base locking
IT1159351B (en) * 1983-02-03 1987-02-25 Cselt Centro Studi Lab Telecom DISTRIBUTED STRUCTURE REFEREE CIRCUIT FOR BUS REQUESTS FOR A MULTIPROCESSOR SYSTEM
US5113523A (en) * 1985-05-06 1992-05-12 Ncube Corporation High performance computer system
US4706080A (en) * 1985-08-26 1987-11-10 Bell Communications Research, Inc. Interconnection of broadcast networks
US4897833A (en) * 1987-10-16 1990-01-30 Digital Equipment Corporation Hierarchical arbitration system
DE3838945A1 (en) * 1987-11-18 1989-06-08 Hitachi Ltd NETWORK SYSTEM WITH LOCAL NETWORKS AND WITH A HIERARCHICAL CHOICE OF PATH
US4811337A (en) * 1988-01-15 1989-03-07 Vitalink Communications Corporation Distributed load sharing
US5027342A (en) * 1989-05-03 1991-06-25 The University Of Toronto Innovations Foundation Local area network
US5138615A (en) * 1989-06-22 1992-08-11 Digital Equipment Corporation Reconfiguration system and method for high-speed mesh connected local area network
US5150360A (en) * 1990-03-07 1992-09-22 Digital Equipment Corporation Utilization of redundant links in bridged networks
US5301333A (en) * 1990-06-14 1994-04-05 Bell Communications Research, Inc. Tree structured variable priority arbitration implementing a round-robin scheduling policy
JPH06500655A (en) * 1990-10-03 1994-01-20 スィンキング マシンズ コーポレーション parallel computer system
US5353412A (en) * 1990-10-03 1994-10-04 Thinking Machines Corporation Partition control circuit for separately controlling message sending of nodes of tree-shaped routing network to divide the network into a number of partitions
FR2668626B1 (en) * 1990-10-30 1992-12-18 Thomson Csf METHOD FOR CONFIGURING A MESH COMPUTER SYSTEM.
FR2676558B1 (en) * 1991-05-15 1993-07-23 Opticable METHOD FOR AUTOMATICALLY DETERMINING THE CONFIGURATION OF A NETWORK.
EP0562222B1 (en) * 1992-03-27 1999-05-12 Alcatel Access control arrangement

Also Published As

Publication number Publication date
KR100290517B1 (en) 2001-09-17
CA2151369A1 (en) 1994-07-07
EP0674788B1 (en) 2005-04-27
CA2408252C (en) 2005-07-26
US5802289A (en) 1998-09-01
JP2002314565A (en) 2002-10-25
DE69333798D1 (en) 2005-06-02
EP1094394A2 (en) 2001-04-25
KR950704745A (en) 1995-11-20
JP3663385B2 (en) 2005-06-22
CA2698356C (en) 2011-04-12
WO1994015302A1 (en) 1994-07-07
JP3834562B2 (en) 2006-10-18
EP1094394B1 (en) 2007-09-12
EP1132821B1 (en) 2007-09-12
DE69334171T2 (en) 2008-06-12
JP3663386B2 (en) 2005-06-22
CA2503335A1 (en) 1994-07-07
JP2006238452A (en) 2006-09-07
US5630173A (en) 1997-05-13
JP3638949B2 (en) 2005-04-13
HK1037035A1 (en) 2002-01-25
JP2006217639A (en) 2006-08-17
JPH08504989A (en) 1996-05-28
JP2004030648A (en) 2004-01-29
EP0674788A1 (en) 1995-10-04
EP1094394A3 (en) 2006-04-19
EP1094395A3 (en) 2006-04-19
EP1094395A2 (en) 2001-04-25
DE69333798T2 (en) 2006-03-09
EP1132821A3 (en) 2006-04-19
EP1094395B1 (en) 2008-07-02
DE69334172D1 (en) 2007-10-31
HK1037037A1 (en) 2002-01-25
JP2006229992A (en) 2006-08-31
JP4195470B2 (en) 2008-12-10
AU5953994A (en) 1994-07-19
DE69334228D1 (en) 2008-08-14
JP2002314566A (en) 2002-10-25
DE69334171D1 (en) 2007-10-25
JP4209428B2 (en) 2009-01-14
HK1037036A1 (en) 2002-01-25
CA2408252A1 (en) 1994-07-07
CA2698356A1 (en) 1994-07-07
DE69334172T2 (en) 2008-06-12
JP4195469B2 (en) 2008-12-10
CA2151369C (en) 2004-02-10
EP1132821A2 (en) 2001-09-12

Similar Documents

Publication Publication Date Title
CA2503335C (en) Method and apparatus for pre-emptively arbitrating on an acyclic directed graph
EP1197870B1 (en) Method and apparatus for unique address assignment, node self-identification and topology mapping for a direct acyclic graph
EP0674790B1 (en) Method and apparatus for transforming an arbitrary topology collection of nodes into an acyclic directed graph
WO1994015305A1 (en) Method and apparatus for transforming an arbitrary acyclic topology collection of nodes into an acyclic directed graph

Legal Events

Date Code Title Description
EEER Examination request
MKEX Expiry

Effective date: 20131216