WO1997004565A1 - Priority arbitration for point-to-point and multipoint transmission - Google Patents

Priority arbitration for point-to-point and multipoint transmission Download PDF

Info

Publication number
WO1997004565A1
WO1997004565A1 PCT/US1996/011945 US9611945W WO9704565A1 WO 1997004565 A1 WO1997004565 A1 WO 1997004565A1 US 9611945 W US9611945 W US 9611945W WO 9704565 A1 WO9704565 A1 WO 9704565A1
Authority
WO
WIPO (PCT)
Prior art keywords
point
multipoint
data
bandwidth
request
Prior art date
Application number
PCT/US1996/011945
Other languages
French (fr)
Other versions
WO1997004565A9 (en
Inventor
Thomas A. Manning
Stephen A. Caldara
Stephen A. Hauser
Matthias L. Colsman
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 JP9506882A priority Critical patent/JPH11510011A/en
Priority to AU65026/96A priority patent/AU6502696A/en
Priority to PCT/US1996/011945 priority patent/WO1997004565A1/en
Publication of WO1997004565A1 publication Critical patent/WO1997004565A1/en
Publication of WO1997004565A9 publication Critical patent/WO1997004565A9/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
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • H04L41/0896Bandwidth or capacity management, i.e. automatically increasing or decreasing capacities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • 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
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/10Flow control between communication endpoints
    • H04W28/14Flow control between communication endpoints using intermediate storage
    • 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

  • the present invention is generally related to telecommunications networks, and more particularly to point- to-point and point-to-multipoint arbitration, bandwidth 10 allocation and delay management within an asynchronous transfer mode switch.
  • ATM networks are used for transfer of audio, video and other data.
  • ATM networks deliver data by routing data units such as ATM cells from source to destination through switches.
  • Switches include input/output (“I/O”) ports through which ATM cells are received and
  • the appropriate output port for transmission of the cell is determined based on the cell header.
  • switches typically have buffers at either the inputs or outputs of the switch for temporarily storing cells prior to transmission.
  • buffer space may be inadequate and data lost. If the buffer size is insufficient, cells are
  • a cell In point-to-point transmission a cell is transmitted from a single input port to a single output port across the switch fabric. In point-to-multipoint transmission a cell is transmitted from a single input to multiple outputs across the switch fabric.
  • each of the designated outputs In order to execute such a transmission, each of the designated outputs must be available to receive the cell from the transmitting input, i.e. , have adequate buffer space. However, the likelihood that each of the designated outputs will be simultaneously prepared to receive the cell when the cell is enqueued decreases as traffic within the switch increases. In some circumstances this may result in delayed transmission. In the worst case, cells will be delayed indefinitely and incoming cells for that connection are discarded. It would therefore be desirable to facilitate transmission by reducing or eliminating delays and cell loss.
  • the ATM switch includes a bandwidth arbiter, a plurality of input ports including one To Switch Port Processor (“TSPP”) per input port and a plurality of output ports.
  • Each input port within the switch includes a switch allocation table ("SAT") which grants bandwidth to connections.
  • Each SAT includes a plurality of sequentially ordered cell time slots and a pointer which is directed to one of the slots.
  • the SAT pointers at each input port are synchronized such that, at any given point in time, each of the pointers is directed to the same slot location in the respective SAT with which the pointer is associated.
  • Each TSPP maintains a list of point-to-point connections, and more particularly maintains one such list for each output port in the switch.
  • the bandwidth arbiter maintains a bit vector for each port indicating requested output ports for transmission of point-to-point cells.
  • Each connection is assigned bandwidth types based on the traffic type associated with the connection.
  • bandwidth There are two types of bandwidth to grant within the switch: allocated and dynamic.
  • Allocated bandwidth is bandwidth which is "reserved" for use by the connection to which the bandwidth is allocated.
  • a connection with allocated bandwidth is guaranteed access to the full amount of bandwidth allocated to that connection.
  • traffic types that need deterministic control of delay are assigned allocated bandwidth.
  • Dynamic bandwidth is bandwidth which is "shared" by any of various competing connections. Because dynamic bandwidth is a shared resource, there is generally no guarantee that any particular connection will have access to a particular amount of bandwidth. For this reason dynamic bandwidth is typically assigned to connections with larger delay bounds. Other connections may be assigned a combination of dynamic and allocated bandwidth. Any cell time where the SAT entry is not valid or where the scheduling list does not contain a cell thus represents an unassigned bandwdith opportunity.
  • the switch To execute point-to-point operation the switch employs the point-to-point request bit vectors and round robin operations to grant dynamic bandwidth to point-to-point connections.
  • matches are determined in parallel for each bit in each selected request bit vector and granting is then executed according to a prioritization scheme begining at a first position. Granting opportunities are then provided to the other request bit vectors until granting opportunities have been provided for each request bit vector. A second position indicates an individual bit which receives priority for the granting opportunity. If bandwdith is not granted, granting opportunities are then provided to the other bits in the request bit vector.
  • the first position In the next cell time the first position is then at the next sequential request bit vector relative to the previous cell time if the output port designated by a second position was granted. Otherwise the first position is unchanged. In this manner each TSPP receives equal treatment over time.
  • the bandwidth arbiter To execute point-to-multipoint operation the bandwidth arbiter maintains a list of connections and bit vectors indicating the designated destination ports for a point-to- multipoint cell. The bandwidth arbiter list is then compared to an unassigned output port bit vector generated from the SATs to determine matches therebetween at which point-to- multipoint transmission may be made by utilizing the instantaneously unused bandwidth within the switch. The bandwidth arbiter may also assign priority to connections in the list.
  • the bandwidth arbiter may also include a combined arbiter mechanism for allocating dynamic bandwidth for both point-to-multipoint and point-to-point connections.
  • each type of connection i.e., point-to- multipoint and point-to-point
  • Dynamic bandwidth is then granted in four main steps.
  • dynamic bandwidth is granted to HI priority point-to-multipoint connections in the manner described above.
  • dynamic bandwidth remaining from the first step is granted to the HI priority point-to-point connections in the manner described above.
  • the bandwidth remaining from the second step is granted to the LO priority point-to-multipoint connections.
  • the bandwidth remaining from the third ⁇ tep is granted to the LO priority point-to-point connection ⁇ .
  • Switch efficiency is increased by utilizing instantaneously unused bandwidth.
  • available bandwidth decreases.
  • unutilized bandwidth will be present from time to time, and such bandwidth is wasted if not utilized. Therefore, point- to-point and point-to-multipoint transmissions which would otherwise be dropped are made using the otherwise unutilized bandwidth, and switch efficiency is increased. Such use is made possible by the arbitration techniques which reduce delay.
  • Fig. 1 is a block diagram of a switch which facilitates point-to-multipoint operation
  • Fig. 2 is a block diagram which illustrates operation of the switch allocation tables of Fig. 1;
  • Fig. 3 is a block diagram which illustrates operation of the bandwidth arbiter list
  • Fig. 4 is a flow diagram which illustrates matching between the request bit vectors and the unas ⁇ igned output port bit vector
  • Fig. 5 is a block diagram which illustrates round-robin allocation of bandwidth to TSPP requests
  • Fig. 6 is a flow diagram which illustrates a method of point-to-multipoint bandwidth arbitration
  • Figs. 7 & 8 are block diagrams which illustrates point- to-point bandwidth arbitration
  • Fig. 9 is block diagram which illustrates combined point-to-point and point-to-multipoint bandwidth arbitration; and Figs. 10A and 10B are flow diagrams which illustrate a method for combined point-to-point and point-to-multipoint bandwidth arbitration.
  • the switch includes an NxN switch fabric 10, a bandwidth arbiter 12, a plurality of to switch port processor subsystems ("TSPP") 14, a plurality of To Switch Port Processor ASIC ⁇ 15, a plurality of from switch port processor subsystems ("FSPP") 16, a plurality of To Switch Port Processor ASICs 17, a plurality of multipoint topology controllers (“MTC”) 18 and a plurality of switch allocation tables ("SAT") 20.
  • the NxN switch fabric which may be an ECL crosspoint switch fabric, is used for cell data transport, and yields Nx670 Mbps throughput.
  • the bandwidth arbiter controls switch fabric interconnection dynamically schedules momentarily unused bandwidth and resolves multipoint-to-point bandwidth contention.
  • Each TSPP 14 schedules transmission of cells 22 to the switch fabric from multiple connections. Not shown are the physical line interfaces between the input link and the TSPP 14.
  • the FSPP receives cells from the switch fabric and organizes those cells onto output links. Not shown are the physical line interfaces between the output link and the FSPP 16.
  • the switch allocation table controls crossbar input to output mapping, connection bandwidth and the maximum delay through the switch fabric.
  • a cell 22 In order to traverse the switch, a cell 22 first enters the switch through an input port 24 and is buffered in a queue 26 of input buffers. The cell is then transmitted from the input buffer ⁇ to a queue 28 of output buffer ⁇ in an output port. From the output port 30, the cell is transmitted outside of the switch, for example, to another switch.
  • each input port 24 includes a TSPP 14, and each output port 30 includes an FSPP 16.
  • the TSPPs and FSPPs each include cell buffer RAM 32 which is organized into queues 26, 28. All cells in a connection pass through a ⁇ ingle queue at each port, one at the TSPP and one at the FSPP, for the life of the connection.
  • the queue ⁇ thu ⁇ preserve cell ordering by handling only one connection per queue. This strategy al ⁇ o allow ⁇ quality of service (“QoS”) guarantees on a per connection basi ⁇ .
  • QoS quality of service
  • TSPP and FSPP to implement flow control.
  • Flow control prevents cell los ⁇ within the switch, and is performed after arbitration, but before transmission of the data cell.
  • Flow control is implemented on a per connection basi ⁇ .
  • each TSPP within the switch includes an SAT 20 which manages bandwidth allocation.
  • the SAT is the basic mechanism behind cell scheduling.
  • Each SAT 20 includes a plurality of sequentially ordered cell time slots 50 and a pointer 52 which is directed to one of the slots. All of the pointers in the switch are synchronized such that at any given point in time each of the SAT pointers at each input port is directed to the same slot location in the respective SAT with which the pointer is as ⁇ ociated, e.g., the fir ⁇ t slot.
  • the pointers are advanced in lock-step, each slot being active for 32 clock cycles at 50 MHz.
  • the TSPP uses the corresponding entry 51 in the SAT to obtain a cell for launching into the switch fabric 10 and to begin flow control.
  • Each of the counters is incremented once for each cell time, and the pointer returns to the first slot after reaching the last slot.
  • the pointers scan the SAT ⁇ approximately every 6msec, thereby providing a maximum delay for transmi ⁇ sion opportunity of approximately 6msec.
  • the delay can be decreased by duplicating a given entry at a plurality of slots within the SAT.
  • the maximum delay that an incoming cell will experience corresponds to the number of slots between the pointer and the slot containing the entry which specifie ⁇ the destination of the cell.
  • the duplicate entrie ⁇ are therefore preferably spaced equidistantly within the SAT.
  • Maximum delay for transmis ⁇ ion opportunity therefore corresponds to the frequency and spacing of duplicate entries within the SAT.
  • the amount of bandwidth granted to a particular connection corresponds to the frequency at which a given entry appears in the SAT.
  • Each slot 50 provides 64Kbps of bandwidth. Since the pointers cycle through the SATs at a constant rate, the total bandwidth granted to a particular connection is equal to the product of 64Kbps and the number of occurrences of that entry. For example, connection identifier "g (4,6)," which occurs in five slots, is granted 320Kbps of bandwidth.
  • in ⁇ tantaneously unused bandwidth 60 will become available in the switch during operation. Such instantaneously unused bandwidth may occur because that bandwidth, i.e., that entry in the SAT, has not been allocated to any connection. Such bandwidth is referred to a ⁇ "unallocated bandwidth.” In ⁇ tantaneously unused bandwidth may also occur when the SAT entry is allocated to a connection, but the connection does not have a cell enqueued for transmission across the switch. Such bandwidth is referred to a ⁇ "unused-allocated" bandwidth. Both type ⁇ of bandwidth are collectively referred to as "dynamic" bandwidth, and some connections, such a ⁇ connections as ⁇ igned an Available Bit Rate (“ABR") QoS level utilize ⁇ uch dynamic bandwidth. The bandwidth arbiter operate ⁇ to increa ⁇ e efficiency within the switch by granting dynamic bandwidth to such connections.
  • ABR Available Bit Rate
  • a connection has no allocated bandwidth, or if the arriving cell rate is greater than the allocated rate as indicated by an input queue threshold, dynamic bandwidth may be employed.
  • the point-to-multipoint transmission described in the SAT entry 51 is entered into a list 53 maintained by the bandwidth arbiter as a "request" in order that the point-to- multipoint transmi ⁇ sion can be made at the next available opportunity.
  • the list 53 maintained by the bandwidth arbiter includes two fields for storing point-to-multipoint transmissions which utilize dynamic bandwidth.
  • a connection identifier field 56 is employed to store the connection identifier, e.g., "a,” and hence also indicates the port of origin.
  • a bit vector field 58 is employed to indicate the designated output port ⁇ for transmission.
  • the bit vector field is a bit mask which, in the case of an 8X8 switch, includes eight bits, each bit corresponding to a specific output port.
  • the list 53 contains "00000110" in the bit vector field (where the port numbers start from “1” rather than "0") .
  • the logic "1" values in the bit vector field indicate destination output ports "2" and “3,” and the logic "0" values indicate non- destination output ports.
  • the connections and bit vectors in the list 53 are entered ⁇ equentially in the order in which they are received.
  • point-to-multipoint connection ⁇ can be divided into ⁇ ub ⁇ ets.
  • the point-to- multipoint bit vector lookup would have an additional identifier indicating which subset to transfer the cell to.
  • the lists maintained at the bbandw3dith arbiter and TSPP would then contain both the connection identifier and the subset identifier.
  • the sub ⁇ et identifier i ⁇ called a ⁇ ubqueue.
  • connection identifier 56 and bit vector 58 corresponding to "a (2,3)" is entered into the list 53 so that the cell will be transmitted when a dynamic bandwidth opportunity become ⁇ available for ⁇ imultaneou ⁇ tran ⁇ mi ⁇ ion to each output port designated by the request.
  • the bandwidth arbiter first calculates an unassigned output port bit vector by ORing all allocated bit vectors from the SAT and toggling each resultant bit to provide a single unassigned output port bit vector.
  • the unassigned output port bit vector is then matched against each request. For a particular input port the entered requests are tested in parallel for a match, and for simplification matching may be made against only the first four requests in the list. If all of the bits in a request match the unassigned bit vector, a match is made.
  • a prioritization technique may be used in conjunction with the matching operation in the bandwidth arbiter in order to support switch traffic having different priority levels, such as QoS levels.
  • priority levels could be HI and LO levels, or include greater than two levels.
  • the bandwidth arbiter attempts to match higher priority requests before attempting to match lower priority request ⁇ . Since the unassigned bit vector contains les ⁇ unassigned bits as each sub ⁇ equent match i ⁇ made, the higher priority requests are then more likely to obtain a match and be transmitted than the lower priority requests. This higher likelihood for a match translates into a quicker response and greater bandwidth for such higher priority connection ⁇ .
  • the bandwidth arbiter may grant bandwidth to requesting TSPPs by attempting to match available bandwidth on a round-robin basis.
  • a pointer 67 is employed to select a TSPP with which matches are first attempted, e.g., TSPP i + 1.
  • HI and LO prioritization When HI and LO prioritization is employed, separate HI and LO round-robin operations are executed to grant bandwidth. Each of the round-robin operations operates in the same fashion, but matching is not attempted on the LO priority requests until a match has been attempted with each of the HI priority request ⁇ . Hence, a ⁇ eparate round robin operation i ⁇ executed for each priority level.
  • Fig. 6 illu ⁇ trate ⁇ a method of point-to-multipoint arbitration.
  • a bit vector representation of the SAT entry is entered 68 into the li ⁇ t as a connection identifier and output bit vector.
  • the allocated bit vector ⁇ are ORed and u ⁇ ed to generate 70 the unassigned bit vector.
  • An attempt is then made to match 72 the unassigned bit vector with request N in the list, where N is the oldest request in the list. If no match is made, N is incremented 74 and an attempt is made to match the unassigned bit vector with request N+l, i.e., the next oldest request in the list.
  • bit vector of the matched request is subtracted 76 from the unassigned bit vector to provide an updated unassigned bit vector.
  • the cell corresponding to the matched request is then transmitted 78, and a determination 80 is made a ⁇ to whether the end of the list maintained by the bandwidth arbiter has been reached. Flow ends if the end of the list has been reached, i.e., an attempt ha ⁇ been made to match the una ⁇ signed bit vector with each request in the list. If the end of the list has not been reached, N is incremented, and an attempt is made to match the next oldest request in the list with the una ⁇ signed bit vector.
  • the bandwidth arbiter 12 may also be employed to grant dynamic bandwidth for point-to- point tran ⁇ mission.
  • Each point-to-point transmission is made from a single input port to a single output port.
  • each TSPP 14 includes a connection list 82 corre ⁇ ponding to each output port in the switch, i.e., one connection li ⁇ t per output port, and the bandwidth arbiter includes a point-to-point request bit vector 84 corresponding to each TSPP in the switch, i.e., one request bit vector per TSPP.
  • connection lists which may be 16,384 deep, include a list of connections having cells enqueued for point-to-point transmission to the output port with which the connection list is associated.
  • Each request bit vector is a per-TSPP bitmask which indicate ⁇ with a logic "1" to which output port each individual TSPP i ⁇ reque ⁇ ting to transmit.
  • the connection lists and request bit vectors are employed to track the output ports for which cells are enqueued in each TSPP, and grant bandwidth based upon that information.
  • the point-to-point request bit vectors are set in response to signals from the TSPPs.
  • connection associated with that cell is loaded into the TSPP connection list and the TSPP send ⁇ a reque ⁇ t message 86 to the bandwidth arbiter containing a request to transmit to the output port specified by the connection.
  • connection "a" when connection "a" is enqueued in connection li ⁇ t 1, TSPP 0 transmits a request message to the bandwidth arbiter, and in response to the request message the bandwidth arbiter sets bit 1 of request bit vector 0 to a logic "1."
  • the bandwidth arbiter sets bit 1 of request bit vector 0 to a logic "1."
  • the bandwidth arbiter ⁇ et ⁇ the bit a ⁇ sociated with the request to a logic "0."
  • the Drop Request message is not sent to the bandwidth arbiter, and the request remain ⁇ in effect for the next enqueued connection.
  • the bandwidth arbiter employ ⁇ the point-to-point request bit vectors and nested round robin operations to grant dynamic bandwidth to point-to-point connections.
  • matches are determined in parallel for each bit in each selected request bit vector and granting is then executed according to a prioritization scheme begining at a first position such as po ⁇ ition 90. Granting opportunities are then provided to the other request bit vectors until granting opportunities have been provided for each request bit vector.
  • a second position 92 indicates an individual bit within the selected request bit vector which receives priority for the granting opportunity. If bandwdith is not granted, granting opportunities are then provided to the other bits in the request bit vector.
  • each TSPP receives equal treatment over time.
  • the bandwidth arbiter may include a combined arbiter mechanism for granting dynamic bandwidth for both point-to-multipoint and point-to-point connections.
  • both point-to- multipoint and point-to-point are prioritized into at least two levels of priority such as HI and LO.
  • Dynamic bandwidth is then granted in four main steps.
  • a first step 94 dynamic bandwidth is granted to HI priority point-to- multipoint connections in the manner de ⁇ cribed with re ⁇ pect to Figs. 1-6 above.
  • the dynamic bandwidth remaining from the first step is granted to the HI priority point-to-point connection ⁇ in the manner described with respect to Figs. 7-8 above.
  • a third step 98 the bandwidth remaining from the ⁇ econd ⁇ tep is granted to the LO priority point-to-multipoint connection ⁇ .
  • a fourth step 100 the bandwidth remaining from the third step is granted to the LO priority point-to-point connections.
  • Figs. 10A and 10B illustrate a method for allocating dynamic bandwidth to both point-to-multipoint and point-to- point connections.
  • a first matching step 102 an attempt is made to match the first HI priority point-to-multipoint request with the unas ⁇ igned output port bit vector representing unassigned output ports, i.e., dynamic bandwidth. If no match i ⁇ made, flow continue ⁇ to ⁇ tep 104 to determine if the end of the point-to-multipoint HI priority list has been reached. If a match is found in step 102, the HI priority point-to-multipoint cell bit vector is subtracted 106 from the una ⁇ signed output port bit vector and the cell is transmitted 108. Flow then continues to step 104. If the end of the list has not been reached, then flow continues to step 110 where the next request is loaded, and flow continue ⁇ at ⁇ tep 102. If the end of the li ⁇ t has been reached, flow continue ⁇ to a second matching step 112.
  • step 112 an attempt i ⁇ made to match the first HI priority point-to-point cell indicated by the first and second pointers. If no match i ⁇ made, flow continue ⁇ to step 114 where a determination is made whether an attempt ha ⁇ been made with each bit in the point-to-point request bit vector for the TSPP indicated by the first pointer. If each bit has not been tested, the second pointer is incremented 116 and flow continues to step 112. If a match is made in step 112, the selected bit is subtracted 118 from the unassigned output port bit vector and the cell is transmitted 120. The first pointer is then incremented 122. A determination is then made in step 124 whether each TSPP has been tested for matches. If not, flow return ⁇ to step 112. If each TSPP has been te ⁇ ted, flow continues to ⁇ tep 126 where the first and second pointers are reset in accordance with the no starvation policy above.
  • step 126 the LO priority point-to-multipoint requests are tested for matche ⁇ .
  • a third matching ⁇ tep 128 an attempt is made to match the first LO priority point- to-multipoint request with the unas ⁇ igned output port bit vector representing una ⁇ igned output ports, i.e., dynamic bandwidth. If no match i ⁇ made, flow continue ⁇ to ⁇ tep 130 to determine if the end of the point-to-multipoint LO priority list has been reached. If a match is found in step 128, the HI priority point-to-multipoint cell bit vector is subtracted 132 from the una ⁇ signed output port bit vector and the cell is transmitted 134. Flow then continues to step 130.
  • step 136 If the end of the li ⁇ t ha ⁇ not been reached, then flow continues to step 136 where the next request i ⁇ loaded, and flow continue ⁇ at ⁇ tep 128. If the end of the li ⁇ t ha ⁇ been reached, flow continues to a fourth matching step 138.
  • step 138 an attempt is made to match the first LO priority point-to-point cell indicated by the first and ⁇ econd pointers. If no match is made, flow continues to step 140 where a determination is made whether an attempt has been made with each bit in the point-to-point request bit vector for the TSPP indicated by the first pointer. If each bit has not been tested, the second pointer is incremented 142 and flow continues to step 138. If a match is made in step 138, the selected bit is subtracted 144 from the unassigned output port bit vector and the cell is transmitted 146. The fir ⁇ t pointer i ⁇ then incremented 148. A determination i ⁇ then made in ⁇ tep 150 whether each TSPP has been tested for matches.

Abstract

An Asynchronous Transfer Mode switch and method which facilitate priority arbitration of point-to-point and point-to-multipoint transmission are disclosed. To execute point-to-multipoint operation a bandwidth arbiter (12) maintains a first list of connections and bit vectors indicating designated destination ports. The list maintained by the bandwidth arbiter is then compared to an unassigned output port bit vector to determine matches therebetween at which point-to-multipoint transmission may be made by utilizing instantaneously unused bandwidth within the switch (18). To execute point-to-point operation, each input port maintains a list of connections associated with each output port, and those lists are used in conjunction with output port request information per input port in the bandwidth arbiter to match requests to the unassigned output port bit vector. The bandwidth arbiter may also assign priority to connections in the list.

Description

PRIORITY ARBITRATION FOR POINT-TO-POINT AND MULTIPOINT TRANSMISSION *5
FIELD OF THE INVENTION The present invention is generally related to telecommunications networks, and more particularly to point- to-point and point-to-multipoint arbitration, bandwidth 10 allocation and delay management within an asynchronous transfer mode switch.
RELATED CASE INFORMATION A claim of priority is made to provisional application 15 60/001,498 entitled COMMUNICATION METHOD AND APPARATUS, filed
July 19, 1995.
BACKGROUND OF THE INVENTION Telecommunications networks such aε asynchronous
20 transfer mode ("ATM") networks are used for transfer of audio, video and other data. ATM networks deliver data by routing data units such as ATM cells from source to destination through switches. Switches include input/output ("I/O") ports through which ATM cells are received and
25 transmitted. The appropriate output port for transmission of the cell is determined based on the cell header.
One problem associated with ATM networks is loss of cells. Cells are buffered within each switch before being routed and transmitted from the switch. More particularly,
30 switches typically have buffers at either the inputs or outputs of the switch for temporarily storing cells prior to transmission. As network traffic increases, there is an increasing possibility that buffer space may be inadequate and data lost. If the buffer size is insufficient, cells are
35 lost. Cell loss causes undesirable interruptions in audio and video data transmissions, and may cause more serious damage to other types of data transmissions.
In point-to-point transmission a cell is transmitted from a single input port to a single output port across the switch fabric. In point-to-multipoint transmission a cell is transmitted from a single input to multiple outputs across the switch fabric. In order to execute such a transmission, each of the designated outputs must be available to receive the cell from the transmitting input, i.e. , have adequate buffer space. However, the likelihood that each of the designated outputs will be simultaneously prepared to receive the cell when the cell is enqueued decreases as traffic within the switch increases. In some circumstances this may result in delayed transmission. In the worst case, cells will be delayed indefinitely and incoming cells for that connection are discarded. It would therefore be desirable to facilitate transmission by reducing or eliminating delays and cell loss.
SUMMARY OF THE INVENTION An Asynchronous Transfer Mode ("ATM") switch and method which facilitate point-to-multipoint and point-to-point transmission is disclosed. The ATM switch includes a bandwidth arbiter, a plurality of input ports including one To Switch Port Processor ("TSPP") per input port and a plurality of output ports. Each input port within the switch includes a switch allocation table ("SAT") which grants bandwidth to connections. Each SAT includes a plurality of sequentially ordered cell time slots and a pointer which is directed to one of the slots. The SAT pointers at each input port are synchronized such that, at any given point in time, each of the pointers is directed to the same slot location in the respective SAT with which the pointer is associated. Each TSPP maintains a list of point-to-point connections, and more particularly maintains one such list for each output port in the switch. The bandwidth arbiter maintains a bit vector for each port indicating requested output ports for transmission of point-to-point cells.
Each connection is assigned bandwidth types based on the traffic type associated with the connection. There are two types of bandwidth to grant within the switch: allocated and dynamic. Allocated bandwidth is bandwidth which is "reserved" for use by the connection to which the bandwidth is allocated. Generally, a connection with allocated bandwidth is guaranteed access to the full amount of bandwidth allocated to that connection. As such, traffic types that need deterministic control of delay are assigned allocated bandwidth. Dynamic bandwidth is bandwidth which is "shared" by any of various competing connections. Because dynamic bandwidth is a shared resource, there is generally no guarantee that any particular connection will have access to a particular amount of bandwidth. For this reason dynamic bandwidth is typically assigned to connections with larger delay bounds. Other connections may be assigned a combination of dynamic and allocated bandwidth. Any cell time where the SAT entry is not valid or where the scheduling list does not contain a cell thus represents an unassigned bandwdith opportunity.
To execute point-to-point operation the switch employs the point-to-point request bit vectors and round robin operations to grant dynamic bandwidth to point-to-point connections. At the start of the cell time, matches are determined in parallel for each bit in each selected request bit vector and granting is then executed according to a prioritization scheme begining at a first position. Granting opportunities are then provided to the other request bit vectors until granting opportunities have been provided for each request bit vector. A second position indicates an individual bit which receives priority for the granting opportunity. If bandwdith is not granted, granting opportunities are then provided to the other bits in the request bit vector. In the next cell time the first position is then at the next sequential request bit vector relative to the previous cell time if the output port designated by a second position was granted. Otherwise the first position is unchanged. In this manner each TSPP receives equal treatment over time.
To execute point-to-multipoint operation the bandwidth arbiter maintains a list of connections and bit vectors indicating the designated destination ports for a point-to- multipoint cell. The bandwidth arbiter list is then compared to an unassigned output port bit vector generated from the SATs to determine matches therebetween at which point-to- multipoint transmission may be made by utilizing the instantaneously unused bandwidth within the switch. The bandwidth arbiter may also assign priority to connections in the list.
The bandwidth arbiter may also include a combined arbiter mechanism for allocating dynamic bandwidth for both point-to-multipoint and point-to-point connections. In the preferred embodiment each type of connection, i.e., point-to- multipoint and point-to-point, is prioritized into at least two levels of priority such as HI and LO. Dynamic bandwidth is then granted in four main steps. In a first step dynamic bandwidth is granted to HI priority point-to-multipoint connections in the manner described above. In a second step the dynamic bandwidth remaining from the first step is granted to the HI priority point-to-point connections in the manner described above. In a third step the bandwidth remaining from the second step is granted to the LO priority point-to-multipoint connections. In a fourth step the bandwidth remaining from the third εtep is granted to the LO priority point-to-point connectionε.
Switch efficiency is increased by utilizing instantaneously unused bandwidth. When εwitch traffic increases, available bandwidth decreases. Neverthelesε, unutilized bandwidth will be present from time to time, and such bandwidth is wasted if not utilized. Therefore, point- to-point and point-to-multipoint transmissions which would otherwise be dropped are made using the otherwise unutilized bandwidth, and switch efficiency is increased. Such use is made possible by the arbitration techniques which reduce delay.
BRIEF DESCRIPTION OF THE DRAWING These and other features and advantages of the present invention will become apparent from the following detailed description of the drawing in which:
Fig. 1 is a block diagram of a switch which facilitates point-to-multipoint operation;
Fig. 2 is a block diagram which illustrates operation of the switch allocation tables of Fig. 1;
Fig. 3 is a block diagram which illustrates operation of the bandwidth arbiter list;
Fig. 4 is a flow diagram which illustrates matching between the request bit vectors and the unasεigned output port bit vector;
Fig. 5 is a block diagram which illustrates round-robin allocation of bandwidth to TSPP requests;
Fig. 6 is a flow diagram which illustrates a method of point-to-multipoint bandwidth arbitration; Figs. 7 & 8 are block diagrams which illustrates point- to-point bandwidth arbitration;
Fig. 9 is block diagram which illustrates combined point-to-point and point-to-multipoint bandwidth arbitration; and Figs. 10A and 10B are flow diagrams which illustrate a method for combined point-to-point and point-to-multipoint bandwidth arbitration.
DETAILED DESCRIPTION OF THE DRAWING Referring now to Fig. 1, the switch includes an NxN switch fabric 10, a bandwidth arbiter 12, a plurality of to switch port processor subsystems ("TSPP") 14, a plurality of To Switch Port Processor ASICε 15, a plurality of from switch port processor subsystems ("FSPP") 16, a plurality of To Switch Port Processor ASICs 17, a plurality of multipoint topology controllers ("MTC") 18 and a plurality of switch allocation tables ("SAT") 20. The NxN switch fabric, which may be an ECL crosspoint switch fabric, is used for cell data transport, and yields Nx670 Mbps throughput. The bandwidth arbiter controls switch fabric interconnection dynamically schedules momentarily unused bandwidth and resolves multipoint-to-point bandwidth contention. Each TSPP 14 schedules transmission of cells 22 to the switch fabric from multiple connections. Not shown are the physical line interfaces between the input link and the TSPP 14. The FSPP receives cells from the switch fabric and organizes those cells onto output links. Not shown are the physical line interfaces between the output link and the FSPP 16. The switch allocation table controls crossbar input to output mapping, connection bandwidth and the maximum delay through the switch fabric.
In order to traverse the switch, a cell 22 first enters the switch through an input port 24 and is buffered in a queue 26 of input buffers. The cell is then transmitted from the input bufferε to a queue 28 of output bufferε in an output port. From the output port 30, the cell is transmitted outside of the switch, for example, to another switch. To facilitate traversal of the switch, each input port 24 includes a TSPP 14, and each output port 30 includes an FSPP 16. The TSPPs and FSPPs each include cell buffer RAM 32 which is organized into queues 26, 28. All cells in a connection pass through a εingle queue at each port, one at the TSPP and one at the FSPP, for the life of the connection. The queueε thuε preserve cell ordering by handling only one connection per queue. This strategy alεo allowε quality of service ("QoS") guarantees on a per connection basiε. Request and feedback messages are transmited between the
TSPP and FSPP to implement flow control. Flow control prevents cell losε within the switch, and is performed after arbitration, but before transmission of the data cell. Flow control is implemented on a per connection basiε.
Referring now to Figs. 1 & 2, each TSPP within the switch includes an SAT 20 which manages bandwidth allocation. The SAT is the basic mechanism behind cell scheduling. Each SAT 20 includes a plurality of sequentially ordered cell time slots 50 and a pointer 52 which is directed to one of the slots. All of the pointers in the switch are synchronized such that at any given point in time each of the SAT pointers at each input port is directed to the same slot location in the respective SAT with which the pointer is asεociated, e.g., the firεt slot. In operation, the pointers are advanced in lock-step, each slot being active for 32 clock cycles at 50 MHz. When the pointer is directed toward a slot, the TSPP uses the corresponding entry 51 in the SAT to obtain a cell for launching into the switch fabric 10 and to begin flow control.
Each of the counters is incremented once for each cell time, and the pointer returns to the first slot after reaching the last slot. Hence, given an SAT depth of 8k, which defines a frame, the pointers scan the SATε approximately every 6msec, thereby providing a maximum delay for transmiεsion opportunity of approximately 6msec. The delay can be decreased by duplicating a given entry at a plurality of slots within the SAT. The maximum delay that an incoming cell will experience corresponds to the number of slots between the pointer and the slot containing the entry which specifieε the destination of the cell. When multiple entries are made in order to decrease the maximum possible number of separating slots, the duplicate entrieε are therefore preferably spaced equidistantly within the SAT. Maximum delay for transmisεion opportunity therefore corresponds to the frequency and spacing of duplicate entries within the SAT.
The amount of bandwidth granted to a particular connection corresponds to the frequency at which a given entry appears in the SAT. Each slot 50 provides 64Kbps of bandwidth. Since the pointers cycle through the SATs at a constant rate, the total bandwidth granted to a particular connection is equal to the product of 64Kbps and the number of occurrences of that entry. For example, connection identifier "g (4,6)," which occurs in five slots, is granted 320Kbps of bandwidth.
Significantly, inεtantaneously unused bandwidth 60 will become available in the switch during operation. Such instantaneously unused bandwidth may occur because that bandwidth, i.e., that entry in the SAT, has not been allocated to any connection. Such bandwidth is referred to aε "unallocated bandwidth." Inεtantaneously unused bandwidth may also occur when the SAT entry is allocated to a connection, but the connection does not have a cell enqueued for transmission across the switch. Such bandwidth is referred to aε "unused-allocated" bandwidth. Both typeε of bandwidth are collectively referred to as "dynamic" bandwidth, and some connections, such aε connections asεigned an Available Bit Rate ("ABR") QoS level utilize εuch dynamic bandwidth. The bandwidth arbiter operateε to increaεe efficiency within the switch by granting dynamic bandwidth to such connections.
Referring now to Figs. 1-3, if a connection has no allocated bandwidth, or if the arriving cell rate is greater than the allocated rate as indicated by an input queue threshold, dynamic bandwidth may be employed. In either situation the point-to-multipoint transmission described in the SAT entry 51 is entered into a list 53 maintained by the bandwidth arbiter as a "request" in order that the point-to- multipoint transmiεsion can be made at the next available opportunity. The list 53 maintained by the bandwidth arbiter includes two fields for storing point-to-multipoint transmissions which utilize dynamic bandwidth. A connection identifier field 56 is employed to store the connection identifier, e.g., "a," and hence also indicates the port of origin. A bit vector field 58 is employed to indicate the designated output portε for transmission. The bit vector field is a bit mask which, in the case of an 8X8 switch, includes eight bits, each bit corresponding to a specific output port. Thus, for the exemplary SAT entry "a (2,3)" the list 53 contains "00000110" in the bit vector field (where the port numbers start from "1" rather than "0") . The logic "1" values in the bit vector field indicate destination output ports "2" and "3," and the logic "0" values indicate non- destination output ports. The connections and bit vectors in the list 53 are entered εequentially in the order in which they are received.
In an alternate implementation, point-to-multipoint connectionε can be divided into εubεets. A cell iε tranεferred to each one of theεe εubεets. The point-to- multipoint bit vector lookup would have an additional identifier indicating which subset to transfer the cell to. The lists maintained at the bbandw3dith arbiter and TSPP would then contain both the connection identifier and the subset identifier. In the current embodiemtn the subεet identifier iε called a εubqueue.
To execute point-to-multipoint operation of cellε deεcribed in the list maintained by the bandwidth arbiter the bandwidth arbiter tests for matches between the list and dynamic bandwidth. More particularly, the connection identifier 56 and bit vector 58 corresponding to "a (2,3)" is entered into the list 53 so that the cell will be transmitted when a dynamic bandwidth opportunity becomeε available for εimultaneouε tranεmiεεion to each output port designated by the request. Referring now to Figs. 1-4, to determine matches between the requests in the list maintained by the bandwidth arbiter and available bandwidth, the bandwidth arbiter first calculates an unassigned output port bit vector by ORing all allocated bit vectors from the SAT and toggling each resultant bit to provide a single unassigned output port bit vector. The unassigned output port bit vector is then matched against each request. For a particular input port the entered requests are tested in parallel for a match, and for simplification matching may be made against only the first four requests in the list. If all of the bits in a request match the unassigned bit vector, a match is made. When a match iε made, the request is subtracted from the unassigned bit vector, and the result serves as the new unassigned bit vector which indicates remaining available output ports for matching against other input port request bit vectorε in the liεt. After matching againεt each of the requests, the matched requests are transmitted and the tranεmitted requests are dequeued from the list. A prioritization technique may be used in conjunction with the matching operation in the bandwidth arbiter in order to support switch traffic having different priority levels, such as QoS levels. To implement such prioritization each TSPP defines a priority level for each submitted request. Such priority levels could be HI and LO levels, or include greater than two levels. When prioritization is implemented the bandwidth arbiter attempts to match higher priority requests before attempting to match lower priority requestε. Since the unassigned bit vector contains lesε unassigned bits as each subεequent match iε made, the higher priority requests are then more likely to obtain a match and be transmitted than the lower priority requests. This higher likelihood for a match translates into a quicker response and greater bandwidth for such higher priority connectionε. Referring now to Fig. 5, the bandwidth arbiter may grant bandwidth to requesting TSPPs by attempting to match available bandwidth on a round-robin basis. A pointer 67 is employed to select a TSPP with which matches are first attempted, e.g., TSPP i + 1. After attempting matches with TSPP i + 1 matches are next attempted with TSPP i + 2, and so on ending with TSPP i such that matches are attempted with each TSPP. If the first TSPP (here TSPP i + 1) is able to transmit the cell in the oldest entry (here deεcribed by connection "a") then the pointer 67 beginε with the next TSPP (here TSPP i + 2) at the next cell time. However, if the firεt TSPP is not able to transmit the cell in the oldest entry then the pointer 67 begins with the same TSPP (here TSPP i + 1) at the next cell time. When multiple matches are determined for a single TSPP the oldest match iε εelected for tranεmiεεion. Thuε, every point-to-multipoint connection is guaranteed to receive bandwidth.
When HI and LO prioritization is employed, separate HI and LO round-robin operations are executed to grant bandwidth. Each of the round-robin operations operates in the same fashion, but matching is not attempted on the LO priority requests until a match has been attempted with each of the HI priority requestε. Hence, a εeparate round robin operation iε executed for each priority level.
To further inεure that there will be opportunities for point-to-multipoint connections to tranε it, a portion of unassigned bandwidth, i.e., unaεεigned SAT entries, may be put aεide for dedication to point-to-multipoint tranεmiεεions. This technique provides increased opportunity for point-to-multipoint connections which specify a greater number of output ports to be matched and transmitted, and hence no connection will be εtuck by being εtarved for bandwidth.
Fig. 6 illuεtrateε a method of point-to-multipoint arbitration. In a firεt step a bit vector representation of the SAT entry is entered 68 into the liεt as a connection identifier and output bit vector. In the next cell time, the allocated bit vectorε are ORed and uεed to generate 70 the unassigned bit vector. An attempt is then made to match 72 the unassigned bit vector with request N in the list, where N is the oldest request in the list. If no match is made, N is incremented 74 and an attempt is made to match the unassigned bit vector with request N+l, i.e., the next oldest request in the list. If a match is made, the bit vector of the matched request is subtracted 76 from the unassigned bit vector to provide an updated unassigned bit vector. The cell corresponding to the matched request is then transmitted 78, and a determination 80 is made aε to whether the end of the list maintained by the bandwidth arbiter has been reached. Flow ends if the end of the list has been reached, i.e., an attempt haε been made to match the unaεsigned bit vector with each request in the list. If the end of the list has not been reached, N is incremented, and an attempt is made to match the next oldest request in the list with the unaεsigned bit vector.
Referring now to Fig. 7, the bandwidth arbiter 12 may also be employed to grant dynamic bandwidth for point-to- point tranεmission. Each point-to-point transmission is made from a single input port to a single output port. In order to execute point-to-point transmission each TSPP 14 includes a connection list 82 correεponding to each output port in the switch, i.e., one connection liεt per output port, and the bandwidth arbiter includes a point-to-point request bit vector 84 corresponding to each TSPP in the switch, i.e., one request bit vector per TSPP. The connection lists, which may be 16,384 deep, include a list of connections having cells enqueued for point-to-point transmission to the output port with which the connection list is associated. Each request bit vector is a per-TSPP bitmask which indicateε with a logic "1" to which output port each individual TSPP iε requeεting to transmit. Together the connection lists and request bit vectors are employed to track the output ports for which cells are enqueued in each TSPP, and grant bandwidth based upon that information. The point-to-point request bit vectors are set in response to signals from the TSPPs. More particularly, when a cell is enqueued for point-to-point transmisεion the connection associated with that cell is loaded into the TSPP connection list and the TSPP sendε a requeεt message 86 to the bandwidth arbiter containing a request to transmit to the output port specified by the connection. For example, when connection "a" is enqueued in connection liεt 1, TSPP 0 transmits a request message to the bandwidth arbiter, and in response to the request message the bandwidth arbiter sets bit 1 of request bit vector 0 to a logic "1." When the cell is transmitted to the output port, the connection is dequeued from the connection list and, if the connection list thereby empties, a Drop Request 88 message is sent to the bandwidth arbiter. In reεponεe, the bandwidth arbiter εetε the bit aεsociated with the request to a logic "0." However, if the connection list is not emptied as a result of dequeueing the connection, then the Drop Request message is not sent to the bandwidth arbiter, and the request remainε in effect for the next enqueued connection.
Referring now to both Fig. 7 and Fig. 8, the bandwidth arbiter employε the point-to-point request bit vectors and nested round robin operations to grant dynamic bandwidth to point-to-point connections. At the start of the cell time, matches are determined in parallel for each bit in each selected request bit vector and granting is then executed according to a prioritization scheme begining at a first position such as poεition 90. Granting opportunities are then provided to the other request bit vectors until granting opportunities have been provided for each request bit vector. A second position 92 indicates an individual bit within the selected request bit vector which receives priority for the granting opportunity. If bandwdith is not granted, granting opportunities are then provided to the other bits in the request bit vector. In the next cell time the first position iε then at the next εequential requeεt bit vector relative to the previous cell time if the output port designated by the second position 92 was granted. Otherwise the first position is unchanged. The second position starting point is determined similarly. In this manner each TSPP receives equal treatment over time.
Referring now to Fig. 9, the bandwidth arbiter may include a combined arbiter mechanism for granting dynamic bandwidth for both point-to-multipoint and point-to-point connections. In the preferred embodiment both point-to- multipoint and point-to-point are prioritized into at least two levels of priority such as HI and LO. Dynamic bandwidth is then granted in four main steps. In a first step 94 dynamic bandwidth is granted to HI priority point-to- multipoint connections in the manner deεcribed with reεpect to Figs. 1-6 above. In a second step 96 the dynamic bandwidth remaining from the first step is granted to the HI priority point-to-point connectionε in the manner described with respect to Figs. 7-8 above. In a third step 98 the bandwidth remaining from the εecond εtep is granted to the LO priority point-to-multipoint connectionε. In a fourth step 100 the bandwidth remaining from the third step is granted to the LO priority point-to-point connections.
Figs. 10A and 10B illustrate a method for allocating dynamic bandwidth to both point-to-multipoint and point-to- point connections. In a first matching step 102 an attempt is made to match the first HI priority point-to-multipoint request with the unasεigned output port bit vector representing unassigned output ports, i.e., dynamic bandwidth. If no match iε made, flow continueε to εtep 104 to determine if the end of the point-to-multipoint HI priority list has been reached. If a match is found in step 102, the HI priority point-to-multipoint cell bit vector is subtracted 106 from the unaεsigned output port bit vector and the cell is transmitted 108. Flow then continues to step 104. If the end of the list has not been reached, then flow continues to step 110 where the next request is loaded, and flow continueε at εtep 102. If the end of the liεt has been reached, flow continueε to a second matching step 112.
In the second matching step 112 an attempt iε made to match the first HI priority point-to-point cell indicated by the first and second pointers. If no match iε made, flow continueε to step 114 where a determination is made whether an attempt haε been made with each bit in the point-to-point request bit vector for the TSPP indicated by the first pointer. If each bit has not been tested, the second pointer is incremented 116 and flow continues to step 112. If a match is made in step 112, the selected bit is subtracted 118 from the unassigned output port bit vector and the cell is transmitted 120. The first pointer is then incremented 122. A determination is then made in step 124 whether each TSPP has been tested for matches. If not, flow returnε to step 112. If each TSPP has been teεted, flow continues to εtep 126 where the first and second pointers are reset in accordance with the no starvation policy above.
Following step 126 the LO priority point-to-multipoint requests are tested for matcheε. In a third matching εtep 128 an attempt is made to match the first LO priority point- to-multipoint request with the unasεigned output port bit vector representing unaεεigned output ports, i.e., dynamic bandwidth. If no match iε made, flow continueε to εtep 130 to determine if the end of the point-to-multipoint LO priority list has been reached. If a match is found in step 128, the HI priority point-to-multipoint cell bit vector is subtracted 132 from the unaεsigned output port bit vector and the cell is transmitted 134. Flow then continues to step 130. If the end of the liεt haε not been reached, then flow continues to step 136 where the next request iε loaded, and flow continueε at εtep 128. If the end of the liεt haε been reached, flow continues to a fourth matching step 138.
In the fourth matching step 138 an attempt is made to match the first LO priority point-to-point cell indicated by the first and εecond pointers. If no match is made, flow continues to step 140 where a determination is made whether an attempt has been made with each bit in the point-to-point request bit vector for the TSPP indicated by the first pointer. If each bit has not been tested, the second pointer is incremented 142 and flow continues to step 138. If a match is made in step 138, the selected bit is subtracted 144 from the unassigned output port bit vector and the cell is transmitted 146. The firεt pointer iε then incremented 148. A determination iε then made in εtep 150 whether each TSPP has been tested for matches. If not, flow returns to step 138. If each TSPP has been tested, flow continues to step 152 where the firεt and second pointers are reset in accordance with the no starvation policy above. Flow then ends for the cell time. Having described the preferred embodiments of the invention, it will now become apparent to one of skill in the art that other embodiments incorporating their concepts may be used. It is felt therefore that the invention should not be limited to disclosed embodiments, but rather should be limited only by the spirit and scope of the appended claims.

Claims

Claims What is claimed is:
1. A network switch for facilitating point-to-point and point-to-multipoint transmission of units of data associated with connections utilizing unassigned output ports, comprising: a plurality of input ports each operative to recieve units of data from outside said switch and transmit the received units of data to output ports; an allocation map operative to store a representation of dynamic bandwidth within the switch; a point-to-multipoint request map operative to store a representation of unitε of data enqueued for point-to- multipoint transmisεion; a point-to-point request map operative to store a representation of units of data enqueued for point-to-point transmission; and a matching operator which functions to match dynamic bandwidth to said point-to-multipoint requeεt map and said point-to-point request map, whereby units of data enqueued for point-to-point and point-to-multipoint transmission are transmitted when matching dynamic bandwidth becomes available.
2. The network switch of claim 1 wherein said point-to- multipoint request map includes a connection field operative to store a representation of the connection associated with each of the unitε of data enqueued for point-to-multipoint tranεmiεsion.
3. The network switch of claim 2 wherein said point-to- multipoint request map further includes a bit vector field operative to εtore a repreεentation of the output portε to which each point-to-multipoint unit of data is to be transmitted.
4. The network switch of claim 3 wherein said allocation map includes a switch allocation table operative to store an index identifier and an allocation table operative to store a bitmask which represents dynamic bandwidth within the switch, said allocation table indexed by said index identifier.
5. The network switch of claim 1 wherein said matching operator functions to match dynamic bandwidth to each unit of data enqueued for point-to-multipoint tranεmiεsion via dynamic bandwidth sequentially starting from the first enqueued point-to-multipoint unit of data.
6. The network switch of claim 5 wherein the enqueued point-to-multipoint units of data are prioritized into at least two separate groups and said matching operator functionε to match dynamic bandwidth to higher priority groupε prior to matching dynamic bandwidth to lower priority groups.
7. The network switch of claim 3 wherein said matching operator generateε an unaεsigned output port bit vector which iε compared with εaid bit vector field to match dynamic bandwidth with the enqueued point-to-multipoint units of data.
8. The network switch of claim 7 wherein said requeεt map includeε a firεt pointer for indicating the order in which enqueued point-to-multipoint unitε of data are matched to dynamic bandwidth, εaid pointer being incremented to provide a round-robin type ordering of unit of data matching.
9. The network switch of claim 1 wherein each input port includes a To Switch Port Processor ("TSPP") having a connection list of point-to-point connections aεεociated with each output port, said lists of point-to-point connections storing repreεentationε of connectionε having a unit of data enqueued for the reεpective output port with which the respective list is asεociated.
10. The network switch of claim 9 wherein said point-to- point request map includes a point-to-point request bit vector for each said TSPP, said point-to-point request bit vector indicating each output port to which a point-to-point unit of data is to be transmitted from the respective TSPP with which the point-to-point request bit vector is associated.
11. The network switch of claim 10 including a first pointer operative to select a point-to-point request bit vector for being operated upon by said matching operator in a round robin manner of selection.
12. The network switch of claim 11 including a second pointer operative to select an output port bit within εaid point-to-point request bit vector for being operated upon by said matching operator in a round robin manner of selection.
13. A method for point-to-point and point-to-multipoint transmiεsion of units of data in a network switch comprising the steps of: in a first storing step, storing a representation of the unit of data in a request list; in a second storing step, storing a representation of available bandwidth in an allocation list; comparing the request liεt with the allocation list to determine if a match therebetween exists; and transmitting at least one unit of data for which a match is determined to exist via the available bandwidth.
14. The method of claim 13 wherein said first storing step includes the further step of storing a request map including a connection field operative to store a representation of the connection associated with each unit of data enqueued for point-to-multipoint transmission.
15. The method of claim 14 wherein said first storing step includes the further step of storing a request bit vector representation of each output port to which the unit of data is to be transmitted.
16. The method of claim 15 wherein said second εtoring step includes the further step of storing a bitmaεk which repreεents dynamic bandwidth within the switch.
17. The method of claim 16 wherein said comparing step includes the further step of comparing the dynamic bandwidth bitmask with the request bit vector.
18. The method of claim 17 wherein a plurality of bit request bit vectors are stored and said comparing step includes the further εtep of prioritizing the requeεt bit vectors into at least two separate groups arranged from high priority to low priority, said comparing step being performed upon higher priority request bit vectors prior to said lower priority request bit vectors.
19. The method of claim 17 wherein the requeεt bitmask field includes a pointer for indicating which the order in which enqueued units of data are first matched to dynamic bandwidth, said comparing step including the further step of incrementing the pointer to provide a round-robin type ordering of unit of data matching.
20. The method of claim 13 wherein said first storing step includes storing a point-to-point request bit vector for each input port in the switch, the request bit vectors containing a indicator of each output port requested by each input port in the switch.
21. The method of claim 20 wherein εaid first storing εtep includeε the further εtep of storing a plurality of listε of point-to-point connectionε having a unit of data enqueued for respective output ports with which the respective list is associated.
PCT/US1996/011945 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission WO1997004565A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP9506882A JPH11510011A (en) 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission
AU65026/96A AU6502696A (en) 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission
PCT/US1996/011945 WO1997004565A1 (en) 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission

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/011945 WO1997004565A1 (en) 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission

Publications (2)

Publication Number Publication Date
WO1997004565A1 true WO1997004565A1 (en) 1997-02-06
WO1997004565A9 WO1997004565A9 (en) 1997-08-28

Family

ID=38659713

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1996/011945 WO1997004565A1 (en) 1995-07-19 1996-07-18 Priority arbitration for point-to-point and multipoint transmission

Country Status (3)

Country Link
JP (1) JPH11510011A (en)
AU (1) AU6502696A (en)
WO (1) WO1997004565A1 (en)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5448559A (en) * 1993-05-07 1995-09-05 Roke Manor Research Limited ATM communication system with interrogation of output port servers for available handing capacity
US5475679A (en) * 1994-12-08 1995-12-12 Northern Telecom Limited Large capacity ATM switch
US5577035A (en) * 1994-03-23 1996-11-19 Roke Manor Research Limited Apparatus and method of processing bandwidth requirements in an ATM switch

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5448559A (en) * 1993-05-07 1995-09-05 Roke Manor Research Limited ATM communication system with interrogation of output port servers for available handing capacity
US5577035A (en) * 1994-03-23 1996-11-19 Roke Manor Research Limited Apparatus and method of processing bandwidth requirements in an ATM switch
US5475679A (en) * 1994-12-08 1995-12-12 Northern Telecom Limited Large capacity ATM switch

Also Published As

Publication number Publication date
JPH11510011A (en) 1999-08-31
AU6502696A (en) 1997-02-18

Similar Documents

Publication Publication Date Title
US5956342A (en) Priority arbitration for point-to-point and multipoint transmission
EP0872089B1 (en) Scheduler for an information packet switch
EP0817436B1 (en) Packet switched communication system
US6434155B1 (en) Weighted round robin engine used in scheduling the distribution of ATM cells
US20040151197A1 (en) Priority queue architecture for supporting per flow queuing and multiple ports
US6768717B1 (en) Apparatus and method for traffic shaping in a network switch
EP1111851B1 (en) A scheduler system for scheduling the distribution of ATM cells
EP0839422B1 (en) Linked-list structures for multiple levels of control in an atm switch
WO1997004564A1 (en) Allocated and dynamic bandwidth management
EP0870415A1 (en) Switching apparatus
WO1997004565A1 (en) Priority arbitration for point-to-point and multipoint transmission
WO1997004562A1 (en) Point-to-multipoint arbitration
JPH11510009A (en) Assignable and dynamic switch flow control
EP0817434B1 (en) A packet switched communication system and traffic shaping process
WO1997004565A9 (en) Priority arbitration for point-to-point and multipoint transmission
JP4504606B2 (en) Apparatus and method for shaping traffic in a network switch
EP0845181A4 (en) Link scheduling
WO1997004542A2 (en) Multipoint-to-point arbitration in a network switch
JPH11510324A (en) Control of bandwidth allocation using pace counter
WO1997004541A2 (en) Multipoint to multipoint processing in a network switch having data buffering queues
JPH11510327A (en) Asynchronous transfer mode based service integrated exchange

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

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: A1

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

121 Ep: the epo has been informed by wipo that ep was designated in this application
CFP Corrected version of a pamphlet front page

Free format text: REVISED ABSTRACT RECEIVED BY THE INTERNATIONAL BUREAU AFTER COMPLETION OF THE TECHNICAL PREPARATIONS FOR INTERNATIONAL PUBLICATION

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

Free format text: PAGES 1/10-10/10,DRAWINGS,REPLACED BY NEW PAGES BEARING THE SAME NUMBER;DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

ENP Entry into the national phase

Ref country code: JP

Ref document number: 1997 506882

Kind code of ref document: A

Format of ref document f/p: F

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