WO1997004541A2 - Multipoint to multipoint processing in a network switch having data buffering queues - Google Patents

Multipoint to multipoint processing in a network switch having data buffering queues Download PDF

Info

Publication number
WO1997004541A2
WO1997004541A2 PCT/US1996/011918 US9611918W WO9704541A2 WO 1997004541 A2 WO1997004541 A2 WO 1997004541A2 US 9611918 W US9611918 W US 9611918W WO 9704541 A2 WO9704541 A2 WO 9704541A2
Authority
WO
WIPO (PCT)
Prior art keywords
port
data
data cell
input
link
Prior art date
Application number
PCT/US1996/011918
Other languages
French (fr)
Other versions
WO1997004541A3 (en
Inventor
Richard G. Bubenik
Stephen A. Caldara
Stephen A. Hauser
Thomas A. Manning
Stephen R. Veit
Original Assignee
Fujitsu Limited
Fujitsu Network Communications, 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 Fujitsu Limited, Fujitsu Network Communications, Inc. filed Critical Fujitsu Limited
Priority to JP50686497A priority Critical patent/JP2002516038A/en
Priority to AU65008/96A priority patent/AU6500896A/en
Priority to PCT/US1996/011918 priority patent/WO1997004541A2/en
Publication of WO1997004541A2 publication Critical patent/WO1997004541A2/en
Publication of WO1997004541A3 publication Critical patent/WO1997004541A3/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/18End to end
    • 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/17356Indirect interconnection networks
    • G06F15/17368Indirect interconnection networks non hierarchical topologies
    • G06F15/17375One dimensional, e.g. linear array, ring
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • 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/46Interconnection of networks
    • H04L12/4604LAN interconnection over a backbone network, e.g. Internet, Frame Relay
    • H04L12/4608LAN interconnection over ATM networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L12/5602Bandwidth control in ATM Networks, e.g. leaky bucket
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/11Identifying congestion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/26Flow control; Congestion control using explicit feedback to the source, e.g. choke packets
    • H04L47/266Stopping or restarting the source, e.g. X-on or X-off
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/29Flow control; Congestion control using a combination of thresholds
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/30Flow control; Congestion control in combination with information about buffer occupancy at either end or at transit nodes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/62Queue scheduling characterised by scheduling criteria
    • H04L47/621Individual queue per connection or flow, e.g. per VC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/104Asynchronous transfer mode [ATM] switching fabrics
    • H04L49/105ATM switching elements
    • H04L49/106ATM switching elements using space switching, e.g. crossbar or matrix
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/10Packet switching elements characterised by the switching fabric construction
    • H04L49/104Asynchronous transfer mode [ATM] switching fabrics
    • H04L49/105ATM switching elements
    • H04L49/107ATM switching elements using shared medium
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/15Interconnection of switching modules
    • H04L49/1515Non-blocking multistage, e.g. Clos
    • H04L49/153ATM switching fabrics having parallel switch planes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/15Interconnection of switching modules
    • H04L49/1553Interconnection of ATM switching modules, e.g. ATM switching fabrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/15Interconnection of switching modules
    • H04L49/1553Interconnection of ATM switching modules, e.g. ATM switching fabrics
    • H04L49/1576Crossbar or matrix
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/20Support for services
    • H04L49/201Multicast operation; Broadcast operation
    • H04L49/203ATM switching fabrics with multicast or broadcast capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/253Routing or path finding in a switch fabric using establishment or release of connections between ports
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/253Routing or path finding in a switch fabric using establishment or release of connections between ports
    • H04L49/255Control mechanisms for ATM switching fabrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/25Routing or path finding in a switch fabric
    • H04L49/256Routing or path finding in ATM switching fabrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • H04L49/3081ATM peripheral units, e.g. policing, insertion or extraction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/30Peripheral units, e.g. input or output ports
    • H04L49/3081ATM peripheral units, e.g. policing, insertion or extraction
    • H04L49/309Header conversion, routing tables or routing tags
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/45Arrangements for providing or supporting expansion
    • H04L49/455Provisions for supporting expansion in ATM switches
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/55Prevention, detection or correction of errors
    • H04L49/552Prevention, detection or correction of errors by ensuring the integrity of packets received through redundant connections
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/55Prevention, detection or correction of errors
    • H04L49/555Error detection
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/324Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the data link layer [OSI layer 2], e.g. HDLC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/04Selecting arrangements for multiplex systems for time-division multiplexing
    • H04Q11/0428Integrated services digital network, i.e. systems for transmission of different types of digitised signals, e.g. speech, data, telecentral, television signals
    • H04Q11/0478Provisions for broadband connections
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • H04J3/0635Clock or time synchronisation in a network
    • H04J3/0682Clock or time synchronisation in a network by delay compensation, e.g. by compensation of propagation delay or variations thereof, by ranging
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • H04J3/0635Clock or time synchronisation in a network
    • H04J3/0685Clock or time synchronisation in a node; Intranode synchronisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5614User Network Interface
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5614User Network Interface
    • H04L2012/5616Terminal equipment, e.g. codecs, synch.
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5625Operations, administration and maintenance [OAM]
    • H04L2012/5627Fault tolerance and recovery
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5628Testing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • H04L2012/5632Bandwidth allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • H04L2012/5632Bandwidth allocation
    • H04L2012/5634In-call negotiation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5629Admission control
    • H04L2012/5631Resource management and allocation
    • H04L2012/5632Bandwidth allocation
    • H04L2012/5635Backpressure, e.g. for ABR
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/564Connection-oriented
    • H04L2012/5642Multicast/broadcast/point-multipoint, e.g. VOD
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/564Connection-oriented
    • H04L2012/5643Concast/multipoint-to-point
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5646Cell characteristics, e.g. loss, delay, jitter, sequence integrity
    • H04L2012/5647Cell loss
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5646Cell characteristics, e.g. loss, delay, jitter, sequence integrity
    • H04L2012/5647Cell loss
    • H04L2012/5648Packet discarding, e.g. EPD, PTD
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5646Cell characteristics, e.g. loss, delay, jitter, sequence integrity
    • H04L2012/5649Cell delay or jitter
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5646Cell characteristics, e.g. loss, delay, jitter, sequence integrity
    • H04L2012/5651Priority, marking, classes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5638Services, e.g. multimedia, GOS, QOS
    • H04L2012/5646Cell characteristics, e.g. loss, delay, jitter, sequence integrity
    • H04L2012/5652Cell construction, e.g. including header, packetisation, depacketisation, assembly, reassembly
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5672Multiplexing, e.g. coding, scrambling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5679Arbitration or scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5681Buffer or queue management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5681Buffer or queue management
    • H04L2012/5682Threshold; Watermark
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5678Traffic aspects, e.g. arbitration, load balancing, smoothing, buffer management
    • H04L2012/5681Buffer or queue management
    • H04L2012/5683Buffer or queue management for avoiding head of line blocking
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/54Store-and-forward switching systems 
    • H04L12/56Packet switching systems
    • H04L12/5601Transfer mode dependent, e.g. ATM
    • H04L2012/5685Addressing issues
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L7/00Arrangements for synchronising receiver with transmitter
    • H04L7/04Speed or phase control by synchronisation signals
    • H04L7/041Speed or phase control by synchronisation signals using special codes as synchronising signal
    • H04L7/046Speed or phase control by synchronisation signals using special codes as synchronising signal using a dotting sequence

Definitions

  • - 2 - resources in a network switch may become unencumbered in a multipoint-to-multipoint switching scenario.
  • the network switch includes a switch fabric, an input processing port connected between a plurality of input links and the switch fabric and having a plurality of data buffering queues, and an output processing port connected between the switch fabric and a plurality of output links and having a plurality of data buffering queues. All of the data buffering queues have a connection identification code, and the data buffering queues in the output processing port have a data cell processing code.
  • the input processing port processes a data cell received on one of the input links by appending to the data cell a link number indicating the input link where the data cell arrived, a port number indicating the input processing port, and a connection identification code associated with a data buffering queue in the input processing port where the data cell will be buffered.
  • the output processing port processes a data cell processed by the input processing port and transferred to the output processing port through the switch fabric by comparing the link number to a link number of a link connected to the output processing port, the port number to a port number of the output processing port, and the connection identification code to a connection identification code associated with a data buffering queue in the output processing port.
  • the data cell is then stored in the data buffering queue in the output processing port according to a matching scheme between the link numbers, the port numbers, and the connection identification codes as dictated by the value of the data cell processing code.
  • the output processing port matching scheme requires that the link - 1 -
  • the present invention is generally related to network switching and, more particularly, to an apparatus and a method for unencumbering valuable switching resources in a network switch involved a multipoint-to-multipoint switching scenario.
  • Telecommunications networks such as asynchronous transfer mode (ATM) networks are used for the transfer of audio, video, and other data.
  • ATM networks deliver data by routing data units such as ATM cells from a source to a destination through switches.
  • Switches typically include multiple input/output (I/O) ports through which ATM cells are received and transmitted. The appropriate output port to which a received ATM cell is to be routed to and thereafter transmitted from is determined based upon an ATM cell header.
  • ATM cells from a variety of sources are transferred from multiple input queues to multiple output queues within a switch.
  • valuable switching resources become unencumbered. Accordingly, it would be desirable to devise a scheme whereby valuable switching numbers, the port numbers, and the connection identification codes match in order for the data cell to be stored in the data buffering queue in the output processing port.
  • the output processing port matching scheme requires that the link numbers, the port numbers, and the connection identification codes do not match in order for the data cell to be stored in the data buffering queue in the output processing port.
  • This mechanism allows each output queue to receive a unique set of ATM cells from a variety of sources, wherein the ATM cells are transferred from multiple input queues to each output queue.
  • the primary object of the present invention is to provide an apparatus and a method for unencumbering valuable switching resources in a network switch involved a multipoint-to-multipoint switching scenario.
  • Fig. 1 is a block diagram of a network switch
  • Fig. 2 illustrates the structure of an input queue
  • Fig. 3 illustrates the structure of a scheduling list
  • Fig. 4 shows the standard data bus format of a data cell
  • Fig. 5 shows the internal switch data cell format of a converted data cell
  • Fig. 6 shows the format of an input queue descriptor
  • Fig. 7 shows the format of an output queue descriptor
  • Fig. 8 contains a table indicating the different echo field codes and the corresponding output port processor functions associated with those codes.
  • Fig. 9 shows a "No Echo" multipoint-to-multipoint switching scenario.
  • a network switch 1 comprising a Data Crossbar 10, a Bandwidth Arbiter (BA) 12, a plurality of input port processors 14, a plurality of output port processors 16, and a plurality of Multipoint Topology Controllers (MTC) 18.
  • the Data Crossbar 10 which may be an N x N crosspoint switch, is used for data cell transport and, in this particular embodiment, yields N x 670 Mbps throughput.
  • the BA 12 controls switch interconnections, dynamically schedules momentarily unused bandwidth, and resolves multipoint-to-point bandwidth contention.
  • Each input port processor 14 schedules the transmission of data cells to the Data Crossbar 10 from multiple connections.
  • Each output port processor 16 receives data cells from the Data Crossbar 10 and organizes those data cells onto output links.
  • a data cell 22 In order to traverse the switch 1, a data cell 22 first enters the switch 1 on a link 24 to an input port processor 14 and is buffered in a queue 26 of input buffers. The data cell 22 is then transmitted from the queue 26 of input buffers through the Data Crossbar 10 to a queue 28 of output buffers in an output port processor 16. From the queue 28 of output buffers, the data cell 22 is transmitted onto a link 30 outside of the switch 1 to, for example, another switch.
  • each input port processor 14 includes a cell buffer RAM 32 and each output port processor 16 includes a cell buffer RAM 34.
  • the cell buffer RAM's 32 and 34 are organized into the respective input and output queues 26 and 28. All data cells 22 in a connection pass must through a unique input queue 26 and a unique output queue 28 for the life of the connection. The queues 26 and 28 thus preserve cell ordering. This strategy also allows quality of service (“QoS”) guarantees on a per connection basis.
  • QoS quality of service
  • the Probe Crossbar 42 which in this particular embodiment is an N x N crosspoint switch, is used to transmit a multiqueue number from an MTC 18 to an output port processor 16.
  • Each input port processor 14 includes a plurality of scheduling lists 47, each of which is a circular list containing input queue numbers for a particular connection.
  • Each multiqueue number is derived from information provided to the MTC 18 from a scheduling list 47 in an input port processor 14.
  • a multiqueue number identifies one or more output queues 28 to which a data cell may be transmitted when making a connection.
  • An output port processor 16 uses the multiqueue number to direct a request message probe to the appropriate output queue or queues 28 and thereby determine if there are enough output buffers available in the output queue or queues 28 for the data cell.
  • the XOFF Crossbar 44 which in this particular embodiment is an N x N crosspoint switch, is used to communicate "DO NOT SEND" type feedback messages from an output port processor 16 to an input port processor 14.
  • the XOFF feedback messages are asserted to halt the transmission of request message probes through the Probe Crossbar 42 from an input port processor 14 to an output port processor 16, and thus put a scheduling list 47 within the receiving input port processor 14 in an XOFF state, meaning that the scheduling list 47 cannot be used to provide a multiqueue number.
  • the scheduling list 47 remains in an XOFF state until receiving an XON message from the output port processor 16, as described below.
  • An input port processor 14 responds to an asserted XOFF feedback message by modifying XOFF state bits in a descriptor of the scheduling list 47.
  • the XOFF state bits prevent the input port processor 14 from attempting to send a request message probe from the input port processor 14 to the output port processor 16 until notified by the output port processor 16 that output buffers are available for a corresponding connection
  • the "DO NOT SEND" type feedback messages also halt the transmission of data cells from an input port processor 14 to an output port processor 16 when sufficient buffer space is not available to receive data cells in the output port processor 16. In such a case, an input port processor 14 will not transmit any data cells through the Data Crossbar 10. An idle cell, containing a complemented cyclic redundancy check (CRC) calculation, is transmitted instead.
  • CRC cyclic redundancy check
  • the XON Crossbar 46 which in this particular embodiment is an N x N crosspoint switch, is used to communicate "ENABLE SEND" type feedback messages from an output port processor 16 to an input port processor 16. More particularly, the XON Crossbar 46 communicates an XON feedback message from an output port processor 16 to an input port processor 14. When an XOFF feedback message has been asserted by an output port processor 16 in response to a request probe message from an input port processor 14, the output port processor 16 sets a state bit in a queue descriptor of a corresponding output queue 28. When the number of data cells in that output queue 28 drops below an XON threshold, an XON message is sent from that output port processor 16 to the input port processor 14. The XON message enables the scheduling list 47 in the input port processor 14 to be used in the sending of request probe messages, and hence data cells.
  • the Probe & XOFF communication paths operate in a pipelined fashion.
  • an input port processor 14 selects a scheduling list 47, and information associated with that scheduling list 47 is used to determine the output port processor 16, or the output queue 28, to which a data cell will be transmitted. More particularly, a multiqueue number. which is derived from information provided to an MTC 18 from a scheduling list 47 in an input port processor 14, is transmitted from the MTC 18 to one or more output port processors 16 using the Probe Crossbar 42.
  • Each output port processor 16 tests for buffer availability and asserts a "DO NOT SEND" type feedback message through the XOFF Crossbar 44 if output buffering is not available for that connection. If output buffering is available for that connection, the input port processor 14 transmits a data cell to one or more output queues 28 through the Data Crossbar 10.
  • Each input port processor 14 within the switch 1 also includes a Switch Allocation Table (SAT) 20 for mapping bandwidth allocation.
  • SAT's 20 are the basic mechanism behind the scheduling of data cells.
  • Each SAT 20 includes a plurality of sequentially ordered cell time slots 50 and a pointer 52 which is always directed to one of the cell time slots 50. All of the pointers 52 in the switch 1 are synchronized such that at any given point in time each of the pointers 52 is directed to the same cell time slot 50 in the respective SAT 20 with which the pointer 52 is associated, e.g., the first cell time slot. In operation, the pointers 52 are advanced in lock-step, with each cell time slot 50 being active for 32 clock cycles at 50 MHz. When a pointer 52 is directed toward a cell time slot 50, an input port processor 14 uses the corresponding entry 51 in the cell time slot 50 to obtain a data cell for launching into the Data Crossbar 10.
  • each SAT entry 51 point to a scheduling list 47.
  • the contents of each (non-empty) entry in a scheduling list 47 consists of an input queue number. Each input queue number points to a input queue descriptor which contains state information that is specific to a particular connection. Each input queue descriptor, in turn, points to the head and the tail of a corresponding input queue 26, which contains data cells for transmission through the Data Crossbar 10. If a SAT entry 51 does not contain a pointer to a scheduling list, i.e. the SAT entry 51 is set to zero, then the corresponding cell time slot 50 in the SAT 20 has not been allocated and that cell time slot 50 is available for dynamic bandwidth.
  • a SAT entry 51 does contain a pointer to a scheduling list 47 but no input queue number is listed in scheduling list 47, then there are no data cells presently available for transmission and the corresponding cell time slot 50 is also available for dynamic bandwidth. Any bandwidth that has not been allocated is referred to as dynamic bandwidth, which is granted to certain types of connections by the BA 12 so as to increase the efficiency of the switch 1.
  • the switch 1 is configured to allow connections having different quality of service attributes to be managed in such a way that there is no interference between the characteristics of any connection with any other connection.
  • an input port processor 14 manages each connection with a set of data structures that are unique for each connection.
  • An input queue 26 is used to manage buffers.
  • An input queue 26 consists of a group of one or more buf ers organized as a FIFO and manipulated as a linked list structure using pointers.
  • Incoming data cells 22 are added (enqueued) to the tail of an input queue 26. Data cells which are sent to the Data
  • Crossbar 10 are removed (dequeued) from the head of an input queue 26.
  • the ordering of data cells is always maintained.
  • the sequence of data cells that are sent to the Data Crossbar 10 is identical to that in which they arrived at an input port processor 14, although the time interval between departing data cells may be different than the time interval between arriving data cells.
  • Fig. 2 illustrates the structure of an input queue 26.
  • a scheduling list 47 is used to manage bandwidth.
  • a scheduling list 47 consists of one or more input queue numbers organized as a circular list. As with input queues 26, scheduling lists 47 are manipulated as a linked list structure using pointers. Input queue numbers are added to the tail of a scheduling list 47 and removed from the head of a scheduling list 47.
  • An input queue number can only appear once on any given scheduling list 47.
  • input queue numbers can be recirculated on a scheduling list 47 by removing the input queue number from the head of the scheduling list 47 and then adding the removed input queue number back onto the tail of the scheduling list 47. This results in round-robin servicing of input queues 26 on a particular scheduling list 47.
  • Fig. 3 illustrates the structure of a scheduling list 47.
  • the first action performed by the input port processor 14 is to check the header of the data cell for errors and then to check that the data cell is associated with a valid connection.
  • Cell header integrity is verified by computing a Header Error Check (HEC) on bytes in the header of a received data cell and then comparing the computed HEC to the HEC field in the header of the received data cell. If the computed HEC and the HEC field do not match, then there is a header error and the data cell will be dropped.
  • HEC Header Error Check
  • an input port processor 14 For each incoming data cell, an input port processor 14 will use VPI/VCI fields specified in the header of the data cell as an index into a translation table in the input port processor 14.
  • the translation table correlates valid connections and input queue numbers.
  • the input port processor 14 first checks to see if the data cell belongs to a valid connection; i.e. one that has been set up by switch control software. If the connection is valid, then the data cell will be assigned an input queue number from the translation table. If the connection is not valid, then the data cell will either be dropped or be assigned an exception input queue number from the translation table, which results in further processing of the data cell.
  • Fig. 4 shows the standard data bus format of a data cell.
  • Fig. 5 shows the internal switch data cell format of a converted data cell.
  • an input queue number is used to point to a queue descriptor, which is a data structure containing state information that is unique to a particular connection.
  • a queue descriptor for each queue in the switch 1; i.e. for both the input queues 26 in the input port processor 14 and the output queues 28 in the output port processor 16.
  • the queue descriptors are maintained by switch control software.
  • Fig. 6 shows the format of an input queue descriptor.
  • Fig. 7 shows the format of an output queue descriptor.
  • the input port processor 14 After a data cell is assigned an input queue number, the input port processor 14 will look at the corresponding queue descriptor for further information on how to process the data cell. The input port processor 14 will first try to assign a buffer for the data cell. If a buffer is available, then the data cell buffer number is enqueued to the tail of the queue and the data cell is written out to the cell buffer RAM 32. If there is no buffer available, the data cell is dropped and a statistic is updated.
  • the input port processor 14 In addition to processing and buffering incoming streams of data cells, the input port processor 14 must transfer data cells from a cell buffer to one or more output port processors 16 through the Data Crossbar 10. The transfer of the data cells is performed through the use of the Probe Crossbar 20, the XOFF Crossbar 24, and the Data Crossbar 10, as previously described. Specifically, a multiqueue number, which is derived from information provided to an MTC 18 from a scheduling list 47 in an input port processor 14, is transmitted from the MTC 18 to one or more output port processors 16 using the Probe Crossbar 42. Each output port processor 16 then tests for buffer availability and asserts a "DO NOT SEND" type feedback message through the XOFF Crossbar 44 if output buffering is not available for that connection.
  • the input port processor 14 transmits a data cell to one or more output queues 28 through the Data Crossbar 10. However, before any data cells are enqueued into any output queue 28, the output port processor 16 processes each data cell based on information contained in the trailer of the converted data cell.
  • connection identification (Conn ID) field 60 contains an arbitrary code that is assigned by the switch control software indicating 1 of 8 possible data flow paths upon which to perform a cell mask.
  • an input port processor 14 When processing a data cell, an input port processor 14 will insert the code from the connection identification field 60 of the input queue descriptor into a similar connection identification (Conn ID) field 62 in the converted data cell (see Fig. 6) .
  • the converted data cell also includes an ingress port number field 64, indicating the number of the input port processor 14 where the data cell 22 was received, and an ingress link number field 66, indicating the number of the input link 24 that the data cell 22 arrived on.
  • the output queue descriptor also contains an "echo" field 68 for a 2-bit code which indicates what action that an output port processor 16 should take when processing a data cell transmitted from an input port processor 14, as will be described in detail below.
  • the code in the echo field 68 is also assigned by the switch control software.
  • an output port processor 16 For every data cell transmitted from an input port processor 14, an output port processor 16 processes the data cell by comparing its own port number, link number, and connection identification code to the port number, link number, and connection identification code of the converted data cell. In conjunction with the 2-bit code in the echo field 68 of the output queue descriptor, this comparison is used to decide whether or not to enqueue the data cell arriving at a corresponding output queue 28.
  • Fig. 8 there is shown a table indicating the different echo field codes and the corresponding output port processor functions associated with those codes. For example, if the echo field 68 in the output queue descriptor is set to "00", the output port processor 16 will always enqueue the data cell. In contrast, if the echo field 68 in the output queue descriptor is set to "11", the output port processor 16 will never enqueue the data cell. More importantly, however, are the actions of the output port processor 16 when the echo field 68 in the output queue descriptor is set to "01" or "10". More specifically, echo processing of data cells received by an output port processor 16 conserves resources in the switch 1 in a multipoint-to- multipoint switching scenario.
  • a switch 1 is often used within a network of similar switches wherein data cells are routed through the network.
  • data cells from a variety of sources are transferred from multiple input queues 26 to multiple output queues 28 within a switch 1.
  • Echo processing of data cells received by an output port processor 16 achieves this objective by essentially screening converted data cells according to the port number, link number, and connection identification code contained in the converted data cells.
  • the output port processor 16 When the echo field 68 in the output queue descriptor is set to "01", a "No Echo” situation, the output port processor 16 will always enqueue the data cell unless the port number, the link number, and the connection identification code of the data cell match the port number, link number, and connection identification code of the output port processor 16. Alternatively, when the echo field 68 in the output queue descriptor is set to "10", an “Only Echo” situation, the output port processor 16 will enqueue the data cell only if the port number, the link number, and the connection identification code of the data cell match the port number, link number, and connection identification code of the output port processor 16.
  • FIG. 9 there is shown an example of a "No Echo" multipoint-to-multipoint switching scenario, wherein a plurality of data cells (A, B, C, and D) are being transmitted from a corresponding plurality of sources (Tl, T2, T3, and SI) to a plurality of destinations (Rl, R2, R3, and S2) .
  • Tl, T2, and T3 denote end station transmitters
  • Rl, R2, and R3 denote end station receivers
  • SI and S2 denote other switching elements within a network.
  • the data cells are received by input port processors 14a and 14b, where they are processed and enqueued in input queues 26a, 26b, 26c, and 26d.
  • Input port processor 14a and output port processor 16a have the same port number, and input port processor 14b and output port processor 16b have the same port number.
  • Links 24a, 24c, 30a, and 30c all have the same link number, and links 24b, 24d, 30b, and 30d all have the same link number. All of the input queues 26 and output queues 28 have been assigned an arbitrary connection identification code of 6.
  • the processing of the data cells includes amending the trailer in each data cell to include an arbitrary connection identification code, a link number, and a port number.
  • data cell A is assigned an arbitrary connection identification code of 6, a link number of 24a, and a port number of 14a.
  • data cell B has been assigned an arbitrary connection identification code of 6, a link number of 24b, and a port number of 14a
  • data cell C has been assigned an arbitrary connection identification code of 6, a link number of 24c, and a port number of 14b
  • data cell D has been assigned an arbitrary connection identification code of 6, a link number of 24d, and a port number of 14b.
  • multiqueue numbers are transmitted simultaneously to the output port processors 16a and 16b, whereby each output port processor 16a and 16b tests for buffer availability, i.e. output port processor 16a tests output queues 28a and 28b for buffer availability, and output port processor 16b tests output queues 28c and 28d for buffer availability. If sufficient buffering is available, the data cells are then transmitted through the Data Crossbar 10 and the data cells are processed by the corresponding output port processors 16a and 16b.
  • output port processors 16a and 16b will enqueue the data cells unless the port number, the link number, and the connection identification code of the data cells match the port number, link number, and connection identification code of the output port processors 16a and 16b.
  • output queue 28a will enqueue data cells B, C, and D
  • output queue 28b will enqueue data cells A, C, and D
  • output queue 28c will enqueue data cells
  • Connection identification codes provide another control to screen sources or destinations from transmitting or receiving, respectively. This augments the physical port and link number screening.
  • echo processing allows each output queue 28a-d to receive data cells from a different set of sources while utilizing a single set connection resources, namely input queues 26a-d, scheduling lists 47, and output queues 28a-d. Echo processing thus allows valuable switching resources to become unencumbered in a network switch involved in a multipoint-to-multipoint switching scenario. It will be understood that various changes and modifications to the above described method and apparatus may be made without departing from the inventive concepts disclosed herein. Accordingly, the present invention is not to be viewed as limited to the embodiment described herein.

Abstract

An apparatus and a method are disclosed for unencumbering valuable switching resources in a network switch involved in a multipoint-to-multipoint switching scenario. The network switch (1) includes an input processing port (14) connected between a plurality of input links and a switching fabric, and having a plurality of data buffering queues (26), and an output processing port (16) connected between the switch fabric and a plurality of output links and having a plurality of data buffering queues (28). The input processing port processes a data cell received on one of the input links by appending to the data cell a link number, a port number, and a connection ID associated with input side. The output processing port processes the data cell processed by the input processing port by comparing the link number, the port number, and the connection ID of the data cell with those associated with the output processing port. The data cell is then stored in the data buffering queue according to a matching scheme.

Description

- 2 - resources in a network switch may become unencumbered in a multipoint-to-multipoint switching scenario.
SUMMARY OF THE INVENTION
An apparatus and a method are disclosed for unencumbering valuable switching resources in a network switch involved a multipoint-to-multipoint switching scenario. The network switch includes a switch fabric, an input processing port connected between a plurality of input links and the switch fabric and having a plurality of data buffering queues, and an output processing port connected between the switch fabric and a plurality of output links and having a plurality of data buffering queues. All of the data buffering queues have a connection identification code, and the data buffering queues in the output processing port have a data cell processing code. The input processing port processes a data cell received on one of the input links by appending to the data cell a link number indicating the input link where the data cell arrived, a port number indicating the input processing port, and a connection identification code associated with a data buffering queue in the input processing port where the data cell will be buffered. The output processing port processes a data cell processed by the input processing port and transferred to the output processing port through the switch fabric by comparing the link number to a link number of a link connected to the output processing port, the port number to a port number of the output processing port, and the connection identification code to a connection identification code associated with a data buffering queue in the output processing port. The data cell is then stored in the data buffering queue in the output processing port according to a matching scheme between the link numbers, the port numbers, and the connection identification codes as dictated by the value of the data cell processing code.
For a first value of the data cell processing code, the output processing port matching scheme requires that the link - 1 -
MULTIPOINT-TO-MULTIPOINT ECHO PROCESSING IN A NETWORK SWITCH
CROSS-REFERENCE TO RELATED APPLICATIONS A claim of priority is made to provisional application 60/001,498, entitled COMMUNICATION METHOD AND APPARATUS, filed July 19, 1995.
FIELD OF THE INVENTION The present invention is generally related to network switching and, more particularly, to an apparatus and a method for unencumbering valuable switching resources in a network switch involved a multipoint-to-multipoint switching scenario.
BACKGROUND OF THE INVENTION
Telecommunications networks such as asynchronous transfer mode (ATM) networks are used for the transfer of audio, video, and other data. ATM networks deliver data by routing data units such as ATM cells from a source to a destination through switches. Switches typically include multiple input/output (I/O) ports through which ATM cells are received and transmitted. The appropriate output port to which a received ATM cell is to be routed to and thereafter transmitted from is determined based upon an ATM cell header.
In a multipoint-to-multipoint switching scenario, ATM cells from a variety of sources are transferred from multiple input queues to multiple output queues within a switch. In such a scenario, it is often beneficial to eliminate duplicate processing of ATM cells or to otherwise prevent the flow of certain ATM cells through a switch by selectively screening ATM cells before allowing them to be transferred through the switch. By only allowing certain ATM cells to be transferred through the switch, valuable switching resources become unencumbered. Accordingly, it would be desirable to devise a scheme whereby valuable switching numbers, the port numbers, and the connection identification codes match in order for the data cell to be stored in the data buffering queue in the output processing port. For a second value of the data cell processing code, the output processing port matching scheme requires that the link numbers, the port numbers, and the connection identification codes do not match in order for the data cell to be stored in the data buffering queue in the output processing port. This mechanism allows each output queue to receive a unique set of ATM cells from a variety of sources, wherein the ATM cells are transferred from multiple input queues to each output queue.
From the above descriptive summary it is apparent how the present invention apparatus can save valuable switching resources in a network switch.
Accordingly, the primary object of the present invention is to provide an apparatus and a method for unencumbering valuable switching resources in a network switch involved a multipoint-to-multipoint switching scenario.
The above-stated primary object, as well as other objects, features, and disadvantages, of the present invention will become readily apparent from the following detailed description which is to be read in conjunction with the appended drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
In order to facilitate a fuller understanding of the present invention, reference is now made to the appended drawings. These drawings should not be construed as limiting the present invention, but are intended to be exemplary only.
Fig. 1 is a block diagram of a network switch;
Fig. 2 illustrates the structure of an input queue;
Fig. 3 illustrates the structure of a scheduling list;
Fig. 4 shows the standard data bus format of a data cell;
Fig. 5 shows the internal switch data cell format of a converted data cell; Fig. 6 shows the format of an input queue descriptor;
Fig. 7 shows the format of an output queue descriptor;
Fig. 8 contains a table indicating the different echo field codes and the corresponding output port processor functions associated with those codes.
Fig. 9 shows a "No Echo" multipoint-to-multipoint switching scenario.
DETAILED DESCRIPTION OF THE PRESENT INVENTION Referring to Fig. 1, there is shown a network switch 1 comprising a Data Crossbar 10, a Bandwidth Arbiter (BA) 12, a plurality of input port processors 14, a plurality of output port processors 16, and a plurality of Multipoint Topology Controllers (MTC) 18. The Data Crossbar 10, which may be an N x N crosspoint switch, is used for data cell transport and, in this particular embodiment, yields N x 670 Mbps throughput. The BA 12 controls switch interconnections, dynamically schedules momentarily unused bandwidth, and resolves multipoint-to-point bandwidth contention. Each input port processor 14 schedules the transmission of data cells to the Data Crossbar 10 from multiple connections. Each output port processor 16 receives data cells from the Data Crossbar 10 and organizes those data cells onto output links.
In order to traverse the switch 1, a data cell 22 first enters the switch 1 on a link 24 to an input port processor 14 and is buffered in a queue 26 of input buffers. The data cell 22 is then transmitted from the queue 26 of input buffers through the Data Crossbar 10 to a queue 28 of output buffers in an output port processor 16. From the queue 28 of output buffers, the data cell 22 is transmitted onto a link 30 outside of the switch 1 to, for example, another switch.
To facilitate traversal of the switch 1, each input port processor 14 includes a cell buffer RAM 32 and each output port processor 16 includes a cell buffer RAM 34. The cell buffer RAM's 32 and 34 are organized into the respective input and output queues 26 and 28. All data cells 22 in a connection pass must through a unique input queue 26 and a unique output queue 28 for the life of the connection. The queues 26 and 28 thus preserve cell ordering. This strategy also allows quality of service ("QoS") guarantees on a per connection basis.
Three communication paths are used to facilitate traversal of the switch 1 via probe and feedback messages: a Probe Crossbar 42, an XOFF Crossbar 44, and an XON Crossbar 46. The Probe Crossbar 42, which in this particular embodiment is an N x N crosspoint switch, is used to transmit a multiqueue number from an MTC 18 to an output port processor 16. Each input port processor 14 includes a plurality of scheduling lists 47, each of which is a circular list containing input queue numbers for a particular connection. Each multiqueue number is derived from information provided to the MTC 18 from a scheduling list 47 in an input port processor 14. A multiqueue number identifies one or more output queues 28 to which a data cell may be transmitted when making a connection. An output port processor 16 uses the multiqueue number to direct a request message probe to the appropriate output queue or queues 28 and thereby determine if there are enough output buffers available in the output queue or queues 28 for the data cell.
The XOFF Crossbar 44, which in this particular embodiment is an N x N crosspoint switch, is used to communicate "DO NOT SEND" type feedback messages from an output port processor 16 to an input port processor 14. The XOFF feedback messages are asserted to halt the transmission of request message probes through the Probe Crossbar 42 from an input port processor 14 to an output port processor 16, and thus put a scheduling list 47 within the receiving input port processor 14 in an XOFF state, meaning that the scheduling list 47 cannot be used to provide a multiqueue number. The scheduling list 47 remains in an XOFF state until receiving an XON message from the output port processor 16, as described below. An input port processor 14 responds to an asserted XOFF feedback message by modifying XOFF state bits in a descriptor of the scheduling list 47. The XOFF state bits prevent the input port processor 14 from attempting to send a request message probe from the input port processor 14 to the output port processor 16 until notified by the output port processor 16 that output buffers are available for a corresponding connection.
The "DO NOT SEND" type feedback messages also halt the transmission of data cells from an input port processor 14 to an output port processor 16 when sufficient buffer space is not available to receive data cells in the output port processor 16. In such a case, an input port processor 14 will not transmit any data cells through the Data Crossbar 10. An idle cell, containing a complemented cyclic redundancy check (CRC) calculation, is transmitted instead.
The XON Crossbar 46, which in this particular embodiment is an N x N crosspoint switch, is used to communicate "ENABLE SEND" type feedback messages from an output port processor 16 to an input port processor 16. More particularly, the XON Crossbar 46 communicates an XON feedback message from an output port processor 16 to an input port processor 14. When an XOFF feedback message has been asserted by an output port processor 16 in response to a request probe message from an input port processor 14, the output port processor 16 sets a state bit in a queue descriptor of a corresponding output queue 28. When the number of data cells in that output queue 28 drops below an XON threshold, an XON message is sent from that output port processor 16 to the input port processor 14. The XON message enables the scheduling list 47 in the input port processor 14 to be used in the sending of request probe messages, and hence data cells.
The Probe & XOFF communication paths operate in a pipelined fashion. First, an input port processor 14 selects a scheduling list 47, and information associated with that scheduling list 47 is used to determine the output port processor 16, or the output queue 28, to which a data cell will be transmitted. More particularly, a multiqueue number. which is derived from information provided to an MTC 18 from a scheduling list 47 in an input port processor 14, is transmitted from the MTC 18 to one or more output port processors 16 using the Probe Crossbar 42. Each output port processor 16 then tests for buffer availability and asserts a "DO NOT SEND" type feedback message through the XOFF Crossbar 44 if output buffering is not available for that connection. If output buffering is available for that connection, the input port processor 14 transmits a data cell to one or more output queues 28 through the Data Crossbar 10.
Each input port processor 14 within the switch 1 also includes a Switch Allocation Table (SAT) 20 for mapping bandwidth allocation. SAT's 20 are the basic mechanism behind the scheduling of data cells. Each SAT 20 includes a plurality of sequentially ordered cell time slots 50 and a pointer 52 which is always directed to one of the cell time slots 50. All of the pointers 52 in the switch 1 are synchronized such that at any given point in time each of the pointers 52 is directed to the same cell time slot 50 in the respective SAT 20 with which the pointer 52 is associated, e.g., the first cell time slot. In operation, the pointers 52 are advanced in lock-step, with each cell time slot 50 being active for 32 clock cycles at 50 MHz. When a pointer 52 is directed toward a cell time slot 50, an input port processor 14 uses the corresponding entry 51 in the cell time slot 50 to obtain a data cell for launching into the Data Crossbar 10.
If valid, the contents of each SAT entry 51 point to a scheduling list 47. The contents of each (non-empty) entry in a scheduling list 47 consists of an input queue number. Each input queue number points to a input queue descriptor which contains state information that is specific to a particular connection. Each input queue descriptor, in turn, points to the head and the tail of a corresponding input queue 26, which contains data cells for transmission through the Data Crossbar 10. If a SAT entry 51 does not contain a pointer to a scheduling list, i.e. the SAT entry 51 is set to zero, then the corresponding cell time slot 50 in the SAT 20 has not been allocated and that cell time slot 50 is available for dynamic bandwidth. Also, if a SAT entry 51 does contain a pointer to a scheduling list 47 but no input queue number is listed in scheduling list 47, then there are no data cells presently available for transmission and the corresponding cell time slot 50 is also available for dynamic bandwidth. Any bandwidth that has not been allocated is referred to as dynamic bandwidth, which is granted to certain types of connections by the BA 12 so as to increase the efficiency of the switch 1.
The switch 1 is configured to allow connections having different quality of service attributes to be managed in such a way that there is no interference between the characteristics of any connection with any other connection. In order to achieve this capability, an input port processor 14 manages each connection with a set of data structures that are unique for each connection.
There are two major data structures used by an input port processor 14 for managing different resources. One data structure is the input queue 26 and the other data structure is the scheduling list 47. In general, an input queue 26 is used to manage buffers. An input queue 26 consists of a group of one or more buf ers organized as a FIFO and manipulated as a linked list structure using pointers. Incoming data cells 22 are added (enqueued) to the tail of an input queue 26. Data cells which are sent to the Data
Crossbar 10 are removed (dequeued) from the head of an input queue 26. The ordering of data cells is always maintained. For a given connection, the sequence of data cells that are sent to the Data Crossbar 10 is identical to that in which they arrived at an input port processor 14, although the time interval between departing data cells may be different than the time interval between arriving data cells. Fig. 2 illustrates the structure of an input queue 26. A scheduling list 47 is used to manage bandwidth. A scheduling list 47 consists of one or more input queue numbers organized as a circular list. As with input queues 26, scheduling lists 47 are manipulated as a linked list structure using pointers. Input queue numbers are added to the tail of a scheduling list 47 and removed from the head of a scheduling list 47. An input queue number can only appear once on any given scheduling list 47. In addition to being added and removed, input queue numbers can be recirculated on a scheduling list 47 by removing the input queue number from the head of the scheduling list 47 and then adding the removed input queue number back onto the tail of the scheduling list 47. This results in round-robin servicing of input queues 26 on a particular scheduling list 47. Fig. 3 illustrates the structure of a scheduling list 47.
When a data cell 22 is received at an input port processor 14, the first action performed by the input port processor 14 is to check the header of the data cell for errors and then to check that the data cell is associated with a valid connection. Cell header integrity is verified by computing a Header Error Check (HEC) on bytes in the header of a received data cell and then comparing the computed HEC to the HEC field in the header of the received data cell. If the computed HEC and the HEC field do not match, then there is a header error and the data cell will be dropped.
For each incoming data cell, an input port processor 14 will use VPI/VCI fields specified in the header of the data cell as an index into a translation table in the input port processor 14. The translation table correlates valid connections and input queue numbers. The input port processor 14 first checks to see if the data cell belongs to a valid connection; i.e. one that has been set up by switch control software. If the connection is valid, then the data cell will be assigned an input queue number from the translation table. If the connection is not valid, then the data cell will either be dropped or be assigned an exception input queue number from the translation table, which results in further processing of the data cell.
While the data cell is being checked, it is converted from a standard data bus format into a internal switch data cell format. Fig. 4 shows the standard data bus format of a data cell. Fig. 5 shows the internal switch data cell format of a converted data cell.
As previously described, an input queue number is used to point to a queue descriptor, which is a data structure containing state information that is unique to a particular connection. There is a queue descriptor for each queue in the switch 1; i.e. for both the input queues 26 in the input port processor 14 and the output queues 28 in the output port processor 16. The queue descriptors are maintained by switch control software. Fig. 6 shows the format of an input queue descriptor. Fig. 7 shows the format of an output queue descriptor.
After a data cell is assigned an input queue number, the input port processor 14 will look at the corresponding queue descriptor for further information on how to process the data cell. The input port processor 14 will first try to assign a buffer for the data cell. If a buffer is available, then the data cell buffer number is enqueued to the tail of the queue and the data cell is written out to the cell buffer RAM 32. If there is no buffer available, the data cell is dropped and a statistic is updated.
In addition to processing and buffering incoming streams of data cells, the input port processor 14 must transfer data cells from a cell buffer to one or more output port processors 16 through the Data Crossbar 10. The transfer of the data cells is performed through the use of the Probe Crossbar 20, the XOFF Crossbar 24, and the Data Crossbar 10, as previously described. Specifically, a multiqueue number, which is derived from information provided to an MTC 18 from a scheduling list 47 in an input port processor 14, is transmitted from the MTC 18 to one or more output port processors 16 using the Probe Crossbar 42. Each output port processor 16 then tests for buffer availability and asserts a "DO NOT SEND" type feedback message through the XOFF Crossbar 44 if output buffering is not available for that connection. If output buffering is available for that connection, the input port processor 14 transmits a data cell to one or more output queues 28 through the Data Crossbar 10. However, before any data cells are enqueued into any output queue 28, the output port processor 16 processes each data cell based on information contained in the trailer of the converted data cell.
Referring particularly to Figs. 6 and 7, the input queue descriptor and the output queue descriptor both include a connection identification (Conn ID) field 60. This field 60 contains an arbitrary code that is assigned by the switch control software indicating 1 of 8 possible data flow paths upon which to perform a cell mask. When processing a data cell, an input port processor 14 will insert the code from the connection identification field 60 of the input queue descriptor into a similar connection identification (Conn ID) field 62 in the converted data cell (see Fig. 6) . The converted data cell also includes an ingress port number field 64, indicating the number of the input port processor 14 where the data cell 22 was received, and an ingress link number field 66, indicating the number of the input link 24 that the data cell 22 arrived on. Note that the output queue descriptor also contains an "echo" field 68 for a 2-bit code which indicates what action that an output port processor 16 should take when processing a data cell transmitted from an input port processor 14, as will be described in detail below. The code in the echo field 68 is also assigned by the switch control software.
For every data cell transmitted from an input port processor 14, an output port processor 16 processes the data cell by comparing its own port number, link number, and connection identification code to the port number, link number, and connection identification code of the converted data cell. In conjunction with the 2-bit code in the echo field 68 of the output queue descriptor, this comparison is used to decide whether or not to enqueue the data cell arriving at a corresponding output queue 28.
Referring to Fig. 8, there is shown a table indicating the different echo field codes and the corresponding output port processor functions associated with those codes. For example, if the echo field 68 in the output queue descriptor is set to "00", the output port processor 16 will always enqueue the data cell. In contrast, if the echo field 68 in the output queue descriptor is set to "11", the output port processor 16 will never enqueue the data cell. More importantly, however, are the actions of the output port processor 16 when the echo field 68 in the output queue descriptor is set to "01" or "10". More specifically, echo processing of data cells received by an output port processor 16 conserves resources in the switch 1 in a multipoint-to- multipoint switching scenario.
To illustrate the aforementioned conservation of switching resources in a multipoint-to-multipoint switching scenario, it must be understood that a switch 1 is often used within a network of similar switches wherein data cells are routed through the network. In a multipoint-to-multipoint switching scenario, data cells from a variety of sources are transferred from multiple input queues 26 to multiple output queues 28 within a switch 1. In such a scenario, it is often beneficial to eliminate duplicate processing of data cells or to otherwise prevent the flow of certain data cells through a switch 1 so as to free up valuable switching resources. Echo processing of data cells received by an output port processor 16 achieves this objective by essentially screening converted data cells according to the port number, link number, and connection identification code contained in the converted data cells.
When the echo field 68 in the output queue descriptor is set to "01", a "No Echo" situation, the output port processor 16 will always enqueue the data cell unless the port number, the link number, and the connection identification code of the data cell match the port number, link number, and connection identification code of the output port processor 16. Alternatively, when the echo field 68 in the output queue descriptor is set to "10", an "Only Echo" situation, the output port processor 16 will enqueue the data cell only if the port number, the link number, and the connection identification code of the data cell match the port number, link number, and connection identification code of the output port processor 16.
Referring to Fig. 9, there is shown an example of a "No Echo" multipoint-to-multipoint switching scenario, wherein a plurality of data cells (A, B, C, and D) are being transmitted from a corresponding plurality of sources (Tl, T2, T3, and SI) to a plurality of destinations (Rl, R2, R3, and S2) . More specifically, Tl, T2, and T3 denote end station transmitters, Rl, R2, and R3 denote end station receivers, and SI and S2 denote other switching elements within a network. The data cells are received by input port processors 14a and 14b, where they are processed and enqueued in input queues 26a, 26b, 26c, and 26d. Input port processor 14a and output port processor 16a have the same port number, and input port processor 14b and output port processor 16b have the same port number. Links 24a, 24c, 30a, and 30c all have the same link number, and links 24b, 24d, 30b, and 30d all have the same link number. All of the input queues 26 and output queues 28 have been assigned an arbitrary connection identification code of 6.
As previously described, the processing of the data cells includes amending the trailer in each data cell to include an arbitrary connection identification code, a link number, and a port number. In this particular example, data cell A is assigned an arbitrary connection identification code of 6, a link number of 24a, and a port number of 14a. Similarly, data cell B has been assigned an arbitrary connection identification code of 6, a link number of 24b, and a port number of 14a, data cell C has been assigned an arbitrary connection identification code of 6, a link number of 24c, and a port number of 14b; data cell D has been assigned an arbitrary connection identification code of 6, a link number of 24d, and a port number of 14b. For each data cell, multiqueue numbers are transmitted simultaneously to the output port processors 16a and 16b, whereby each output port processor 16a and 16b tests for buffer availability, i.e. output port processor 16a tests output queues 28a and 28b for buffer availability, and output port processor 16b tests output queues 28c and 28d for buffer availability. If sufficient buffering is available, the data cells are then transmitted through the Data Crossbar 10 and the data cells are processed by the corresponding output port processors 16a and 16b.
In the "No Echo" scenario, the output port processors 16a and 16b will enqueue the data cells unless the port number, the link number, and the connection identification code of the data cells match the port number, link number, and connection identification code of the output port processors 16a and 16b. Thus, output queue 28a will enqueue data cells B, C, and D, output queue 28b will enqueue data cells A, C, and D, output queue 28c will enqueue data cells
A, B, and D, and output queue 28d will enqueue data cells A,
B, and C.
Connection identification codes provide another control to screen sources or destinations from transmitting or receiving, respectively. This augments the physical port and link number screening.
As illustrated above, echo processing allows each output queue 28a-d to receive data cells from a different set of sources while utilizing a single set connection resources, namely input queues 26a-d, scheduling lists 47, and output queues 28a-d. Echo processing thus allows valuable switching resources to become unencumbered in a network switch involved in a multipoint-to-multipoint switching scenario. It will be understood that various changes and modifications to the above described method and apparatus may be made without departing from the inventive concepts disclosed herein. Accordingly, the present invention is not to be viewed as limited to the embodiment described herein.

Claims

CLAIMS What is claimed is:
1. A method for unencumbering valuable switching resources in a network switch, wherein network switch has an input processing port and an output processing port connected to a plurality of links and having a plurality of data buffering queues, wherein each of said data buffering queues has a connection identification code, and wherein said data buffering queues in said output processing port have a data cell processing code, said method comprising the steps of: receiving a data cell at an output processing port, said data cell containing a link number indicating an input link where said data cell arrived, a port number indicating an input processing port where said data cell was received, and a connection identification code associated with an data buffering queue in said input processing port where said data cell was buffered; comparing said link number to a link number of a link connected to said output processing port, said port number to a port number of said output processing port, and said connection identification code to a connection identification code associated with a data buffering queue in said output processing port; and storing said data cell in said data buffering queue in said output processing port according to a matching scheme between said link numbers, said port numbers, and said connection identification codes as dictated by the value of said data cell processing code.
2. The method as defined in claim 1, wherein said matching scheme requires that said link numbers, said port numbers, and said connection identification codes match in order for said data cell to be stored in said data buffering queue.
3. The method as defined in claim 1, wherein said matching scheme requires that said link numbers, said port numbers, and said connection identification codes do not match in order for said data cell to be stored in said data buffering queue.
4. A method for unencumbering valuable switching resources in a network switch, wherein network switch has an input processing port and an output processing port connected to a plurality of links and having a plurality of data buffering queues, wherein each of said data buffering queues has a connection identification code, and wherein said data buffering queues in said output processing port have a data cell processing code, said method comprising the steps of: receiving a data cell at an output processing port, said data cell containing a link number indicating an input link where said data cell arrived, a port number indicating an input processing port where said data cell was received, and a connection identification code associated with an data buffering queue in said input processing port where said data cell was buffered; and processing said data cell according to a matching scheme, as dictated by the value of said data cell processing code, between said link number and a link number of a link connected to said output processing port, said port number and a port number of said output processing port, and said connection identification code and a connection identification code associated with a data buffering queue in said output processing port.
5. The method as defined in claim 4, wherein said step of processing said data cell comprises storing said data cell in said data buffering queue in said output processing port when said link numbers, said port numbers, and said connection identification codes match.
6. The method as defined in claim 4, wherein said step of processing said data cell comprises storing said data cell in said data buffering queue in said output processing port when said link numbers, said port numbers, and said connection identification codes do not match.
7. An network switch that is capable of unencumbering valuable switching resources within the network switch, said network switch comprising: a switch fabric; an input processing port connected between a plurality of input links and said switch fabric and having a plurality of data buffering queues, wherein each of said data buffering queues has a connection identification code, wherein said input processing port processes a data cell received on one of said plurality of input links by appending to said data cell a link number indicating an input link where said data cell arrived, a port number indicating said input processing port, and a connection identification code associated with a data buffering queue in said input processing port where said data cell will be buffered; and an output processing port connected between said switch fabric and a plurality of output links and having a plurality of data buffering queues, wherein each of said data buffering queues has a connection identification code, wherein said data buffering queues in said output processing port have a data cell processing code, wherein said output processing port processes a data cell processed by said input processing port and transferred to said output processing port through said switch fabric by comparing said link number to a link number of a link connected to said output processing port, said port number to a port number of said output processing port, and said connection identification code to a connection identification code associated with a data buffering queue in said output processing port, and then storing said data cell in said data buffering queue in said output processing port according to a matching scheme between said link numbers, said port numbers, and said connection identification codes as dictated by the value of said data cell processing code.
8. The network switch as defined in claim 7, wherein said output processing port matching scheme requires that said link numbers, said port numbers, and said connection identification codes match in order for said data cell to be stored in said data buffering queue.
9. The network switch as defined in claim 7, wherein said output processing port matching scheme requires that said link numbers, said port numbers, and said connection identification codes do not match in order for said data cell to be stored in said data buffering queue.
PCT/US1996/011918 1995-07-19 1996-07-18 Multipoint to multipoint processing in a network switch having data buffering queues WO1997004541A2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP50686497A JP2002516038A (en) 1995-07-19 1996-07-18 Multipoint-to-multipoint echo processing in a network switch
AU65008/96A AU6500896A (en) 1995-07-19 1996-07-18 Multipoint-to-multipoint echo processing in a network switch
PCT/US1996/011918 WO1997004541A2 (en) 1995-07-19 1996-07-18 Multipoint to multipoint processing in a network switch having data buffering queues

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US149895P 1995-07-19 1995-07-19
US60/001,498 1995-07-19
PCT/US1996/011918 WO1997004541A2 (en) 1995-07-19 1996-07-18 Multipoint to multipoint processing in a network switch having data buffering queues

Publications (2)

Publication Number Publication Date
WO1997004541A2 true WO1997004541A2 (en) 1997-02-06
WO1997004541A3 WO1997004541A3 (en) 1997-03-20

Family

ID=38659409

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1996/011918 WO1997004541A2 (en) 1995-07-19 1996-07-18 Multipoint to multipoint processing in a network switch having data buffering queues

Country Status (3)

Country Link
JP (1) JP2002516038A (en)
AU (1) AU6500896A (en)
WO (1) WO1997004541A2 (en)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5179558A (en) * 1989-06-22 1993-01-12 Digital Equipment Corporation Routing apparatus and method for high-speed mesh connected local area network
US5191582A (en) * 1991-08-14 1993-03-02 Transwitch Corporation Method and apparatus for the high speed modification of a packet address field of a transmitted packet in a frame relay system
US5440547A (en) * 1993-01-07 1995-08-08 Kabushiki Kaisha Toshiba Data-transfer routing management for packet-oriented digital communication system including ATM networks
US5519690A (en) * 1993-11-08 1996-05-21 Hitachi, Ltd. Communication control apparatus having function for limiting frame reception and switching system with the same
US5533020A (en) * 1994-10-31 1996-07-02 International Business Machines Corporation ATM cell scheduler

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5179558A (en) * 1989-06-22 1993-01-12 Digital Equipment Corporation Routing apparatus and method for high-speed mesh connected local area network
US5191582A (en) * 1991-08-14 1993-03-02 Transwitch Corporation Method and apparatus for the high speed modification of a packet address field of a transmitted packet in a frame relay system
US5440547A (en) * 1993-01-07 1995-08-08 Kabushiki Kaisha Toshiba Data-transfer routing management for packet-oriented digital communication system including ATM networks
US5519690A (en) * 1993-11-08 1996-05-21 Hitachi, Ltd. Communication control apparatus having function for limiting frame reception and switching system with the same
US5533020A (en) * 1994-10-31 1996-07-02 International Business Machines Corporation ATM cell scheduler

Also Published As

Publication number Publication date
WO1997004541A3 (en) 1997-03-20
JP2002516038A (en) 2002-05-28
AU6500896A (en) 1997-02-18

Similar Documents

Publication Publication Date Title
US5933429A (en) Multipoint-to-multipoint echo processing in a network switch
US5166930A (en) Data channel scheduling discipline arrangement and method
US5926459A (en) Rate shaping in per-flow queued routing mechanisms for available bit rate service
EP0785699B1 (en) Multicast routing in multistage networks
US6377583B1 (en) Rate shaping in per-flow output queued routing mechanisms for unspecified bit rate service
US6064677A (en) Multiple rate sensitive priority queues for reducing relative data transport unit delay variations in time multiplexed outputs from output queued routing mechanisms
US6768717B1 (en) Apparatus and method for traffic shaping in a network switch
EP0839422B1 (en) Linked-list structures for multiple levels of control in an atm switch
EP0839420A4 (en) Allocated and dynamic bandwidth management
EP0817435B1 (en) A switch for a packet communication system
WO1997004541A2 (en) Multipoint to multipoint processing in a network switch having data buffering queues
EP0817432B1 (en) A packet switched communication system
EP0817434A2 (en) A packet switched communication system and traffic shaping process
JP4504606B2 (en) Apparatus and method for shaping traffic in a network switch
WO1997004542A2 (en) Multipoint-to-point arbitration in a network switch
WO1997004562A1 (en) Point-to-multipoint arbitration
WO1997004570A1 (en) Controlling bandwidth allocation using a pace counter
WO1997004565A9 (en) Priority arbitration for point-to-point and multipoint transmission
JPH11510327A (en) Asynchronous transfer mode based service integrated exchange
WO1997004565A1 (en) Priority arbitration for point-to-point and multipoint transmission

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AL AM AT AU AZ BB BG BR BY CA CH CN CZ DE DK EE ES FI GB GE HU IL IS JP KE KG KP KR KZ LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK TJ TM TR TT UA UG US UZ VN AM AZ BY KG KZ MD RU TJ TM

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): KE LS MW SD SZ UG AT BE CH DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA

AK Designated states

Kind code of ref document: A3

Designated state(s): AL AM AT AU AZ BB BG BR BY CA CH CN CZ DE DK EE ES FI GB GE HU IL IS JP KE KG KP KR KZ LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK TJ TM TR TT UA UG US UZ VN AM AZ BY KG KZ MD RU TJ TM

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): KE LS MW SD SZ UG AT BE CH DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA

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

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: CA