Packet classification method for networks with static routing

Information

  • Patent Application
  • 20070286186
  • Publication Number
    20070286186
  • Date Filed
    August 04, 2006
    18 years ago
  • Date Published
    December 13, 2007
    17 years ago
Abstract
Packet classification and routing in a data communication network with static routing procedure, wherein the routing is performed without using a routing table. First values for each common address bit of end service points adjacent to a switch as a response to a local subnet mask of the switch are defined. Then the packet flows from the current switch to the adjacent switches are forwarded in response to a value of differentiation bits. Unprocessed packets are forwarded to the main adjacent switch according to the main adjacent switch definition. Unforwarded are processed packets locally as exceptions.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings, which are included to provide a further understanding of the invention and constitute a part of this specification, illustrate embodiments of the invention and together with the description help to explain the principles of the invention. In the drawings:



FIG. 1 is a flow chart of a method according to the present invention,



FIG. 2 is a block diagram of an example embodiment of a routing element according to the present invention, and



FIG. 3 is a block diagram of an example network implementation according to the present invention.





DETAILED DESCRIPTION OF THE INVENTION

Reference will now be made in detail to the embodiments of the present invention, examples of which are illustrated in the accompanying drawings.


The present invention discloses a new forwarding procedure for networks with static routing. The new forwarding procedure makes route classification decision by mapping values of the certain areas of destination address to the available set of outgoing ports. Depending on a role of switch or router element, or alike, in the network, the packet route classification procedure comprises one, two or three steps. Description of these steps simplifies description of the present invention, as each step addresses on possible type of adjacent node, wherein end service points are covered by step one, main adjacent switch that is used as a default path to the network are covered by step three, and other adjacent switches are covered by step two.


In FIG. 1 the first step 10 is performed only if the switch local subnetwork mask is set and matches to the destination address of the received packet flow. The switch local subnetwork mask defines value of all common address bits for end service points adjacent to the switch. The switch local subnetwork masks are set only for the peripheral switches (that have adjacent end service points) and used for verifying that the packet is at the right destination. The switch makes forwarding decision based on a route classification area, of which an example is disclosed in FIG. 2. The route classification area is a set of bits in the destination address, which allows the network element 20, such as a router, switch, or alike, to classify to which of the adjacent end service points 22-28 the flow is addressed. The flow is received from data communication connection 21 that is connected to another network element, such as a router, switch or alike. The route classification area is defined by the size that reflects number of allowed routing decisions, for example, the number of outgoing ports towards end service point, and by its offset in the destination address. The offset and size are defined as smallest values, which allow distinguishing flows to N destination addresses, where N is a number of adjacent end service points. Based on that the size is equal to log2(N) rounded up to the closest integer.


It is important to note that any subset of the destination address, and correspondingly any offset value can be used. The route classification procedure defines ID of the outgoing port as a value of the route classification area corrected by the value of ID shift, where ID shift is defined individually for each switch. For example, if switch has 4 adjacent end service points with 32-bits addresses: 10.0.0.2, 10.0.0.3, 10.0.0.4 and 10.0.0.5, and the corresponding port IDs are 4-7, as the lower ports are connected to other switches, then the route classification area size is 2, offset is 29 so that the route classification area covers bits 29 and 30, and now for correct mapping of these two bits of the route classification area to the allocated outgoing port IDs, a positive ID shift of value 4 has to be done. If the switch does not have outgoing port with the calculated ID, the case is handled by third step of the proposed procedure.


The second step 11 implements efficient forwarding of packet flows from the current switch to all adjacent switches, except the main adjacent switch. Similar to the first step, the switch makes forwarding decision based on a value of differentiation bits. The differentiation bits field is a set of bits in the destination address, which allows classifying flows addressed to the adjacent switches. The differentiation bits field is defined by the offset in the destination address and size, and it is set individually for each switch. The offset and size are defined as smallest values, which allow to distinguish flows addressed to N groups of destination addresses, where N is a number of adjacent switches, excluding the main adjacent switch. In the well designed networks the field size is equal to log2(N) rounded up to the closest integer, however, in some corner cases the field area might be larger.


At the second step, the route classification procedure maps the value of the differentiation bits to the set of outgoing ports towards the adjacent switches. In a general case, the mapping is performed by using a route mapping table, which associates outgoing port ID with the corresponding value of differentiation bits, and has size equal to a number of adjacent switches. The alternative solution is to use the same approach as described in the first step of the invented procedure, i.e. to directly use the value of the differentiation bits as an outgoing port ID. This approach can be used only when it is guaranteed that the value of differentiation bits for all flows is mapped to the outgoing port toward correct adjacent switch, or it is mapped to non-existing port ID, if the correct route for such flows is towards the main adjacent switch, as this case is handled by third step of the proposed procedure.


Despite to the strong restrictions, there are a lot of example cases where the alternative approach can be applied, for example, on the central network switches, which are adjacent only with switches and do not have adjacent end points. Actually this case can be seen as a special case of the first step of the proposed procedure. The important feature is that a flow cannot be forwarded back to the same node from where it was received. If the direction obtained in the local mapping procedure informs that the packet has to be sent back to the same switch, it will be instead sent to the main adjacent switch. This rule prevents creation of the traffic loops on the link and allows implementation of centralized handling of all routing errors at the default network switch. It also allows to utilize unused address space that is covered by the route classification areas of the switches down the line but not presented in their subnetworks, which is possible as a number of end service points adjacent to the switch not always is equal to the powers of 2, for example, 2, 4, 8, and so on.


The third step 13 implements default treatment of the packets, which were not processed in the previous steps. If the main adjacent switch is defined, all unprocessed packets are forwarded to it, step 12. Otherwise they are treated locally as exceptions and the switch sets a corresponding alert signal and drops the packets, step 13. In practice this concept is very similar to the idea of default route.


Based on the procedure described above the following four routing configurations of the network devices are defined. FIG. 3 discloses an example configuration of the network devices.


1) End service point 36 implements only the third step of the described procedure and performs default routing of all packets to the directly adjacent peripheral switch. No routing settings are required.


2) Simple peripheral switch 31, 32, 33, 34 is a switch connected to only one other switch and has a number of adjacent end service points that form local subnetwork. These switches implement first and third steps routing within local subnetwork and forwarding other traffic to the main adjacent switch. The following routing settings are required:


a) local subnetwork mask for classifying whether the packet destination might belong to the local subnetwork,


b) route classification area is a certain area in the destination address field of the packet that classifies uniquely packets in the local subnetwork,


c) value of ID shift for translating values of the route classification area to the correct outgoing port towards end service point in the local subnetwork, and


d) main adjacent switch is an association of one of the local ports with the default routing solution.


3) Complex peripheral switch 35 is a switch connected to a number of switches and end service points. Such switches implement all three steps of the defined procedure. First the switch checks if the packets flow is addressed to the local subnetwork and if yes, the switch routes it to the corresponding end service point. Otherwise it separates groups of flows and forwards them to the corresponding adjacent switches according to the second step and other traffic is forwarded to the main adjacent switch. Comparing to the simple peripheral switch this switch requires the following additional routing setting:


a) differentiation bits field is an area in the destination address field of the packet that allows uniquely classify packets for routing to subnetworks of the corresponding adjacent switches.


It is important to mention that most of network types, for which the current invention is made, do not use complex peripheral switches as their use is also related to a number of additional problems in general network planning. Thus, this scenario is very unlikely.


4) Central switch 30 is a switch connected to a number of switches. These switches implement second and third steps of the proposed procedure and in most cases more efficient implementation of the second step is possible. The following routing settings are required:


a) Differentiation bits field is a certain area in the destination address field of the packet that allows uniquely classify packets for routing to subnetworks of the corresponding adjacent switches, and


b) Main adjacent switch is an association of one of the local ports with the default routing solution.


As we can see from the listed above characteristics of the network devices, the proposed solution is extremely simple from the implementation point of view, allows completely replacing heavy mechanisms of classical route classification that is based on routing-table lookup, and provides a lot of possibilities for the further optimization. The method replaces comparison of the destination address with the addresses in the routing tables of all intermediate switches by the direct calculation of outgoing ports ID based on the certain areas of the destination address plus verification whether address matches to the subnetwork mask on peripheral switches.


For achieving good performance the network should be designed according to the following recommendations. However, the present invention is beneficial even if all of the following recommendations cannot be met. The network should be designed with switch units with the number of outgoing ports equal to powers of 2. It is recommended that one port of the peripheral switches is connected to one of central network switches and others are connected with the end service points. Usually it is better to avoid using complex peripheral switches. The central network switches should advantageously be adjacent only with other central and peripheral switches. Special attention should be given to design of the default network switch (which is the main adjacent switch of the main central switch) subnetwork, which in most cases is presented by a single end service point that takes care of handling network error cases but in some cases it has to implement a subnetwork with a simple peripheral switch in the center.


After the network topology is defined, the following network address assignment rules can be used for assisting the designer(s) to make proper planning of the network.


1) Define which of the central network switches has the smallest summary ratio of the subnetworks sizes attached to its ports. The subnetwork size is calculated as a number of end service points the shortest paths to which, in any measure best applicable for a given network type, go via the corresponding port. Only one ratio is calculated for each possible pair of outgoing ports, where the size of bigger subnetwork attached to the port is divided by the size of smaller subnetwork. Based on that the ratio is always greater or equal to one.


2) At the selected central switch, set the differentiation bits field to be mapped to the top K bits of the available address space, where K=log2(N) rounded up to the closest integer, and N is a number of outgoing ports on the switch. For the first processed central switch (hereafter main central switch), the differentiation bits offset is 0 and size is K.


3) The main adjacent switch of the main central switch is called the default network switch. This switch has a special role in the network as it is only place where all unused addresses, covered by the route classification area, but not presented in the corresponding subnetworks of the peripheral switches, can be used, as all traffic, which was not processed in the network will end up here. It is also a place where handling of the routing error cases should be performed. The default network switch gives a way of utilizing the unused address space, but it is quite implementation expensive solution, so it is recommended to use it only when there is no other address space left. If the network does not need to utilize all available address space, then the default network switch does not need to play role of the switch and the corresponding reference of the main central switch should point to a central network errors handling device. Otherwise the default network switch is build using the following rules:


a) The default network switch is a simple peripheral switch that can perform address mapping by using mapping table, which associates outgoing port ID with the corresponding value of the route classification area. In case if only one subset of unused address space fulfills to the target number of end service points, the table scheme might be replaced with the values translation rule and then ID shift value has to be specified accordingly.


b) The local subnetwork mask covers all bits that are in common for all subnetwork addresses, and this is the main criterion for selecting which addresses from the unused address space should be allocated for the subnetwork service points.


c) The main adjacent switch is pointing to the main central switch, but in addition the default network switch defines a port for handling traffic that is classified to the same port from where it was originally received. This additional port is pointing to the central network errors handling device.


4) For each central switch directly connected to the main central switch, we set the differentiation bits field to be mapped to the top K′ bits of the available address space that excludes differentiation bits of the main central switch. The value K′ is equal to log2(N′) rounded up to the closest integer, and N′ is a number of outgoing ports on the switch. The differentiation bits offset is calculated as a value of offset plus size of the differentiation bits field at the upper level switch for the switches directly connected to the main central switch it is equal to 0+K=K value defined at step 2) and the size of differentiation bits field is K′. The main adjacent switch reference is pointing to the upper level central switch.


5) The step 4 is repeated for all central network switches taking into account the offset and size of the differentiation bits field of the upper level switch and by setting upper switch to be the main adjacent switch.


6) After setting all the central switches, the peripheral switches are set. For the peripheral switches we define prefix of the local subnetwork mask equal to a set of all differentiation bits fields along the shortest path to the main central switch. The offset of route classification area should be set to the end of local subnetwork mask prefix. The size of route classification area depends on how we want to use the unused parts of the address space (difference between total address length and size of the local subnetwork mask prefix plus size of required route classification area M=log2(N″) rounded up to the closest integer, where N″ is a number of outgoing ports of the switch):


a) One embodiment is to use the remaining tail bits of the destination address for some special purposes, for example, MIPI/UniPro allows using tail address bits for identifying special “hardware” ports at the end service points. In this case the route classification area size should be set equal to M as defined above. In practice it means that one end service point is getting a set of network addresses defined by the tail bits. The additional addresses can be also used for building static multipath and load balancing mechanisms.


b) Another option is to let reuse the remaining address space under the default network switch. In this case the size should be set to a difference of total address length and size of the local subnetwork mask prefix. The same solution should be taken when this address space is not needed (end points with the corresponding addresses are not defined in the network) and then packet with such destination should be send to the default network switch, where it will be handled by the central network errors handling device.


7) The end service points addresses are allocated based on the value of the local subnetwork mask and adjacent port ID of the corresponding switch. The end point does not need to perform verification of the destination address of the received packet, as such verification is already performed by the adjacent peripheral switch as a part of the route classification process.


8) If the network contains complex peripheral switches, for them first the value of the differentiation bits field should be defined according to point 4, where total number of outgoing ports is replaced by the number of outgoing ports adjacent to the other switches plus one value should be reserved for the local subnetwork mask. This value should be used for extending size of the local subnetwork mask prefix and then actions according to points 6 and 7 should be taken.


Note that the described network planning procedure assumes that a switch does not have address, but if it is required then at the planning phase the switch should be logically split to the pure switch and end service point to which a certain address can be allocated using the same address allocation rules as for other end service points within the local subnetwork.


The network planning procedure presented above suggests an example set of rules by using which the invention-compatible network planning can be done. It should be understood that a person skilled in the art uses professional expertise in the planning and other network planning rules might be used, as long as they inline with the main restrictions of the invention. The actual network planning depends on the network requirements. Different needs require different types of networks. Thus, different planning techniques are applied when needed.


It is obvious to a person skilled in the art that with the advancement of technology, the basic idea of the invention may be implemented in various ways. The invention and its embodiments are thus not limited to the examples described above; instead they may vary within the scope of the claims.

Claims
  • 1. A method comprising: defining values for each common address bit of network nodes adjacent to a current node, wherein the network nodes are included in a network with static routing;forwarding packets from the current node to adjacent network nodes in response to values of differentiation bits;forwarding unprocessed packets as a response to a main adjacent switch definition; andprocessing unforwarded packets locally as exceptions.
  • 2. The method according to claim 1, wherein the current node performs classification based on a local subnet mask, whether the packet destination belongs to a local subnetwork.
  • 3. The method according to claim 1, wherein the main adjacent switch is defined as an association of a local port and a default route.
  • 4. The method according to claim 1, wherein the packets are forwarded to an adjacent node essentially using the numerical value of the differentiation bit field as an address of an outgoing port.
  • 5. A system comprising: a plurality of switches in a network with static routing, wherein one of the switches is configured as a main adjacent switch;at least one end service point;wherein the plurality of switches are configured to route data packets to the at least one end service point and adjacent switches as a response to a local subnet mask and differentiation bits and wherein the main adjacent switch is configured to receive unprocessed packets.
  • 6. A system according to claim 5, wherein switches connected to the plurality of switches are configured as central switches.
  • 7. A System according to claim 5, wherein the switches are configured to classify, based on the local subnet mask, whether the packet destination belongs to a local subnetwork.
  • 8. A System according to claim 5, wherein the main adjacent switch is defined as an association of a local port and a default route.
  • 9. A network node for packet classification in a network with static routing, wherein the network node is connected to at least one further network node and is configured to route data packets to the end service points and adjacent network nodes as a response to a local subnet mask and differentiation bits.
  • 10. A network node according to claim 9, wherein the network node is configured to act as a main adjacent network node, which is configured to receive unprocessed packets.
  • 11. A network node according to claim 9, wherein the network node comprises a switch.
  • 12. A network node according to claim 9, wherein the network node comprises a router.
  • 13. A network element according to claim 11, wherein the switche is connected to a plurality of switches configured as central switches.
  • 14. A network element according to claim 13, wherein the switches are configured to classify, based on a local subnet mask, whether the packet destination belongs to a local subnetwork.
  • 15. A network element according to claim 11, wherein a main adjacent switch is defined as an association of a local port and a default route.
  • 16. A network element according to claim 9, wherein the packets are forwarded to an adjacent node essentially using the numerical value of the differentiation bit field as an address of an outgoing port.
  • 17. A system comprising: defining means for defining values for each common address bit of network nodes adjacent to a current node, wherein the network nodes are included in a network with static routing;first forwarding means for forwarding packets from the current node to adjacent network nodes in response to values of differentiation bits;second forwarding means for forwarding unprocessed packets as a response to a main adjacent switch definition; andprocessing means for processing unforwarded packets locally as exceptions.
Priority Claims (1)
Number Date Country Kind
20060563 Jun 2006 FI national