The present invention generally relates to data communication networks. The invention relates more specifically to a method and apparatus for providing multicast messages within a virtual private network across a data communication network.
The approaches described in this section could be pursued, but are not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, the approaches described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.
In computer networks such as the Internet packets of data are sent from a source to a destination via a network of elements including links (communication paths such as telephone or optical lines) and nodes (usually routers directing the packet along one or more of a plurality of links connected to it) according to one of various routing protocols, including internet protocol (IP).
Each node on the network advertises, throughout the network, links to neighboring nodes and provides a cost associated with each link, which can be based on any appropriate metric such as link bandwidth or delay and is typically expressed as an integer value. A link may have an asymmetric cost, that is, the cost in the direction AB along a link may be different from the cost in a direction BA. Based on the advertised information each node constructs a link state database (LSDB), which is a map of the entire network topology and from that constructs generally a single optimum route to each available node based on an appropriate algorithm such as, for example, a shortest path first (SPF) algorithm. As a result a “spanning tree” is constructed, rooted at the node and showing an optimum path including intermediate nodes to each available destination node. Because each node has a common LSDB (other than when advertised changes are propagating around the network) any node is able to compute the spanning tree rooted at any other node. The results of the SPF are stored in a routing information base (RIB) and based on these results the forwarding information base (FIB) or forwarding table is updated to control forwarding of packets appropriately. When there is a network change information representing the change is flooded through the network, each node sending it to each adjacent node.
IP Multicast is a bandwidth-conserving technology that reduces traffic by simultaneously delivering a single stream of information from a source to a plurality of receiving devices, for instance to thousands of corporate recipients and homes. Examples of applications that take advantage of multicast technologies include video conferencing, corporate communications, distance learning, and distribution of software, stock quotes and news. IP multicast delivers source traffic to multiple receivers without burdening the source or the receivers while using a minimum of network bandwidth. Multicast packets are replicated in the network at the point where paths diverge by routers enabled with Protocol Independent Multicast (PIM) and other supporting multicast protocols, resulting in efficient delivery of data to multiple receivers. The routers use Protocol Independent Multicast (PIM) to dynamically create a multicast distribution tree.
This can be understood by referring to
Each VPN is associated with one or more VPN routing/forwarding instances (VRFs). A VRF defines the VPN membership of a customer site attached to a PE router. A VRF consists of an IP routing table, a derived forwarding table, a set of indicators that uses the forwarding table, and a set of rules and routing protocol parameters that control the information that is included in the routing table.
A service provider edge (PE) router 16 can learn an IP prefix from a customer edge router 14 by static configuration, through a BGP session with a CE router or through a routing information protocol (RIP) exchange with the CE router 14.
A Route Distinguisher (RD) is an 8-byte value that is concatenated with an IPv4 prefix to create a unique VPN IPv4 prefix. The IP prefix is a member of the IPv4 address family. After it learns the IP prefix, the PE converts it into a VPN-IPv4 prefix by combining it with an 8-byte route distinguisher (RD). The generated prefix is a member of the VPN-IPv4 address family. It serves to uniquely identify the customer address, even if the customer site is using globally non-unique (unregistered private) IP addresses. The route distinguisher used to generate the VPN-IPv4 prefix is specified by a configuration command associated with the VRF on the PE router.
Border Gateway Protocol (BGP) distributes reachability information for prefixes for each VPN. BGP communication takes place at two levels: within IP domains, known as autonomous systems (interior BGP or IBGP) and between autonomous systems (external BGP or EBGP). PE-PE or PE-RR (route reflector) sessions are IBGP sessions, and PE-CE sessions are EBGP sessions.
BGP propagates reachability information for VPN-IPv4 prefixes among PE routers 16 by means of BGP multiprotocol extensions (for example see RFC 2283, Multiprotocol Extensions for BGP-4) which define support for address families other than IPv4. It does this in a way that ensures the routes for a given VPN are learned only by other members of that VPN, enabling members of the VPN to communicate with each other.
Based on routing information stored in the VRF IP routing table and forwarding tables, packets are forwarded to their destination using multi-protocol label switching (MPLS). A PE router binds the label to each customer prefix learnt from the CE router 14 and includes the label in the network reachability information for the prefix that advertises to other PE routers. When a PE router 16 forwards a packet received from a CE router 14 across the provider network 13, it labels the packet with a label (an example of which is a PIM join) learned from the destination PE router. When the destination PE router 16 receives a label packet it pops the label and uses it to direct the packet to the correct CE router. Label forwarding across the provider backbone is based on either dynamic label switching or traffic engineered paths. A customer packet carries two levels of labels when traversing the backbone: a top label which directs the packet to the correct PE router and a second label which indicates how that PE router should forward the packets to the CE router.
Multicast Virtual Private Networks (MVPN) have been devised to provide a user with the ability to send multicast packets over VPNs. To achieve this, MVPN uses a Multicast GRE Tunnel to forward packets across a provider network. Customers can use the MVPN service from a provider to connect office locations as if they were virtually one network. The GRE Tunnel, also known as a Multicast Distribution Tunnel (MDT), is built across the provider network and spans a single BGP Autonomous System (AS).
However, it would be beneficial for the MDT to be spanned over multiple autonomous systems since many customers have an internal network that is split into multiple autonomous systems or have VPN sites that are connected to multiple service providers. This means that service providers, who may be competitors, would need to provide their internal IP address to each other to make the MDT reachable. The MDT is built between two Provider Edge (PE) routers, and other routers in between the PE routers need a way to select the reverse path forwarding (RPF) interface towards the other PE of the other AS or VPN. However service providers are unwilling to make their PE routers reachable via unicast for security reasons and therefore do not want to redistribute the PE information into other (competitor) domains.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
A method and apparatus for providing multicast messages for a virtual private network across a data communication network is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
Embodiments are described herein according to the following outline:
The needs identified in the foregoing Background, and other needs and objects that will become apparent for the following description, are achieved in the present invention, which comprises, in one aspect, a method for providing multicast messages for a virtual private network across a data communication network, the method comprising the computer-implemented steps of: receiving a multicast join message; adding to the multicast join message a next hop and address of a router to which the multicast message is to be sent; and forwarding the multicast message based on the next hop address.
This is repeated as necessary until the multicast message is received by the final address at which point the multicast message is forwarded to the address indicated in the original multicast message.
In other aspects, the invention encompasses a computer apparatus and a computer-readable medium configured to carry out the foregoing steps.
2.0 Structural and Functional Overview
Each Autonomous System 13 comprises a Provider Edge (PE) router 16 that interfaces to a Customer Edge router 14. The PE router is then attached to one or more Provider (P) routers 18.
Each Autonomous System 13 also comprises an Autonomous System Boundary Router (ASBR) 22. An ASBR router is located on the border of an Autonomous System that connects the Autonomous System to a backbone network. These routers are considered members of both the backbone and the attached Autonomous System. PIM uses the ABSR to discover and announce RP-set information for each group prefix to all the routers in a PIM domain. They therefore maintain routing tables describing both the backbone topology and the topology of the associated Autonomous System.
Thus, in the arrangement shown in
To enable Multicast communication, end nodes (for instance CE devices 14) inform the adjacent PE router 16 of the network layer Multicast addresses they wish to receive. This may be done using Internet Group Management Protocol (IGMP). Routers then use a technique (such as Protocol Independent Multicast) PIM to build a tree for the route. The PE routers 16 typically use a reverse path forwarding technique which is an optimized form of flooding. In reverse path forwarding a node accepts a packet from source S via interface N only if N is the interface you would forward to in order to reach S. This reduces the overhead of flooding considerably. Because a router accepts the packet only from one interface, it floods it only once. Thus, in the example shown in
One way of implementing a Multicast system is to use a tree building protocol, for instance Protocol Independent Multicast (PIM).
To allow MVPN's to span multiple autonomous systems, the customer VPNv4 routes are advertised to each of the PE routers that has information about the VPN. Such routes are customer routes and do not belong to the provider. We call the routes VPNv4 routes.
The routes may be advertised using BGP and follow the complete path from one PE to the other. The BGP VPNv4 routes may be advertised with a Next-Hop (NH) attribute. This NH indicates via which router the route is reachable. These NH's are global routes belonging to the provider.
When a user wishes to join a multicast group, a device associated with the user obtains the source and group address. This may be achieved in many ways. One way is for a node to direct the user to an intranet page which includes the source and group address of the multicast group of interest. This information is then input to the user device. When a host joins a multicast group, the directly connected PE router sends a PIM join message toward the rendezvous point (RP). The RP keeps track of multicast groups. Hosts that send multicast packets are registered with the RP by the first hop router of that host. The RP then sends join messages toward the source. At this point, packets are forwarded on a shared distribution tree. If the multicast traffic from a specific source is sufficient, the first hop router of the host may send join messages toward the source to build a source-based distribution tree.
Thus when a host (attached to a CE device 14) wishes to join a multicast group, it sends a message which includes the multicast group and a source address (for instance obtained as described). This source is used by the receiving PE router to create a PIM join which is then sent to an upstream RP router. For a single autonomous system as shown in
In this case, if PE router 16A is the Rendezvous Point for the Multicast group, RP is in a different AS from the sending router 14D. As addresses are not typically passed across AS boundaries, the PE device on one AS is unaware of the addresses for devices on another AS. The NH's of the VPNv4 routes are rewritten at the exit of the network (ASBR routers) and internal addresses are not advertised into the other AS. As a result, the VPNv4 becomes unreachable.
On a PE router, each VRF has its own multicast routing and forwarding database called MVRF. Each MVRF has its own Multicast Domain. Each multicast domain is assigned a distinct group address from a pool administered by the service provider(s). The group ranges used by these multicast domains are called MDT groups. A Multicast Tunnel is established between the two end-points of two Multicast VRFs on two PEs. The Multicast VPN traffic travels over these tunnels. The source addresses of these default tunnels are the local peering addresses used for BGP peering by the PE routers. This tunnel endpoint information is distributed by BGP.
To connect the MVPN's across autonomous systems, a MDT-default tunnel is set up between the two PE's. The PE's accomplish that by joining the configured MDT-default group. This MDT-default group is configured on the PE and unique per VPN. Both PE's know the MDT-default group address. In Source Specific Multicast (SSM) mode they also need to know the source address, which is an address configured on the PE. This information will be propagated by BGP.
There are two kinds of multicast tunnels that need to be established across a Provider's network to transit Multicast VPN traffic through the core. A VPN PIM Join Message coming from a CE triggers the establishment of these tunnels. The Multicast Default Tunnel is established as a result of the PE endpoints and the per-VRF default MDTs being exchanged in the core. This may be done via BGP. Once the CE sends a Join, it triggers the establishment of the Multicast Data Tunnels which get established and abolished on an as needed basis.
Multicast-capable VRFs have a unique default-MDT associated with each VRF on a PE. Sites belonging to the same VPN have the same default-MDT. A default-MDT tunnel is setup between the PEs (one per VPN). This default-MDT Tunnel is triggered by a PIM Join to the default-MDT Group address, which is sent to all the PEs that have the default-MDT configured on any of their attached VRFs. This information is advertised by those PEs to all the other routers in the core, for instance via BGP. When multicast trees are built using the MDT-default MVPN traffic traverses the MDT-default tunnel.
MDT-data trees are dynamically created for multicast streams in cases of high bandwidth groups.
For RPF checks in single-AS and Inter-Provider Scenarios, the PIM Join Message contains the Unicast address of the Upstream Neighbor to which the Join is being sent. RPF-lookups across autonomous systems, without having IPv4-unicast routing reachability to the destination PE (which may be in another AS), are not sufficient.
However, there is reachability to the BGP next hop of the BGP MDT update received in the MDT SAFI (Subsequent Address Family Identifier). So by including in the PIM Join both the remote PE's address (as advertised in the MDT SAFI) and the BGP next hop of this address as found in the MDT SAFI table, the RPF check requirement can be satisfied.
For the sake of explanation, let us call the remote PE's address in the PIM Join as “Upstream Neighbor Address” and the Next hop as found in the MDT table as “Upstream Next hop Address”. On the PE originating the PIM Join to the default-MDT address, both of the above will be put in the PIM Join. When a P router receives the PIM Join, the P router carries out an RPF check on the Upstream Next hop address in the PIM join and sends the Join on to that address. When an ASBR receives this PIM Join and finds that the “Upstream Next hop Address” is its own, it finds the new “Upstream Next hop Address” by looking up the “Upstream Neighbor Address” in the MDT SAFI table. It carries out an RPF-checkup on the new “Upstream Next hop Address” and sends the Join to the next address.
“Upstream Neighbor Address” is found in the Unicast or the MDT SAFI table. This information may be included in the Join itself, to avoid multiple table-lookups.
Consider the topology shown in
The operation of a method and apparatus for providing multicast messages across such a data communication network will now be described. PE1 16A advertises its MVPN attribute {RD1, N1, MDT1} as Network Layer Reachability Information (NLRI) in the BGP MDT SAFI to its BGP peers. It also advertises VPNv4 prefixes with a next hop and a Connector attribute containing the address N1. Similarly, PE2 16C & PE3 16D advertise their RD, MDT attribute and next hop bindings to their respective BGP peers. The three ASBRs 22A, 22B, 22C also exchange this information in the form of BGP Update Messages. ASBR1 22A propagates the information about {RD2, N2, MDT1} and {RD3, N3, MDT1} to PE1, 16A. On receiving this information, PE1 16A installs it in the BGP MDT SAFI table. Similarly, ASBR2 22B and ASBR3 22C also propagate the information about {RD1, N1, MDT1}) and {RD3, N3, MDT1}/{RD2, N2, MDT1} to PE2 16C and PE3 16D.
Now consider that ASBR2 and ASBR3 peer with each other and also exchange the MDT SAFI. ASBR2 then propagates {RD3, N3, MDT1} and ASBR3 also propagates {RD2, N2, MDT1} to ASBR1. ASBR1 then runs a best path algorithm based on BGP attributes contained in the BGP UPDATE Message and propagates this best path to PE1. PE1 then runs a best path algorithm and hands the information to PIM. PIM then triggers the setup of a tunnel.
Now consider a prefix belonging to VRF with RD2. The next hop for the VPNv4 advertisement, when advertised by PE2 16C, was N2. However by the time PE1 16A receives the advertisement, the next hop could be ASBR2 (assuming there is no next-hop-unchanged configuration done in AS2) or if ASBR1 does next-hop-self, then it will be ASBR1. The correlation between the next hop & the prefix may then be lost. So the original next hop may be preserved by carrying the original PE's address in a new attribute defined in BGP called the Connector attribute.
For the tunnel to be setup, the PIM Join from PE1 needs to be able to reach PE2 and PE3. This is trivial if PE1 has reachability to N2, N3 and PE2 and PE3 have reachability to N1, N3/N2. In the absence of this reachability, the MVPN requirements need the ability to do an RPF-check on the intermediate-hops. For example, PE1 16A does not know how to reach N2 on PE2 16C. However it does have reachability to the ASBR1 22A in its own AS 13A. So PE1 looks in its MVPN table for the next hop to be used for reaching {RD2, N2, MDT2} and it finds it to be ASBR1 (the BGP next hop received in the Update Message for the MDT SAFI). The PIM join is then sent by PE1 to ASBR1 22A. ASBR1 then looks into its MVPN table and finds the next hop for {RD2, N2, MDT2} to be ASBR2 22B and forwards the PIM Join to ASBR2. When the PIM join is received by ASBR2 22B, ASBR2 knows how to reach N2. Thus there is provided the ability to reach across ASs without having unicast reachability between them and the ability to do RPF-checks on the intermediate hops.
3.0 Method of Providing Multicast Messages Across a Data Communication Network
Methods of providing multicast messages across a data communication network will now be described with reference to a network as shown in
If the address of the next hop of the Join message is the same as the address of the receiving node (step 804) (for instance, say the receiving node is ASBR router 22B), then the receiving node determines the next hop for the RD of the PIM Join. The receiving node forwards the multicast join message on through the network (step 806) towards the address now given by the new next hop, according to routing information at the node. These steps may be repeated many times in the network as the multicast join message is routed through the network before reaching the node determined by RD.
Thus a multicast join message having a source address S in a first AS is routed through a network comprising a plurality of AS. The source address may not be known to all routers in a network comprising a plurality of AS. Including the RD and the BGP next hop in the multicast join message allows the message to be routed through AS that do not know how to reach source S.
Computer system 900 includes a bus 902 or other communication mechanism for communicating information, and a processor 904 coupled with bus 902 for processing information. Computer system 900 also includes a main memory 906, such as a random access memory (RAM), flash memory, or other dynamic storage device, coupled to bus 902 for storing information and instructions to be executed by processor 904. Main memory 906 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 904. Computer system 900 further includes a read only memory (ROM) 908 or other static storage device coupled to bus 902 for storing static information and instructions for processor 904. A storage device 910, such as a magnetic disk, flash memory or optical disk, is provided and coupled to bus 902 for storing information and instructions.
A communication interface 918 may be coupled to bus 902 for communicating information and command selections to processor 904. Interface 918 is a conventional serial interface such as an RS-232 or RS-422 interface. An external terminal 912 or other computer system connects to the computer system 900 and provides commands to it using the interface 918. Firmware or software running in the computer system 900 provides a terminal interface or character-based command interface so that external commands can be given to the computer system.
A switching system 916 is coupled to bus 902 and has an input interface and a respective output interface (commonly designated 919) to external network elements. The external network elements may include a plurality of additional routers 920 or a local network coupled to one or more hosts or routers, or a global network such as the Internet having one or more servers. The switching system 916 switches information traffic arriving on the input interface to output interface 919 according to pre-determined protocols and conventions that are well known. For example, switching system 916, in cooperation with processor 904, can determine a destination of a packet of data arriving on the input interface and send it to the correct destination using the output interface. The destinations may include a host, server, other end stations, or other routing and switching devices in a local network or Internet.
The computer system 900 implements as a router acting as a node in the above described method generating routing information. The implementation is provided by computer system 900 in response to processor 904 executing one or more sequences of one or more instructions contained in main memory 906. Such instructions may be read into main memory 906 from another computer-readable medium, such as storage device 910. Execution of the sequences of instructions contained in main memory 906 causes processor 904 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the sequences of instructions contained in main memory 906. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the method. Thus, embodiments are not limited to any specific combination of hardware circuitry and software.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor 904 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 910. Volatile media includes dynamic memory, such as main memory 906. Transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 902. Transmission media can also take the form of wireless links such as acoustic or electromagnetic waves, such as those generated during radio wave and infrared data communications.
Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor 904 for execution. For example, the instructions may initially be carried on a magnetic disk of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 900 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector coupled to bus 902 can receive the data carried in the infrared signal and place the data on bus 902. Bus 902 carries the data to main memory 906, from which processor 904 retrieves and executes the instructions. The instructions received by main memory 906 may optionally be stored on storage device 910 either before or after execution by processor 904.
Interface 919 also provides a two-way data communication coupling to a network link that is connected to a local network. For example, the interface 919 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, the interface 919 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, the interface 919 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
The network link typically provides data communication through one or more networks to other data devices. For example, the network link may provide a connection through a local network to a host computer or to data equipment operated by an Internet Service Provider (ISP). The ISP in turn provides data communication services through the world wide packet data communication network now commonly referred to as the “Internet”. The local network and the Internet both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on the network link and through the interface 919, which carry the digital data to and from computer system 900, are exemplary forms of carrier waves transporting the information.
Computer system 900 can send messages and receive data, including program code, through the network(s), network link and interface 919. In the Internet example, a server might transmit a requested code for an application program through the Internet, ISP, local network and communication interface 918. One such downloaded application provides for the method as described herein.
The received code may be executed by processor 904 as it is received, and/or stored in storage device 910, or other non-volatile storage for later execution. In this manner, computer system 900 may obtain application code in the form of a carrier wave.
In the foregoing specification, the invention has been described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
6078590 | Farinacci et al. | Jun 2000 | A |
6147970 | Troxel | Nov 2000 | A |
6185210 | Troxel | Feb 2001 | B1 |
6339595 | Rekhter et al. | Jan 2002 | B1 |
6385647 | Willis et al. | May 2002 | B1 |
6415323 | McCanne et al. | Jul 2002 | B1 |
6473421 | Tappan | Oct 2002 | B1 |
6483832 | Civanlar et al. | Nov 2002 | B1 |
6484257 | Ellis | Nov 2002 | B1 |
6526056 | Rekhter et al. | Feb 2003 | B1 |
6584082 | Willis et al. | Jun 2003 | B1 |
6625773 | Boivie et al. | Sep 2003 | B1 |
6633835 | Moran et al. | Oct 2003 | B1 |
6636895 | Li et al. | Oct 2003 | B1 |
6654796 | Slater et al. | Nov 2003 | B1 |
6701361 | Meier | Mar 2004 | B1 |
6721315 | Xiong et al. | Apr 2004 | B1 |
6732189 | Novaes | May 2004 | B1 |
6735200 | Novaes | May 2004 | B1 |
6791981 | Novaes | Sep 2004 | B1 |
6801940 | Moran et al. | Oct 2004 | B1 |
6804492 | Kay | Oct 2004 | B2 |
6810417 | Lee | Oct 2004 | B2 |
6839348 | Tang et al. | Jan 2005 | B2 |
6973057 | Forslow | Dec 2005 | B1 |
7082140 | Hass | Jul 2006 | B1 |
7120165 | Kasvand-Harris et al. | Oct 2006 | B2 |
7139278 | Gibson et al. | Nov 2006 | B2 |
7158497 | Li et al. | Jan 2007 | B2 |
7281058 | Shepherd et al. | Oct 2007 | B1 |
7484003 | Chandra et al. | Jan 2009 | B2 |
7570605 | Aggarwal et al. | Aug 2009 | B1 |
7856509 | Kodeboyina | Dec 2010 | B1 |
8078758 | Callon | Dec 2011 | B1 |
20010024443 | Alriksson et al. | Sep 2001 | A1 |
20020004843 | Andersson et al. | Jan 2002 | A1 |
20020012320 | Ogier | Jan 2002 | A1 |
20020023164 | Lahr | Feb 2002 | A1 |
20020031107 | Li et al. | Mar 2002 | A1 |
20020046287 | La Porta et al. | Apr 2002 | A1 |
20020062388 | Ogier et al. | May 2002 | A1 |
20020067725 | Oguchi et al. | Jun 2002 | A1 |
20020075807 | Troxel et al. | Jun 2002 | A1 |
20020075866 | Troxel et al. | Jun 2002 | A1 |
20020078127 | Troxel et al. | Jun 2002 | A1 |
20020078238 | Troxel et al. | Jun 2002 | A1 |
20020085498 | Nakamichi et al. | Jul 2002 | A1 |
20020147011 | Kay | Oct 2002 | A1 |
20020172155 | Kasvand-Harris et al. | Nov 2002 | A1 |
20020184368 | Wang | Dec 2002 | A1 |
20030037109 | Newman et al. | Feb 2003 | A1 |
20030048790 | McAllister et al. | Mar 2003 | A1 |
20030051048 | Watson et al. | Mar 2003 | A1 |
20030053457 | Fox et al. | Mar 2003 | A1 |
20030063608 | Moonen | Apr 2003 | A1 |
20030067928 | Gonda | Apr 2003 | A1 |
20030074584 | Ellis | Apr 2003 | A1 |
20030105865 | McCanne et al. | Jun 2003 | A1 |
20030110288 | Ramanujan et al. | Jun 2003 | A1 |
20030147405 | Khill | Aug 2003 | A1 |
20030152063 | Giese et al. | Aug 2003 | A1 |
20030165140 | Tang et al. | Sep 2003 | A1 |
20030172145 | Nguyen | Sep 2003 | A1 |
20030174706 | Shankar et al. | Sep 2003 | A1 |
20030179742 | Ogier et al. | Sep 2003 | A1 |
20030200307 | Raju et al. | Oct 2003 | A1 |
20030212821 | Gillies et al. | Nov 2003 | A1 |
20040025018 | Haas et al. | Feb 2004 | A1 |
20040037279 | Zelig et al. | Feb 2004 | A1 |
20040039839 | Kalyanaraman et al. | Feb 2004 | A1 |
20040054799 | Meier et al. | Mar 2004 | A1 |
20040062267 | Minami et al. | Apr 2004 | A1 |
20040081154 | Kouvelas | Apr 2004 | A1 |
20040103282 | Meier et al. | May 2004 | A1 |
20040133619 | Zelig et al. | Jul 2004 | A1 |
20040165600 | Lee | Aug 2004 | A1 |
20040205215 | Kouvelas et al. | Oct 2004 | A1 |
20050108419 | Eubanks | May 2005 | A1 |
20060147204 | Yasukawa et al. | Jul 2006 | A1 |
20090086644 | Kompella et al. | Apr 2009 | A1 |
Entry |
---|
Cisco Technology, Inc., “MPLS Virtual Private Networks,” Cisco IOS Release 12.0(5)T, pp. 1-50. |
Cisco Technology, Inc. “IP Multicast Technology Overview,” DIG: Enterprise Campus Technology, Apr. 18, 2002, pp. 3-26. |
Number | Date | Country | |
---|---|---|---|
20060088031 A1 | Apr 2006 | US |