Some embodiments of the invention provide a system for implementing several logical switching elements across several managed switching elements. The system of some embodiments includes a set of network controllers for controlling the managed switching elements. In some embodiments, the set of network controllers configures the managed switching elements to forward network data such that network data forwarded through a first logical switching element implemented by the managed switching elements is isolated from network data forwarded through a second logical switching element implemented by the managed switching elements.
The managed switching elements of different embodiments are implemented differently. For instance, the managed switching elements of some embodiments are hardware switching elements. In some such embodiments, the hardware switching elements are top-of-rack hardware switches. Each top-of-rack hardware switch may be coupled to a set of network hosts that are included in the rack with which the hardware switch is associated. In other embodiments, the managed switching elements are software switching elements. The software switching elements of some of these other embodiments are virtual switching elements. In some cases where the software switching elements are virtual switching elements, the virtual switching elements are each hosted by a network host included in a rack of network hosts. In some of these embodiments, the racks of network hosts are coupled to an unmanaged top-of-rack hardware switching element while, in other of these embodiments, the racks of network hosts are coupled to an unmanaged top-of-rack hardware switching element. In yet other embodiments, the managed switching elements include both hardware switching elements and software switching elements.
The preceding Summary is intended to serve as a brief introduction to some embodiments of the invention. It is not meant to be an introduction or overview of all inventive subject matter disclosed in this document. The Detailed Description that follows and the Drawings that are referred to in the Detailed Description will further describe the embodiments described in the Summary as well as other embodiments. Accordingly, to understand all the embodiments described by this document, a full review of the Summary, Detailed Description and the Drawings is needed. Moreover, the claimed subject matters are not to be limited by the illustrative details in the Summary, Detailed Description and the Drawings, but rather are to be defined by the appended claims, because the claimed subject matters can be embodied in other specific forms without departing from the spirit of the subject matters.
The novel features of the invention are set forth in the appended claims. However, for purposes of explanation, several embodiments of the invention are set forth in the following figures.
In the following detailed description of the invention, numerous details, examples, and embodiments of the invention are set forth and described. However, it will be clear and apparent to one skilled in the art that the invention is not limited to the embodiments set forth and that the invention may be practiced without some of the specific details and examples discussed.
I. Environment
The following section will describe the environment in which some embodiments of the inventions are implements. In the present application, switching elements and machines may be referred to as network elements. In addition, a network that is managed by one or more network controllers may be referred to as a managed network in the present application. In some embodiments, the managed network includes only managed switching elements (e.g., switching elements that are controlled by one or more network controllers) while, in other embodiments, the managed network includes managed switching elements as well as unmanaged switching elements (e.g., switching elements that are not controlled by a network controller).
In some embodiments, the managed switching elements 130-150 route network data (e.g., packets) between network elements in the network that are coupled to the managed switching elements 130-150. For instance, the managed switching element 130 routes network data between the machines 155-165 and the managed switching element 140. Similarly, the managed switching element 140 routes network data between the machine 170 and the managed switching elements 140 and 150, and the managed switching element 150 routes network data between the machines 175-185 and the managed switching element 150.
The managed switching elements 130-150 of some embodiments can be configured to route network data according to defined rules. In some embodiments, the managed switching elements 130-150 routes network data based on routing criteria defined in the rules. Examples of routing criteria include source media access control (MAC) address, destination MAC, packet type, source Internet Protocol (IP) address, destination IP address, source port, destination port, and/or virtual local area network (VLAN) identifier, among other routing criteria.
In some embodiments, the managed switching elements 130-150 can include standalone physical switching elements, software switching elements that operate within a computer, or any other type of switching element. For example, each of the managed switching elements 130-150 may be implemented as a hardware switching element, a software switching element, a virtual switching element, a network interface controller (NIC), or any other type of network element that can route network data. Moreover, the software or virtual switching elements may operate on a dedicated computer, or on a computer that performs non-switching operations.
The machines 155-185 send and receive network data between each other over the network. In some embodiments, the machines 155-185 are referred to as network hosts that are each assigned a network layer host addresses (e.g., IP address). Some embodiments refer to the machines 155-185 as end systems because the machines 155-185 are located at the edge of the network. In some embodiments, each of the machines 155-185 can be a desktop computer, a laptop computer, a smartphone, a virtual machine (VM) running on a computing device, a terminal, or any other type of network host.
In some embodiments, each of the network controllers 110 and 120 controls one or more managed switching elements 130-150 that are located at the edge of a network (e.g., edge switching elements or edge devices). In this example, the managed switching elements 130-150 are edge switching elements. That is, the managed switching elements 130-150 are switching elements that are located at or near the edge of the network. In some embodiments, an edge switching element is the last switching element before end machines (the machines 155-185 in this example) in a network. As indicated by dashed arrows in
In addition to controlling edge switching elements, the network controllers 110 and 120 of some embodiments also utilize and control non-edge switching elements (e.g., pool nodes, root nodes, and extenders, which are described in further detail below) that are inserted in the network to simplify and/or facilitate the operation of the managed edge switching elements. For instance, in some embodiments, the network controller 110 and 120 require the switching elements that the network controller 110 and 120 control to be interconnected in a hierarchical switching architecture that has several edge switching elements as the leaf nodes in the hierarchical switching architecture and one or more non-edge switching elements as the non-leaf nodes in this architecture. In some such embodiments, each edge switching element connects to one or more of the non-leaf switching elements, and uses such non-leaf switching elements to facilitate the communication of the edge switching element with other edge switching elements. Examples of such communications with an edge switching elements in some embodiments include (1) routing of a packet with an unknown destination address (e.g., unknown MAC address) to the non-leaf switching element so that the non-leaf switching element can route the packet to the appropriate edge switching element, (2) routing a multicast or broadcast packet to the non-leaf switching element so that the non-leaf switching element can distribute the multicast or broadcast packet to the desired destinations.
Some embodiments employ one level of non-leaf (non-edge) switching elements that connect to edge switching elements and in some cases to other non-leaf switching elements. Other embodiments, on the other hand, employ multiple levels of non-leaf switching elements, with each level of non-leaf switching elements after the first level serving as a mechanism to facilitate communication between lower level non-leaf switching elements and leaf switching elements. In some embodiments, the non-leaf switching elements are software switching elements that are implemented by storing the switching tables in the memory of a standalone computer instead of an off the shelf switch. In some embodiments, the standalone computer may also be executing in some cases a hypervisor and one or more virtual machines on top of that hypervisor. Irrespective of the manner by which the leaf and non-leaf switching elements are implemented, the network controllers 110 and 120 of some embodiments store switching state information regarding the leaf and non-leaf switching elements.
As mentioned above, the switching elements 130-150 of some embodiments route network data between network elements in the network. In some embodiments, the network controllers 110 and 120 configure the managed switching elements 130-150s′ routing of network data between the network elements in the network. In this manner, the network controllers 110 and 120 can control the flow (i.e., specify the datapath) of network data between network elements.
For example, the network controller 110 might instruct the managed switching elements 130 and 140 to route network data from the machine 155 to the machine 170 (and vice versa) and to not route (e.g., drop) network data from other machines to the machines 155 and 170. In such case, the network controller 110 controls the flow of network data through the managed switching elements 130 and 140 such that network data transmitted to and from the machine 155 is only routed to the machine 170. Thus, the machines 155 and 170 cannot send and receive network data to and from the machines 160, 165, and 175-185.
In some embodiments, the network controllers 110 and 120 store physical network information and logical network information. The physical network information specifies the physical components in the managed network and how the physical components are physically connected one another in the managed network. For example, the physical network information may include the number of machines, managed switching elements, pool nodes, root nodes, and extenders (the latter three are described in further detail in the following sections), and how the components are physically connected to one another in the managed network. The logical network information may specify the logical connections between a set of physical components in the managed network (e.g., machines) and a mapping of the logical connections across the physical components of the managed network.
Some embodiments of the network controllers 110 and 120 implement a logical switching element across the managed switching elements 130-150 based on the physical network information and the logical switching element information described above. A logical switching element can be defined to function any number of different ways that a switching element might function. The network controllers 110 and 120 implement the defined logical switching element through control of the managed switching elements 130-150. In some embodiments, the network controllers 110 and 120 implement multiple logical switching elements across the managed switching elements 130-150. This allows multiple different logical switching elements to be implemented across the managed switching elements 130-150 without regard to the network topology of the network.
In some embodiments, a logical datapath set defines a logical switching element. A logical datapath set, in some embodiments, is a set of network datapaths through the managed switching elements 130-150 that implement the logical switching element and the logical switch's defined functionalities. In these embodiments, the network controllers 110 and 120 translate (e.g., maps) the defined logical datapath set into network configuration information for implementing the logical switching element. The network controllers 110 and 120 translate the defined logical datapath set into a corresponding set of data flows (i.e., datapaths) between network elements in the network, in some embodiments. In these instances, the network controllers 110 and 120 instruct the managed switching elements 130-150 to route network data according to the data flows and, thus, implement the functionalities of the defined logical switching element.
Different embodiments of the network controllers 110 and 120 are implemented differently. For example, some embodiments implement the network controllers 110 and 120 in software as instances of a software application. In these cases, the network controllers 110 and 120 may be executed on different types of computing devices, such as a desktop computer, a laptop computer, a smartphone, etc. In addition, the software application may be executed on a virtual machine that runs on a computing device in some embodiments. In some embodiments, the network controllers 110 and 120 are implemented in hardware (e.g., circuits).
As mentioned above by reference to
A TOR switching element, in some embodiments, routes network data between hosts in the TOR switch's rack and network elements coupled to the TOR switching element. In the example illustrated in
As shown, each rack of hosts 260-280 includes multiple hosts. The hosts of some embodiments in the racks of hosts 260-280 are physical computing devices. In some embodiments, each host is a computing device that is assigned a network layer host address (e.g., IP address). The hosts of some embodiments send and receive network data to and from each other over the network.
As mentioned above, the network controller of some embodiments can be implemented in software as an instance of an application. As illustrated in
In some embodiments, the control application layer receives user input that specifies a network switching element. The control application layer may receive the user input in any number of different interfaces, such as a graphical user interface (GUI), a command line interfaces, a web-based interface, a touchscreen interface, etc. In some embodiments, the user input specifies characteristics and behaviors of the network switching element, such as the number of switching element ports, access control lists (ACLs), network data forwarding, port security, or any other network switching element configuration options.
The control application layer of some embodiments defines a logical datapath set based on user input that specifies a network switching element. As noted above, a logical datapath set is a set of network datapaths through managed switching elements that are used to implement the user-specified network switching element. In other words, the logical datapath set is a logical representation of the network switching element and the network switch's specified characteristics and behaviors.
Some embodiments of the virtualization application layer translate the defined logical datapath set into network configuration information for implementing the logical network switching element across the managed switching elements in the network. For example, the virtualization application layer of some embodiments translates the defined logical datapath set into a corresponding set of data flows. In some of these cases, the virtualization application layer may take into account various factors (e.g., logical switching elements that are currently implemented across the managed switching elements, the current network topology of the network, etc.), in determining the corresponding set of data flows.
The network operating system layer of some embodiments configures the managed switching elements' routing of network data. In some embodiments, the network operating system instructs the managed switching elements to route network data according to the set of data flows determined by the virtualization application layer.
In some embodiments, the network operating system layer maintains several views of the network based on the current network topology. One view that the network operating system layer maintains is a logical view. The logical view of the network includes the different logical switching elements that are implemented across the managed switching elements, in some embodiments. Some embodiments of the network operating system layer maintain a managed view of the network. Such managed views include the different managed switching elements in the network (i.e., the switching elements in the network that the network controllers control). In some embodiments, the network operating system layer also maintains relationship data that relate the logical switching elements implemented across the managed switching elements to the managed switching elements.
While
The TOR switching elements 330-350 are similar to the TOR switching elements 230-250. The TOR switching elements 330-350 route network data between network elements in the network that are coupled to the TOR switching elements 330-350. In this example, the TOR switching element 330 routes network data between the rack of hosts 360 and TOR switching elements 340 and 350, the TOR switching element 340 routes network data between the rack of hosts 370 and TOR switching elements 330 and 350, and the TOR switching element 350 routes network data between the rack of hosts 380 and TOR switching elements 330 and 340. Since the TOR switching elements 330-350 are not managed switching elements, the network controllers 310 and 320 do not control these switching elements. Thus, the TOR switching elements 330-350 rely on the switching elements' preconfigured functionalities to route network data.
As illustrated in
The OVSs of some embodiments route network traffic between network elements coupled to the OVSs. For example, in this example, each OVS routes network data between VMs that are running on the host on which the OVS is running, OVSs running on other hosts in the rack of hosts, and the TOR switching element of the rack.
By running a software switching element and several VMs on a host, the number of end machines or network hosts in the network may increase. Moreover, when a software switching element and several VMs are run on hosts in the racks of hosts 360-380, the network topology of the network is changed. In particular, the TOR switching elements 330-350 are no longer edge switching elements. Instead, the edge switching elements in this example are the software switching elements running on the hosts since these software switching elements are the last switching elements before end machines (i.e., VMs in this example) in the network.
The network controllers 310 and 320 perform similar functions as the network controllers 210 and 220, which described above by reference to
The above
The network controllers 410 and 420 perform similar functions as the network controllers 210 and 220, which described above by reference to
The above figures illustrate examples of network controllers that control edge switching elements in a network. However, in some embodiments, the network controllers can control non-edge switching elements as well.
As shown in
II. Network Constructs
The following section describes several network constructs. Different embodiments described in this application may utilize one or more of these network constructs to facilitate some or all of the functionalities of the different embodiments.
The machines 650-680 of some embodiments are network hosts that are each assigned a set of network layer host addresses (e.g., a MAC address for network layer 2, an IP address for network layer 3, etc.). The machines 650-680 may also be referred to as end machines. Similar to the machines 155-185 described above, each of the machines 650-680 can be a desktop computer, a laptop computer, a smartphone, a virtual machine (VM) running on a computing device, a terminal, or any other type of network host. In addition, the machines 650-680 may belong to different tenants (e.g., in a data center environment). As illustrated in
The switching elements 630 and 640 are network switching elements that route (e.g., forwards) network data at the data link layer (also referred to as layer 2 or L2 layer) based on protocols such as the Ethernet protocol. The switching elements 630 and 640 may also be referred to as network bridges in some embodiments. As shown, the switching element 630 routes network data at the data link layer between the machines 650 and 660 and the router 610, and the switching element 640 routes network data at the data link layer between the machines 670 and 680 and the router 620.
To route network data at the data link layer, some embodiments of the switching elements 630 and 640 use a media access control (MAC) address of a network host's network interface card (NIC) to determine where to route network data (e.g., packets, frames, etc.). The switching elements 630 and 640 are implemented differently in different embodiments. For instance, each of the switching elements 630 and 640 can be implemented as a hardware switching element, a software switching element, a virtual switching element, some types of network interface card (NIC), or any other type of network element that can route network data at the data link layer.
Furthermore, the switching elements 630 and 640 support any number of different types of tunneling protocols in different embodiments. As shown, examples of tunneling protocols include control and provisioning of wireless access points (CAPWAP), generic route encapsulation (GRE), GRE Internet Protocol Security (IPsec), among other types of tunneling protocols.
The routers 610 and 620 are network routers that route network data at the network layer (also referred to as the layer 3 or L3 layer) based on protocols such as the Internet Protocol (IP). As illustrated in
In order to route network data at the network layer, the routers 610 and 620 of some embodiments use an IP address assigned to a network host to determine where to route network data (e.g., packets). Moreover, the routers 610 and 620 of some embodiments may provide other functions as well, such as security functions, quality of service (QoS) functions, checksum functions, flow accounting functions, or any other type of router functions.
Different embodiments of the routers 610 and 620 can be implemented differently. For example, each of the routers 610 and 620 can be implemented as a hardware router, a software router, a virtual router, or any other type of network element that can route network data at the network layer.
As mentioned above, the switching elements 630 and 640 of some embodiments can support tunneling protocols. In some embodiments, a tunneling protocol allows network data to be sent along a path between two points in a network where the tunneling protocol used by the network elements along the path in the network is different than the payload protocol used by the destination network element
In some embodiments, a tunneling protocol is a network protocol (e.g., a delivery protocol) that encapsulates another protocol (e.g., a payload protocol). A tunneling protocol can be used, for example, to transmit network data over an incompatible delivery-network. For instance, in this example, a tunneling protocol may provide a tunnel over a layer 3 network through which layer 2 network data is transmitted. As such, from the perspective of the machines 650-680, the machines 650-680 are communicating over an L2 network. In other words, a tunneling protocol facilitates the communication of layer 2 network data between network hosts separated by a layer 3 network.
As shown in
Although
As illustrated in
When transmitting network data through the tunnel 770, some embodiments include an identifier (ID) tag with the network data when the network data is transmitted through the tunnel 770. In some embodiments, an ID tag is a unique identifier for identifying a tenant to which the network data is associated. In this manner, switching elements can identify the tenant to which the network data belongs. This enables network data for different tenants to be transmitted through a single tunnel. In some embodiments, an ID tag allows machines of different tenants to have overlapping network identifiers (e.g., logical MAC addresses or logical IP addresses). For example, in a layer 2 network where some machines of different tenants each has the same MAC address, an ID tag can be used to differentiate between the machines of the different tenants and the network data directed at the different tenants. Similarly, an ID tag may be used to differentiate between machines of different tenants where some of the machines of the different tenants each has the same IP address.
The following will describe an example of transmitting network data belonging to different tenants that have overlapping network identifiers through a single tunnel by reference to
When the machine 730 sends packet A to machine 750, the packet A is transmitted to the switching element 710. When the switching element 710 receives the packet A, the switching element 710 determines that the packet A originated from a machine that belongs to tenant A (e.g., based on the packet A's source MAC address and/or the port through which the packet A is received). Then, the switching element 710 identifies the ID tag (e.g., by performing a lookup on a lookup table) that is associated with tenant A (ID 1 in this example) and includes the ID tag in the packet A before the packet is transmitted to the switching element 720 through the tunnel 770. Since tenant A's machine (machine 750) and tenant B's machine (machine 760) have overlapping network identifiers (e.g., the machine 750 and 760 each has the same MAC address or use the same private IP address space), the switching element 720 would not be able to differentiate between tenant A's machines and tenant B's machines based only on the machines' network identifiers. However, the ID tag allows the switching element 720 to differentiate between tenant A's machines and tenant B's machines. Therefore, when the switching element 720 receives the packet A from the switching element 710 through the tunnel 770, the switching element 720 examines the ID tag included in the packet A and determines the tenant to which the packet A belongs (e.g., by performing a lookup on a lookup table). After determining the tenant to which the packet A belongs, the switching element 720 removes the ID tag from the packet A and transmits to the packet A to the machine 750, the intended recipient of the packet A in this example.
When the machine 740 sends packet B to machine 760, the switching elements 710 and 720 perform similar functions as those performed for the packet A described above. That is, the switching element 710 determines the tenant to which the packet B belongs, identifies the ID tag associated with the tenant, and includes the ID tag in the packet B. Then, the switching element 710 transmits the packet B to the switching element 720 through the tunnel 770. When the switching element 720 receives the packet B from the switching element 710 through the tunnel 770, the switching element 720 determines the tenant to which the packet B belongs by examining the ID tag included in the packet, removes the ID tag from the packet B, and transmits the packet B to the machine 760. As explained, the ID tag allows network data for tenants A's machines and tenant B's machines, which have overlapping network identifiers, to be transmitted through a single tunnel 770.
As mentioned above, the managed switching elements of some embodiments can be configured to route network data based on different routing criteria. In this manner, the flow of network data through switching elements in a network can be controlled in order to implement multiple logical switching elements across the switching elements.
The switching elements 810-830 of some embodiments route network data (e.g., packets, frames, etc.) between network elements in the network that are coupled to the switching elements 810-830. As shown, the switching element 810 routes network data between the machines 840 and 845 and the switching element 820. Similarly, the switching element 810 routes network data between the machine 850 and the switching elements 810 and 820, and the switching element 830 routes network data between the machines 855-865 and the switching element 820.
Moreover, each of the switching elements 810-830 routes network data based on the switch's forwarding tables. In some embodiments, a forwarding table determines where to route network data (e.g., a port on the switch) according to routing criteria. For instance, a forwarding table of a layer 2 switching element may determine where to route network data based on MAC addresses (e.g., source MAC address and/or destination MAC address). As another example, a forwarding table of a layer 3 switching element may determine where to route network data based on IP addresses (e.g., source IP address and/or destination IP address). Many other types of routing criteria are possible.
As shown in
The following will describe the conceptual flow entries for implementing the flow of network data originating from the machine 840 and destined for the machine 850 and originating from the machine 840 and destined for the machine 860. First, the flow entries for routing network data originating from the machine 840 and destined for the machine 850 will be described followed by the flow entries for routing network data originating from the machine 840 and destined for the machine 860.
The flow entry “A1 to A2” in the switching element 810's forwarding table instructs the switching element 810 to route network data that originates from machine 810 and is destined for the machine 850 to the switching element 820. The flow entry “A1 to A2” in the forwarding table of the switching element 820 instructs the switching element 820 to route network data that originates from machine 810 and is destined for the machine 850 to the machine 850. Therefore, when the machine 840 sends network data that is destined for the machine 850, the switching elements 810 and 820 route the network data along datapath 870 based on the corresponding records in the switching elements' forwarding tables.
Furthermore, the flow entry “A1 to A3” in the switching element 810's forwarding table instructs the switching element 810 to route network data that originates from machine 810 and is destined for the machine 850 to the switching element 820. The flow entry “A1 to A3” in the forwarding table of the switching element 820 instructs the switching element 820 to route network data that originates from machine 810 and is destined for the machine 860 to the switching element 830. The flow entry “A1 to A3” in the forwarding table of the switching element 830 instructs the switching element 830 to route network data that originates from machine 810 and is destined for the machine 860 to the machine 860. Thus, when the machine 840 sends network data that is destined for the machine 860, the switching elements 810-830 route the network data along datapath 875 based on the corresponding records in the switching elements' forwarding tables.
While conceptual flow entries for routing network data originating from the machine 840 and destined for the machine 850 and originating from the machine 840 and destined for the machine 860 are described above, similar flow entries would be included in the forwarding tables of the switching elements 810-830 for routing network data between other machines in tenant A's logical network 880. Moreover, similar flow entries would be included in the forwarding tables of the switching elements 810-830 for routing network data between the machines in tenant B's logical network 890.
In some embodiments, tunnels provided by tunneling protocols described above may be used to facilitate the implementation of the logical switching elements 885 and 895 across the switching elements 810-830. The tunnels may be viewed as the “logical wires” that connect machines in the network in order to implement the logical switching elements 880 and 890. In some embodiments, unidirectional tunnels are used. For instance, a unidirectional tunnel between the switching element 810 and the switching element 820 may be established and through which network data originating from the machine 840 and destined for the machine 850 is transmitted. Similarly, a unidirectional tunnel between the switching element 810 and the switching element 830 may be established and through which network data originating from the machine 840 and destined for the machine 860 is transmitted. In some embodiments, a unidirectional tunnel is established for each direction of network data flow between two machines in the network.
Alternatively, or in conjunction with unidirectional tunnels, bidirectional tunnels can be used in some embodiments. For instance, in some of these embodiments, only one bidirectional tunnel is established between two switching elements. Referring to
Configuring the switching elements in the various ways described above to implement multiple logical switching elements across a set of switching elements allows multiple tenants, from the perspective of each tenant, to each have a separate network and/or switching element while the tenants are in fact sharing some or all of the same set of switching elements and/or connections between the set of switching elements (e.g., tunnels, physical wires).
The ingress ports 910 conceptually represent a set of ports through which the switching element 900 receives network data. The ingress ports 910 may include different amounts of ingress ports in different embodiments. As shown, the ingress ports 910 can receive network data that is external to the switching element 900, which is indicated as incoming packets in this example. The ingress ports 910 can also receive network data (e.g., packets) within the switching element 900 from the dispatch port 930. When the ingress ports 910 receive network data, the ingress ports 910 forwards the network data to the forwarding tables 940.
The forwarding tables 940 conceptually represent a set of forwarding tables for routing and modifying network data received from the ingress ports 910. In some embodiments, the forwarding tables 940 include a set of records (or rules) that instruct the switching element 900 to route and/or modify network data and send the network data to the egress ports 920 and/or the dispatch port 930 based on defined routing criteria. As noted above, examples of routing criteria include source media access control (MAC) address, destination MAC, packet type, source Internet Protocol (IP) address, destination IP address, source port, destination port, and/or virtual local area network (VLAN) identifier, among other routing criteria. In some embodiments, the switching element 900 routes network data to a particular egress port according to the routing criteria.
The egress ports 920 conceptually represent a set of ports through which the switching element 900 sends network data out of the switching element 900. The egress ports 920 may include different amounts of egress ports in different embodiments. In some embodiments, some or all of the egress ports 920 may overlap with some or all of the ingress ports 910. For instance, in some such embodiments, the set of ports of the egress ports 920 is the same set of ports as the set of ports of ingress ports 910. As illustrated in
In some embodiments, the dispatch port 930 allows packets to be reprocessed by the forwarding tables 940. In some cases, the forwarding tables 940 are implemented as a single table (e.g., due to the switching element 900s hardware and/or software limitations). However, some embodiments of the forwarding tables 940 may logically need more than one table. Therefore, in order to implement multiple forwarding tables in a single table, the dispatch port 930 may be used. For example, when the forwarding tables 940 processes a packet, the packet may be tagged (e.g., modifying a context tag of the packet or a header field of the packet) and sent to the dispatch port 930 for the forwarding tables 940 to process again. Based on the tag, the forwarding tables 940 processes the packet using a different set of records. So logically, a different forwarding table is processing the packet.
The dispatch port 930 receives after the switching element 900 processes the network data according to the forwarding tables 940. As noted above, the switching element 900 might route the network data to the dispatch port 930 according to routing criteria defined the forwarding tables 940. When the dispatch port 930 receives network data, the dispatch port 930 sends the network data to the ingress ports 910 to be further processed by the forwarding tables 940. For example, the switching element 900 might modify the network data based on the forwarding tables 940 and send the modified network data to the dispatch port 930 for further processing by the forwarding tables 940.
The ingress ports 1010 are similar to the ingress ports 910 illustrated in
The management processor 1050 controls the operations and functions of the switching element 1000. As shown in
The management processor 1050 also receives configuration information through a configuration protocol. When the management processor 1050 receives configuration information, the management processor 1050 sends the configuration information to the configuration database 1060 for the configuration database 1060 to store. In some embodiments, configuration information includes information for configuring the switching element 1000, such as information for configuring ingress ports, egress ports, QoS configurations for ports, etc.
When the management processor 1050 of some embodiments receives switching control commands and the configuration commands, the management processor 1050 translates such commands into equivalent commands for configuring the switching element 1000 to implement the functionalities of the commands. For instance, when the management processor 1050 receives a command to add a flow entry, the management processor 1050 translates the flow entry into equivalent commands that configure the switching element 1000 to perform functions equivalent to the flow entry. In some embodiments, the management processor 1050 might request configuration information from the configuration database 1060 in order to perform translation operations.
Some embodiments of the management processor 1050 are implemented as electronic circuitry while other embodiments of the management processor 1050 are implemented as an embedded central processing unit (CPU) that executes switching element management software (e.g., OVS) that performs some or all of the functions described above.
The configuration database 1060 of some embodiments stores configuration information that the configuration database 1060 receives from the management processor 1050. In addition, when the management processor 1050 sends requests for configuration information to the configuration database 1060, the configuration database 1060 retrieves the appropriate configuration information and sends the requested configuration information to the management processor 1050.
In some embodiments, the control plane 1070 stores a set of flow tables that each includes a set of flow entries (also referred to collectively as configured flow entries). The control plane 1070 of some embodiments receives flow entries from the management processor 1050 to add to the set of flow tables, and receives requests from the management processor 1050 to remove and modify flow entries in the set of flow tables. In addition, some embodiments of the control plane 1070 might receive requests from the management processor 1050 for flow tables and/or flow entries. In such instances, the control plane 1070 retrieves the requested flow tables and/or flow entries and sends the flow tables and/or flow entries to the management processor 1050.
In addition, the control plane 1070 of some embodiments stores different flow tables and/or flow entries that serve different purposes. For instance, as mentioned above, a switching element may be one of several switching elements in a network across which multiple logical switching elements are implemented. In some such embodiments, the control plane 1070 stores flow tables and/or flow entries for operating in the physical domain (i.e., physical context) and stores flow tables and/or flow entries for operating in the logical domain (i.e., logical context). In other words, the control plane 1070 of these embodiments stores flow tables and/or flow entries for processing network data (e.g., packets) through logical switching elements and flow tables and/or flow entries for processing network the data through physical switching elements in order to implement the logical switching elements. In this manner, the control plane 1070 allows the switching element 1000 to facilitate implementing logical switching elements across the switching element 1000 (and other switching elements in the managed network).
In some embodiments, the flow tables and/or flow entries for operating in the physical domain process packets based on a set of fields in the packets' header (e.g., source MAC address, destination MAC address, source IP address, destination IP address, source port number, destination port number) and the flow tables and/or flow entries for operating in the logical domain process packets based on the packets' logical context ID (e.g., as described above by reference to
Some embodiments of the communication interface 1080 facilitate communication between management processor 1050 and packet processor 1090. For instance, when the communication interface 1080 receives messages (e.g., commands) from the management processor 1050, the communication interface 1080 forwards the messages to the packet processor 1090 and when the communication interface 1080 receives messages from the packet processor 1090, the communication interface 1080 forwards the messages to the management processor 1050. In some embodiments, the communication interface 1080 translates the messages such that the recipient of the message can understand the message before sending the message to the recipient. The communication interface 1080 can be implemented as a peripheral component interconnect (PCI) or PCI express bus in some embodiments. However, the communication interface 1080 may be implemented as other types of busses in other embodiments.
In some embodiments, the forwarding tables 1040 store active flow tables and/or flow entries that are used to determine operations for routing or modifying network data (e.g., packets). In some embodiments, active tables and/or flow entries are a subset of the flow tables and/or entries stored in the control plane 1070 that the forwarding tables 1040 is currently using or was recently using to process and route network data.
In this example, each flow entry is includes a qualifier and an action. The qualifier defines a set of fields to match against the network data. Examples of fields for matching network data include ingress port, source MAC address, destination MAC address, Ethernet type, VLAN ID, VLAN priority, multiprotocol label switching (MPLS) label, MPLS traffic class, source IP address, destination IP address, transport control protocol (TCP)/user datagram protocol (UDP)/stream control transmission protocol (SCTP) source port, and/or TCP/UDP/SCTP destination port. Other types of packet header fields are possible as well in other embodiments. The action of a flow entry defines operations for processing the network data when the network data matches the qualifier of the flow entry. Examples of actions include modify the network data and route the network data to a particular port or ports. Other embodiments provide additional and/or other actions to apply to the network data.
In some embodiments, the packet processor 1090 processes network data (e.g., packets) that the packet processor 1090 receives from the ingress ports 1010. Specifically, the packet processor 1090 processes (e.g., route, modify, etc.) the network data based on flow entries in the forwarding tables 1040. In order to process the network data, the packet processor 1090 accesses the flow entries in the forwarding tables 1040. As mentioned above, the forwarding tables 1040 include a subset of flow tables and/or flow entries stored in the control plane 1070. When the packet processor 1090 needs a flow table and/or flow entries that is not in the forwarding tables 1040, the packet processor 1090 requests the desired flow table and/or flow entries, which are stored in the control plane 1070, from the management processor 1050 through the communication interface 1080.
Based on the flow entries in the forwarding tables 1040, the packet processor 1090 sends the network data to one or more ports of the egress ports 1020 or the dispatch port 1030. In some embodiments, the network data may match multiple flow entries in the forwarding tables 1040. In such cases, the packet processor 1090 might process the network data based on the first flow entry that has a qualifier that matches the network data.
In some embodiments, the packet processor 1090 is an application-specific integrated circuit (ASIC) that performs some or all of the functions described above. In other embodiments, the packet processor 1090 is an embedded CPU that executes packet processing software that performs some or all of the functions described above.
Different embodiments of the switching element 1000 may implement the packet processor 1090 and forwarding tables 1040 differently. For instance, in some embodiments, the packet processor 1090 and forwarding tables 1040 are implemented as a multi-stage processing pipeline. In these embodiments, each flow entry in the forwarding tables 1040 are implemented as one or more operations along one or more stages of the multi-stage packet processing pipeline. As explained above, the management processor 1050 of some embodiments translates flow entries into equivalent commands that configure the switching element 1000 to perform functions equivalent to the flow entry. Accordingly, the management processor 1050 would configure the multi-stage packet processing pipeline to perform the functions equivalent to the flow entries in the forwarding tables.
In some embodiments, the physical ports 1140 of the physical host 1100 are a set of network interface controllers (NICs) that are for receiving network data and sending network data outside the physical host 1100. In some embodiments, the physical ports 1140 are a set of wireless NICs. The physical ports 1140 of other embodiments are a combination of NICs and wireless NICs.
The hypervisor 1145 (also referred to as a virtual machine monitor (VMM)) of some embodiments is a virtualization application that manages multiple operating systems (e.g., VMs) on the physical host 1100. That is, the hypervisor 1145 provides a virtualization layer in which other operating systems can run with the appearance of full access to the underlying system hardware (not shown) of the physical host 1100 except such access is actually under the control of the hypervisor 1145. In this example, the hypervisor 1145 manages the VMs 1120-1135 running on the physical host 1100.
In some embodiments, the hypervisor 245 manages system resources, such as memory, processors (or processing units), persistent storage, or any other type of system resource, for each of the operating systems that the hypervisor 1145 manages. For this example, the hypervisor 1145 manages the physical ports 1140, the network resources of the physical host 1100. In particular, the hypervisor 1145 manages and controls network data flowing through the physical ports 1140 and the patch ports 1150 by, for example, mapping each port of the patch ports 1150 to a corresponding port of the physical ports 1140.
Different embodiments use different hypervisors. In some embodiments, the hypervisor 1145 is a Xen hypervisor is used while, in other embodiments, the hypervisor 1145 is a VMware hypervisor. Other hypervisors can be used in other embodiments.
The patch ports 1150 are a set of virtual ports (e.g., virtual network interfaces (VIFs)). To the software switching element 1110 and the hypervisor 1145, the patch ports 1150 appear and behave similar to physical ports on a hardware switching element. For instance, the software switching element 1110 and the hypervisor 1145 may send and receive network data through the patch ports 1150. In some embodiments, the patch ports 1150 are provided by the hypervisor 1145 to the software switching element 1110 while, in other embodiments, the patch ports 1150 are provided by the software switching element 1110 to the hypervisor 1145.
The patch ports 1155 are a set of virtual ports that are similar to the patch ports 250. That is, to the software switching element 1110 and the VMs 1120-1135, the patch ports 1155 appear and behave similar to physical ports on a hardware switching element. As such, the software switching element 1110 and the VMs 1120-1135 may send and receive network data through the patch ports 1155. In some embodiments, the patch ports 1155 are provided by the software switching element 1110 to the VMs 1120-1135 while, in other embodiments, the patch ports 1155 are provided by the VMs 1120-1135 to the software switching element 1110.
As shown, the software switching element 1110 includes a control plane 1160, a configuration database 1165, a forwarding plane 1170, and forwarding tables 1175. The control plane 1160 of some embodiments is similar to the control plane 1070 of
In some embodiments, the forwarding plane 1170 and the forwarding tables 1175 performs functions similar to ones performed by packet processor 1090 and the forwarding tables 1040 described above by reference to
Based on the flow entries in the forwarding tables 1175, the forwarding plane 1170 sends the network data to one or more ports of the patch ports 1150 and/or one or more ports of the patch ports 1155. In some embodiments, the network data may match multiple flow entries in the forwarding tables 1175. In these instances, the forwarding plane 1170 might process the network data based on the first flow entry that has a qualifier that matches the network data.
As illustrated in
The hypervisor 1220 is a software abstraction layer that runs on top of the hardware 1205 and runs below any operation system. The hypervisor 1205 handles various management tasks, such as memory management, processor scheduling, or any other operations for controlling the execution of the VMs 1285-1295. Moreover, the hypervisor 1220 communicates with the VM 1285 to achieve various operations (e.g., setting priorities). In some embodiments, the hypervisor 1220 is a Xen hypervisor while, in other embodiments, the hypervisor 1220 may be any other type of hypervisor for providing hardware virtualization of the hardware 1205 on the host 1200.
As shown, the hypervisor 1220 includes device drivers 1225 and 1230 for the NICs 1210 and 1215, respectively. The device drivers 1225 and 1230 allow an operating system to interact with the hardware of the host 1200. In this example, the device driver 1225 allows the VM 1285 to interact with the NIC 1210. And the device driver 1230 allows the VM 1285 to interact with the NIC 1215. The hypervisor 1220 may include other device drivers (not shown) for allowing the VM 1285 to interact with other hardware (not shown) in the host 1200.
VMs 1285-1295 are virtual machines running on the hypervisor 1220. As such, the VMs 1285-1295 run any number of different operating systems. Examples of such operations systems include Solaris, FreeBSD, or any other type of Unix-based operating system. Other examples include Windows-based operating systems as well.
In some embodiments, the VM 1285 is a unique virtual machine, which includes a modified Linux kernel, running on the hypervisor 1220. In such cases, the VM 1285 may be referred to as domain 0 or dom0 in some embodiments. The VM 1285 of such embodiments is responsible for managing and controlling other VMs running on the hypervisor 1220 (e.g., VMs 1290 and 1295). For instance, the VM 1285 may have special rights to access the hardware 1205 of the host 1200. In such embodiments, other VMs running on the hypervisor 1220 interact with the VM 1285 in order to access the hardware 1205. In addition, the VM 1285 may be responsible for starting and stopping VMs on the hypervisor 1220. The VM 1285 may perform other functions for managing and controlling the VMs running on the hypervisor 1220.
Some embodiments of the VM 1285 may include several daemons (e.g., Linux daemons) for supporting the management and control of other VMs running on the hypervisor 1220. Since the VM 1285 of some embodiments is manages and controls other VMs running on the hypervisor 1220, the VM 1285 may be required to run on the hypervisor 1220 before any other VM is run on the hypervisor 1220.
As shown in
As shown, the user space of the VM 1285 includes the OVS daemon 1265 and the OVS DB daemon 1267. Other applications (not shown) may be included in the user space of the VM 1285 as well. The OVS daemon 1265 is an application that runs in the background of the user space of the VM 1285. Some embodiments of the OVS daemon 1265 communicate with a network controller 1280 in order to process and route packets that the VM 1285 receives. For example, the OVS daemon 1265 receives commands from the network controller 1280 regarding operations for processing and routing packets that the VM 1285 receives. The OVS daemon 1265 communicates with the network controller 1280 through the Openflow protocol. In some embodiments, another type of communication protocol is used. Additionally, some embodiments of the OVS daemon 1265 receives configuration information from the OVS DB daemon 1267 to facilitate the processing and routing of packets.
In some embodiments, the OVS DB daemon 1267 is also an application that runs in the background of the user space of the VM 1285. The OVS DB daemon 1267 of some embodiments communicates with the network controller 1280 in order to configure the OVS switching element (e.g., the OVS daemon 1265 and/or the OVS kernel module 1245). For instance, the OVS DB daemon 1267 receives configuration information from the network controller 1280 for configuring ingress ports, egress ports, QoS configurations for ports, etc., and stores the configuration information in a set of databases. In some embodiments, the OVS DB daemon 1267 communicates with the network controller 1280 through a database communication protocol (e.g., a JavaScript Object Notation (JSON) remote procedure call (RPC)-based protocol). In some embodiments, another type of communication protocol is utilized. In some cases, the OVS DB daemon 1267 may receive requests for configuration information from the OVS daemon 1265. The OVS DB daemon 1267, in these cases, retrieves the requested configuration information (e.g., from a set of databases) and sends the configuration information to the OVS daemon 1265.
The network controller 1280 is similar to the various network controllers described in this application, such as the ones described by reference to
The flow processor 1275 manages the rules for processing and routing packets. For instance, the flow processor 1275 stores rules (e.g., in a storage medium, such as a disc drive) that the flow processor 1275 receives from the Openflow protocol module 1270 (which, in some cases, the Openflow protocol module 1270 receives from the network controller 1280). In some embodiments, the rules are stored as a set of flow tables that each includes a set of flow entries (also referred to collectively as configured flow entries). As noted above, flow entries specify operations for processing and/or routing network data (e.g., packets) based on routing criteria. In addition, when the flow processor 1275 receives commands from the Openflow protocol module 1270 to remove rules, the flow processor 1275 removes the rules.
In some embodiments, the flow processor 1275 supports different types of rules. For example, the flow processor 1275 of such embodiments supports wildcard rules and exact match rules. In some embodiments, an exact match rule is defined to match against every possible field of a particular set of protocol stacks. A wildcard rule is defined to match against a subset of the possible fields of the particular set of protocol stacks. As such, different exact match rules and wildcard rules may be defined for different set of protocol stacks.
The flow processor 1275 handles packets for which integration bridge 1250 does not have a matching rule. For example, the flow processor 1275 receives packets from the integration bridge 1250 that does not match any of the rules stored in the integration bridge 1250. In such cases, the flow processor 1275 matches the packets against the rules stored in the flow processor 1275, which include wildcard rules as well as exact match rules. When a packet matches an exact match rule or a wildcard rule, the flow processor 1275 sends the exact match rule or the wildcard rule and the packet to the integration bridge 1250 for the integration bridge 1250 to process.
In some embodiment, when a packet matches a wildcard rule, the flow processor 1275 generates an exact match rule based on the wildcard rule to which the packet matches. As mentioned above, a rule, in some embodiments, specifies an action to perform based on a qualifier. As such, in some embodiments, the generated exact match rule includes the corresponding action specified in the wildcard rule from which the exact match rule is generated.
In other embodiment, when a packet matches a wildcard rule, the flow processor 1275 generates a wildcard rule that is more specific than the wildcard rule to which the packet matches. Thus, in some embodiments, the generated (and more specific) wildcard rule includes the corresponding action specified in the wildcard rule from which the exact match rule is generated.
In some embodiments, the flow processor 1275 may not have a rule to which the packet matches. In such cases, some embodiments of the flow process 1275 send the packet to the network controller 1280 (through the Openflow protocol module 1270). However, in other cases, the flow processor 1275 may have received from the network controller 1280 a catchall rule that drops the packet when a rule to which the packet matches does not exist in the flow processor 1275.
After the flow processor 1275 generates the exact match rule based on the wildcard rule to which the packet originally matched, the flow processor 1275 sends the generated exact match rule and the packet to the integration bridge 1250 for the integration bridge 1250 to process. This way, when the integration bridge 1250 receives a similar packet that matches generated the exact match rule, the packet will be matched against the generated exact match rule in the integration bridge 1250 so the flow processor 1275 does not have to process the packet.
Some embodiments of the flow processor 1275 support rule priorities for specifying the priority for a rule with respect to other rules. For example, when the flow processor 1275 matches a packet against the rules stored in the flow processor 1275, the packet may match more than one rule. In these cases, rule priorities may be used to specify which rule among the rules to which the packet matches that is to be used to match the packet.
The flow processor 1275 of some embodiments is also responsible for managing rules in the integration bridge 1250. As explained in further detail below, the integration bridge 1250 of some embodiments stores only active rules. In these embodiments, the flow processor 1275 monitors the rules stored in the integration bridge 1250 and removes the active rules that have not been access for a defined amount of time (e.g., 1 second, 3 seconds, 5, seconds, 10 seconds, etc.). In this manner, the flow processor 1275 manages the integration bridge 1250 so that the integration bridge 1250 stores rules that are being used or have recently been used.
Although
As illustrated in
The OVS kernel module 1245 processes and routes network data (e.g., packets) between VMs running on the host 1200 and network hosts external to the host 1200 (i.e., network data received through the NICs 1210 and 1215). For example, the OVS kernel module 1245 of some embodiments routes packets between VMs running on the host 1200 and network hosts external to the host 1200 (e.g., when packets are not routed through a tunnel) through a set of patch ports (not shown) that couple the OVS kernel module 1245 to the PIF bridges 1255 and 1260. In several of the figures in this application (e.g.,
To facilitate the processing and routing of network data, the OVS kernel module 1245 communicates with OVS daemon 1265. For example, the OVS kernel module 1245 receives processing and routing information (e.g., flow entries) from the OVS daemon 1265 that specifies how the OVS kernel module 1245 is to process and route packets when the OVS kernel module 1245 receives packets. Some embodiments of the OVS kernel module 1245 include a bridge interface (not shown) that allows the hypervisor network stack 1240 to send packets to and receiving packets from the OVS kernel module 1245. In other embodiments, the hypervisor 1240 sends packets to and receives packets from the bridges included in OVS kernel module 1245 (e.g., integration bridge 1250 and/or PIF bridges 1255 and 1260).
In some embodiments, the set of rules that the integration bridge 1250 stores are only exact match rules. The integration bridge 1250 of some such embodiments stores only active exact match rules, which are a subset of the rules stored in the flow processor 1275 (and/or rules derived from rules stored in the flow processor 1275) that the integration bridge 1250 is currently using or was recently using to process and route packets. The integration bridge 1250 of some embodiments stores a set of rules (e.g., flow entries) for performing mapping lookups and logical forwarding lookups, such as the ones described below in further detail by reference to
In some embodiments, the OVS kernel module 1245 includes a PIF bridge for each NIC in the hardware 1205. For instance, if the hardware 1205 includes four NICs, the OVS kernel module 1245 would include four PIF bridges for each of the four NICs in the hardware 1205. In other embodiments, a PIF bridge in the OVS kernel module 1245 may interact with more than one NIC in the hardware 1205.
The PIF bridges 1255 and 1260 route network data between the hypervisor network stack 1240 and network hosts external to the host 1200 (i.e., network data received through the NICs 1210 and 1215). As shown, the PIF bridge 1255 routes network data between the hypervisor network stack 1240 and the NIC 1210 and the PIF bridge 1260 routes network data between the hypervisor network stack 1240 and the NIC 1215. The PIF bridges 1255 and 1260 of some embodiments perform standard layer 2 packet learning and routing. In some embodiments, the PIF bridges 1255 and 1260 performs physical lookups/mapping, such as the ones described below in further detail by reference to
In some embodiments, the VM 1285 provides and controls the PIF bridges 1255 and 1260. However, the network controller 1280 may, in some embodiments, control the PIF bridges 1255 and 1260 (via the OVS daemon 1265) in order to implement various functionalities (e.g., quality of service (QoS)) of the software switching element.
In several of the figures in this application (e.g.,
The architectural diagram of the software switching element and the host illustrated in
The following will describe an exemplary operation of the OVS switching element illustrated in
Furthermore, the OVS kernel module 1245 can receive a packet from a network host external to the host 1200 through one of the NICs 1210 and 1215, the NIC's corresponding PIF bridge (i.e., PIF bridge 1225 or PIF bridge 1230), and the hypervisor network stack 1240. The hypervisor network stack 1240 then sends the packets to the integration bridge 1250 of the OVS kernel bridge 1245. In some cases, the packet is received from a network host external to the host 1200 through a tunnel. In some embodiments, the tunnel terminates at the hypervisor network stack 1240. Thus, when the hypervisor network stack 1240 receives the packet through the tunnel, the hypervisor network stack 1240 unwraps (i.e., decapsulates) the tunnel header and determines, based on the tunnel information (e.g., tunnel ID), which integration bridge of the OVS kernel module 1245 to which to send the unwrapped packet. As mentioned above, the OVS kernel module 1245 of some embodiments may include an integration bridge for each logical switching element that is implemented across the managed network to which the OVS switching element belongs. Accordingly, the hypervisor network stack 1240 determines the logical switching element to which the tunnel belongs, identifies the integration bridge that corresponds to the determined logical switching element, and sends the packet to the identified integration bridge.
In addition, the OVS kernel module 1245 can receive a packet from a network host external to the host 1200 through one of the NICs 1210 and 1215, the NIC's corresponding PIF bridge (i.e., PIF bridge 1225 or PIF bridge 1230), and a set of patch ports (not shown) that couple the PIF bridge to the OVS kernel module 1245. As noted above, the OVS kernel module 1245 of some embodiments may include an integration bridge for each logical switching element that is implemented across the managed network to which the OVS switching element belongs. Accordingly, the NIC's corresponding PIF bridge determines the logical switching element to which the tunnel belongs, identifies the integration bridge that corresponds to the determined logical switching element, and sends the packet to the identified integration bridge.
When the integration bridge 1250 receives a packet in any of the manners described above, the integration bridge 1250 processes the packet and routes the packet. As noted above, some embodiments of the integration bridge 1250 stores only active exact match rules, which are a subset of the rules stored in the flow processor 1275 (and/or rules derived from rules stored in the flow processor 1275) that the integration bridge 1250 is currently using or was recently using to process and route packets. The integration bridge 1250 performs a lookup based on a set of fields in the packet's header (e.g., by applying a hash function to the set of fields). In some embodiments, the set of fields may include a field for storing metadata that describes the packet. If the lookup returns a rule to which the packet matches, the integration bridge 1250 performs the action (e.g., forward the packet, drop the packet, reprocess the packet, etc.) specified in the rule. However, if the lookup does not return a rule, the integration bridge 1250 sends the packet to the flow processor 1275 to process.
As explained above, the flow processor 1275 handles packets for which the integration bridge 1250 does not have a matching rule. When the flow processor 1275 receives the packet from the integration bridge 1250, the flow processor 1275 matches the packet against the rules stored in the flow processor 1275, which include wildcard rules as well as exact match rules. When a packet matches an exact match rule, the flow processor 1275 sends the exact match rule and the packet to the integration bridge 1250 for the integration bridge 1250 to process. When a packet matches a wildcard rule, the flow processor 1275 generates an exact match rule based on the wildcard rule to which the packet matches, and sends the generated exact match rule and the packet to the integration bridge 1250 for the integration bridge 1250 to process.
Although
The network controller 1310 is similar to the network controllers described above by reference to
In some embodiments, the switching element 1320 is a software switching element (e.g., the OVS switching element illustrated in
As shown, the switching element 1320 includes a user space daemon 1325 and a forwarding plane 1355. The user space daemon 1325 includes an OVS connection manager 1330, a configuration database controller 1335, a configuration database 1340, a control plane controller 1345, and a control plane 1350. The OVS connection manager 1330 manages the connection between the network controller 1310 and the configuration database controller 1335, and the connection between the network controller 1310 and the control plane controller 1345 so that communications received over a particular connection is routed to the appropriate controller.
In some embodiments, the OVS connection manager 1330 translates the commands and/or messages into a format that the recipient can understand. For example, when the network controller 1310 sends a command to the switching element 1320 through the database connection, the OVS connection manager 1330 may translate the command so that the configuration database controller 1335 can understand the command. Similarly, when the network controller 1310 sends a command to the switching element 1320 through the Openflow connection, the OVS connection manager 1330 may translate the command so that the control plane controller 1345 can understand the command.
The configuration database controller 1340 of some embodiments manages the configuration database 1340 and receives commands from the OVS connection manager 1330 related to the configuration database 1340. Examples of commands include create a table, delete a table, create a record in a table, modify (i.e., update) a record in a table, delete a record in a table, among other types of database commands. When the configuration database controller 1335 receives a command from the OVS connection manager 1330, the configuration database controller 1335 performs the corresponding action to the configuration database 1340.
The configuration database 1335 is similar to the configuration database 1060, which is described above by reference to
Some embodiments of the control plane controller 1345 manage the Openflow rules stored in the control plane 1350 and receives commands from the OVS connection manager 1330 related to the control plane 1350. Examples of commands include add a rule, modify (i.e., update) a rule, delete a rule, or other types of Openflow commands. When the configuration database controller 1335 receives a command from the OVS connection manager 1330, the configuration database controller 1335 performs the command's corresponding action to the configuration database 1340.
The control plane 1350 is similar to the control plane 1070, which is described above by reference to
The forwarding plane 1355 is similar to the forwarding plane described above by reference to
In some embodiments, a packet includes a header and a payload. The header includes, in some embodiments, a set of fields that contains information used for routing the packet through a network. Switching elements may determine switching decisions based on the contained in the header and may, in some cases, modify some or all of the header fields. As explained above, some embodiments determine switching decisions based on flow entries in the switching elements' forwarding tables.
In some embodiments, the processing pipeline 1400 may be implemented by flow entries in the managed switching elements in the network. For instance, some or all of the flow entries are defined such that the packet is processed against the flow entries based on the logical context tag in the packet's header. Therefore, in some of these embodiments, the managed switching elements are configured (e.g., by a network controller illustrated in
In the first stage 1410 of the processing pipeline 1400, a logical context lookup is performed on a packet to determine the logical context of the packet. In some embodiments, the first stage 1410 is performed when the logical switching element receives the packet (e.g., the packet is initially received by a managed switching element in the network that implements the logical switching element).
In some embodiments, a logical context represents the state of the packet with respect to the logical switching element. For example, some embodiments of the logical context may specify the logical switching element to which the packet belongs, the logical port of the logical switching element through which the packet was received, the logical port of the logical switching element through which the packet is to be transmitted, the stage of the logical forwarding plane of the logical switching element the packet is at, etc. Referring to
Some embodiments determine the logical context of a packet based on the source MAC address of the packet (i.e., the machine from which the packet was sent). Some embodiments perform the logical context lookup based on the source MAC address of the packet and the inport (i.e., ingress port) of the packet (i.e., the port of the managed switching element through which the packet was received). Other embodiments may use other fields in the packet's header (e.g., MPLS header, VLAN id, etc.) for determining the logical context of the packet.
After the logical context of the packet is determined, some embodiments store the information that represents the determined logical context in one or more fields of the packet's header. These fields may also be referred to as a logical context tag or a logical context ID. Furthermore, the logical context tag may coincide with one or more known header fields (e.g., the VLAN id field) in some embodiments. As such, these embodiments do not utilize the known header field or its accompanying features in the manner that the header field is defined to be used.
In the second stage 1420 of the processing pipeline 1400, logical forwarding lookups are performed on the packets to determine where to route the packet based on the logical switching element (e.g., the logical port of the logical switching element of which to send the packet out) through which the packet is being processed. In some embodiment, the logical forwarding lookups include a logical ingress ACL lookup for determining access control when the logical switching element receives the packet, a logical L2 lookup for determining where to route the packet through a layer 2 network, and a logical egress ACL lookup for determining access control before the logical switching element routes the packet out of the logical switching element. Alternatively, or in conjunction with the logical L2 lookup, some embodiments of the logical forwarding lookups include a logical L3 lookup for determining where to route the packet through a layer three network. These logical lookups are performed based on the logical context tag of the packet in some of these embodiments.
In some embodiments, the result of the logical forwarding lookups may include dropping the packet, forwarding the packet to one or more logical egress ports of the logical switching element, or forwarding the packet to a dispatch port of the logical switching element. When the logical forwarding lookups determines that the packet is to be routed to the dispatch port of the logical switching element, some embodiments repeat the logical forwarding lookups until the packet is determined to be either dropped or forwarded to one or more logical egress ports.
Next, the third stage 1430 of the processing pipeline 1400 performs a mapping lookup on the packet. In some embodiments, the mapping lookup is a logical to physical mapping lookup that determines the logical egress port of the logical switching element. That is, the mapping lookup determines one or more ports of one or more managed switching elements that correspond to the logical egress port of the logical switching element through which the packet is to be sent out. For instance, if the packet is a broadcast packet or a multicast packet, the third stage 1430 of some embodiments determines the ports of the managed switching elements that correspond to the logical egress ports of the logical switching element through which the packet is to be broadcasted or multicasted out (i.e., the logical ports to which the intended recipients of the packet is coupled). If the packet is a unicast packet, the third stage 1430 determines a port of a managed switching element that corresponds to the logical egress port of the logical switching element through which the packet is to be sent out (i.e., the logical port to which the intended recipient of the packet is coupled). In some embodiments of the third stage 1430, the mapping lookups are performed based on the logical context tag of the packet.
At the fourth stage 1440 of the processing pipeline 1400, a physical lookup is performed. The physical lookup of some embodiments determines operations for routing the packet to the physical port(s) that corresponds to the logical egress port(s) that was determined in the third stage 1430. For example, the physical lookup of some embodiments determines one or more ports of the managed switching element on which the processing pipeline 1400 is being performed through which to send the packet out in order for the packet to reach the physical port(s) determined in the third stage 1430. This way, the managed switching elements can route the packet along the correct path in the network for the packet to reach the determined physical port(s) that corresponds to the logical egress port(s).
Some embodiments remove the logical context tag after the fourth stage 1440 is completed in order to return the packet to its original state before the packet was processed by the processing pipeline 1400.
As mentioned above, in some embodiments, the processing pipeline 1400 is performed by each managed switching element in the managed network that is used to implement the logical switching element. In some embodiments, some of the managed switching elements perform only a portion of the processing pipeline 1400. For example, in some embodiments, the managed switching element that initially receives the packet may perform the first-fourth stages 1410-1440 and the remaining managed switching elements that subsequently receive the packet only perform the first, third, and fourth stages 1410, 1430, and 1440.
The process 1500 begins by determining (at 1505) whether the packet has a logical context tag. When the process 1500 determines that the packet does not have a logical context tag, the process 1500 determines (at 1510) whether the packet matches a flow entry that specifies a logical context. In some embodiments, the process 1500 determines the packet's logical context in a similar fashion as that described above by reference to the first stage 1410 of
When the process 1500 determines that the packet does not match a flow entry that specifies a logical context, the process 1500 drops (at 1535) the packet and the process 1500 then ends. When the process 1500 determines that the packet matches a flow entry that specifies a logical context, the process 1500 adds (at 1515) a logical context tag to the header of the packet. After the process 1500 adds the logical context tag to the header of the packet, the process 1500 proceeds to 1520. When the process 1500 determines that the packet does have a logical context tag, the process 1500 proceeds to 1520.
At 1520, the process 1500 determines whether the packet matches a flow entry that specifies the packet's logical context tag to be modified. In some embodiments, the flow entries that the process 1500 matches the packet against are flow entries that implement the logical ingress ACL lookup described above by reference to the second stage 1420 of
Next, the process 1500 determines (at 1530) whether the packet matches a flow entry that specifies the packet to be dropped. In some embodiments, the flow entries that the process 1500 matches the packet against are flow entries that implement the logical L2 lookup described above by reference to the second stage 1420 of
When the process 1500 determines that the packet does not match a flow entry that specifies the packet to be dropped, the process 1500 determines (at 1540) whether the packet matches a flow entry that specifies the destination of the packet is local. In some embodiments, the destination of the packet is local when the recipient of the packet is coupled to the managed switching element on which the process 1500 is being performed. When the process 1500 determines that the packet matches a flow entry that specifies the destination of the packet is local, the process 1500 removes (at 1545) the logical context tag from the packet's header. Next, the process 1500 forwards (at 1550) the packet to the local destination. In some embodiments, the process 1500 determines the local destination by matching the packet against flow entries that implement the logical L2 lookup described above by reference to the second stage 1420 of
When the process 1500 determines that the packet does not match a flow entry that specifies the destination of the packet is local, the process 1500 forwards (at 1555) the packet to the next managed switching element for further processing. Then, the process 1500 ends.
III. Hierarchical Switching Architecture
In some embodiments, the pool node 1605 is a switching element (e.g., a hardware switching element or an OVS) that is coupled to and positioned above the managed switching elements 130-150 in the hierarchy of the network architecture 1600 to assist in the implementation of logical switching elements across the managed switching elements 130-150. The following will describe some of the functions that some embodiments of the pool node 1605 provide.
The pool node 1605 of some embodiments is responsible for processing packets that the managed switching elements 130-150 cannot process. In instances where one of the managed switching elements 130-150 cannot process a packet, the managed switching element sends the packet to the pool node 1605 to process. For instance, the pool nodes 1605 processes packets with destination MAC addresses that are not known to one of the managed switching elements 130-150 (e.g., the managed switching element does not have a flow entry that matches the destination MAC address). In some cases, one of the managed switching elements 130-150 cannot process a packet due to the limited storage capacity of the managed switching element and does not include flow entries for processing the packet. Another example where the managed switching elements 130-150 cannot process a packet is because the packet is destined for a remote network that may not be managed by the network controllers 110 and 120.
In some embodiments, the pool node 1605 serves as a communication bridge between managed switching elements. Referring to
Some embodiments of the pool node 1605 process packets are that are intended for multiple recipients (e.g., broadcast packets and multicast packets) in the same logical network. For instance, when one of the managed switching elements 130-150 receives a broadcast or multicast packet from one of the machines, the managed switching element sends the broadcast or multicast packet to the pool node 1605 for processing. Referring to
As explained above, the pool node 1605 of some embodiments processes packets that are intended for multiple recipients in the same logical network.
In this example, tenant B's machine 165 sends a multi-recipient packet (e.g., a broadcast packet or a multicast packet) to the managed switching element 130. In some embodiments, the multi-recipient packet specifies a destination MAC address that is defined (e.g., by a network controller managing) to indicate the packet is a multi-recipient packet. Some embodiments might indicate that the packet is a multi-recipient packet through data stored in a set of fields (e.g., a context tag) in the packet's header. The managed switching element 130 identifies the packet as a multi-recipient packet based on the defined destination MAC address and/or the set of header fields. Since the pool node 1605 is responsible for processing multi-recipient packets, the managed switching element 130 forwards the packet to the pool node 1605 for processing.
When the pool node 1605 receives the packet from the managed switching element 130, the pool node 1605 determines that the packet is a multi-recipient packet by examining the destination MAC address of the packet and/or the set of header fields. In some embodiments, the packet also specifies the logical network to which the packet belongs (e.g., via a context tag). In this example, the packet specifies that the packet belongs to the logical network that includes tenant B's machines (machines 165, 180, and 185 in this example). After the pool node 1605 determines that logical network to which the packet belongs, the pool node 1605 determines the managed switching elements to which to route the multi-recipient packet. Since the managed switching element 140 is not coupled to any of tenant B's machines, the pool node 1605 only forwards the multi-recipient packet to the managed switching element 150.
When the managed switching element 150 receives the packet, the managed switching element 150 determines that the packet is a multi-recipient packet by examining the destination MAC address of the packet. The managed switching element 150 then determines the logical network to which the packet belongs and identifies the machines coupled to the managed switching element 150 that belong to the logical network to which the packet belongs. For this example, the packet belongs to tenant B's logical network. Therefore, the managed switching element 150 identifies the machines 180 and 185 as the machines coupled to the managed switching element 150 that belong to tenant B's logical network. Then, the managed switching element 150 replicates the multi-recipient packet for each identified machine, modifies each replicated packet to specify the MAC address of the corresponding machine as the packet's destination MAC address, and sends the replicated packets to the machines.
As shown,
For this example, tenant A's machine 175 sends a multi-recipient packet (e.g., a broadcast packet or a multicast packet) to the managed switching element 150 that specifies tenant A's machine 155 and 160 as recipients of the packet. In some embodiments, the multi-recipient packet specifies a destination MAC address that is defined (e.g., by a network controller managing) to indicate the packet is a multi-recipient packet and the recipients of the multi-recipient packet. Some embodiments might indicate that the packet is a multi-recipient packet through data stored in a set of fields (e.g., a context tag) in the packet's header. The managed switching element 130 identifies the packet as a multi-recipient packet based on the defined destination MAC address and/or the set of header fields. As the pool node 1605 is responsible for processing multi-recipient packets, the managed switching element 150 forwards the packet to the pool node 1605 for processing.
When the pool node 1605 receives the packet from the managed switching element 150, the pool node 1605 determines that the packet is a multi-recipient packet by examining the destination MAC address of the packet and/or the set of header fields. In some embodiments, the packet also specifies the logical network to which the packet belongs (e.g., via a context tag). In this example, the packet specifies that the packet belongs to the logical network that includes tenant A's machines (machines 155, 160, 170, and 175 in this example). After the pool node 1605 determines the logical network to which the packet belongs, the pool node 1605 identifies the set of managed switching elements (the managed switching element 130 in this example) to which the intended recipients of the multi-recipient packet (the machines 155 and 160 in this example) are coupled. The pool node 1605 then replicates the multi-recipient packet and sends a copy of the multi-recipient packet to each of the identified set of managed switching elements.
The above description by reference to
As shown, the managed switching element 130 includes a forwarding table 1920 and the managed switching element 150 includes a forwarding table 1930. As noted above, the managed switching elements of some embodiments may have limited storage capacity and cannot store all the necessary flow entries to process the different packets in the network. In this example, the managed switching element 130 can only store 27 flow entries (i.e., 9 flow entries for each of the machines 155-165) and the managed switching element 150 can only store 21 flow entries (i.e., 7 flow entries for each of the machines 175-185). The flow entries in each of the forwarding tables 1920 and 1930 conceptually represent the packets that the managed switching elements 130 and 150 can process.
As described above, the pool node 1605 processes packets that the managed switching elements 130 and 150 cannot process (e.g., unknown destination MAC address, broadcast and multicast packets, etc.). As shown, the pool node 1605 includes a forwarding table 1910 with m+n flow entries. The flow entries in the forwarding table 1910 conceptually represent flow entries for processing packets that the managed switching elements 130 and 150 cannot process.
In some embodiments, a pool node includes all the flow entries that are used to manage the network. For instance, referring to
Although
The process 2000 starts by determining (at 2010) whether the packet has an unknown destination MAC address. In some embodiments, the destination MAC address of the packet is unknown when the managed switching element that is performing the process 2000 does not have a flow entry that matches the packet's destination MAC address. When the process 2000 determines that the packet does not have an unknown destination MAC address, the process 2000 proceeds to 2020. Otherwise, the process 2000 forwards (at 2060) the packet to a pool node and then the process 2000 ends.
Next, the process 2000 determines (at 2020) whether the packet can be processed. In some embodiments, the packet can be processed when the managed switching element on which the process 2000 is being performed has a flow entry that matches the packet. When the process 2000 determines that the packet cannot be processed, the process 2000 forwards (at 2060) the packet to a pool node and then the process 2000 ends.
When the process 2000 determines that the packet can be processed, the process 2000 processes (at 2030) the packet. The process 2000 of some embodiments processes the packet by performing the action specified in the flow entry that matches the packet. After processing the packet, the process 2000 proceeds to 2040.
At 2040, the process 2000 determines whether the packet is a multicast or broadcast packet. Some embodiments define a multicast or broadcast packet as a packet with defined values in a set of header fields (e.g., destination MAC address, inport, etc.). When the process 2000 determines that the packet is not a multicast or broadcast packet, the process 2000 ends. Otherwise, the process 2000 determines (at 2050) whether the packet needs further processing. A packet may need further processing when the packet is a multicast or broadcast packet and one or more of the recipients of the multicast or broadcast packet are unknown (e.g., the recipients are not coupled to the managed switching element that is performing the process 2000).
When the process 2000 determines that the packet needs further processing, the process 2000 forwards (at 2060) the packet to a pool node and then the process 2000 ends. When the process 2000 determines that the packet does not need further processing, the process 2000 ends.
In some embodiments, some or all of the operations in the process 2000 is implemented by flow entries in the managed switching element on which the process 2000 is performed. For instance, the managed switching element may include a set of flow entries that define a broadcast or multicast packet in some such embodiments. In such cases, the managed switching element performs a lookup on the set of flow entries to determine whether a packet is a broadcast or multicast packet (i.e., whether the packet matches against the set of flow entries).
In some embodiments, a root node is similar to a pool node in that the root node is a switching element (e.g., a hardware switching element or an OVS) that is for assisting in the implementation of logical switching elements across managed switching elements. However, the root node provides different functions than a pool node and is positioned at a different level in the network hierarchy. The following will describe some functions that the root node of some embodiments provides.
Some embodiments of the root nodes 2105 and 2110 provide a communication bridge between zones in the network. In some embodiments, a zone is a defined group of machines in a network. A zone may be defined any number of different ways in different embodiments. For instance, a zone may be defined as a group of machines in an office, a group of machines in a section of a data center, a group of machines in a building. As shown, zone 1 of the network architecture includes the pool nodes 2115 and 2120 and the managed switching elements 2135-2150 and the zone 2 of the network architecture includes the pool nodes 2125 and 2130 and the managed switching elements 2155-2170.
As shown in
In some embodiments, the root nodes 2105 and 2110 perform logical context learning. Logical context learning, in some embodiments, is a process of identifying the network element(s) to which packets are forwarded so that the packets can reach the packets' intended destination. Referring to
As described above,
As shown, the pool node 2210 includes pool node network stack 2220, the root bridge 2230, patch bridge 2240, and a set of NICs 2250. In some embodiments, each NIC in the set of NICs 2250 is typical network interface controllers for connecting a computing device to one or more networks and sending and receiving network data (e.g., packets) over such networks. In addition, the set of NICs 2250 sends and receives network data from the pool node network stack 2220.
The pool node network stack 2220 is similar to the hypervisor network stack described above by reference to
In some embodiments, the patch bridge 2240 stores a set of rules (e.g., flow entries) that specify operations for processing and routing packets. The patch bridge 2240 communicates with a network controller 2260 in order to process and route packets that the patch bridge 2240 receives. For instance, the patch bridge 2240 receives commands from the network controller 2260 related to processing and routing of packets that the pool node 2210 receives. In some embodiments, the patch bridge 2240 communicates with the network controller 2260 through the Openflow protocol while, in other embodiments, another type of communication protocol may be used. The network controller 2260 is similar to the various network controllers described in this application, such as the ones described by reference to
As explained above, a pool node of some embodiments is responsible for processing packets that managed switching elements in a managed network cannot process. In this example, the patch bridge 2240 processes and routes such packets. The patch bridge 2240 receives packets from managed switching elements through the set of NICs 2250 and the pool node network stack 2220. When the patch bridge 2240 receives a packet, the patch bridge 2240 processes and routes the packet according to the set of rules stored in the patch bridge 2240. In some cases, the patch bridge 2240 cannot process a packet (e.g., the patch bridge 2240 does not have a rule to which the packet matches). In these cases, the patch bridge 2240 sends the packet to the root bridge 2230 for processing.
Some embodiments of the root bridge 2230 are responsible for a learning function. The root bridge 2230 of some embodiments stores a set of tables of learned MAC addresses (unlike the pool nodes and managed switches of some embodiments, which are controlled by a network controller). The root bridge 2230 learns MAC addresses in the typical manner that layer 2 switches learn MAC addresses. For instance, when the root bridge 2230 does not know a MAC address (i.e., a destination MAC address of a packet is not included in the set of tables of learned MAC addresses), the root bridge 2230 floods all of the ports of the root bridge 2230 and records the MAC address of the packet that responds to the flood in the set of tables. As another example, when the root bride 2230 receives a packet that includes a destination MAC address that the root bridge 2230 does not know (i.e., the destination MAC address of the packet is not included in the set of tables of learned MAC addresses), the root bridge 2230 records the source MAC address of the packet in the set of tables of learned MAC addresses. When the root bridge 2230 knows the MAC address of a packet (i.e., the MAC address is included in the set of tables of learned MAC addresses), the root bridge 2230 sends the packet to the patch bridge 2240 to forward to the appropriate NIC in the set of NICs 2250 in order for the packet to reach the packet's destination. In some embodiments, the root bridge 2230 and the patch bridge 2240 communicate through a set of patch ports, which are for connecting two bridges directly together. In some embodiments, the root bridge 2230 may be directly connected to one or more extenders. In some of these embodiments, a tunnel is established between the root bridge 2230 and each of the extenders in order for the root bridge 2230 and the extenders to communicate.
Although
In some embodiments, an extender is a switching element (e.g., a hardware switching element or an OVS) for communicatively bridging remote managed networks that are separated by one or more other networks. As shown in
The above
The unmanaged network zone includes an extender 2410, switching elements 1-n, and multiple end hosts. One of ordinary skill in the art will realize that the unmanaged network zone may include any number of different networks and end hosts, as indicated by dashed lines in
Since the network elements (e.g., switching elements 1-n) in the unmanaged network zone are not used to implement logical switching elements (i.e., not controlled by a network controller), the network elements in the unmanaged network zone will not recognize logical context tags defined for the managed network. Accordingly, some embodiments of the extenders 2405 and 2410 remove the logical context tag from packets before sending the packets to the network elements of the unmanaged network zone. In some embodiments, the extender 2405 removes the logical context tag from packets to be forwarded to the extender 2410 while, in other embodiments, the extender 2410 removes the logical context tag from packets that the extender 2410 receives from the extender 2405 and that are to be forwarded to network elements in the unmanaged network zone.
Conversely, some embodiments of the extenders 2405 and 2410 add logical context tags to packets that are received from network elements in the unmanaged network zone and destined for the managed network zone. For instance, the extender 2410 of some embodiments may add a logical context tag to a packet that the extender 2410 receives from one of the network elements (e.g., switching elements 1-n). The logical context tag may, in some embodiments, indicate that the packet belongs to a generic logical context representing packets that originate from an unmanaged network that are destined for the managed network zone. In some embodiments, the extender 2410 adds the logical context tag to the packet when the extender 2410 receives the packets from network elements in the unmanaged network zone while, in other embodiments, the extender 2405 adds the logical context tag to the packet when the extender 2405 receives the packets from the extender 2410.
As illustrated in
The unmanaged network zone includes an extender 2555, switching elements 1-n, and multiple machines. One of ordinary skill in the will realize that the unmanaged network zone may include any number of different networks and end hosts, as indicated by dashed lines. In addition,
In some embodiments, the extender 2555 in the unmanaged network zone is configured before deploying the extender in the unmanaged network zone. For example, some embodiments require an IP address of a network controller (or a network controller of a control cluster) that is will be controlling the extender 2555 to be specified (e.g., through a command line interface provided by the extender 2555).
Because the network elements (e.g., switching elements 1-n) in the unmanaged network zone are not used to implement logical switching elements (i.e., not controlled by a network controller), the network elements in the unmanaged network zone will not recognize logical context tags defined for the managed network. Therefore, some embodiments of the extender 2555 removes the logical context tag from packets before sending the packets to the network elements of the unmanaged network zone through the network 2560. In addition, the extender 2555 of some embodiments adds logical context tags to packets that are received from network elements in the unmanaged network zone and destined for the managed network. For instance, the extender 2555 of some embodiments may add a logical context tag to a packet that the extender 2555 receives from one of the network elements (e.g., switching elements 1-n). The logical context tag may, in some embodiments, indicate that the packet belongs to a generic logical context representing packets that originate from an unmanaged network. In some embodiments, the extender 2555 adds the logical context tag to the packet when the extender 2555 receives the packets from network elements in the unmanaged network zone that are destined for the managed network zone.
Although
In some embodiments, the extender 2630 receives packet from the managed network zone that includes a logical context tag. Referring to
The extender 2630 of some embodiments maps packets from the unmanaged network zone to the managed network zone. In some of these embodiments, the extender 2630 identifies a logical context for the packets and adds a logical context tag that represents the identified logical context. Referring to
While
The extender 2785 essentially functions similar to the VM 1285, as explained above. Thus, NICs 2710 and 2715 function similar to the NICs 1210 and 1215, extender network stack 2740 functions similar to the hypervisor network stack 1240, PIF bridges 2755 and 2760 function similar to the PIF bridges 1255 and 1260, integration bridge 2750 functions similar to the integration bridge 1250, flow processor 2775 functions similar to the flow processor 1275, and Openflow protocol module 2770 functions similar to the Openflow protocol module 1270. However, the extender 2785 of some embodiments serves different purposes in a managed network, as noted above, and, thus, may be configured differently by a network controller of the managed network.
As described above, a software switching element may be an OVS that runs on a physical host in some embodiments. In this example, the software switching elements 2815-2825 are OVSs that each runs a physical host. On the right side of
To distribute packet processing between the pool nodes 2805 and 2810, each of the pool nodes 2805 and 2810 needs to be able to process a given packet. As such, the pool nodes 2805 and 2810 each include the same set of flow entries, in some embodiments. This way, either the pool node 2805 or the pool node 2810 can process a given packet.
Moreover, each of the software switching elements 2815-2825 needs to be able to access both of the pool nodes 2805 and 2810 in some embodiments. As such, some embodiments couple the software switching elements 2815-2825 to the pool nodes 2805 and 2810 using tunnels that are provided by tunneling protocols that are described above by reference to
In some embodiments, software switching elements 2815-2825 send packets to the pool nodes 2805 and 2810 through designated ports. The designated ports are referred to as uplink ports in some embodiments. As shown in
As mentioned above,
As the number of pool nodes, root nodes, and/or managed switching elements increases in a manage network utilizing a full tunnel mesh configuration, the complexity of the configuration can increase and the resources for establishing tunnels can decrease.
As illustrated in
Referring to
The process 3000 is similar in many respects to the process 2000 described above by reference to
The operations 3010-3050 of the process 3000 are the same as the operations 2010-2050 of the process 2000. That is, the process 3000 determines (at 3010) whether the packet has an unknown destination MAC address. If the packet has an unknown destination MAC address, the process 3000 continues to 3060. Otherwise, the process 3000 determines (at 3020) whether the packet can be processed. If the packet cannot be processed, the process 3000 proceeds to 3060. If the process 3000 determines that the packet can be processed, the process 3000 processes (at 3030) the packet and then the process 3000 determines (at 3040) whether the packet is a multicast or broadcast packet.
If the process 3000 determines that the packet is not a multicast or broadcast packet, the process 3000 ends. Otherwise, the process 3000 determines (at 3050) whether the packet needs further processing. If the packet does not need further processing, the process 3000 ends. Otherwise, the process 3000 proceeds to 3060.
At 3060, the process 3000 applies a hash function on a set of fields of the packet. Different embodiments of the process 3000 apply a hash function on different sets of fields of the packet. For instance, some embodiments apply a hash function on the source MAC address of the packet while other embodiments apply a hash function on the source IP address of the packet. In some embodiments, a hash function is applied on the destination MAC address of the packet. Some embodiments may apply a hash function on both the source MAC address and the source IP address. Other ways of applying a hash function on the packet are possible in other embodiments.
Finally, the process 3000 forwards (at 3070) the packet to a pool node based on the hash of the packet. In some embodiments, the hash function used to hash the packet may be defined based on the number of pool nodes from which to choose in the managed network. For instance, referring to
The ingress ports 3110, the egress ports 3120, the dispatch port 3130, and the forwarding tables 3140 are similar to the ingress ports 910, the egress ports 920, the dispatch port 930, and the forwarding tables 940, which are described above by reference to
In some embodiments, the packet processor 3150 is similar to the packet processor 1090, which is described above by reference to
In some embodiments, the hash function module 3160 performs a hash function on the packet and returns a hash value. As mentioned above, different embodiments define different types of hash functions that can be applied on different sets of fields of the packet (e.g., the source MAC address, the source IP address, etc.). The hash function module 3160 of some embodiments receives hash functions from the virtualization application 3175.
The range list module 3170 of some embodiments restricts the hash values of the hash functions to a defined range of values. The range of values corresponds to the number of pool nodes in the managed network from which a pool node can be selected. Some embodiments of the range list module 3170 restrict the hash values of the hash function to the defined range of values by mapping hash values to a corresponding value in the defined range of values.
In some embodiments, the virtualization application 3175 is similar to the virtualization applications described above by reference to
Further, the virtualization application 3175 sends defined hash functions to the hash function module 3160, in some embodiments. When a pool node is added or removed (e.g., the pool node fails) from the managed network, some embodiments of the virtualization application 3175 alternatively, or in conjunction with redefining a range of values for the range list module 3170, redefine a hash function and provide the redefined hash function to the hash function module 3160.
The following will describe an example packet processing operation to determine a pool node to which to send a packet. When the switching element 3100 receives a packet through a port of the ingress ports 3110, the packet is forwarded to the packet processor 3150 to process. The packet processor 3150 matches the packet against the flow entries in the forwarding tables 3140 to process the packet. In this example, the packet is a multicast packet and needs to be processed by a pool node in the managed network. As such, the packet processor 3150 determines that the packet matches the first flow entry illustrated in the forwarding tables 3140. The first flow entry specifies to apply a hash function on the packet in order to select a pool node from the pool nodes 3180-3190 to which to sent the packet for processing.
The packet processor 3150 sends a copy of the packet to the hash function module 3160. The hash function module 3160 applies the defined hash function on the copy of the packet and returns a hash value to the packet processor 3150. Then, the packet processor 3150 sends the hash value to the range list module 3170 to receive a value that corresponds to one of the pool nodes 3180-3190. When the range list module 3170 receives the hash value from the packet processor 3150, the range list module 3170 identifies a value in a defined set of values to which the hash value maps and returns the identified value to the packet processor 3150. For this example, the identified value is 2.
Next, the packet processor 3150 stores the value that the packet processor 3150 receives from the range list module 3170 in the packet (e.g., in a logical context tag or another field in the packet header). The packet processor 3150 then sends the packet to the dispatch port 3130 for further processing. When the dispatch port 3130 receives the packet, the packet is sent back to a port of the ingress ports 3110. The packet is then forwarded back to the packet processor 3150 for processing.
Alternatively, some embodiments of the packet processor 3150 store the value that the packet processor 3150 receives from the range list module 3170 as metadata that is associated with (instead of stored in the packet itself) and passed along with the packet. In some of these embodiments, the packet processor 3150 sends the packet and the associated metadata to the dispatch port 3130 for further processing. When the dispatch port 3130 receives the packet and the associated metadata, the packet and the associated metadata is sent back to a port of the ingress ports 3110. The packet and the associated metadata is then forwarded back to the packet processor 3150 for processing.
The packet processor 3150 again matches the packet against the flow entries in the forwarding tables 3140 to process the packet. This time, the packet processor 3150 determines that the packet matches the third flow entry illustrated in the forwarding tables 3140. The third flow entry specifies that the packet be sent to uplink port 2, which corresponds to the pool node 3185 in this example. Accordingly, the packet processor 3150 sends the packet to the port of the egress ports 3120 that corresponds to the uplink port 2. In some embodiments, the packet processor 3150 removes the value (“2” in this example) resulting from the hash operation from the packet's header before sending the packet to the egress ports 3120.
IV. Defining Switching Infrastructures
The following section will describe several examples of operations that are performed when a managed network is operating. Some of the operations relate to pool node creation, root node creation, hash function updating, and network controller creation, among other operations.
The process 3200 begins by determining (at 3210) whether the managed network needs switching elements. In some embodiments, switching elements include pool nodes, root nodes, and extenders. The process 3200 of some embodiments can determine whether the managed network needs switching elements based on several factors. Examples of such factors include the number of machines, VMs, hosts, and any other type of network host in the managed network, the number of managed switching elements in the managed network, the attributes of the managed switching elements (e.g., hardware switching element or software switching element, amount of memory, amount of processing power, etc.) in the managed networks, the number of tenants in the managed network, etc. When the process 3200 determines that the managed network does not need switching elements, the process 3200 proceeds to 3230.
When the process 3200 determines that the managed network needs switching elements, the process 3200 creates (at 3220) a set of switching elements for the managed network. Some embodiments of the process 3200 determine the number of switching elements to create based on the same or similar factors listed above for the operation 3210.
Next, the process 3200 creates (at 3230) tunnels in the managed network. As described in various sections above, different embodiments create tunnels for different purposes and in different situations. For instance, some embodiments use tunnels to connect pool nodes and managed switching elements in a full tunnel mesh configuration in order to distribute packet processing between the pool nodes. Some embodiments use tunnels to form cliques of managed switching elements.
Finally, the process 3200 populates (at 3240) flow entries in the managed switching elements and switching elements in the managed network. Flow entries specify operations for processing packets as the packets flow through the various managed switching elements and switching elements in the managed network. As such, the process 3200 of some embodiments determines and defines flow entries for each managed switching element and switching element in the managed network. In some embodiments, flow entries are determined and defined based on the same factors used in the operation 3210 described above. Some embodiments also take into account the switching elements, if any, that were created at the operation 3220 and the tunnels that were created at the operation 3230 in determining and defining the flow entries. After the process 3200 determines and defines all the flow entries, the process 3200 populates the flow entries into the respective managed switching elements and switching elements (e.g., through a switching control protocol, such as the Openflow protocol). The process 3200 then ends.
At any given time while a managed network is operating, changes to the managed network (e.g., machines added, machines removed, switching elements added, switching elements removed, etc.) may occur. In some embodiments, the managed network may be reconfigured (e.g., by a network controller managing the managed network) in response to a change. For instance, additions of machines to the managed network might require additional switching elements (e.g., managed switching elements, pool nodes, root nodes, etc.). Conversely, when machines are removed from the managed network, switching elements might be removed from the managed network as well. Different embodiments consider any number of different factors in determine when and in what manner to respond to a change in the managed switching element. Several of the following figures illustrate examples of how a managed network may respond to changes that occur to the managed network.
The first stage 3310 illustrates that the managed network 3300 includes a pool node 3330, managed switching elements 3340-3360, and machines belonging to a tenant A that are coupled to each of the managed switching elements 3340-3360. In addition, the first stage 3310 illustrates that tunnel is established between the each of the managed switching elements 3340-3360 and the pool node 3330, and between the managed switching element 3350 and the managed switching element 3360.
In the second stage 3320 of the managed network 3300, additional machines have been added to the managed network 3300. Specifically, machines that belong to a tenant B are now coupled to each of the managed switching elements 3340-3360. In this example, the pool node 3330 cannot handle processing load with the addition of tenant B's machines. Therefore, a set of network controllers (not shown) that are managing the managed network 3300 determined that the managed network 3300 requires another pool node 3380 to lessen the load on the pool node 3330.
In this example, only one pool node can support each of the managed switching elements 3340-3360. Therefore, the set of network controllers also determined that the pool node 3380 will support the managed switching element 3350. In response, the tunnel between the managed switching element 3350 and the pool node 3330 is torn down and a tunnel between the managed switching element 3350 and the pool node 3380 is established. As a result, the pool node 3330 and the managed switching element 3340 will not be able to communicate with the pool node 3380 and the managed switching elements 3350 and 3360. In addition, since there are multiple tenants in the managed network 3300, logical context learning needs to be performed. Thus, the set of network controllers determined to create a root node 3370 to provide a communication bridge between the pool nodes 3330 and 3380 and to perform logical context learning. As shown, tunnels between the pool nodes 3330 and 3380 and the root node 3370 are established.
As shown in the first stage 3405, the managed network 3400 includes a pool node 3420, cliques 3430 and 3440, and groups of machines 3450 and 3460, which to a tenant A. Each of the cliques 3430 and 3440 includes three managed switching elements that are coupled to each other with tunnels in a full tunnel mesh configuration. In addition, for each of the cliques 3430 and 3440, the managed switching elements each include the same set of flow entries (not shown). As shown, the machines 3450 are coupled to the clique 3430 and the machines 3460 are coupled to the clique 3440.
In this example, the pool node 3420 processes packets that the managed switching elements in the cliques 3430 and 3440 cannot process. As such, the cliques 3430 and 3440 are each coupled to the pool node 3420 through tunnels. That is, a tunnel is established between each of the managed switching elements in the cliques 3430 and 3440 and the pool node 3420.
The second stage 3410 illustrates that additional groups of machines 3480 and 3490 have been added to the managed network 3400. As shown, the machines 3480 are coupled to the managed switching elements in the clique 3430 and the machines 3490 are coupled to the managed switching elements in the clique 3440. In some embodiments, the addition of the machines 3480 and 3490 increases the load on the three managed switching elements in the cliques 3430 and 3440 that are illustrated in the first stage 3405. As a result, a set of network controllers (not shown) that are managing the managed network 3400 determined that the managed network 3400 requires additional managed switching elements. As illustrated in the second stage 3410 of
In some embodiments, the addition of the machines 3480 and 3490 and the managed switching elements to the cliques 3430 and 3440 also increases the load on the pool node 3420. The pool nodes 3420 may not have sufficient resources (e.g., memory or data storage) to handle all the packets that the managed switching elements in the cliques 3430 and 3440 cannot handle. Thus, the set of network controllers has also determined that the managed network 3400 needs another pool node 3470. As shown in the second stage 3410, the pool node 3470 has been created and added to the managed network 3400. In this example, the packet processing distribution technique described above by reference to
As explained above, some embodiments use a hashing technique to distribute packet processing that managed switching elements cannot handle across several pool nodes in a managed network.
The first stage 3510 illustrates that the managed network includes the switching element 3540 and pool nodes 3560 and 3570. As shown, the switching element 3540 includes a forwarding plane 3550. The forwarding plane 3550 of some embodiments is similar to the forwarding plane 1170 described above by reference to
In addition, the forwarding plane 3550 includes a hash function X. The hash function X represents is a hash function that the forwarding plane 3550 uses to select one of the pool nodes 3560 and 3570 when the forwarding plane 3550 wants to send a packet to a pool node for processing. In this example, packet processing is distributed based on logical datapaths. Therefore, different logical datapaths in a logical datapath set may be distributed to different pool nodes. The hash function X may be applied to data in the packet (e.g., a header field, such as a logical context tag) that represents the logical datapath to which the packet belongs, in some embodiments. The first stage 3510 shows that the hash function X is defined to map packets that belong to the logical datapath of flow A to the pool node 3560, map packets that belong to the logical datapath of flow B to the pool node 3560, and map packets that belong to the logical datapath of flow C to the pool node 3570.
In the second stage 3520, another pool node 3580 is added to the managed network, as indicated by a box with dashed lines. The pool node 3580 includes the same set of flow entries as the pool nodes 3560 and 3580. At this stage 3520, the hash function for selecting a pool node is still hash function X. As shown, packets that belong to the logical datapath of flow A are still mapped to the pool node 3560, packets that belong to the logical datapath of flow B are still mapped to the pool node 3560, and packets that belong to the logical datapath of flow C are still mapped to the pool node 3570.
The third stage 3530 illustrates the switching element 3540 after the hash function X has been updated to a hash function Y in response to the addition of the pool node 3580. In some embodiments, the hash function Y is provided to the switching element 3540 by a network controller that manages the switching element 3540. The hash function Y is defined to evenly distribute packets that belong to the logical datapaths A, B, and C. For this example, the hash function Y maps packets that belong to the logical datapath of flow A to the pool node 3560, maps packets that belong to the logical datapath of flow B to the pool node 3570, and maps packets that belong to the logical datapath of flow C to the pool node 3580.
While
The process 3600 begins by determining (at 3610) whether a change in the status of pool nodes in the managed network has occurred. In some embodiments, a change in the status of the pool nodes includes a pool node is added to the managed network, a pool node is removed from the managed network, or a pool node in the managed network is not functioning. A change in the status of pool nodes in the managed network may include additional and/or other types of events in other embodiments.
When the process 3600 determines that a change in the status of the pool nodes has occurred, the process 3600 updates (at 3620) the status of uplink ports on the managed switching elements in the managed network. For instance, when a pool node is added to the managed network, the process 3600 of some embodiments updates the status of the uplink ports on the managed switching elements to include another uplink port for the newly added pool node. Conversely, when a pool node is removed from the managed network, some embodiments of the process 3600 updates the status of the uplink ports on the managed switching elements to remove an uplink port. Next, the process 3600 sends (at 3630) an updated hash flow entry to the managed switching elements. In some embodiments, the hash flow entry specifies the hash function for the managed switching elements to select a pool node in the managed network to which to send packets that the managed switching elements cannot process. The process 3600 then ends.
When the process 3600 determines that a change in the status of the pool nodes has not occurred, the process 3600 continues to 3640, the process 3600 determines (at 3640) whether a hash error has occurred on one of the managed switching elements in the managed network. Examples of hash errors include hash value collisions, hash values that are outside a defined range, etc. When the process 3600 determines that a hash error has occurred on one of the managed switching elements in the managed network, the process 3600 sends (at 3630) an updated hash flow entry to the managed switching elements. As noted above, some embodiments sends a hash flow entry that specifies a hash function for the managed switching elements to select a pool node in the managed network to which to send packets that the managed switching elements cannot process. Specifically, the process 3600 sends a hash flow entry that corrects the hash error. Then, the process 3600 ends.
In some embodiments, the process 3600 is constantly repeated while the network controller is managing the managed switching elements in the managed network in order to continue checking for changes in the status of pool nodes in the managed network and updating the hash flow entries in the managed switching elements accordingly. In other embodiments, the process 3600 is repeated at defined intervals (e.g., 1 minute, 5 minutes, 30 minutes, 1 hour, etc.).
The above description of
Some embodiments utilize tunnel “bundling” as a pool node fault tolerance technique. In some such embodiments, each pool node in the network is designated a failover pool node so that packets destined for the failed pool node may quickly continue to be processed by the network architecture. In some embodiments, the failover pool node is referred to as a secondary pool node and the pool node for which the failover pool node is designated is referred to as a primary pool node.
Different embodiments designate secondary pool nodes for the primary pool nodes in the network differently. For instance, some embodiments specify, for a particular primary pool node, another primary pool node in the network as a secondary pool node.
In addition, since the pool node B was designated as the secondary pool node for the pool node 1, the managed switching element 3705 has modified the hierarchy traversal table 3715 to no longer specify a secondary pool node for the pool node 1. However, in some embodiments, the managed switching element 3705 automatically designates new secondary pool nodes when a pool node fails. The managed switching element 3705, for example, may designate the pool node C as the secondary pool node for the pool node 1 and designate the pool node A as the secondary pool node for the pool node 2.
Instead of specifying one of the primary pool nodes in the network as a secondary pool node of a particular primary pool node, some embodiments may provide backup pool nodes as secondary pool nodes. The backup pool nodes of some embodiments are configured to stand by and replace a primary pool node when the primary pool node fails.
Moreover, by utilizing a tunnel bundling technique, the tunnels to the pool nodes and the pool nodes may be viewed as a single entity (a “bundle” of tunnels) from the perspective of the network controllers in the network. Specifically, the network controllers view the managed switching element as coupled to a single pool node through a single tunnel. In some such embodiments, the network controllers may send flow entries that only specify that packets be sent to a pool node instead of having to determine the number of pool nodes in the network and to specify pool node to which the packet be sent. In other words, the managed switching elements are responsible for selecting a pool node when a packet to be sent to a pool node for processing.
By having the managed switching elements 3705 and 3710 handle pool node failures, the network controller or control cluster managing the managed network does not need to specify new flow entries to the managed switching elements 3705 and 3710 each time a pool node fails. In addition, the response time to a pool node failure is faster by implementing this functionality in the managed switching elements 3705 and 3710 instead of the network controller or control cluster.
The first stage 3810 of
The second stage 3820 of
Similar to the second stage 3320, the pool node 3330, at the second stage 3820, cannot handle processing load with the addition of tenant B's and tenant C's machines. Therefore, the network controller 3830 determined that the managed network 3800 requires another pool node 3380 to lessen the load on the pool node 3330. As a result, the tunnel between the managed switching element 3350 and the pool node 3330 is torn down, a tunnel between the managed switching element 3350 and the pool node 3380 is established, and a root node 3380 is created to provide a communication bridge between the pool nodes 3330 and 3380 and to perform logical context learning.
In addition, the second stage 3820 illustrates that another network controller 3840 has been added to the control cluster. In some embodiments, the computation demands of a network controller 3830 increases as the number of tenants increases in the managed network 3800 since the network controller would have to implement a logical switching element for each additional tenant across the managed switching elements in the managed network. Similarly, an increase in the number of machines and/or switching elements in the managed network 3800 would increase the computational demands of the network controller 3830.
In this example, the network controller cannot handle the load of managing managed network 3800 due to the addition of tenant B's and tenant C's machines to the managed network 3800. For instance, the network controller 3830 would have to define logical datapath sets for each of the tenants B and C in order to implement corresponding logical switching elements for the tenants across the managed switching elements 3340-3360 in the managed network 3800. Therefore, the network controller 3830 determined to add the network controller 3840 to assist in the management of the managed network 3800.
As shown,
Referring to the example illustrated in
Thus, in order to maximize reliability of the control cluster, additions of network controllers to the control clusters are constrained to numbers that maximizes the size of the minority of network controllers in the control cluster.
The first stage 3850 of
The second stage 3860 of
While some factors for determining whether to add a network controller to a managed network have been described above, other embodiments may consider additional and/or other factors as well in such a determination.
Some embodiments may provide a network controller fault tolerance method for handling the failure of a network controller. In some embodiments, a logical switching element is managed by only one network controller (but a network controller may manage more than one logical switching elements). Thus, some of these embodiments specify, for a particular network controller, another network controller as a failover network controller in the event the particular network controller fails. In some embodiments, the failover network controller is referred to as a secondary network controller and the network controller for which the failover network controller is specified is referred to as a primary network controller.
In
Additionally, since the network controller A was designated as the secondary network controller for the logical switching element 3, the network controllers B and C have modified the logical switching element master table 4710 to no longer specify a secondary network controller for the logical switching element 3. However, in some embodiments, the network controllers B and C may automatically designate new secondary network controllers when a network controller fails. For instance, the network controllers B and C may specify the network controller C as the secondary network controller for the logical switching element 1 and specify the network controller B as the secondary network controller for the logical switching element 3.
Although
In
Furthermore, since the network controller B was designated as the secondary network controller for the managed switching element 1, the network controllers A and C have modified the managed switching element master table 4810 to no longer specify a secondary network controller for the managed switching element 1. However, the network controllers A and C of some embodiments may automatically specify new secondary network controllers when a network controller fails. For instance, the network controllers A and C may specify the network controller C as the secondary network controller for the managed switching element 1 and specify the network controller A as the secondary network controller for the logical switching element 2.
V. Logical Processing
The process 3900 starts by mapping (at 3910) the packet to a logical context. As noted above, a logical context of some embodiments represents the state of the packet with respect to a logical switching element. The process 3900 maps the packet to the packet's logical context in order to identify the stage in the logical switching element the packet is at.
Next, the process 3900 performs (at 3920) logical processing on the packet. Different embodiments perform logical processing on the packet differently. For example, the logical switching element may be implemented as a layer 2 switching element. In these cases, the logical processing includes performing logical layer 2 operations on the packet, such as performing a logical layer 2 lookup on the packet to determine the logical egress port of the logical switching element through which to send the packet.
In some cases, the process 3900 performs only a portion of the logical processing on the packet. For example, the process 3900 may start performing the logical processing on the packet, but the process 3900 does not complete the logical processing. Rather than waste the logical processing that has already been performed on the packet, the process 3900 modifies the logical context of the packet to indicate the stage in the logical processing that the packet is at so that logical processing on the packet can resume where the logical processing left off the next time the logical processing is performed on the packet (e.g., by the managed switching element that receives the packet next).
Other instances where the process 3900 performs only a portion of the logical processing on the packet is when a portion of the logical processing has already been performed on the packet (e.g., by a previous managed switching element). In these instances, the logical context of the packet, which was identified by the mapping of the packet to a logical context in the operation 3910, indicates the stage in the logical processing that the packet is at. Accordingly, the process 3900 resumes performing the logical processing on the packet at this point in the logical processing.
After the process 3900 performs the logical processing (or a portion of the logical processing) on the packet, the process 3900 maps (at 3930) the result of the logical processing of the packet a corresponding physical result. For example, when the result of the logical processing of the packet determines a logical port of the logical switching element through which to send the packet, the process 3900 maps the logical port(s) to a corresponding physical port(s) (e.g., a port of a managed switching element that is used to implement the logical switching element) through which to send the packet. In some embodiments, the physical port may be a physical port of a managed switching element that is different from the managed switching element that is performing the process 3900.
Finally, the process 3900 performs (at 3940) physical processing on the packet to determine the physical port of the managed switching element that is performing the process 3900 through which to send the packet so the packet reaches the physical port(s) determined at the operation 3930.
In some embodiments, a packet includes a header and a payload. The header includes, in some embodiments, a set of fields that contains information used for routing the packet through a network. Switching elements may determine switching decisions based on the contained in the header and may, in some cases, modify some or all of the header fields. As explained above, some embodiments determine switching decisions based on flow entries in the switching elements' forwarding tables.
In some embodiments, the processing pipeline 4000 may be implemented by flow entries in the managed switching elements in the network. For instance, some or all of the flow entries are defined such that the packet is processed against the flow entries based on the logical context tag in the packet's header. Therefore, in some of these embodiments, the managed switching elements are configured (e.g., by a network controller illustrated in
As shown,
The first stage 4020 is similar to the first stage 1410 of the processing pipeline 1400, which is described above by reference to
Some embodiments determine the logical context of a packet based on the source MAC address of the packet (i.e., the machine from which the packet was sent). Some embodiments perform the logical context lookup based on the source MAC address of the packet and the inport (i.e., ingress port) of the packet (i.e., the port of the managed switching element through which the packet was received). Other embodiments may use other fields in the packet's header (e.g., MPLS header, VLAN id, etc.) for determining the logical context of the packet.
After the first stage 4020 is performed, some embodiments store the information that represents the logical context in one or more fields of the packet's header. These fields may also be referred to as a logical context tag or a logical context ID. Furthermore, the logical context tag may coincide with one or more known header fields (e.g., the VLAN id field) in some embodiments. As such, these embodiments do not utilize the known header field or its accompanying features in the manner that the header field is defined to be used. Alternatively, some embodiments store the information that represents the logical context as metadata that is associated with (instead of stored in the packet itself) and passed along with the packet.
In some embodiments, the second stage 4030 is defined for the logical switching element. In some such embodiments, the second stage 4030 operates on the packet's logical context to determine ingress access control of the packet with respect to the logical switching element. For example, an ingress ACL is applied to the packet to control the packet's access to the logical switching element when the logical switching element receives the packet. The ingress ACL may be defined to implement other ACL functionalities, such as counters, port security (e.g., allow packets received through a port that originated only from a particular machine(s)), and machine isolation (e.g., allow broadcast/multicast packets received from a particular machine to be sent to only machines that belong to the same tenant or logical switching element), among other ACL functionalities. Based on the ingress ACL defined for the logical switching element, the packet may be further processed (e.g., by the third stage 4040) or the packet may be dropped, for example.
In the third stage 4040 of the processing pipeline 4000, logical processing is performed on the packet in the context of the logical switching element. In some embodiments, the third stage 4040 operates on the packet's logical context to process and route the packet with respect to the logical switching element. Different embodiments define logical processing for the logical switching element differently. For instance, some embodiments define a logical layer 2 table for processing the packet at layer 2 of the logical network. Alternatively, or in conjunction with the logical layer 2 table, some embodiments define a logical layer 3 table for processing the packet at layer 3 of the logical network. Other embodiments may define other logical process for the packet at the stage 4040.
The fourth stage 4050 of some embodiments is defined for the logical switching element. The fourth stage 4050 of some such embodiments operates on the packet's logical context to determine egress access control of the packet with respect to the logical switching element. For instance, an egress ACL may be applied to the packet to control the packet's access out of the logical switching element after logical processing has been performed on the packet. Based on the egress ACL defined for the logical switching element, the packet may be further processed (e.g., sent out of a logical port of the logical switching element or sent to a dispatch port for further processing) or the packet may be dropped, for example.
In the fifth stage 4060 of the processing pipeline 4000 is similar to the third stage 1430 of the processing pipeline 1400, which is described above by reference to
The sixth stage 4070 of the processing pipeline 4000 performs a physical mapping based on the egress context mapping performed at the fifth stage 4060. In some embodiments, the physical mapping determines operations for routing the packet to the physical port that was determined in the fifth stage 4060. For example, the physical mapping of some embodiments determines one or more queues in the set of queues 4080 associated with one or more ports of the set of ports 4080 of the managed switching elements that is performing the processing pipeline 4000 through which to send the packet in order for the packet to reach the physical port(s) determined in the fifth stage 4060. This way, the managed switching elements can route the packet along the correct path in the network for the packet to reach the determined physical port(s). Also, some embodiments remove the logical context tag after the sixth stage 4070 is completed in order to return the packet to its original state before the packet was processed by the processing pipeline 4000.
As mentioned above, in some embodiments, the processing pipeline 4000 is performed by each managed switching element in the managed network that is used to implement the logical switching element. The processing pipeline 4000 of some embodiments may be distributed across the managed switching elements in the managed network. For example, in some embodiments, the second-fourth stages 4030-4050 are distributed across the managed switching elements in the managed network. In some of these embodiments, the managed switching element that initially receives the packet may perform the first-sixth stages 4020-4070 and the remaining managed switching elements that subsequently receive the packet only perform the first, fifth, and sixth stages 4020, 4060, and 4070.
As explained above, a packet, in some embodiments, includes a header and a payload. In some embodiments, the header includes a set of fields that contains information used for routing the packet through a network. Switching elements may determine switching decisions based on the fields contained in the header and may, in some cases, modify some or all of the header fields. As explained above, some embodiments determine switching decisions based on flow entries in the switching elements' forwarding tables.
In this example, the 64-bit context tag is a field that is included in the header of a packet. As shown, the 64-bit context tag includes a 32-bit virtual routing function (VRF) field, a 16-bit logical inport field, and a 16-bit logical outport field. The 32-bit VRF field represents the logical switching element to which the packet belongs and the stage of the logical forwarding plane of the logical switching element the packet is at, the 16-bit logical inport field represents the logical port of the logical switching element through which the packet was received, and the 16-bit logical outport field represents the logical port of the logical switching element through which the packet is to be transmitted.
In some embodiments, the processing pipeline 4100 may be implemented by flow entries in the managed switching elements in the network. For instance, some or all of the flow entries are defined such that the packet is processed against the flow entries based on the 64-bit logical context tag in the packet's header. Therefore, in some of these embodiments, the managed switching elements are configured (e.g., by a network controller illustrated in
As shown,
At the first stage 4120 of the processing pipeline 4100, a physical to logical mapping is performed on a packet to determine the logical context of the packet. In this example, the physical to logical mapping of the first stage 4120 determines the logical switching element to which the packet belongs, the stage of the logical forwarding plane of the logical switching element the packet is at, and the logical port of the logical switching element through which the packet was received. In some embodiments, the first stage 4120 is performed when the logical switching element receives the packet (e.g., the packet is initially received by a managed switching element in the network that implements the logical switching elements).
Different embodiments determine the logical context of a packet based on different fields of the packet's header. For instance, as shown in
After the first stage 4120 is performed, some embodiments store the information that represents the logical context in the packet's 64-bit logical context tag, as illustrated by arrows from the stage 4120 to the corresponding fields below. For example, the logical switching element to which the packet belongs and the stage of the logical forwarding plane of the logical switching element the packet is at is stored in the 32-bit VRF field, and the logical port of the logical switching element through which the packet was received is stored in the 16-bit logical inport field.
In some embodiments, the second stage 4130 is defined for the logical switching element. In this example, the second stage 4130 operates on the packet's 64-bit logical context tag to determine access control of the packet with respect to the logical switching element. As shown by arrows pointing from the fields below to the stage 4130, an ACL operates on the 16-bit logical inport field and the 32-bit VRF field of the packet's 64-bit logical context tag, which results in allowing the packet to be further processed (e.g., by the third stage 4140), denying the packet (i.e., dropping the packet), or enqueuing the packet. In some embodiments, enqueuing the packet involves sending the packet to a queue in the set of queues 4180 that is associated with a port in the set of egress ports 4190 for QoS purposes. In addition, the ACL may be defined to implement other ACL functionalities (not shown), such as counters, port security (e.g., allow packets received through a port that originated only from a particular machine(s)), and machine isolation (e.g., allow broadcast/multicast packets received from a particular machine to be sent to only machines that belong to the same tenant or logical switching element), among ACL functionalities.
In the third stage 4140 of the processing pipeline 4100, the packet is processed against a logical L2 (layer 2) table to determine a logical outport, which corresponds to a logical port of the logical switching element through which the packet is to be sent. As shown by arrows pointing from the fields below to the stage 4140, the L2 table operates on the 16-bit logical inport field and the 32-bit VRF field of the packet's 64-bit logical context tag in addition to the destination MAC address of the packet. After the third stage 4140 is performed, some embodiments store the information that represents the determined logical outport in the 16-bit logical outport field of the packet's 64-bit logical context tag, as illustrated by an arrow from the stage 4140 to the outport field below.
At the fourth stage 4150 of the processing pipeline 4100, a logical to physical mapping is performed to identify one or more physical ports of one or more managed switching elements in the managed network that corresponds to the logical outport, which was determined in the third stage 4140, of the logical switching element. For this example, the fourth stage 4150 operates on the packet's 64-bit logical context tag to identify one or more physical ports in the set of egress ports 4190 through which to send the packet out in order for the packet to reach the determined logical outport. As shown by arrows pointing from the fields below to the stage 4150, the fourth stage 4150 operates on the 16-bit logical outport field and the 32-bit VRF field of the packet's 64-bit logical context tag, which results in setting the 64-bit logical context tag (e.g., saving the stage of the logical switching element that the packet is at, removing the 64-bit logical context tag), setting the one or more queues in the set of queues 4180 associated with the physical ports, and setting the one or more physical ports in the set of egress ports 4190 through which to send the packet out.
As mentioned above, in some embodiments, the processing pipeline 4100 is performed by each managed switching element in the managed network that is used to implement the logical switching element. The processing pipeline 4100 of some embodiments may be distributed across the managed switching elements in the managed network. For example, in some embodiments, the second and third stages 4130 and 4140 are distributed across the managed switching elements in the managed network. In some of these embodiments, the managed switching element that initially receives the packet may perform the first-fourth stages 4120-4150 and the remaining managed switching elements that subsequently receive the packet only perform the first and fourth stages 4120 and 4150.
In the above description of
As mentioned above, some embodiments may distribute the processing of a processing pipeline across managed switching elements in a managed network.
As illustrated in
As shown in the top half of
Based on the logical context and/or other fields stored in the packet 4230's header, the managed switching element 4210 identifies a record indicated by an encircled 2 (referred to as “record 2”) in the forwarding tables that implements the ingress ACL of the stage 4250. In this example, the record 2 allows the packet 4230 to be further processed and, thus, specifies the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port). In addition, the record 2 specifies that the managed switching element 4210 store the logical context (i.e., the packet 4230 has been processed by the second stage 4250 of the processing pipeline 4200) of the packet 4230 in the set of fields of the packet 4230's header.
Next, the managed switching element 4210 identifies, based on the logical context and/or other fields stored in the packet 4230's header, a record indicated by an encircled 3 (referred to as “record 3”) in the forwarding tables that implements the logical L2 forwarding of the stage 4260. The record 3 identifies the logical port of the logical switching element, which is implemented by the managed switching elements 4210 and 4220, to which the packet 4230 is to be forwarded. The record 3 also specifies that the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port). Also, the record 3 specifies that the managed switching element 4210 store the logical context (i.e., the packet 4230 has been processed by the third stage 4260 of the processing pipeline 4200) in the set of fields of the packet 4230's header.
Based on the logical context and/or other fields stored in the packet 4230's header, the managed switching element 4210 identifies a record indicated by an encircled 4 (referred to as “record 4”) in the forwarding tables that implements the egress ACL of the stage 4270. In this example, the record 4 allows the packet 4230 to be further processed and, thus, specifies the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port). In addition, the record 4 specifies that the managed switching element 4210 store the logical context (i.e., the packet 4230 has been processed by the fourth stage 4270 of the processing pipeline 4200) of the packet 4230 in the set of fields of the packet 4230's header.
In the fifth stage 4270 of the processing pipeline 4200, the managed switching element 4210 identifies, based on the logical context and/or other fields stored in the packet 4230's header, a record indicated by an encircled 5 (referred to as “record 5”) in the forwarding tables that implements the context mapping of the stage 4280. In this example, the record 5 identifies the VIF (not shown) of the managed switching element 4220 to which the VM 2 is coupled as the port that corresponds to the logical port of the logical switching element to which the packet 4230 is to be forwarded. The record 5 additionally specifies that the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port).
Based on the logical context and/or other fields stored in the packet 4230's header, the managed switching element 4210 then identifies a record indicated by an encircled 6 (referred to as “record 6”) in the forwarding tables that implements the physical mapping of the stage 4290. The record 6 specifies the port of the managed switching element 4210 through which the packet 4230 is to be sent in order for the packet 4230 to reach the VM 2. In this case, the managed switching element 4210 is to send the packet 4230 out of the port (not shown) of managed switching element 4210 that is coupled to the managed switching element 4220.
As shown in the bottom half of
Next, the managed switching element 4220 identifies, based on the logical context and/or other fields stored in the packet 4230's header, a record indicated by an encircled 2 (referred to as “record 2”) in the forwarding tables that implements the context mapping of the stage 4280. In this example, the record 2 identifies the VIF (not shown) of the managed switching element 4220 to which the VM 2 is coupled as the port that corresponds to the logical port of the logical switching element (which was determined by the managed switching element 4210) to which the packet 4230 is to be forwarded. The record 2 additionally specifies that the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port).
Based on the logical context and/or other fields stored in the packet 4230's header, the managed switching element 4220 identifies a record indicated by an encircled 3 (referred to as “record 3”) in the forwarding tables that implements the physical mapping of the stage 4290. The record 3 specifies the port of the managed switching element 4220 through which the packet 4230 is to be sent in order for the packet 4230 to reach the VM 2. In this case, the managed switching element 4220 is to send the packet 4230 out of the VIF (not shown) of managed switching element 4220 that is coupled to the VM 2.
The above description of
As illustrated in the bottom half of
Based on the logical context and/or other fields stored in the packet 4230's header, the managed switching element 4220 identifies a record indicated by an encircled 2 (referred to as “record 2”) in the forwarding tables that implements the egress ACL of the stage 4270. In this example, the record 2 allows the packet 4230 to be further processed and, thus, specifies the packet 4230 be further processed by the forwarding tables (e.g., by sending the packet 4230 to a dispatch port). In addition, the record 2 specifies that the managed switching element 4220 store the logical context (i.e., the packet 4230 has been processed by the fourth stage 4270 of the processing pipeline 4200) of the packet 4230 in the set of fields of the packet 4230's header. Finally, the managed switching element 4210 performs the context mapping of the stage 4280 and the physical mapping of the stage 4290 is a similar manner was that described above by reference to
While
As shown, flow entry 1 is for performing physical to logical mapping (i.e., ingress context mapping). The flow entry 1 specifies that when a packet is received on port 1, the packet's VLAN id is to be modified to 2057 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2057 represents the context of the packet and indicates that the packet has been received on port 1 of the managed switching element 1.
Flow entry 2 is for modifying the packet's context to indicate that the packet is at the start of logical processing (e.g., stages 4250-4270 of the processing pipeline 4200) of the processing pipeline. As shown, the flow entry 2 specifies that when a packet is received on port 4000 and the packet's VLAN id is 2057, the packet's VLAN id is to be modified to 2054 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2054 represents the context of the packet and indicates that the packet is at the start of the logical processing of the processing pipeline.
Next, flow entry 3 is for performing an ingress ACL lookup. As shown, the flow entry 3 specifies that when a packet is received on port 4000 and the packet's VLAN id is 2054, the packet's VLAN id is to be modified to 2055 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2055 represents the context of the packet and indicates that the packet has been processed by the ingress ACL and allowed through the ingress ACL.
Flow entries 4-6 are for performing logical lookups. The flow entry 4 specifies that when a packet is received on port 4000, the packet's VLAN id is 2055, and the packet's destination MAC address is 00:23:20:01:01:01, the packet's VLAN id is to be modified to 2056 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2056 represents the context of the packet and indicates that the packet is to be sent to the VM 1.
The flow entry 5 specifies that when a packet is received on port 4000, the packet's VLAN id is 2055, and the packet's destination MAC address is 00:23:20:03:01:01, the packet's VLAN id is to be modified to 2058 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2058 represents the context of the packet and indicates that the packet is to be sent to the VM 2.
The flow entry 6 specifies that when a packet is received on port 4000, the packet's VLAN id is 2055, and the packet's destination MAC address is ff:ff:ff:ff:ff:ff, the packet's VLAN id is to be modified to 2050 and the packet is to be submitted to port 4000, which is the dispatch port. The VLAN id of 2050 represents the context of the packet and indicates that the packet is a broadcast packet.
As shown, flow entry 7 is for performing logical to physical mapping (i.e., egress context mapping). The flow entry 7 specifies that when a packet is received on port 4000, and the packet's VLAN id is 2056, the packet's VLAN id is to be stripped (i.e., removed) and the packet is to be submitted to port 1 which is the port to which VM 1 is coupled. Thus, the flow entry 7 is for sending the packet to VM 1.
Flow entry 8 is for performing logical to physical mapping (i.e., egress context mapping). As illustrated in
Next, flow entry 9 is for processing a broadcast packet. Specifically, the flow entry 9 specifies that when a packet is received on port 4000 and the packet's VLAN id is 2050, the packet's VLAN id is to be modified to 2056 and the packet is to be submitted to port 4000, which is the dispatch port. In addition, the flow entry 9 specifies that when a packet is received on port 4000 and the packet's VLAN id is 2050, the packet's VLAN id is to be modified to 2056 and a copy of the packet is to be submitted to port 4000. Therefore, the flow entry 9 is for sending a broadcast packet to the VM 1 and to other VMs in the same logical network as the VM 1, which include the VM 2 in this example.
Flow entry 10 is for sending a broadcast packet to the pool node. As shown in
As shown, flow entry 11 is for performing logical to physical mapping (i.e., egress context mapping). The flow entry 11 specifies that when a packet is received on port 3, which is the tunnel (i.e., a tunnel port) that couples the managed switching element 1 to the managed switching element 2, and the packet's VLAN id is 2056, the packet's VLAN id is to be modified to 2056 and the packet is to be submitted to port 4000, which is the dispatch port. Therefore, the flow entry 11 is for sending the packet, which is received from the managed switching element 2, to the VM 1.
Next, flow entry 12 is for performing logical to physical mapping (i.e., egress context mapping). As illustrated, the flow entry 12 specifies that when a packet is received on port 2, which is the tunnel (i.e., a tunnel port) that couples the managed switching element 1 to the pool node, and the packet's VLAN id is 2056, the packet's VLAN id is to be modified to 2056 and the packet is to be submitted to port 4000, which is the dispatch port. As such, the flow entry 12 is for sending the packet, which is received from the pool node, to the VM 1.
Flow entry 13 is for performing a logical lookup. Specifically, the flow entry 13 is for sending all packets with unknown destination MAC addresses to a pool node via an uplink. As shown in
Finally, flow entry 14 is for sending a packet with an unknown MAC address to the pool node. As illustrated in
VI. Computer System
Many of the above-described features and applications are implemented as software processes that are specified as a set of instructions recorded on a computer readable storage medium (also referred to as computer readable medium). When these instructions are executed by one or more processing unit(s) (e.g., one or more processors, cores of processors, or other processing units), they cause the processing unit(s) to perform the actions indicated in the instructions. Examples of computer readable media include, but are not limited to, CD-ROMs, flash drives, RAM chips, hard drives, EPROMs, etc. The computer readable media does not include carrier waves and electronic signals passing wirelessly or over wired connections.
In this specification, the term “software” is meant to include firmware residing in read-only memory or applications stored in magnetic storage which can be read into memory for processing by a processor. Also, in some embodiments, multiple software inventions can be implemented as sub-parts of a larger program while remaining distinct software inventions. In some embodiments, multiple software inventions can also be implemented as separate programs. Finally, any combination of separate programs that together implement a software invention described here is within the scope of the invention. In some embodiments, the software programs, when installed to operate on one or more electronic systems, define one or more specific machine implementations that execute and perform the operations of the software programs.
The bus 4605 collectively represents all system, peripheral, and chipset buses that communicatively connect the numerous internal devices of the electronic system 4600. For instance, the bus 4605 communicatively connects the processing unit(s) 4610 with the read-only memory 4630, the GPU 4620, the system memory 4625, and the permanent storage device 4635.
From these various memory units, the processing unit(s) 4610 retrieve instructions to execute and data to process in order to execute the processes of the invention. The processing unit(s) may be a single processor or a multi-core processor in different embodiments. Some instructions are passed to and executed by the GPU 4620. The GPU 4620 can offload various computations or complement the image processing provided by the processing unit(s) 4610.
The read-only-memory (ROM) 4630 stores static data and instructions that are needed by the processing unit(s) 4610 and other modules of the electronic system. The permanent storage device 4635, on the other hand, is a read-and-write memory device. This device is a non-volatile memory unit that stores instructions and data even when the electronic system 4600 is off. Some embodiments of the invention use a mass-storage device (such as a magnetic or optical disk and its corresponding disk drive) as the permanent storage device 4635.
Other embodiments use a removable storage device (such as a floppy disk, flash drive, or ZIP® disk, and its corresponding disk drive) as the permanent storage device. Like the permanent storage device 4635, the system memory 4625 is a read-and-write memory device. However, unlike storage device 4635, the system memory is a volatile read-and-write memory, such a random access memory. The system memory stores some of the instructions and data that the processor needs at runtime. In some embodiments, the invention's processes are stored in the system memory 4625, the permanent storage device 4635, and/or the read-only memory 4630. For example, the various memory units include instructions for processing multimedia clips in accordance with some embodiments. From these various memory units, the processing unit(s) 4610 retrieve instructions to execute and data to process in order to execute the processes of some embodiments.
The bus 4605 also connects to the input and output devices 4640 and 4645. The input devices enable the user to communicate information and select commands to the electronic system. The input devices 4640 include alphanumeric keyboards and pointing devices (also called “cursor control devices”). The output devices 4645 display images generated by the electronic system. The output devices include printers and display devices, such as cathode ray tubes (CRT) or liquid crystal displays (LCD). Some embodiments include devices such as a touchscreen that function as both input and output devices.
Finally, as shown in
Some embodiments include electronic components, such as microprocessors, storage and memory that store computer program instructions in a machine-readable or computer-readable medium (alternatively referred to as computer-readable storage media, machine-readable media, or machine-readable storage media). Some examples of such computer-readable media include RAM, ROM, read-only compact discs (CD-ROM), recordable compact discs (CD-R), rewritable compact discs (CD-RW), read-only digital versatile discs (e.g., DVD-ROM, dual-layer DVD-ROM), a variety of recordable/rewritable DVDs (e.g., DVD-RAM, DVD-RW, DVD+RW, etc.), flash memory (e.g., SD cards, mini-SD cards, micro-SD cards, etc.), magnetic and/or solid state hard drives, read-only and recordable Blu-Ray® discs, ultra density optical discs, any other optical or magnetic media, and floppy disks. The computer-readable media may store a computer program that is executable by at least one processing unit and includes sets of instructions for performing various operations. Examples of computer programs or computer code include machine code, such as is produced by a compiler, and files including higher-level code that are executed by a computer, an electronic component, or a microprocessor using an interpreter.
While the above discussion primarily refers to microprocessor or multi-core processors that execute software, some embodiments are performed by one or more integrated circuits, such as application specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs). In some embodiments, such integrated circuits execute instructions that are stored on the circuit itself.
As used in this specification and any claims of this application, the terms “computer”, “server”, “processor”, and “memory” all refer to electronic or other technological devices. These terms exclude people or groups of people. For the purposes of the specification, the terms display or displaying means displaying on an electronic device. As used in this specification and any claims of this application, the terms “computer readable medium” and “computer readable media” are entirely restricted to tangible, physical objects that store information in a form that is readable by a computer. These terms exclude any wireless signals, wired download signals, and any other ephemeral signals.
While the invention has been described with reference to numerous specific details, one of ordinary skill in the art will recognize that the invention can be embodied in other specific forms without departing from the spirit of the invention. In addition, a number of the figures (including
This application is a continuation application of U.S. patent application Ser. No. 16/902,251, filed Jun. 15, 2020, now published as U.S. Patent Publication 2020/0396130. U.S. patent application Ser. No. 16/902,251 is a continuation application of U.S. patent application Ser. No. 16/034,035, filed Jul. 12, 2018, now issued as U.S. Pat. No. 10,686,663. U.S. patent application Ser. No. 16/034,035 is a continuation application of U.S. patent application Ser. No. 15/076,634, filed Mar. 21, 2016, now issued as U.S. Pat. No. 10,038,597. U.S. patent application Ser. No. 15/076,634 is a continuation application of U.S. patent application Ser. No. 13/218,477, filed Aug. 26, 2011, now issued as U.S. U.S. Pat. No. 9,306,875. U.S. patent application Ser. No. 13/218,477 is a continuation application of U.S. patent application Ser. No. 13/177,535, filed Jul. 6, 2011, now issued as U.S. Pat. No. 8,750,164; a continuation in part application of U.S. patent application Ser. No. 13/177,53513/177,536, filed on Jul. 6, 2011, now issued as U.S. Pat. No. 8,959,215; and a continuation in part application of U.S. patent application Ser. No. 13/177,538, filed on Jul. 6, 2011, now issued as U.S. Pat. No. 8,830,823. U.S. patent application Ser. No. 13/177,535, U.S. patent application Ser. No. 13/177,536, and U.S. patent application Ser. No. 13/177,538 claim benefit to U.S. Provisional Patent Application 61/361,912, filed on Jul. 6, 2010; U.S. Provisional Patent Application 61/361,913, filed on Jul. 6, 2010; U.S. Provisional Patent Application 61/429,753, filed on Jan. 4, 2011; U.S. Provisional Patent Application 61/429,754, filed on Jan. 4, 2011; U.S. Provisional Patent Application 61/466,453, filed on Mar. 22, 2011; U.S. Provisional Patent Application 61/482,205, filed on May 3, 2011; U.S. Provisional Patent Application 61/482,615, filed on May 4, 2011; U.S. Provisional Patent Application 61/482,616, filed on May 4, 2011; U.S. Provisional Patent Application 61/501,743, filed on Jun. 27, 2011; and U.S. Provisional Patent Application 61/501,785, filed on Jun. 28, 2011. U.S. patent application Ser. No. 13/218,477 claims the benefit of U.S. Provisional Patent Application 61/482,205, filed on May 3, 2011; U.S. Provisional Patent Application 61/482,615, filed on May 4, 2011; U.S. Provisional Application 61/482,616, filed on May 4, 2011; U.S. Provisional Patent Application 61/501,743, filed on Jun. 27, 2011; U.S. Provisional Patent Application 61/501,785, filed on Jun. 28, 2011; US. Provisional Patent Application 61/505,100, filed on Jul. 6, 2011; U.S. Provisional Patent Application 61/505,102, filed on Jul. 6, 2011; and U.S. Provisional Patent Application 61/505,103, filed on Jul. 6, 2011. These applications, namely Ser. Nos. 16/902,251, 16/034,035, 15/076,634, 13/218.477, 13/177,535, 61/361,912, 61/361,913, 61/429,753, 61/429,754, 61/466,453, 61/482,205, 61/482,615, 61/482,616, 61/501,743, and 61/501,785 are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5224100 | Lee et al. | Jun 1993 | A |
5245609 | Ofek et al. | Sep 1993 | A |
5265092 | Soloway et al. | Nov 1993 | A |
5504921 | Dev et al. | Apr 1996 | A |
5550816 | Hardwick et al. | Aug 1996 | A |
5729685 | Chatwani et al. | Mar 1998 | A |
5751967 | Raab et al. | May 1998 | A |
5796936 | Watabe et al. | Aug 1998 | A |
5831975 | Chen et al. | Nov 1998 | A |
5926463 | Ahearn et al. | Jul 1999 | A |
6006275 | Picazo et al. | Dec 1999 | A |
6055243 | Vincent et al. | Apr 2000 | A |
6104699 | Holender et al. | Aug 2000 | A |
6104700 | Haddock et al. | Aug 2000 | A |
6108304 | Abe et al. | Aug 2000 | A |
6141738 | Munter et al. | Oct 2000 | A |
6181697 | Nurenberg et al. | Jan 2001 | B1 |
6219699 | McCloghrie et al. | Apr 2001 | B1 |
6243720 | Munter et al. | Jun 2001 | B1 |
6272621 | Key et al. | Aug 2001 | B1 |
6359909 | Ito et al. | Mar 2002 | B1 |
6366582 | Nishikado et al. | Apr 2002 | B1 |
6377998 | Noll et al. | Apr 2002 | B2 |
6456624 | Eccles et al. | Sep 2002 | B1 |
6510135 | Almulhem et al. | Jan 2003 | B1 |
6512745 | Abe et al. | Jan 2003 | B1 |
6513108 | Kerr et al. | Jan 2003 | B1 |
6539432 | Taguchi et al. | Mar 2003 | B1 |
6574230 | Almulhem et al. | Jun 2003 | B1 |
6597658 | Simmons | Jul 2003 | B1 |
6611522 | Zheng et al. | Aug 2003 | B1 |
6654353 | Tokura et al. | Nov 2003 | B1 |
6658002 | Ross et al. | Dec 2003 | B1 |
6680934 | Cain | Jan 2004 | B1 |
6697338 | Breitbart et al. | Feb 2004 | B1 |
6717944 | Bryden et al. | Apr 2004 | B1 |
6728777 | Lee et al. | Apr 2004 | B1 |
6768740 | Perlman et al. | Jul 2004 | B1 |
6785843 | McRae et al. | Aug 2004 | B1 |
6792423 | Jeffries et al. | Sep 2004 | B1 |
6804263 | Okawa | Oct 2004 | B1 |
6862263 | Simmons | Mar 2005 | B1 |
6912221 | Zadikian et al. | Jun 2005 | B1 |
6917985 | Madruga et al. | Jul 2005 | B2 |
6934252 | Mehrotra et al. | Aug 2005 | B2 |
6941487 | Balakrishnan et al. | Sep 2005 | B1 |
6947433 | Carvey | Sep 2005 | B2 |
6950428 | Horst et al. | Sep 2005 | B1 |
6959002 | Wynne et al. | Oct 2005 | B2 |
6963585 | Pennec et al. | Nov 2005 | B1 |
6999454 | Crump | Feb 2006 | B1 |
7013342 | Riddle | Mar 2006 | B2 |
7042912 | Smith et al. | May 2006 | B2 |
7046630 | Abe et al. | May 2006 | B2 |
7061896 | Jabbari et al. | Jun 2006 | B2 |
7089240 | Basso et al. | Aug 2006 | B2 |
7096228 | Theimer et al. | Aug 2006 | B2 |
7120728 | Krakirian et al. | Oct 2006 | B2 |
7126923 | Yang et al. | Oct 2006 | B1 |
7149216 | Cheriton | Dec 2006 | B1 |
7158972 | Marsland | Jan 2007 | B2 |
7177943 | Temoshenko et al. | Feb 2007 | B1 |
7197561 | Lovy et al. | Mar 2007 | B1 |
7197572 | Matters et al. | Mar 2007 | B2 |
7200144 | Terrell et al. | Apr 2007 | B2 |
7209439 | Rawlins et al. | Apr 2007 | B2 |
7263290 | Fortin et al. | Aug 2007 | B2 |
7283465 | Zelig et al. | Oct 2007 | B2 |
7283473 | Arndt et al. | Oct 2007 | B2 |
7286490 | Saleh et al. | Oct 2007 | B2 |
7292542 | Wright | Nov 2007 | B2 |
7333487 | Novaes | Feb 2008 | B2 |
7339929 | Zelig et al. | Mar 2008 | B2 |
7342916 | Das et al. | Mar 2008 | B2 |
7343410 | Mercier et al. | Mar 2008 | B2 |
7349382 | Marimuthu et al. | Mar 2008 | B2 |
7352745 | Perera et al. | Apr 2008 | B2 |
7359971 | Jorgensen | Apr 2008 | B2 |
7369852 | Newberg et al. | May 2008 | B2 |
7382787 | Barnes et al. | Jun 2008 | B1 |
7391771 | Orava et al. | Jun 2008 | B2 |
7415463 | Testa | Aug 2008 | B2 |
7428220 | Caronni et al. | Sep 2008 | B1 |
7436782 | Ngo et al. | Oct 2008 | B2 |
7447203 | Chen et al. | Nov 2008 | B2 |
7450598 | Chen et al. | Nov 2008 | B2 |
7460482 | Pike | Dec 2008 | B2 |
7463579 | Lapuh et al. | Dec 2008 | B2 |
7478173 | Delco | Jan 2009 | B1 |
7483370 | Dayal et al. | Jan 2009 | B1 |
7483411 | Weinstein et al. | Jan 2009 | B2 |
7496597 | Rising | Feb 2009 | B2 |
7512744 | Banga et al. | Mar 2009 | B2 |
7522595 | Ben-Dvora et al. | Apr 2009 | B2 |
7529199 | Wijnands et al. | May 2009 | B1 |
7555002 | Arndt et al. | Jun 2009 | B2 |
7587492 | Dyck et al. | Sep 2009 | B2 |
7590669 | Yip et al. | Sep 2009 | B2 |
7606187 | Zeng et al. | Oct 2009 | B2 |
7606229 | Foschiano et al. | Oct 2009 | B1 |
7606260 | Oguchi et al. | Oct 2009 | B2 |
7616599 | Jabbari et al. | Nov 2009 | B2 |
7619966 | Lee | Nov 2009 | B2 |
7633961 | Raut et al. | Dec 2009 | B2 |
7643488 | Khanna et al. | Jan 2010 | B2 |
7646734 | Wright | Jan 2010 | B2 |
7649851 | Takashige et al. | Jan 2010 | B2 |
7660253 | Monette et al. | Feb 2010 | B2 |
7693073 | Soja-Molloy et al. | Apr 2010 | B2 |
7693158 | Carrie | Apr 2010 | B1 |
7702630 | Basso et al. | Apr 2010 | B2 |
7710872 | Vasseur | May 2010 | B2 |
7710874 | Balakrishnan et al. | May 2010 | B2 |
7715309 | Scholl et al. | May 2010 | B2 |
7764599 | Doi et al. | Jul 2010 | B2 |
7778259 | Mahalingaiah | Aug 2010 | B1 |
7783856 | Hashimoto et al. | Aug 2010 | B2 |
7792029 | Feld et al. | Sep 2010 | B2 |
7792046 | Kucharczyk et al. | Sep 2010 | B2 |
7792099 | Yasukawa et al. | Sep 2010 | B2 |
7792987 | Vohra et al. | Sep 2010 | B1 |
7796503 | Hamada et al. | Sep 2010 | B2 |
7796594 | Melman et al. | Sep 2010 | B2 |
7801137 | Vasseur et al. | Sep 2010 | B2 |
7802251 | Kitamura | Sep 2010 | B2 |
7805407 | Verbeke et al. | Sep 2010 | B1 |
7808919 | Nadeau et al. | Oct 2010 | B2 |
7808929 | Wong et al. | Oct 2010 | B2 |
7808983 | Joly | Oct 2010 | B2 |
7813340 | Novaes | Oct 2010 | B2 |
7817637 | Kitani et al. | Oct 2010 | B2 |
7818452 | Matthews et al. | Oct 2010 | B2 |
7822032 | Parker et al. | Oct 2010 | B1 |
7826482 | Minei et al. | Nov 2010 | B1 |
7830882 | Johnson | Nov 2010 | B2 |
7839847 | Nadeau et al. | Nov 2010 | B2 |
7855950 | Zwiebel et al. | Dec 2010 | B2 |
7856549 | Wheeler | Dec 2010 | B2 |
7876754 | Novaes | Jan 2011 | B2 |
7885276 | Lin | Feb 2011 | B1 |
7894450 | Unbehagen | Feb 2011 | B2 |
7895412 | Kerr et al. | Feb 2011 | B1 |
7899027 | Castagnoli et al. | Mar 2011 | B2 |
7907595 | Khanna et al. | Mar 2011 | B2 |
7912955 | Machiraju et al. | Mar 2011 | B1 |
7916739 | Trostle et al. | Mar 2011 | B2 |
7936770 | Frattura et al. | May 2011 | B1 |
7937438 | Miller et al. | May 2011 | B1 |
7948986 | Ghosh et al. | May 2011 | B1 |
7953865 | Miller et al. | May 2011 | B1 |
7961646 | Liu et al. | Jun 2011 | B2 |
7961652 | Wright | Jun 2011 | B2 |
7970917 | Nakano et al. | Jun 2011 | B2 |
7974202 | Solomon | Jul 2011 | B2 |
7978725 | Gong et al. | Jul 2011 | B2 |
7991859 | Miller et al. | Aug 2011 | B1 |
7995483 | Bayar et al. | Aug 2011 | B1 |
7995569 | Ashwood-Smith et al. | Aug 2011 | B2 |
8000261 | Nimon et al. | Aug 2011 | B2 |
8023414 | Soja-Molloy et al. | Sep 2011 | B2 |
8023465 | Prehofer | Sep 2011 | B2 |
8027354 | Portolani et al. | Sep 2011 | B1 |
8031606 | Memon et al. | Oct 2011 | B2 |
8031633 | Bueno et al. | Oct 2011 | B2 |
8032899 | Archer et al. | Oct 2011 | B2 |
8036229 | Banerjee | Oct 2011 | B2 |
8045550 | LaVigne et al. | Oct 2011 | B2 |
8046456 | Miller et al. | Oct 2011 | B1 |
8054744 | Bishara | Nov 2011 | B1 |
8054832 | Shukla et al. | Nov 2011 | B1 |
8055789 | Richardson et al. | Nov 2011 | B2 |
8059560 | Ushiyama et al. | Nov 2011 | B2 |
8060875 | Lambeth | Nov 2011 | B1 |
8064336 | Scholl et al. | Nov 2011 | B2 |
8089871 | Toglu et al. | Jan 2012 | B2 |
8089904 | Balasubramaniam et al. | Jan 2012 | B2 |
8089963 | Melman et al. | Jan 2012 | B2 |
8089964 | Lo et al. | Jan 2012 | B2 |
8094659 | Arad | Jan 2012 | B1 |
8098656 | Lapuh | Jan 2012 | B2 |
8102781 | Smith | Jan 2012 | B2 |
8121041 | Sajassi et al. | Feb 2012 | B2 |
8130648 | Kwan et al. | Mar 2012 | B2 |
8131773 | Watanabe et al. | Mar 2012 | B2 |
8131852 | Miller et al. | Mar 2012 | B1 |
8146148 | Cheriton | Mar 2012 | B2 |
8149734 | Lu | Apr 2012 | B2 |
8149737 | Metke et al. | Apr 2012 | B2 |
8155000 | Vasseur | Apr 2012 | B2 |
8155028 | Abu-Hamdeh et al. | Apr 2012 | B2 |
8160069 | Jacobson et al. | Apr 2012 | B2 |
8161152 | Ogielski et al. | Apr 2012 | B2 |
8161270 | Parker et al. | Apr 2012 | B1 |
8165031 | Mohan | Apr 2012 | B2 |
8166201 | Richardson et al. | Apr 2012 | B2 |
8166205 | Farinacci et al. | Apr 2012 | B2 |
8174992 | Farkas et al. | May 2012 | B2 |
8199750 | Schultz et al. | Jun 2012 | B1 |
8213424 | Jabbari et al. | Jul 2012 | B2 |
8223668 | Allan et al. | Jul 2012 | B2 |
8224931 | Brandwine et al. | Jul 2012 | B1 |
8224971 | Miller et al. | Jul 2012 | B1 |
8230050 | Brandwine et al. | Jul 2012 | B1 |
8233489 | Welin et al. | Jul 2012 | B2 |
8243732 | Chen et al. | Aug 2012 | B2 |
8260914 | Ranjan | Sep 2012 | B1 |
8265075 | Pandey | Sep 2012 | B2 |
8279871 | Sivan et al. | Oct 2012 | B1 |
8300532 | Venkatramani et al. | Oct 2012 | B1 |
8310957 | Rekhter | Nov 2012 | B1 |
8312129 | Miller et al. | Nov 2012 | B1 |
8339959 | Moisand et al. | Dec 2012 | B1 |
8339994 | Gnanasekaran et al. | Dec 2012 | B2 |
8340090 | Bettink et al. | Dec 2012 | B1 |
8345650 | Foxworthy et al. | Jan 2013 | B2 |
8351418 | Zhao et al. | Jan 2013 | B2 |
8370834 | Edwards et al. | Feb 2013 | B2 |
8391185 | Wijnands et al. | Mar 2013 | B2 |
8422359 | Nakajima | Apr 2013 | B2 |
8441919 | Vasseur | May 2013 | B2 |
8456984 | Ranganathan et al. | Jun 2013 | B2 |
8462774 | Page et al. | Jun 2013 | B2 |
8504718 | Wang et al. | Aug 2013 | B2 |
8514890 | Kidambi et al. | Aug 2013 | B2 |
8537720 | North et al. | Sep 2013 | B2 |
8537860 | Kidambi et al. | Sep 2013 | B2 |
8538919 | Nielsen et al. | Sep 2013 | B1 |
8565124 | Umayabashi et al. | Oct 2013 | B2 |
8571031 | Davies et al. | Oct 2013 | B2 |
8578003 | Brandwine et al. | Nov 2013 | B2 |
8599822 | Castagnoli | Dec 2013 | B2 |
8611351 | Gooch et al. | Dec 2013 | B2 |
8611352 | Mizrahi et al. | Dec 2013 | B2 |
8612627 | Brandwine | Dec 2013 | B1 |
8625594 | Safrai et al. | Jan 2014 | B2 |
8625603 | Ramakrishnan et al. | Jan 2014 | B1 |
8625616 | Vobbilisetty et al. | Jan 2014 | B2 |
8627313 | Edwards et al. | Jan 2014 | B2 |
8635375 | Gnanasekaran | Jan 2014 | B2 |
8644188 | Brandwine et al. | Feb 2014 | B1 |
8650618 | Asati et al. | Feb 2014 | B2 |
8665886 | Gupta et al. | Mar 2014 | B2 |
8670450 | Biswas et al. | Mar 2014 | B2 |
8705513 | Merwe et al. | Apr 2014 | B2 |
8717895 | Koponen et al. | May 2014 | B2 |
8718070 | Koponen et al. | May 2014 | B2 |
8724638 | Carrie | May 2014 | B1 |
8730979 | Chen et al. | May 2014 | B2 |
8743888 | Casado et al. | Jun 2014 | B2 |
8743889 | Koponen et al. | Jun 2014 | B2 |
8750119 | Lambeth et al. | Jun 2014 | B2 |
8750164 | Casado et al. | Jun 2014 | B2 |
8761036 | Fulton et al. | Jun 2014 | B2 |
8767731 | Balus et al. | Jul 2014 | B2 |
8775594 | Koponen et al. | Jul 2014 | B2 |
8798056 | Ganga | Aug 2014 | B2 |
8817596 | Chen et al. | Aug 2014 | B2 |
8817620 | Koponen et al. | Aug 2014 | B2 |
8817621 | Casado et al. | Aug 2014 | B2 |
8824485 | Biswas et al. | Sep 2014 | B2 |
8830823 | Koponen et al. | Sep 2014 | B2 |
8837493 | Casado et al. | Sep 2014 | B2 |
8842679 | Koponen et al. | Sep 2014 | B2 |
8854982 | Mohan | Oct 2014 | B2 |
8880468 | Koponen et al. | Nov 2014 | B2 |
8897134 | Kern et al. | Nov 2014 | B2 |
8913483 | Pfaff et al. | Dec 2014 | B2 |
8958292 | Fulton et al. | Feb 2015 | B2 |
8959215 | Koponen et al. | Feb 2015 | B2 |
8964528 | Casado et al. | Feb 2015 | B2 |
8964598 | Casado et al. | Feb 2015 | B2 |
8966035 | Casado et al. | Feb 2015 | B2 |
8966040 | Koponen et al. | Feb 2015 | B2 |
8971332 | Unbehagen | Mar 2015 | B2 |
9007903 | Koponen et al. | Apr 2015 | B2 |
9008087 | Lambeth et al. | Apr 2015 | B2 |
9032095 | Traina et al. | May 2015 | B1 |
9043452 | Fulton | May 2015 | B2 |
9049153 | Casado et al. | Jun 2015 | B2 |
9077664 | Casado et al. | Jul 2015 | B2 |
9106587 | Koponen et al. | Aug 2015 | B2 |
9112811 | Casado et al. | Aug 2015 | B2 |
9172663 | Casado et al. | Oct 2015 | B2 |
9231891 | Thakkar et al. | Jan 2016 | B2 |
9300603 | Casado et al. | Mar 2016 | B2 |
9306875 | Casado et al. | Apr 2016 | B2 |
9363210 | Lambeth et al. | Jun 2016 | B2 |
9391928 | Koponen et al. | Jul 2016 | B2 |
9525647 | Koponen et al. | Dec 2016 | B2 |
9590919 | Casado et al. | Mar 2017 | B2 |
9680750 | Casado et al. | Jun 2017 | B2 |
9692655 | Koponen et al. | Jun 2017 | B2 |
10021019 | Koponen et al. | Jul 2018 | B2 |
10038597 | Casado et al. | Jul 2018 | B2 |
10686663 | Casado et al. | Jun 2020 | B2 |
11641321 | Koponen et al. | May 2023 | B2 |
11743123 | Casado et al. | Aug 2023 | B2 |
20010043614 | Viswanadham et al. | Nov 2001 | A1 |
20020034189 | Haddock et al. | Mar 2002 | A1 |
20020093952 | Gonda | Jul 2002 | A1 |
20020131414 | Hadzic | Sep 2002 | A1 |
20020194369 | Rawlins et al. | Dec 2002 | A1 |
20030009552 | Benfield et al. | Jan 2003 | A1 |
20030014391 | Evans et al. | Jan 2003 | A1 |
20030026241 | Ono et al. | Feb 2003 | A1 |
20030026258 | Takatani et al. | Feb 2003 | A1 |
20030041170 | Suzuki | Feb 2003 | A1 |
20030058850 | Rangarajan et al. | Mar 2003 | A1 |
20030069972 | Yoshimura et al. | Apr 2003 | A1 |
20030185217 | Ganti et al. | Oct 2003 | A1 |
20030204768 | Fee | Oct 2003 | A1 |
20040037279 | Zelig et al. | Feb 2004 | A1 |
20040047286 | Larsen et al. | Mar 2004 | A1 |
20040054680 | Kelley et al. | Mar 2004 | A1 |
20040054793 | Coleman | Mar 2004 | A1 |
20040062209 | Goldman et al. | Apr 2004 | A1 |
20040073659 | Rajsic et al. | Apr 2004 | A1 |
20040097232 | Haverinen | May 2004 | A1 |
20040098505 | Clemmensen | May 2004 | A1 |
20040165600 | Lee | Aug 2004 | A1 |
20040186914 | Shimada | Sep 2004 | A1 |
20040210889 | Childress et al. | Oct 2004 | A1 |
20040267866 | Carollo et al. | Dec 2004 | A1 |
20040267897 | Hill et al. | Dec 2004 | A1 |
20050018669 | Arndt et al. | Jan 2005 | A1 |
20050021683 | Newton et al. | Jan 2005 | A1 |
20050027881 | Figueira et al. | Feb 2005 | A1 |
20050050377 | Chan et al. | Mar 2005 | A1 |
20050053079 | Havala | Mar 2005 | A1 |
20050083953 | May | Apr 2005 | A1 |
20050111445 | Wybenga et al. | May 2005 | A1 |
20050120160 | Plouffe et al. | Jun 2005 | A1 |
20050132044 | Guingo et al. | Jun 2005 | A1 |
20050169270 | Mutou et al. | Aug 2005 | A1 |
20050201398 | Naik et al. | Sep 2005 | A1 |
20050232230 | Nagami et al. | Oct 2005 | A1 |
20050238058 | Peirce et al. | Oct 2005 | A1 |
20060002370 | Rabie et al. | Jan 2006 | A1 |
20060026225 | Canali et al. | Feb 2006 | A1 |
20060028999 | Iakobashvili et al. | Feb 2006 | A1 |
20060029056 | Perera et al. | Feb 2006 | A1 |
20060031432 | Patrick | Feb 2006 | A1 |
20060037075 | Frattura et al. | Feb 2006 | A1 |
20060056412 | Page | Mar 2006 | A1 |
20060092976 | Lakshman et al. | May 2006 | A1 |
20060174087 | Hashimoto et al. | Aug 2006 | A1 |
20060178898 | Habibi | Aug 2006 | A1 |
20060182037 | Chen et al. | Aug 2006 | A1 |
20060184653 | Riel | Aug 2006 | A1 |
20060184937 | Abels et al. | Aug 2006 | A1 |
20060187950 | Bou-Diab et al. | Aug 2006 | A1 |
20060193266 | Siddha et al. | Aug 2006 | A1 |
20060221961 | Basso et al. | Oct 2006 | A1 |
20060245438 | Sajassi et al. | Nov 2006 | A1 |
20060248179 | Short et al. | Nov 2006 | A1 |
20060251074 | Solomon | Nov 2006 | A1 |
20060282895 | Rentzis et al. | Dec 2006 | A1 |
20060291388 | Amdahl et al. | Dec 2006 | A1 |
20070028239 | Dyck et al. | Feb 2007 | A1 |
20070050763 | Kagan et al. | Mar 2007 | A1 |
20070076709 | Mattson et al. | Apr 2007 | A1 |
20070076719 | Allan et al. | Apr 2007 | A1 |
20070086448 | Hu | Apr 2007 | A1 |
20070098006 | Parry et al. | May 2007 | A1 |
20070110047 | Kim | May 2007 | A1 |
20070140235 | Aysan et al. | Jun 2007 | A1 |
20070156919 | Potti et al. | Jul 2007 | A1 |
20070174429 | Mazzaferri et al. | Jul 2007 | A1 |
20070183421 | Terrell et al. | Aug 2007 | A1 |
20070220358 | Goodill et al. | Sep 2007 | A1 |
20070234302 | Suzuki et al. | Oct 2007 | A1 |
20070239987 | Hoole et al. | Oct 2007 | A1 |
20070240160 | Paterson-Jones et al. | Oct 2007 | A1 |
20070245082 | Margolus et al. | Oct 2007 | A1 |
20070250608 | Watt | Oct 2007 | A1 |
20070258447 | Raszuk et al. | Nov 2007 | A1 |
20070260721 | Bose et al. | Nov 2007 | A1 |
20070266433 | Moore | Nov 2007 | A1 |
20070271362 | Bamnolker | Nov 2007 | A1 |
20070280243 | Wray et al. | Dec 2007 | A1 |
20070286137 | Narasimhan et al. | Dec 2007 | A1 |
20070286185 | Eriksson et al. | Dec 2007 | A1 |
20070297428 | Bose et al. | Dec 2007 | A1 |
20080002579 | Lindholm et al. | Jan 2008 | A1 |
20080002683 | Droux et al. | Jan 2008 | A1 |
20080008202 | Terrell et al. | Jan 2008 | A1 |
20080031263 | Ervin et al. | Feb 2008 | A1 |
20080034249 | Husain et al. | Feb 2008 | A1 |
20080040467 | Mendiratta et al. | Feb 2008 | A1 |
20080049614 | Briscoe et al. | Feb 2008 | A1 |
20080049621 | McGuire et al. | Feb 2008 | A1 |
20080049646 | Lu | Feb 2008 | A1 |
20080052206 | Edwards et al. | Feb 2008 | A1 |
20080059556 | Greenspan et al. | Mar 2008 | A1 |
20080071900 | Hecker et al. | Mar 2008 | A1 |
20080112400 | Dunbar et al. | May 2008 | A1 |
20080159301 | Heer | Jul 2008 | A1 |
20080163207 | Reumann et al. | Jul 2008 | A1 |
20080186962 | Sinha | Aug 2008 | A1 |
20080189769 | Casado et al. | Aug 2008 | A1 |
20080196100 | Madhavan et al. | Aug 2008 | A1 |
20080212496 | Zou | Sep 2008 | A1 |
20080212963 | Fortin et al. | Sep 2008 | A1 |
20080225780 | McCormick et al. | Sep 2008 | A1 |
20080225853 | Melman et al. | Sep 2008 | A1 |
20080240121 | Xiong et al. | Oct 2008 | A1 |
20080240122 | Richardson et al. | Oct 2008 | A1 |
20080253366 | Zuk et al. | Oct 2008 | A1 |
20080279196 | Friskney et al. | Nov 2008 | A1 |
20080285452 | Oran | Nov 2008 | A1 |
20080285463 | Oran | Nov 2008 | A1 |
20080291910 | Tadimeti et al. | Nov 2008 | A1 |
20080310437 | Cheng et al. | Dec 2008 | A1 |
20090031041 | Clemmensen | Jan 2009 | A1 |
20090041032 | Dong et al. | Feb 2009 | A1 |
20090043823 | Iftode et al. | Feb 2009 | A1 |
20090073989 | Cai et al. | Mar 2009 | A1 |
20090083445 | Ganga | Mar 2009 | A1 |
20090089625 | Kannappan et al. | Apr 2009 | A1 |
20090092137 | Haigh et al. | Apr 2009 | A1 |
20090097495 | Palacharla et al. | Apr 2009 | A1 |
20090122710 | Bar-Tor et al. | May 2009 | A1 |
20090138577 | Casado et al. | May 2009 | A1 |
20090141729 | Fan | Jun 2009 | A1 |
20090144220 | Feng et al. | Jun 2009 | A1 |
20090150527 | Tripathi et al. | Jun 2009 | A1 |
20090161547 | Riddle et al. | Jun 2009 | A1 |
20090168786 | Sarkar et al. | Jul 2009 | A1 |
20090177863 | Rehman et al. | Jul 2009 | A1 |
20090213858 | Dolganow et al. | Aug 2009 | A1 |
20090222924 | Droz et al. | Sep 2009 | A1 |
20090232029 | Abu-Hamdeh et al. | Sep 2009 | A1 |
20090249473 | Cohn | Oct 2009 | A1 |
20090276661 | Deguchi et al. | Nov 2009 | A1 |
20090279536 | Unbehagen et al. | Nov 2009 | A1 |
20090279545 | Moonen | Nov 2009 | A1 |
20090292858 | Ambeth et al. | Nov 2009 | A1 |
20090296726 | Snively et al. | Dec 2009 | A1 |
20090303880 | Maltz et al. | Dec 2009 | A1 |
20100027429 | Jorgens et al. | Feb 2010 | A1 |
20100046531 | Louati et al. | Feb 2010 | A1 |
20100061231 | Harmatos et al. | Mar 2010 | A1 |
20100082799 | DeHaan et al. | Apr 2010 | A1 |
20100107162 | Edwards et al. | Apr 2010 | A1 |
20100115101 | Lain et al. | May 2010 | A1 |
20100125667 | Soundararajan | May 2010 | A1 |
20100131636 | Suri et al. | May 2010 | A1 |
20100153554 | Anschutz et al. | Jun 2010 | A1 |
20100153701 | Shenoy et al. | Jun 2010 | A1 |
20100157888 | Aggarwal et al. | Jun 2010 | A1 |
20100157889 | Aggarwal et al. | Jun 2010 | A1 |
20100165874 | Brown et al. | Jul 2010 | A1 |
20100165877 | Shukla et al. | Jul 2010 | A1 |
20100165923 | Tseng et al. | Jul 2010 | A1 |
20100169302 | Lopes et al. | Jul 2010 | A1 |
20100169467 | Shukla et al. | Jul 2010 | A1 |
20100185672 | Rising | Jul 2010 | A1 |
20100191612 | Raleigh | Jul 2010 | A1 |
20100191846 | Raleigh | Jul 2010 | A1 |
20100192207 | Raleigh | Jul 2010 | A1 |
20100192225 | Ma et al. | Jul 2010 | A1 |
20100205479 | Akutsu et al. | Aug 2010 | A1 |
20100214949 | Smith et al. | Aug 2010 | A1 |
20100250784 | Henry et al. | Sep 2010 | A1 |
20100257263 | Casado et al. | Oct 2010 | A1 |
20100275199 | Smith et al. | Oct 2010 | A1 |
20100284402 | Narayanan | Nov 2010 | A1 |
20100290485 | Martini et al. | Nov 2010 | A1 |
20100306408 | Greenberg et al. | Dec 2010 | A1 |
20100322255 | Hao et al. | Dec 2010 | A1 |
20100329265 | Lapuh | Dec 2010 | A1 |
20110002346 | Wu | Jan 2011 | A1 |
20110004698 | Wu | Jan 2011 | A1 |
20110004876 | Wu et al. | Jan 2011 | A1 |
20110004877 | Wu | Jan 2011 | A1 |
20110004913 | Nagarajan et al. | Jan 2011 | A1 |
20110013557 | Westberg et al. | Jan 2011 | A1 |
20110016215 | Wang | Jan 2011 | A1 |
20110022695 | Dalal et al. | Jan 2011 | A1 |
20110026521 | Gamage et al. | Feb 2011 | A1 |
20110032830 | Merwe et al. | Feb 2011 | A1 |
20110032843 | Papp et al. | Feb 2011 | A1 |
20110075664 | Lambeth et al. | Mar 2011 | A1 |
20110075674 | Li et al. | Mar 2011 | A1 |
20110085557 | Gnanasekaran et al. | Apr 2011 | A1 |
20110085559 | Chung et al. | Apr 2011 | A1 |
20110119748 | Edwards et al. | May 2011 | A1 |
20110128959 | Bando et al. | Jun 2011 | A1 |
20110134931 | Merwe et al. | Jun 2011 | A1 |
20110142053 | Merwe et al. | Jun 2011 | A1 |
20110185075 | Du et al. | Jul 2011 | A1 |
20110194567 | Shen | Aug 2011 | A1 |
20110206053 | Henry et al. | Aug 2011 | A1 |
20110261812 | Kini et al. | Oct 2011 | A1 |
20110261825 | Ichino | Oct 2011 | A1 |
20110261828 | Smith | Oct 2011 | A1 |
20110268118 | Schlansker et al. | Nov 2011 | A1 |
20110271007 | Wang et al. | Nov 2011 | A1 |
20110283017 | Alkhatib et al. | Nov 2011 | A1 |
20110299413 | Chatwani et al. | Dec 2011 | A1 |
20110299534 | Koganti et al. | Dec 2011 | A1 |
20110310899 | Alkhatib et al. | Dec 2011 | A1 |
20110318011 | Brassil | Dec 2011 | A1 |
20120014386 | Xiong et al. | Jan 2012 | A1 |
20120014387 | Dunbar et al. | Jan 2012 | A1 |
20120016947 | Damola et al. | Jan 2012 | A1 |
20120027018 | Ilyadis | Feb 2012 | A1 |
20120033668 | Humphries | Feb 2012 | A1 |
20120044943 | Hinz et al. | Feb 2012 | A1 |
20120063360 | Muramoto et al. | Mar 2012 | A1 |
20120093429 | Vleuten et al. | Apr 2012 | A1 |
20120096211 | Davis et al. | Apr 2012 | A1 |
20120099602 | Nagapudi et al. | Apr 2012 | A1 |
20120120964 | Koponen et al. | May 2012 | A1 |
20120126488 | Araújo | May 2012 | A1 |
20120131643 | Cheriton | May 2012 | A1 |
20120137075 | Vorbach | May 2012 | A1 |
20120147898 | Koponen et al. | Jun 2012 | A1 |
20120158993 | McNamee et al. | Jun 2012 | A1 |
20120207018 | Goldenberg et al. | Aug 2012 | A1 |
20120239790 | Doane et al. | Sep 2012 | A1 |
20120246637 | Kreeger et al. | Sep 2012 | A1 |
20120257629 | Ramakrishnan et al. | Oct 2012 | A1 |
20120291029 | Kidambi et al. | Nov 2012 | A1 |
20120300615 | Kempf et al. | Nov 2012 | A1 |
20130058208 | Pfaff et al. | Mar 2013 | A1 |
20130058215 | Koponen et al. | Mar 2013 | A1 |
20130058225 | Casado et al. | Mar 2013 | A1 |
20130058226 | Casado et al. | Mar 2013 | A1 |
20130058228 | Koponen et al. | Mar 2013 | A1 |
20130058229 | Casado et al. | Mar 2013 | A1 |
20130058250 | Casado et al. | Mar 2013 | A1 |
20130058251 | Koponen et al. | Mar 2013 | A1 |
20130058252 | Casado et al. | Mar 2013 | A1 |
20130058255 | Casado et al. | Mar 2013 | A1 |
20130058334 | Koponen et al. | Mar 2013 | A1 |
20130058335 | Koponen et al. | Mar 2013 | A1 |
20130058339 | Casado et al. | Mar 2013 | A1 |
20130058340 | Lambeth et al. | Mar 2013 | A1 |
20130058341 | Fulton et al. | Mar 2013 | A1 |
20130058342 | Casado et al. | Mar 2013 | A1 |
20130058343 | Casado et al. | Mar 2013 | A1 |
20130058344 | Casado et al. | Mar 2013 | A1 |
20130058348 | Koponen et al. | Mar 2013 | A1 |
20130058350 | Fulton | Mar 2013 | A1 |
20130058351 | Casado et al. | Mar 2013 | A1 |
20130058353 | Koponen et al. | Mar 2013 | A1 |
20130058354 | Casado et al. | Mar 2013 | A1 |
20130058356 | Koponen et al. | Mar 2013 | A1 |
20130058357 | Koponen et al. | Mar 2013 | A1 |
20130058358 | Fulton et al. | Mar 2013 | A1 |
20130060736 | Casado et al. | Mar 2013 | A1 |
20130060737 | Koponen et al. | Mar 2013 | A1 |
20130060738 | Koponen et al. | Mar 2013 | A1 |
20130060817 | Koponen et al. | Mar 2013 | A1 |
20130060818 | Lambeth et al. | Mar 2013 | A1 |
20130060819 | Lambeth et al. | Mar 2013 | A1 |
20130060922 | Koponen et al. | Mar 2013 | A1 |
20130060929 | Koponen et al. | Mar 2013 | A1 |
20130060940 | Koponen et al. | Mar 2013 | A1 |
20130073743 | Ramasamy et al. | Mar 2013 | A1 |
20150180801 | Casado et al. | Jun 2015 | A1 |
20160127274 | Casado et al. | May 2016 | A1 |
20160294627 | Koponen et al. | Oct 2016 | A1 |
20160315882 | Casado et al. | Oct 2016 | A1 |
20160359674 | Koponen et al. | Dec 2016 | A1 |
20170085395 | Koponen et al. | Mar 2017 | A1 |
20190028351 | Casado et al. | Jan 2019 | A1 |
20190044845 | Koponen et al. | Feb 2019 | A1 |
20200396130 | Casado et al. | Dec 2020 | A1 |
20220394014 | Wang et al. | Dec 2022 | A1 |
Number | Date | Country |
---|---|---|
1653688 | May 2006 | EP |
2002141905 | May 2002 | JP |
2003069609 | Mar 2003 | JP |
2003124976 | Apr 2003 | JP |
2003318949 | Nov 2003 | JP |
9506989 | Mar 1995 | WO |
2005106659 | Nov 2005 | WO |
2005112390 | Nov 2005 | WO |
2008095010 | Aug 2008 | WO |
2009042919 | Apr 2009 | WO |
2010115060 | Oct 2010 | WO |
2012093429 | Jul 2012 | WO |
2012126488 | Sep 2012 | WO |
Entry |
---|
Al-Fares, Mohammad, et al., “A Scalable, Commodity Data Center Network Architecture,” SIGCOMM '08, Aug. 17-22, 2008, 12 pages, Seattle, Washington, USA. |
Anderson, Thomas, et al., “Overcoming the Internet Impasse through Virtualization,” Apr. 2005, 8 pages, IEEE Computer Society. |
Anhalt, Fabienne, et al., “Analysis and Evaluation of a XEN based Virtual Router,” Sep. 2008, 63 pages, Unite de recherché INRA Phone-Alpes, Montbonnot Saint-Ismier, France. |
Anwer, Muhammad Bilal, et al., “Building A Fast, Virtualized Data Plane with Programmable Hardware,” Aug. 17, 2009, 8 pages, VISA'09, ACM, Barcelona, Spain. |
Author Unknown, “Cisco VN-Link: Virtualization-Aware Networking,” Mar. 2009, 10 pages, Cisco Systems, Inc. |
Author Unknown, “OpenFlow Switch Specification, Version 0.9.0 (Wire Protocol 0x98),” Jul. 20, 2009, 36 pages, Open Networking Foundation. |
Author Unknown, OpenFlow Switch Specification, Version 1.0.0 (Wire Protocol 0x01), Dec. 31, 2009, 42 pages, Open Networking Foundation. |
Author Unknown, “OpenFlow Switch Specification, Version 1.1.0 Implemented (Wire Protocol 0x02),” Feb. 28, 2011, 56 pages, Open Networking Foundation. |
Bavier, Andy, et. al., “In VINI Veritas: Realistic and Controlled Network Experimentation,” SIGCOMM'06, Sep. 2006, 14 pages, Pisa, Italy. |
Bhatia, Sapan, et al., “Trellis: A Platform for Building Flexible, Fast Virtual Networks on Commodity Hardware,” ROADS'08, Dec. 9, 2008, 6 pages, Madrid, Spain, ACM. |
Caesar, Matthew, et al., “Design and Implementation of a Routing Control Platform,” NSDI '05: 2nd Symposium on Networked Systems Design & Implementation , Apr. 2005, 14 pages, Usenix Association. |
Cai, Zheng, et al., “The Preliminary Design and Implementation of the Maestro Network Control Platform,” Oct. 1, 2008, 17 pages, NSF. |
Casado, Martin, et al. “Ethane: Taking Control of the Enterprise,” SIGCOMM'07, Aug. 27-31, 2007, 12 pages, ACM, Kyoto, Japan. |
Casado, Martin, et al., “Rethinking Packet Forwarding Hardware,” Seventh ACM SIGCOMM' HotNets Workshop, Nov. 2008, 6 pages, ACM. |
Casado, Martin, et al., “SANE: A Protection Architecture for Enterprise Networks,” Proceedings of the 15th USENIX Security Symposium, Jul. 31-Aug. 4, 2006, 15 pages, USENIX, Vancouver, Canada. |
Casado, Martin, et al., “Scaling Out: Network Virtualization Revisited,” Month Unknown 2010, 8 pages. |
Casado, Martin, et al., “Virtualizing the Network Forwarding Plane,” Dec. 2010, 6 pages. |
Das, Saurav, et al., “Simple Unified Control for Packet and Circuit Networks,” Month Unknown 2009, 2 pages, IEEE. |
Das, Saurav, et al., “Unifying Packet and Circuit Switched Networks with OpenFlow,” Dec. 7, 2009, 10 pages, available at http://OpenFlowSwitch.org/downloads/technicalreports/openflow-tr-2009-4-unification.pdf. |
Dobrescu, Mihai, et al., “RouteBricks: Exploiting Parallelism To Scale Software Routers,” SOSP'09, Proceedings of the ACM SIGOPS 22nd Symposium on Operating Systems Principles, Oct. 2009, 17 pages, ACM, New York, NY. |
Farinacci, D., et al., “Generic Routing Encapsulation (GRE),” Mar. 2000, pp. 1-9, The Internet Society (RFC 2784). |
Fernandes, Natalia C., et al., “Virtual Networks: Isolation, Performance, and Trends,” Annals of Telecommunications, Oct. 7, 2010, 17 pages, vol. 66, Institut Telecom and Springer-Verlag, Paris. |
Godfrey, P. BRIGHTEN, et al., “Pathlet Routing,” SIGCOMM, Aug. 2009, pp. 1-6, ACM. |
Greenberg, Albert, et al., “VL2: A Scalable and Flexible Data Center Network,” SIGCOMM '09, Aug. 17-21, 2009, 12 pages, ACM, Barcelona, Spain. |
Greenhalgh, Adam, et al., “Flow Processing and The Rise of Commodity Network Hardware,” ACM SIGCOMM Computer Communication Review, Apr. 2009, 6 pages, vol. 39, No. 2. |
Gude, Natasha, et al., “NOX: Towards an Operating System for Networks,” ACM SIGCOMM Computer Communication Review, Jul. 2008, 6 pages, vol. 38, No. 3, ACM. |
Guo, Chanxiong, et al., “BCube: A High Performance, Server-centric Network Architecture for Modular Data Centers,” SIGCOMM'09, Aug. 17-21, 2009, 12 pages, ACM, Barcelona, Spain. |
Hamilton, James, et al., “Datacenter Networks Are In My Way,” Principals of Amazon Series, Oct. 28, 2010, 14 pages. |
Hinrichs, Timothy L., et al., “Practical Declarative Network Management,” WREN'09, Aug. 21, 2009, 10 pages, Barcelona, Spain. |
Keller, Eric, et al., “The ‘Platform as a Service’ Model for Networking,” Month Unknown 2010, 6 pages. |
Kim, Changhoon, et al., “Floodless in Seattle: A Scalable Ethernet Architecture for Large Enterprises,” SIGCOMM'08, Aug. 17-22, 2008, 12 pages, ACM, Seattle, Washington, USA. |
Koponen, Teemu, et al., “Onix: A Distributed Control Platform for Large-scale Production Networks,” In Proc. OSDI, Oct. 2010, 14 pages. |
Lakshminarayanan, Karthik, et al., “Routing as a Service,” Report No. UCB/CSD-04-1327, Month Unknown 2004, 16 pages, Computer Science Division (EECS), University of California—Berkeley, Berkeley, California. |
Loo, Boon Thau, et al., “Declarative Routing: Extensible Routing with Declarative Queries,” In Proc. of SIGCOMM, Aug. 21-26, 2005, 12 pages, Philadelphia, PA, USA. |
Loo, Boon Thau, et al., “Implementing Declarative Overlays,” In Proc. of SOSP, Oct. 2005, 16 pages, Brighton, UK. |
Luo, Jianying, et al., “Prototyping Fast, Simple, Secure Switches for Ethane,” Month Unknown 2007, 6 pages. |
McKeown, Nick, et al., “OpenFlow: Enabling Innovation in Campus Networks,” ACM SIGCOMM Computer Communication Review, Apr. 2008, 6 pages, vol. 38, No. 2, ACM. |
Mysore, Radhka Niranjan, et al., “PortLand: A Scalable Fault-Tolerant Layer 2 Data Center Network Fabric,” Proc. Of SIGCOMM, Aug. 17-21, 2009, 12 pages. |
PCT International Search Report and Written Opinion dated Sep. 17, 2010 for commonly owned International Patent Application PCT/US10/029717, 14 pages, International Searching Authority. |
Pettit, Justin, et al., “Virtual Switching in an Era of Advanced Edges,” In Proc. 2nd Workshop on Data Center-Converged and Virtual Ethernet Switching (DCCAVES), Sep. 2010, 7 pages, vol. 22. ITC. |
Pfaff, Ben., et al., “Extending Networking into the Virtualization Layer,” Proc. Of HotNets, Oct. 2009, 6 pages. |
Sherwood, Rob, et al., “Can the Production Network Be the Testbed?,” Month Unknown 2010, 14 pages. |
Sherwood, Rob, et al., “Carving Research Slices Out of Your Production Networks with OpenFlow,” ACM SIGCOMM Computer Communications Review, Jan. 2010, 2 pages, vol. 40, No. 1. |
Sherwood, Rob, et al., “FlowVisor: A Network Virtualization Layer,” Oct. 14, 2009, 15 pages, Openflow-TR-2009-1. |
Tavakoli, Arsalan, et al., “Applying NOX to the Datacenter,” Proc. HotNets, Month Unknown 2009, 6 pages. |
Turner, Jon, et al., “Supercharging PlanetLab—High Performance, Multi-Application Overlay Network Platform,” SIGCOMM-07, Aug. 27-31, 2007, 12 pages, ACM, Koyoto, Japan. |
Wang, Wei-Ming, et al., “Analysis and Implementation of an Open Programmable Router Based on Forwarding and Control Element Separation,” Journal of Computer Science and Technology, Sep. 2008, 11 pages, vol. 23, No. 5. |
Yang, L., et al., “Forwarding and Control Element Separation (ForCES) Framework,” Apr. 2004, 41 pages, The Internet Society. |
Yu, Minlan, et al., “Scalable Flow-Based Networking with DIFANE,” In Proc. SIGCOMM, Aug. 2010, 16 pages. |
Number | Date | Country | |
---|---|---|---|
20240039791 A1 | Feb 2024 | US |
Number | Date | Country | |
---|---|---|---|
61505103 | Jul 2011 | US | |
61505100 | Jul 2011 | US | |
61505102 | Jul 2011 | US | |
61501785 | Jun 2011 | US | |
61501743 | Jun 2011 | US | |
61482615 | May 2011 | US | |
61482616 | May 2011 | US | |
61482205 | May 2011 | US | |
61466453 | Mar 2011 | US | |
61429753 | Jan 2011 | US | |
61429754 | Jan 2011 | US | |
61361913 | Jul 2010 | US | |
61361912 | Jul 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16902251 | Jun 2020 | US |
Child | 18239084 | US | |
Parent | 16034035 | Jul 2018 | US |
Child | 16902251 | US | |
Parent | 15076634 | Mar 2016 | US |
Child | 16034035 | US | |
Parent | 13218477 | Aug 2011 | US |
Child | 15076634 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13177536 | Jul 2011 | US |
Child | 13218477 | US | |
Parent | 13177535 | Jul 2011 | US |
Child | 13218477 | US | |
Parent | 13177538 | Jul 2011 | US |
Child | 13218477 | US |