EP2869509A1 - Procédé, appareil et système de traitement de paquet de données - Google Patents

Procédé, appareil et système de traitement de paquet de données Download PDF

Info

Publication number
EP2869509A1
EP2869509A1 EP20120882133 EP12882133A EP2869509A1 EP 2869509 A1 EP2869509 A1 EP 2869509A1 EP 20120882133 EP20120882133 EP 20120882133 EP 12882133 A EP12882133 A EP 12882133A EP 2869509 A1 EP2869509 A1 EP 2869509A1
Authority
EP
European Patent Office
Prior art keywords
field
information
bit field
data packet
match
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
EP20120882133
Other languages
German (de)
English (en)
Other versions
EP2869509B1 (fr
EP2869509A4 (fr
Inventor
Yan Wang
Weihua Hu
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Publication of EP2869509A1 publication Critical patent/EP2869509A1/fr
Publication of EP2869509A4 publication Critical patent/EP2869509A4/fr
Application granted granted Critical
Publication of EP2869509B1 publication Critical patent/EP2869509B1/fr
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/24Traffic characterised by specific attributes, e.g. priority or QoS
    • H04L47/2483Traffic characterised by specific attributes, e.g. priority or QoS involving identification of individual flows
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/38Flow based routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/52Multiprotocol routers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/70Routing based on monitoring results

Definitions

  • the present invention relates to the technical field of information, and particularly, to a method, apparatus and system for processing a data packet.
  • OpenFlow OpenFlow
  • OpenFlow Switch OpenFlow Switch
  • Controller OpenFlow Controller
  • the embodiments of the present invention provide a method, apparatus and system for processing a data packet, which can achieve flexible custom processing of the data packet.
  • a method for processing a data packet including: matching a data packet with match field information of a flow entry, the flow entry comprising the match field information and operation field information; wherein the operation field information comprises an operation type and first bit field indication information, the first bit field indication information comprises a first offset and a first field length, and the first bit field indication information is used for indicating a first bit field of the data packet, or the match field information comprises second bit field indication information and a match value, the second bit field indication information comprises a second offset and a second field length, and the second bit field indication information is used for indicating a second bit field of the data packet; and performing, if the data packet is successfully matched with the match field information, an operation on the data packet according to the operation field information.
  • the operation field information comprises an operation type and first bit field indication information
  • the first bit field indication information comprises a first offset and a first field length
  • the first bit field indication information is used for indicating a first bit field of the data packet
  • the match field information comprises second bit field indication information
  • the performing the operation on the data packet according to the operation field information comprises:determining the first bit field of the data packet according to the first bit field indication information; and performing the operation on the first bit field according to the operation type.
  • the matching the data packet with the match field information of the flow entry comprises: determining the second bit field of the data packet according to the second bit field indication information; and matching the second bit field according to the match value.
  • an apparatus for processing a data packet including: a matching unit, configured to match a data packet with match field information of a flow entry; the flow entry including the match field information and operation field information; wherein the operation field information includes an operation type and first bit field indication information, the first bit field indication information includes a first offset and a first field length, and the first bit field indication information is used for indicating the first bit field of the data packet, or the match field information includes second bit field indication information and a match value, the second bit field indication information includes a second offset and a second field length, and the second bit field indication information is used for indicating the second bit field of the data packet; and an operating unit, configured to perform, if the data packet is successfully matched with the match field information, an operation on the data packet according to the operation field information.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet
  • the operating unit when the operation field information includes the operation type and the first bit field indication information, the operating unit is specifically configured to, if the data packet is successfully matched with the match field information, determine the first bit field of the data packet according to the first bit field indication information, and perform the operation on the first bit field according to the operation type.
  • the matching unit when the match field information includes the second bit field indication information and the match value, is specifically configured to determine the second bit field of the data packet according to the second bit field indication information; and match the second bit field according to the match value.
  • a method for processing a data packet including: generating a flow entry addition indication message, the flow entry addition indication message comprising match field information and operation field information; wherein the operation field information comprises an operation type and first bit field indication information, the first bit field indication information comprises a first offset and a first field length, and the first bit field indication information is used for indicating a first bit field of the data packet, or the match field information comprises second bit field indication information and a match value, the second bit field indication information comprises a second offset and a second field length, and the second bit field indication information is used for indicating a second bit field of the data packet; and sending the flow entry addition indication message to a switching device, for enabling the switching device to generate a flow entry according to the flow entry addition indication message and process the data packet according to the flow entry.
  • the operation field information comprises an operation type and first bit field indication information
  • the first bit field indication information comprises a first offset and a first field length
  • the first bit field indication information is used for indicating a first bit field of the data packet
  • the method further includes: sending a feature request message to the switching device, wherein the feature request message is used for inquiring whether the match field information or the operation field information is supported; and receiving a feature response message sent by the switching device, wherein the feature response message is used for indicating that the match field information or the operation field information is supported.
  • an apparatus for processing a data packet including: a generating unit configured to generate a flow entry addition indication message, and the flow entry addition indication message includes match field information and operation field information; wherein the operation field information includes an operation type and first bit field indication information, the first bit field indication information includes a first offset and a first field length, the first bit field indication information is used for indicating a first bit field of the data packet, or the match field information includes second bit field indication information and a match value, the second bit field indication information includes a second offset and a second field length, and the second bit field indication information is used for indicating a second bit field of the data packet; and a sending unit, configured to send the flow entry addition indication message to a switching device, for enabling the switching device to generate a flow entry according to the flow entry addition indication message and process the data packet according to the flow entry.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for
  • the sending unit is further configured to send a feature request message to the switching device, wherein the feature request message is used for inquiring whether the match field information or the operation field information is supported; and the apparatus further includes a receiving unit, configured to receive a feature response message sent by the switching device, wherein the feature response message is used for indicating that the match field information or the operation field information is supported.
  • a system for processing a data packet including the apparatus for processing a data packet provided in the second aspect and the apparatus for processing a data packet provided in the fourth aspect.
  • a particular bit field of the data packet may be flexibly determined according to the offset and the field length and the particular bit field is matched or operated, flexible custom processing of the data packet may be achieved, such that the processing of the data packet is not limited to a particular protocol format any more, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • Fig.1 is a schematic diagram of an example of a network architecture capable of applying an embodiment of the present invention. It should be noted that, the example of Fig.1 is only intended to help those skilled in the art to understand the embodiment of the present invention in a better way, rather than limiting the scope of the embodiment of the present invention. In Fig.1 , the architecture of an OpenFlow network is taken as an example for illustration.
  • an Openflow switch includes one or multiple flow tables (Flow table) for achieving packet message matching and forwarding functions and a secure channel (Secure channel) connected with an external Openflow controller.
  • Flow table flow tables
  • Secure channel secure channel
  • the secure channel of the Openflow switch and the Openflow controller interact through Openflow protocol messages, to operate the flow tables in the switch.
  • Each flow table includes one or multiple flow entries (Flow entry).
  • the Openflow controller may add, update or delete the flow entries in the flow table by use of the Openflow protocol message.
  • Each flow entry includes match field information and corresponding operation field information, wherein the operation field information may also called as action (Actions) field information or instruction (Instructions) field information.
  • Actions action field information
  • Instructions instruction field information
  • the switch compares the received packet with the match field information of the flow entries in the flow table, and if a flow entry matched with the received packet exists in the flow table, corresponding operation in the operation field information in the flow entry is implemented.
  • An operation field in the flow entry includes two types of information, the first type is to make the matched packet jump to the next flow table for further processing, and meanwhile, corresponding metadata may also be transmitted; and the second type is to modify and forward the data packet to an output port.
  • the OpenFlow switching device may be a device supporting an OpenFlow technology and having a switching function, which may be an OpenFlow switch, and is not limited in the embodiment of the present invention.
  • the OpenFlow switching device may be called as switching device for short.
  • the OpenFlow control device may be a device supporting the OpenFlow technology and having a control function, which may be an OpenFlow controller, and is not limited in the embodiment of the present invention. In the following embodiments, the OpenFlow control device is called as control device for short.
  • OpenFlow network is taken as an example for illustration, the embodiment of the present invention may also be applied to other network architectures similar to the OpenFlow network and having separated control planes and forwarding planes. This is not limited in the embodiment of the present invention.
  • Fig.2 is a schematic flowchart of a data packet processing method according to an embodiment of the present invention.
  • the method of Fig.2 is implemented by switching device, for example, a switch supporting an OpenFlow technology.
  • a data packet is matched with match field information of a flow entry.
  • the flow entry includes the match field information and operation field information.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet.
  • the beginning position of a particular bit field of the data packet in the data packet may be determined according to the first offset of the first bit field indication information, and the length of the particular bit field may be determined according to the first field length, thus the particular bit field may be acquired, and then corresponding operation may be performed on the particular bit field according to the operation type. Therefore, the particular bit field in the data packet may be freely acquired to perform the corresponding operation without being limited to a particular protocol format, so as to avoid standardized extension of a newly added protocol.
  • the first bit field indication information further includes a first mask.
  • the particular bit field is acquired according to the first offset and the first field length
  • one or multiple bits in the bit field namely at least one bit in the bit field
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit field of the data packet.
  • the second bit field is successfully matched with the match value, namely the data packet is successfully matched with the flow entry.
  • the match value is corresponding to the second bit field indication information.
  • the match field information includes the second bit field indication information
  • the beginning position of a particular bit field of the data packet in the data packet may be determined according to the second offset, and the length of the particular bit field may be determined according to the second field length, thus the particular bit field may be acquired, and then the bit field is matched according to the match value. Therefore, the particular bit field in the data packet may be freely acquired to for matching without being limited to the particular protocol format, so as to avoid the standardized extension of the newly added protocol.
  • the second bit field indication information further includes a second mask.
  • the particular bit field is acquired according to the second offset and the second field length
  • one or multiple bits in the bit field namely at least one bit in the bit field
  • the second mask may be acquired according to the second mask, and then the acquired one or multiple bits may be matched according to the match value. Therefore, on the basis of freely acquiring the particular bit field of the data packet, one or multiple particular bits in the particular bit field may be freely acquired for matching, thus increasing the degree of freedom and universality of custom processing of the data packet.
  • the data packet may be a packet data-packet.
  • the operation being performed on the data packet may include that the first bit field of the data packet is determined according to the first bit field indication information, and the operation is performed on the first bit field according to the operation type.
  • the operation being performed on the data packet may include that the first bit field of the data packet is determined according to the first bit field indication information, at least one bit of the first bit field is acquired according to the first mask, and the operation is performed on the at least one bit of the first bit field according to the operation type.
  • the operation being performed on the first bit field according to the operation type may include that the operation is performed on the first bit field and the operand according to the operation type.
  • the operation being performed on the at least one bit of the first bit field according to the operation type may include that the operation is performed on the at least one bit of the first bit field and the operand according to the operation type.
  • the switching device may have a forwarding plane function while having no control plane function.
  • the control plane function may be implemented by an external control device.
  • the control device may parse context information of a protocol format and the protocol format of the data packet, and map the processing of the data packet into the match field information and/or operation field information in the flow entry, in order to make processing of a forwarding plane irrelevant to the specific protocol format.
  • the switching device may arbitrarily determine the first bit field in the data packet according to the first bit field indication information and operate the first bit field without parsing the specific protocol format of the data packet. Similarly, the switching device may arbitrarily determine the second bit field in the data packet according to the second bit field indication information and match the second bit field without parsing the specific protocol format of the data packet.
  • the switching device does not need to extend the existing specification with respect to the specific protocol format of the data packet, thereby flexible user-definable flow operation can be achieved and the standardized extension that continuously occurrs for newly added protocols can be avoided. Therefore, in the embodiment of the present invention, the data packet processing method is more universal, and the application scenarios are more extensive. Comparatively speaking, since the types of the protocol formats supported in the existing OpenFlow specification are limited, if a data packet in a newly added protocol format needs to be processed, the existing specification needs to be further extended as for the newly added protocol format, which results in obese extensions.
  • step 210 in which the switching device matches the data packet with the match field information of the flow entry may also be implemented according to the process that the switching device matches the data packet with the match field information of the flow entry in the related art. This is not limited in the embodiment of the present invention.
  • step 220 in which the switching device operates the data packet according to the operation field information may also be implemented according to the process that the switching device operates the data packet according to the operation field information in the related art. This is not limited in the embodiment of the present invention.
  • the above-mentioned offset may be calculated from the beginning position of a grouping frame received from the input port of the switching device, and the unit may be octet (byte).
  • the above-mentioned field length may express the number of bytes of continuous fields after the offset.
  • the offset and the field length may be used for co-indicating a continuous byte segment with a determined length in the data packet.
  • the above-mentioned mask (Mask) may express a bit mask in the field co-indicated by the offset and the field length. The length of the mask may be equal to the field length.
  • the above-mentioned operation type may include a pop operation type, a push operation type, a Set-value operation type, a Calculate-Length operation type, a Calculate-Checksum operation type, a Verify-Checksum operation type, an increment operation type, a decrement operation type or a copy operation type.
  • the switching device may receive a flow entry addition indication message sent by a control device, and the flow entry addition indication message may include match field information and operation field information.
  • the switching device may generate a flow entry according to the received match field information and operation field information. Those of ordinary skill in the art should know that the flow entry may also be configured previousely on the switching device.
  • the switching device may receive a flow entry modification indication message sent by a control device, and the flow entry modification indication message may include match field information and new operation field information.
  • the switching device may modify the flow entry according to the match field information and the new operation field information.
  • the switching device may receive a feature request message sent by a control device, and the feature request message may be used for inquiring whether the switching device supports generic flow processing capacity, namely whether the above-mentioned match field information or the above-mentioned operation field information is supported.
  • the switching device may send a feature response message to the control device, and the feature response message may be used for indicating that the generic flow processing capacity is supported, namely, the above-mentioned match field information or the above-mentioned operation field information is supported.
  • the generic flow processing may refer to that the processing of the data packet by the switching device is not limited to the specific protocol format of the data packet, that is to say, the switching device may process the data packet without parsing the context information related to the specific protocol of the data packet and the format of the data packet.
  • the above-mentioned flow entry and the flow entry in the related art may coexist in the same flow table.
  • the above-mentioned flow entry may be stored in a flow table independently.
  • the above-mentioned flow entry may be an extension to the existing flow entry, wherein for example, the above-mentioned operation field information and/or match field information may be added to the flow entry of the existing common flow table.
  • the above-mentioned flow entry may also be independently stored in a flow table which is newly added in the switching device.
  • the newly added flow table may be called as a generic flow table (Generic Flow Table).
  • the generic flow table may be inserted in the existing flow pipeline (Flow Pipeline), the other common flow tables in the flow pipeline may jump to the generic flow table, and the generic flow table may also jump back to the other common flow tables in the flow pipeline.
  • Fig.3 is a schematic flowchart of a data packet processing method according to an embodiment of the present invention.
  • the method of the Fig.3 is implemented by a control device, for example, a controller supporting an OpenFlow technology.
  • the flow entry addition indication message includes match field information and operation field information.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet.
  • the operation field information may further include an operand.
  • the first bit field indication information may further include a first mask.
  • the operation type includes a pop operation type, a push operation type, a Set-value operation type, a Calculate-Length operation type, a Calculate-Checksum operation type, a Verify-Checksum operation type, an increment operation type, a decrement operation type or a copy operation type.
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit field of the data packet.
  • the second bit field indication information may further include a second mask.
  • the flow entry addition indication message is sent to a switching device.
  • the switching device may generate a flow entry according to the flow entry addition indication message, namely according to the match field information and the operation field information carried in the flow entry addition indication message, and process the data packet according to the generated flow entry.
  • the control device may generate a flow entry modification indication message, and the flow entry modification indication message also includes the above-mentioned match field information and operation field information.
  • the control device may send the generated flow entry modification indication message to the switching device.
  • the switching device may find a corresponding flow entry according to the match field information in the flow entry modification indication message, and then modify the operation field information of the corresponding flow entry into the operation field information carried in the flow entry modification indication message. In this way, the switching device may process the data packet according to the updated flow entry.
  • the control device may send a feature request message to the switching device, and the feature request message is used for inquiring whether the switching device supports the bit field indication information or the match field information.
  • the control device receives a feature response message returned by the switching device, and the feature response message may be used for indicating that the match field information or the operation field information is supported, and may also be used for indicating that the match field information or the operation field information is not supported.
  • the match field information or the operation field information may be prevented from being sent to the switching device which does not support the match field information or the operation field information, to prevent the switching device from wrongly adding or updating the flow entry, thus avoiding processing incorrectly the data packet by using the flow entry.
  • the processing of the data packet is not limited to a particular protocol format any more, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • Fig.4 is a schematic flowchart of a process of a data packet processing method according to an embodiment of the present invention.
  • a switching device is a switch
  • a control device is a controller.
  • the switch and the controller may communicate with each other.
  • a transport layer security (Transport Layer Security; TLS) channel may be established between the switch and the controller, to perform a session through the TLS channel.
  • TLS Transport Layer Security
  • a network application Network Application; Network App
  • the controller may be integrated into a physical entity and may also be separate, and this is not limited in the embodiment of the present invention.
  • the controller sends a feature request message to the switch, wherein the feature request message is used for inquiring whether the switch supports generic flow processing capacity.
  • the switch sends a feature response message to the controller, wherein the feature response message is used for indicating that the switch supports the generic flow processing capacity.
  • whether the generic flow processing capacity is supported refers to whether the capacity of positioning a particular bit field by use of offset and a field length is supported.
  • the capacity may be specifically expressed in a plurality of manners, for example, whether the processing of the first bit field indication information or the second bit field indication information in the embodiment as shown in Fig.2 is supported, or for example, whether operation field information including the first bit field indication information or match field information including the second bit field indication information is supported, and this is not limited in the embodiment of the present invention.
  • the switch may carry a generic flow processing capacity flag bit in the feature response message, to notify the controller that whether the generic flow processing capacity is supported through the flag bit.
  • the network application layer sends a flow entry addition indication message or a flow entry modification indication message to the controller, wherein the flow entry addition indication message or the flow entry modification indication message is used for indicating operation to be performed on the flow entry in the switch.
  • the network application layer may map the operation on the switch into the operation on the flow entry according to service logic.
  • the operation on the flow entry may include adding a flow entry, modifying a flow entry or the like.
  • the network application layer may send the flow entry addition indication message to the controller and may also call a flow table modification API (Application Programming Interface, application programming interface), and the flow entry addition indication message may carry the match field information and the operation field information.
  • the network application layer may send the flow entry modification indication message to the controller, and the flow entry modification indication message may carry the match field information and new operation field information.
  • the network application layer may also instruct to delete the flow entry through a flow entry deletion indication message.
  • the controller sends the flow entry addition indication message or the flow entry modification indication message to the switch.
  • the flow entry addition indication message may carry the match field information and the operation field information issued by the network application layer.
  • the flow entry modification indication message may carry the match field information and the new operation field information issued by the network application layer.
  • controller may also send a flow entry deletion indication message to the switch according to the flow entry deletion indication message issued by the network application layer.
  • the switch performs operation on the flow entry according to the flow entry addition indication message or the flow entry modification indication message sent by the controller.
  • the switch may generate a flow entry according to the match field information and the operation field information carried in the flow entry addition indication message.
  • the switch may also performs operation on the flow entry according to the match field information and the new operation field information carried in the flow entry modification indication message. For example, the operation field information in the flow entry corresponding to the match field information carried in the flow entry modification indication message may be updated to the new operation field information.
  • the switch sends a flow entry addition response message or a flow entry modification response message to the controller.
  • the switch notifies the controller that the operation on the flow entry has been completed through the flow entry addition response message or the flow entry modification response message.
  • the controller sends the flow entry addition response message or the flow entry modification response message to the network application layer.
  • the controller notifies the network application layer that the switch has completed the operation on the flow entry through the flow entry addition response message or the flow entry modification response message.
  • 401-407 exemplarily describes the method of operation of the controller for adding and updating the flow entry on the switch.
  • the sending of the flow entry addition or modification response message by the controller may also be triggered by other conditions, and this is not limited in the embodiment of the present invention. It will be described how to perform data packet processing on the flow entry by the switch below.
  • the switch receives a data packet from another external network element.
  • the switch matches the data packet with the flow entry.
  • the above-mentioned flow entry may include match field information
  • the match field information may include second bit field indication information and a match value
  • the second bit field indication information may include a second offset and a second field length
  • the second bit field indication information may be used for indicating the second bit field of the data packet.
  • the switch may determine the second bit field in the data packet according to the second bit field indication information. For example, the switch may determine the second bit field according to the second offset and the second field length. In addition, the second bit field indication information may further include a second mask. Then the switch may also determine a particular bit in the second bit field according to the second offset, the second field length and the second mask. For convenience of expression, the particular bit in the second bit field is also called as the second bit field hereinafter.
  • the switch may match the second bit field according to the match value.
  • the second bit field is successfully matched with the match value, namely the data packet is successfully matched with the flow entry.
  • the match value is corresponding to the second bit field indication information.
  • Fig.5 is a schematic diagram of an example of a data packet matching process according to an embodiment of the present invention.
  • the generic match field information proposed in the present invention is defined by use of a match field information format in the existing OpenFlow protocol.
  • the content of the existing OpenFlow match field information may be described by use of an OXM (OpenFlow Extensible Match) TLV (Type-Length-Value, type-length-value) structure.
  • OXM TLV OpenFlow Extensible Match
  • Each OXM TLV may be as long as 5-259 bytes, and the header may occupy 4 bytes.
  • An example of the header format of the OXM TLV structure is as shown in Table 1.
  • Table 1 an example of the OXM TLV structure Name Length (bit) Description OXM_TYPE OXM_CLASS 16 Match class (Match class): member class (member class) or reserved class (reserved class) OXM_FIELD 7 Match field name corresponding to the match class OXM_HASMASK 1 Set if the content (Value) part of the OXM includes a bit mask OXM_LENGTH 8 Length of the OXM content (Value) part OXM_VALUE 8 *OXM_LENGTH OXM content, namely the match value
  • the OXM_CLASS and the OXM_FIELD in the OXM_TYPE express match field name corresponding to the match field information in the flow entries, for example, an Ethernet destination address (ETH_DST).
  • the OXM_VALUE is an OXM content and is used for recording a match value corresponding to the OXM_TYPE.
  • the OXM_HASMASK in the OXM_TYPE indicates whether a part of bits in the OXM_VALUE need to be matched further through the mask in the determined second bit field.
  • OXM_HASMASK If the OXM_HASMASK is equal to 0, it indicates that all bits of the OXM_VALUE are used as match values; and if the OXM_HASMASK is equal to 1, it indicates that the bits corresponding to the mask part in the OXM_VALUE are used as the match values, and the value of a mask with the same byte length as the value of the OXM_VALUE follows the OXM_VALUE immediately.
  • the match field information may also adopt the format of the OXM structure.
  • the OXM structure adopted by the match field information in the embodiment of the present invention is called as a generic OXM structure.
  • a newly defined member class may be introduced into the OXM_CLASS, for example, OFPXMC_HW_0, to indicate that the extension is defined by a certain ONF (Open Networking Foundation, open networking foundation) member.
  • a new match field type is introduced into the OXM_FIELD, for example, OXM_OF_GENERIC_FIELD, to indicate that the OXM is a generic match type.
  • the OXM_VALUE is no longer a pure numerical value, but includes a second offset, a second field length, a second mask and a match value.
  • the second offset, the second field length, the second mask and the match value are respectively expressed by Offset, Size, Mask and Data.
  • the four parameters may be arranged in a specified sequence, or each parameter may be defined as an independent sub-TLV structure, wherein Type is a parameter type, for example, as the second offset, the second field length, the second mask or the match value. Length expresses a length of byte(s) of the parameter, and Value means a specific numerical value of the parameter.
  • multiple generic OXM may be added in the flow entries.
  • Table 2 an example of formats of the match field information
  • OXM_CLASS OFPXMC_HW_0
  • OXM_FIELD OXM_OF_GENERIC_FIELD
  • Len unit16 Total length of generic OXM Value ( bytes may be filled following this part to ensure that the total length is an integer multiple of 8 bytes)
  • Offset unit16 Second offset Size unit16
  • Second field length Mask[Size] unit8 Second mask.
  • the byte length occupied by the Mask is determined by Size Data[Size] unit8 Match value, namely the value of a second bit field.
  • the length of a byte segment is determined by size
  • IP Internet Protocol, internet protocol
  • DA Destination Address
  • the left column is match field information described by adopting the OpenFlow standard OXM and used for matching the IP destination addresses
  • OXM_CLASS indicates that the following OXM is defined by the OpenFlow standard protocol
  • OXM_FIELD specifies the class of the currently matched bit field as an IPv4 destination address
  • OXM_HASMASK indicates that a mask is needed
  • VALUE expresses a specific numerical value of the IPv4 address after being masked.
  • the right column of Table 3 is a manner for matching the IP destination addresses, described by adopting the generic OXM defined in the embodiment of the present invention.
  • OXM_CLASS indicates that the OXM is defined by an ONF organization member by means of extension
  • the OXM_FIELD is identified as a generic match field class
  • OXM_HASMASK indicates that no mask is needed
  • Value refers to the position and the value of the IPv4 destination address, described by adopting the second offset, the second field length, the second mask and the match value, in the data packet.
  • process that the switch matches the data packet with the flow entry may be performed according to the process that the switch matches the data packet with the flow entry in the related art. This is not limited in the embodiment of the present invention.
  • the switch performs operation on the data packet according to the flow entry.
  • the flow entry may include operation field information, the operation field information may include an operation type and first bit field indication information, the first bit field indication information may include a first offset and a first field length, and the first bit field indication information may be used for indicating the first bit field of the data packet.
  • the switch may determine the first bit field in the data packet according to the first bit field indication information. For example, the switch may determine the first bit field according to the first offset and the first field length.
  • the first bit field indication information may further include a first mask. In this way, the switch may also determine a particular bit in the first bit field according to the first offset, the first field length and the first mask. For convenience of expression, the particular bit in the first bit field is also called as the first bit field below.
  • the switch may perform operation on the first bit field in the data packet according to the operation type.
  • an operation field may further include an operand corresponding to the operation type.
  • the switch may perform operation on the first bit field of the data packet and the operand according to the operation type.
  • the operation type may include a pop operation type, a push operation type, a Set-value operation type, a Calculate-Length operation type, a Calculate-Checksum operation type, a Verify-Checksum operation type, an increment operation type, a decrement operation type or a copy operation type.
  • the operation type in the embodiment of the present invention is not limited to the operation types listed above, and may include other operation types,which is not limited in the embodiment of the present invention.
  • the first offset may include Top-offset and/or Bottom-offset.
  • the Top-offset may be calculated from the beginning position of a packet frame received from the input port of the switch, and the Bottom-offset may be calculated from the tail position of the packet frame.
  • the Top-offset and the Bottom-offset may be used for co-indicating a continuous byte segment.
  • Size expresses the first field length, and the first field length may include Size 1 and Size 2.
  • Data or Step expresses the operand, and Mask expresses the first mask.
  • Serial number Operation type Expression Description 1 Pop operation type Pop (Top-offset, Size) An specified bit field is popped. The operation type may be used for decapsulating a tunnel header (Tunnel Header). 2 push operation type Push (Top-offset, Size, Data) A bit field with length of Size bytes and value of Data is pushed at Top-offset. The operation type is used for encapsulating the tunnel header.
  • Calculate-Length operation type Calculate-Length (Top-offset 1, Bottom-offset1, Top-offset2, Size2) The byte length of a bit field 1 (specified by Top-offset1 and Bottom-offset 1) is calculated, and the byte length of the bit field 1 is stored in a bit field 2 (specified by Top-offset2 and Size2).
  • the operation type is mainly used for calculating a payload length.
  • Calculate-Checksum operation type Calculate-Checksum (Top-offset1, Size1/Bottom-offset1, Top-offset2, Size2)
  • the checksum of the bit field 1 (the bit field 1 is specified by the Top-offset1 and the Bottom-offset1 or size1) is calculated, and the checksum is stored in the bit field 2 (the bit field 2 is specified by the Top-offset2 and the Size2).
  • the operation type is mainly used for calculating the payload checksum.
  • Verify-Checksum operation type Verify-Checksum (Top-offset1, Size1/Bottom-offset1, Top-offset2, Size2)
  • the checksum of the bit field 1 (the bit field 1 is specified by the Top-offset1 and the Bottom-offset1 or Size1) is calculated, and the checksum is compared with an original checksum stored in the bit field 2 (the bit field 2 is specified by the Top-offset2 and the Size2). If they are not equal, subsequent operation is terminated, and error information is reported to the controller.
  • 7 increment operation type Increment (Top-offset, Size, Mask, Step) The size of Step is increased in the value of a field specified by the Top-offset and the Size.
  • the operation type may be used for progressively increasing a sequence number (sequence number).
  • the above-mentioned operation field information may also adopt a TLV structure.
  • An example of the type (TYPE) definition of the above-mentioned operation types may refer to Table 5.
  • Table 5 an example of type values of the operation types in the operation field information Type (TYPE) title Value Description OFPAT_GENERIC_POP 31 Bit field Pop operation OFPAT_GENERIC_PUSH 32 Bit field Push operation OFPAT_GENERIC_SET_VALUE 33 Bit field Set-value operation OFPAT_GENERIC_CALCULATE_LENGTH 34 Bit fieldCalculate-Length operation OFPAT_GENERIC_CALCULATE_CHECKSUM 35 Bit field Calculate-Checksum operation OFPAT_GENERIC_VERIFY_CHECKSUM 36 Bit field Verify-Checksum operation OFPAT_GENERIC_INCREMENT 37 Bit field value increment operation OFPAT_GENERIC_DECREMENT 38 Bit field value decrement operation OFPAT_GENERIC_COPY 39 Bit field value copy operation
  • the first offset may include the Top-offset and/or the Bottom-offset, and may also include the Top-offset1, the Top-offset2 and the Bottom-offset1.
  • Size expresses the first field length, and the first field length may include the Size1 and the Size2.
  • Data or Step expresses an operand, and Mask expresses the first mask.
  • each parameter e.g., Top-offset, Bottom-offset, Size, Mask, Data, Step
  • each parameter e.g., Top-offset, Bottom-offset, Size, Mask, Data, Step
  • Type expresses a parameter type, for example, as Offset, Size, Mask, Data or Step
  • Length expresses the byte length of the parameter
  • Value expresses the specific numerical value of the parameter.
  • the switch may perform operation on the data packet without parsing the protocol format of the data packet. Therefore, the above-mentioned operation field information may also be called as generic action field (Generic Action Field) information.
  • Generic Action Field Generic Action Field
  • step 410 in which the switch operates the data packet may also be performed according to the operation manner in the related art, and this is not limited in the embodiment of the present invention.
  • step 401 to step 402 and step 403 to step 407 do not need to be performed prior to every data packet processing, and for example, may be performed once during startup, or step 403 to step 407 is performed when it is needed to configure the flow entry. In this way, in the subsequent data packet processing process, step 401 to step 402 and step 403 to step 407 do not need to be performed. In this way, the switch may directly perform step 409 and step 410 after receiving the data packet.
  • the operation on the data packet is not limited to a particular protocol format any more, thus standardized extension of a newly added protocol is avoided, and full user-definable flow operation may be achieved.
  • the matching of the data packet is not limited to the particular protocol format any more, thus the standardized extension of the newly added protocol is avoided, and the full user-definable flow operation may be achieved.
  • the types of protocol formats in the existing OpenFlow specification are limited, resulting in limited application scenarios.
  • the existing OpenFlow specification does not support a variety of processes of tunnel encapsulation and decapsulation.
  • the pop (pop) and push (push) operations of VLAN (Virtual Local Area Network, virtual local area network) and MPLS (Multi-Protocol Label Switching, multi-protocol label switching) may be performed, while as for PPPoE, L3 tunnel encapsulation and decapsulation lack a necessary processing mechanism.
  • GTP General Packet Radio Service, general packet radio service Tunneling Protocol
  • GRPS tunneling protocol GPRS (General Packet Radio Service, general packet radio service) Tunneling Protocol
  • a process of creating a GTP tunnel based on the method of the embodiment of the present invention will be illustrated below in detail. It should be noted that, the examples of Fig.6 to Fig.10 are only intended to help those skilled in the art to better understand the embodiment of the present invention, rather than limiting the scope of the embodiment of the present invention.
  • Fig.6 is a schematic flowchart of an example of a process of a data packet processing method according to an embodiment of the present invention.
  • a control device herein is a controller
  • a switching device is a switch.
  • the controller receives a GTP-C (GTP-Control) request message.
  • GTP-C GTP-Control
  • the controller receives a create session request (Create Session Request) message.
  • the message may come from another external network element and may also come from other logic entities of this network element. This is not limited in the embodiment of the present invention.
  • the controller creates GTP session information.
  • the controller may create GTP-U user plane context information, for example, including user ID, bearing TEID (Tunnel Endpoint Identifier, tunnel endpoint identifier), a QoS (Quality of Service, quality of service) parameter, a charging parameter or the like.
  • the controller returns a GTP-C creation response message.
  • the controller maps GTP session context information into match field information and operation field information of a flow entry in the switch.
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit field of the data packet.
  • the second bit field indication information may further include a second mask.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet.
  • the first bit field indication information may further include a first mask.
  • match field information and the operation field information may refer to descriptions in Fig.2 or Fig.4 , and will not be repeated redundantly herein.
  • the controller sends a flow entry addition indication message to the switch, wherein the flow entry addition indication message carries the match field information and the operation field information.
  • the switch generates a flow entry according to the match field information and the operation field information carried in the flow entry addition indication message.
  • the switch sends a flow entry addition response message to the controller.
  • the switch receives an uplink GTP-U data packet from another external network element.
  • the switch may receive the uplink GTP-U data packet from another external network element.
  • the switch matches the data packet in step 608 according to the match field information of the flow entry, and performs a GTP-U decapsulation operation on the data packet according to the operation field information after the matching is successful.
  • the switch forwards an IP data packet acquired by decapsulation in step 609.
  • the switch receives a downlink IP data packet from another network element.
  • the switch performs a GTP-U encapsulation operation on the data packet according to the match field information and the operation field information in the flow entry.
  • the switch performs operation on a GTP-U data packet acquired by encapsulation in step 612.
  • examples of matching of the data packet according to the match field information and processing of the data packet according to the operation field information may refer to descriptions in Fig.2 or Fig.4 , and will not be repeated redundantly herein.
  • the controller creates the GTP session context information according to the GTP-C request message and maps the subsequent GTP-U decapsulation or encapsulation operation into the match field information and the operation field information of the flow entry.
  • the switch generates the flow entry according to the match field information and the operation field information, and may determine a corresponding bit field of the subsequent GTP-U data packet through the first bit field indication information or the second bit field indication information, and directly process and forward the data packet without parsing the protocol format of the data packet.
  • the flow entry is generated according to the match field information and the operation field information sent by the controller, so that the switch may directly perform tunnel encapsulation or decapsulation processing on the GTP-U data packet without parsing the protocol format of the data packet, and flexible user-definable flow operation can be achieved.
  • Fig.7 is a schematic diagram of another example of a process of a data packet processing method according to an embodiment of the present invention.
  • a switching device in the embodiment is a switch
  • a control device is a controller.
  • the switch receives the first uplink GTP-U data packet from another network element.
  • the switch sends the first uplink GTP-U data packet in step 701 to the controller through a PKT-IN (Packet-in, data packet input) message.
  • PKT-IN Packet-in, data packet input
  • the switch may forward the first uplink GTP-U data packet to the controller through the PKT-IN message.
  • the controller parses the first uplink GTP-U data packet, and maps decapsulation processing into match field information and operation field information of a flow entry if it is determined that a GTP decapsulation operation needs to be performed on the data packet.
  • the controller sends a flow entry addition indication message to the switch, wherein the flow entry addition indication message carries the match field information and the operation field information in step 703.
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit field of the data packet.
  • the second bit field indication information may further include a second mask.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet.
  • the first bit field indication information may further include a first mask.
  • match field information and the operation field information may refer to descriptions in Fig.2 or Fig.4 , and will not be repeated redundantly herein.
  • the switch generates a flow entry according to the match field information and the operation field information in step 704.
  • the switch sends a flow entry addition response message to the controller.
  • the controller returns the first uplink GTP-U data packet to the switch through a PKT-OUT (Packet-out, data packet output) message.
  • PKT-OUT Packet-out, data packet output
  • the switch matches the first uplink GTP-U data packet according to the match field information of the flow entry, and performs a decapsulation operation on the first uplink GTP-U data packet according to the operation field information after the matching is successful.
  • the switch forwards the first uplink IP data packet acquired by decapsulation.
  • the switch receives a subsequent uplink GTP-U data packet from another network element.
  • the switch matches the subsequent uplink GTP-U data packet according to the match field information of the flow entry, and performs a decapsulation operation on the subsequent uplink GTP-U data packet according to the operation field information after the matching is successful.
  • the switch forwards a subsequent IP data packet acquired by decapsulation.
  • the switch receives the first downlink IP data packet from another external network element.
  • the switch sends the first downlink IP data packet in step 713 to the controller through the PKT-IN (Packet-in) message.
  • PKT-IN Packet-in
  • the switch may forward the first downlink IP data packet to the controller through the PKT-IN message.
  • the controller parses the first IP data packet and maps encapsulation processing into the match field information and the operation field information of the flow entry if it is determined that a GTP-U encapsulation processing needs to be performed on the data packet.
  • the controller sends the flow entry addition indication message to the switch, wherein the flow entry addition indication message carries the match field information and the operation field information.
  • the switch generates the flow entry according to the match field information and the operation field information of the flow entry.
  • the switch sends the flow entry addition response message to the controller.
  • the controller returns the first downlink IP data packet to the switch through the PKT-OUT message.
  • the switch matches the first downlink IP data packet according to the match field information of the flow entry, and performs a encapsulation operation on the first downlink IP data packet according to the operation field information after the matching is successful.
  • the switch forwards the first GTP-U data packet acquired by encapsulation.
  • the switch receives a subsequent downlink IP data packet from another external network element.
  • the switch matches the subsequent downlink IP data packet according to the match field information of the flow entry, and performs a encapsulation operation on the subsequent downlink IP data packet according to the operation field information after the matching is successful.
  • the switch forwards the subsequent downlink GTP-U data packet acquired by encapsulation.
  • examples of matching of the data packet according to the match field information and processing of the data packet according to the operation field information may refer to descriptions in Fig.2 or Fig.4 , and will not be repeated redundantly herein.
  • a GTP-C signaling stage at a GTP-C signaling stage, no flow entry is created.
  • the first data packet is firstly forwarded to the controller, and the controller parses the data packet and maps the GTP-U decapsulation or encapsulation processing into the match field information and the operation field information of the flow entry.
  • the switch generates the flow entry according to the match field information and the operation field information, and may directly determine a particular bit field of the subsequent GTP-U data packet according to the first bit field indication information or the second bit field indication information, and process and forward the data packet without parsing the protocol format of the data packet.
  • the flow entry is generated according to the match field information and the operation field information sent by the controller, so that the switch may directly perform tunnel encapsulation or decapsulation processing on the GTP-U data packet without parsing the protocol format of the data packet, and flexible user-definable processing of the data packet may be achieved.
  • Fig.8 is a schematic diagram of another example of a process of a data packet processing method according to an embodiment of the present invention.
  • a switching device in the embodiment is a switch
  • a control device is a controller.
  • Match field information includes second bit field indication information and a match value, the second bit field indication information includes a second offset and a second field length, and the second bit field indication information is used for indicating the second bit field of the data packet.
  • the switch may match a second bit field determined by the second bit field indication information in the match field information and corresponding to an IP source address (Source Address, SA), namely, the switch determines the bit field where the IP SA in the IP data packet is located according to the second bit field indication information in the OXM indicating the IP SA, and compares to determine whether the value of the bit field is equal to the match value in the OXM.
  • SA IP source address
  • the switch may implement the operation type in the operation field information of the flow entry.
  • the control device may determine that GTP encapsulation needs to be performed on the data packet by means of the foregoing GTP session creation operation or parse of the first GTP-U data packet.
  • the switch has created the flow entry according to the foregoing flow entry addition indication message sent by the controller.
  • the operation field information in the flow entry may include multiple groups of operation types corresponding to encapsulation processing and first bit field indication information corresponding to the operation types, wherein a GTP encapsulation header may include an outer layer IP header, a UDP (User Data gram Protocol, user data gram protocol) header and a GTP header, the outer layer IP header includes a source endpoint address and a destination endpoint address of a tunnel, and the GTP encapsulation header may further include allocated TEID.
  • the encapsulation processing may include the following several groups of operation types and the first bit field indication information corresponding to the operation types:
  • the flow entry is generated according to the match field information and the operation field information sent by the controller, so that the switch may directly determine and process a particular bit field in the GTP-U data packet without parsing the protocol format of the data packet, and flexible user-definable processing of the data packet can be achieved.
  • Fig.9 is a schematic diagram of another example of a process of a data packet processing method according to an embodiment of the present invention.
  • a switching device is a switch
  • a control device is a controller.
  • a match field of the flow entry includes two groups of second bit field indication information and match values.
  • the switch may match a bit field determined by the first group of second bit field indication information in the match field and corresponding to IP DA, and match a bit field determined by the second group of second bit field indication information in the match field and corresponding to a UDP port number 2152. Namely, the switch may determine the bit field where the IP DA in the GTP-U data packet is located according to the first group of second bit field indication information in OXM indicating the IP DA, and compare to determine whether the value of the bit field is equal to the first group of match values in the OXM.
  • the switch may determine the bit field where a UDP port in the GTP-U data packet is located according to the second group of second bit field indication information in the OXM indicating the UDP port, and compare to determine whether the value of the bit field is equal to the second group of match values in the OXM. If the two bit fields are both matched successfully, the switching device may perform a GTP decapsulation according to operation field information in the flow entry.
  • the controller may determine that the GTP decapsulation needs to be performed on the data packet by means of the foregoing GTP-C session creation operation or parse of the first GTP-U data packet.
  • the switch has created the flow entry according to the foregoing flow entry addition indication message sent by the controller.
  • the operation field information in the flow entry may include multiple groups of operation types corresponding to decapsulation processing and first bit field indication information corresponding to the operation types, wherein a GTP encapsulation header may include an outer layer IP header, a UDP header and a GTP header.
  • the decapsulation processing may include the following several groups of operation types and the first bit field indication information corresponding to the operation types:
  • the flow entry is generated according to the match field information and the operation field information sent by the controller, so that the switch may directly perform tunnel decapsulation processing on the GTP-U data packet according to the first bit field indication information and the second bit field indication information without parsing the protocol format of the data packet, and flexible user-definable flow operation may be achieved.
  • Fig.10 is a schematic diagram of another example of a process of a data packet processing method according to an embodiment of the present invention.
  • a switching device is a switch
  • a control device is a controller.
  • Fig.10 with a GTP protocol as an example, after the switch creates a flow entry and when the switch receives a GTP-U data packet, how to perform GTP tunnel decapsulation and re-encapsulation processing according to the flow entry is described. In the processing process, there is no need to pop the original tunnel packet header firstly and then push a new tunnel packet header, while only an outer layer IP address, tunnel ID and other information need to be modified.
  • a match field of the flow entry includes two groups of second bit field indication information and match values.
  • the switch may match a bit field determined by the first group of second bit field indication information in the match field and corresponding to IP DA, and match a bit field determined by the second group of second bit field indication information in the match field and corresponding to a UDP port number 2152. Namely, the switch may determine the bit field where the IP DA in the GTP-U data packet is located according to the first group of second bit field indication information in OXM indicating the IP DA, and compare to determine whether the value of the bit field is equal to the first group of match values in the OXM.
  • the switching device may determine the bit field where a UDP port in the GTP-U data packet is located according to the second group of second bit field indication information in the OXM indicating the UDP port, and compare to determine whether the value of the bit field is equal to the second group of match values in the OXM. If the two bit fields are both matched successfully, the switching device may modify tunnel header field information according to operation field information in the flow entry.
  • the controller may determine that GTP decapsulation and re-encapsulation needs to be performed on the data packet by means of the foregoing GTP-C session creation operation or parse of the first GTP-U data packet.
  • the switch has created the flow entry according to the foregoing flow entry addition indication message sent by the controller.
  • the operation field information in the flow entry may include multiple groups of operation types corresponding to the decapsulation and re-encapsulation processing and first bit field indication information corresponding to the operation types.
  • a GTP encapsulated header may include an outer layer IP header, a UDP header and a GTP header.
  • the decapsulation and re-encapsulation processing may include the following several groups of operation types and the first bit field indication information corresponding to the operation types:
  • the flow entry is generated according to the match field information and the operation field information sent by the controller, so that the switch may directly perform tunnel decapsulation and re-encapsulation processing on the GTP-U data packet according to the first bit field indication information and the second bit field indication information without parsing the protocol format of the data packet, and flexible user-definable flow operation may be achieved.
  • the above-mentioned flow entry may be extension of an existing flow entry, for example, the above-mentioned operation field information and/or match field information may be added in the flow entry of an existing common flow table.
  • the above-mentioned flow entry may also be indepedently stored in a flow table newly added in the switch. The arrangement of the flow table in the embodiment of the present invention will be described below in detail in combination with specific examples.
  • Fig.11 is a schematic diagram of an example of an arrangement of a flow table according to an embodiment of the present invention.
  • a flow entry in the embodiment of the present invention may be indepedently stored in a newly added flow table, and in order to differ from other existing common flow tables (the flow table as shown in Fig.1 ), and the newly added flow table may be called as a generic flow table.
  • the other common flow tables may be kept unchanged.
  • the generic flow table may be inserted in an existing flow pipeline, the other common flow tables in the flow pipeline may jump to the generic flow table, and the generic flow table may also jump back to the other common flow tables in the flow pipeline.
  • the flow entry of the generic flow table adopts the same structure as the flow entry in the common flow table, but may include OXM in the embodiment of the present invention in match field information, and may include an operation type and corresponding first bit field indication information in the embodiment of the present invention in operation field information.
  • Fig.12 is a schematic block diagram of a data packet processing apparatus according to an embodiment of the present invention.
  • An example of the apparatus 1200 as shown in Fig.12 is switching device, for example, an OpenFlow switch.
  • the apparatus 1200 includes a matching unit 1210 and an operating unit 1220.
  • the matching unit 1210 is configured to match a data packet with match field information of a flow entry; the flow entry includes the match field information and operation field information; wherein the operation field information includes an operation type and first bit field indication information, the first bit field indication information includes a first offset and a first field length, and the first bit field indication information is used for indicating the first bit field of the data packet, or the match field information includes second bit field indication information and a match value, the second bit field indication information includes a second offset and a second field length, and the second bit field indication information is used for indicating the second bit field of the data packet.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the
  • the operating unit 1220 is configured to, if the data packet is successfully matched with the match field information, perform operation on the data packet according to the operation field information.
  • the operating unit 1220 is specifically configured to, if the data packet is successfully matched with the match field information, determine the first bit field of the data packet according to the first bit field indication information, and perform the operation on the first bit field according to the operation type.
  • the operating unit 1220 is specifically configured to, if the data packet is successfully matched with the match field information, determine the first bit field of the data packet according to the first bit field indication information, acquire at least one bit of the first bit field according to the first mask, and perform the operation on the at least one bit of the first bit field according to the operation type.
  • the operating unit 1220 is specifically configured to, if the data packet is successfully matched with the match field information, determine the first bit field of the data packet according to the first bit field indication information, and perform the operation on the first bit field and the operand according to the operation type.
  • the matching unit 1210 is specifically configured to determine the second bit field of the data packet according to the second bit field indication information, and match the second bit field according to the match value.
  • the matching unit 1210 is specifically configured to determine the second bit field of the data packet according to the second bit field indication information, acquire at least one bit of the second bit field according to the second mask, and match the at least one bit of the second bit field according to the match value.
  • the operation type includes a pop operation type, a push operation type, a Set-value operation type, a Calculate-Length operation type, a Calculate-Checksum operation type, a Verify-Checksum operation type, an increment operation type, a decrement operation type or a copy operation type.
  • the operation of the data packet is not limited to a particular protocol format any more.
  • the switching device may arbitrarily determine the second bit field in the data packet according to the second bit field indication information and match the second bit field without parsing the specific protocol format of the data packet. Therefore, by adopting the apparatus as shown in Fig.12 , standardized extension of a newly added protocol may be avoided, thus flexible user-definable flow operation can be achieved.
  • the apparatus 1200 may further includes a receiving unit 1230 and a generating unit 1240.
  • the receiving unit 1230 is configured to receive a flow entry addition indication message sent by control device, wherein the flow entry addition indication message includes the match field information and the operation field information; and the generating unit is configured to generate the flow entry according to the match field information and the operation field information.
  • the receiving unit 1230 is further configured to receive a flow entry modification indication message sent by the control device, wherein the flow entry modification indication message includes the match field information and new operation field information; correspondingly, the apparatus 1200 further includes a modifying unit 1240, configured to modify the flow entry according to the match field information and the new operation field information.
  • the receiving unit 1230 is further configured to receive a feature request message sent by the control device, wherein the feature request message is used for inquiring whether the operation field information or the match field information is supported; and correspondingly, the apparatus 1200 further includes a sending unit 1250, configured to send a feature response message to the control device, wherein the feature response message is used for indicating that the operation field information or the match field information is supported.
  • the apparatus 1200 may be a switching device.
  • the switching device may be a switch.
  • Fig.13 is a schematic block diagram of a data packet processing apparatus according to another embodiment of the present invention. As shown in Fig.13 , the apparatus 1300 includes a generating unit 1310 and a sending unit 1320.
  • the generating unit 1310 is configured to generate a flow entry addition indication message, and the flow entry addition indication message includes match field information and operation field information, wherein the operation field information includes an operation type and first bit field indication information, the first bit field indication information includes a first offset and a first field length, and the first bit field indication information is used for indicating the first bit field of the data packet, or the match field information includes second bit field indication information and a match value, the second bit field indication information includes a second offset and a second field length, and the second bit field indication information is used for indicating the second bit field of the data packet.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit
  • the sending unit 1320 is configured to send the flow entry addition indication message to switching device, for enabling the switching device to generate a flow entry according to the flow entry addition indication message and process the data packet according to the flow entry.
  • the generating unit 1310 is further configured to generate a flow entry modification indication message, wherein the flow entry modification indication message includes the match field information and new operation field information; and correspondingly, the sending unit 1320 is further configured to send the flow entry modification indication message to the switching device, for enabling the switching device to modify the flow entry corresponding to the match field information according to the match field information and the new operation field information.
  • the sending unit 1320 is further configured to send a feature request message to the switching device, wherein the feature request message is used for inquiring whether the match field information or the operation field information is supported; and correspondingly, the apparatus 1300 further includes a receiving unit 1330, configured to receive a feature response message sent by the switching device, wherein the feature response message is used for indicating that the match field information or the operation field information is supported.
  • the apparatus 1300 may be a control device, and exemplarily, may be a controller.
  • the working manner of the apparatus 1300 in the embodiment may refer to the working manner of the control devices as shown in Fig.3 to Fig.11 , and will not be repeated redundantly herein.
  • the apparatus in the embodiment of the present invention by sending the bit field indication information carrying the offset and the field length to the switching device, may achieve flexible positioning of a particular bit field in the data packet and achieve flexible custom processing of the data packet, such that the processing of the data packet is not limited to a particular protocol format any more, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • Another embodiment of the present invention further provides a data packet processing system, as shown in Fig.14 , the system includes switching device 1410 and control device 1420.
  • the switching device 1410 may be the apparatus as shown in Fig.12
  • the control device may be the apparatus as shown in Fig.13 .
  • the working manner of the system may refer to the working manners in the embodiments as shown in Fig.2 to Fig.11 , and will not be repeated redundantly herein.
  • a particular bit field of a data packet may be flexibly determined according to offset and a field length, and the particular bit field is matched or operated, thus flexible custom processing of the data packet may be achieved, such that the processing of the data packet is not limited to a particular protocol format any more, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • Another embodiment of the present invention further provides a flow entry, including match field information and operation field information.
  • the operation field information includes an operation type and first bit field indication information
  • the first bit field indication information includes a first offset and a first field length
  • the first bit field indication information is used for indicating the first bit field of the data packet
  • the match field information includes second bit field indication information and a match value
  • the second bit field indication information includes a second offset and a second field length
  • the second bit field indication information is used for indicating the second bit field of the data packet.
  • the first bit field indication information further includes a first mask.
  • the second bit field indication information further includes a second mask.
  • the operation field information further includes an operand.
  • the operation type includes a pop operation type, a push operation type, a Set-value operation type, a Calculate-Length operation type, a Calculate-Checksum operation type, a Verify-Checksum operation type, an increment operation type, a decrement operation type or a copy operation type.
  • a particular bit field of a data packet may be flexibly determined, and the particular bit field is matched or operated, thus flexible custom processing of the data packet can be achieved, such that the processing of the data packet is not limited to a particular protocol format any more, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • Another embodiment of the present invention further provides a computer program product for processing a data packet.
  • the computer program product includes a computer-executable program code, and the program code is used for implementing the data packet processing method as shown in Fig.2 .
  • the embodiment of the present invention provides a hardware implementation of a data packet processing apparatus.
  • the apparatus may be switching device, and exemplarily, may be a switch supporting an OpenFlow technology.
  • the apparatus includes a processor, a memory, a first network interface, a second network interface and a third network interface.
  • the first network interface, the second network interface, the third network interface, the processor and the memory are interconnected through a bus.
  • the first network interface may be connected with a control device for interaction, and exemplarily, the control device may be a controller supporting the OpenFlow technology.
  • the second network interface is used as the input port of the apparatus and may be used for receiving a data packet.
  • the third network interface is used as the output port of the apparatus and may be used for sending a data packet processed by the processor.
  • each network interface may include a plurality of input and output ports.
  • the first, second and third network interfaces may be mutually independent network interfaces, and may also be mutually combined into one network interface.
  • the memory may be a semiconductor storage unit and may be directly accessed by the processor.
  • the memory is used for storing computer-executable program codes, and the program codes are used for implementing the data packet processing method as shown in Fig.2 and storing the flow entry provided by the embodiment of the present invention.
  • the processor is used for implementing the data packet processing method as shown in Fig.2 according to the computer-executable program codes stored in the memory and processing the received data packet.
  • a flow entry addition indication message sent by the control device may be received, the flow entry addition indication message may include match field information and operation field information of the flow entry provided by the embodiment of the present invention, and the processor may generate the flow entry provided by the embodiment of the present invention according to the match field information and the operation field information carried in the flow entry addition indication message, and store the flow entry in the memory.
  • a flow entry modification indication message sent by the control device may also be received, similar to the flow entry addition indication message, the flow entry modification indication message may include the match field information and the operation field information of the flow entry provided by the embodiment of the present invention, and the processor may find the corresponding flow entry in the memory according to the match field information and update the operation field information in the flow entry into the operation field information carried in the flow entry modification indication message.
  • a feature request message sent by the control device may also be received, and the feature request message may be used for inquiring whether the switching device supports generic flow processing capacity, namely, whether the match field information or the operation field information of the flow entry provided by the embodiment of the present invention is supported.
  • a feature response message may be sent to the control device, and the feature response message may be used for indicating that the generic flow processing capacity is supported, namely, the match field information or the operation field information of the flow entry provided by the embodiment of the present invention is supported.
  • the embodiment of the present invention provides a hardware implementation of a data packet processing apparatus.
  • the apparatus may be a control device, and exemplarily, may be a controller supporting an OpenFlow technology.
  • the apparatus includes a memory, a processor and a controller.
  • the memory, the processor and the controller are mutually communicated through a bus.
  • a network interface may be connected to a switching device for interacting with the switching device.
  • the memory may be a semiconductor device and may be directly accessed by the processor.
  • the memory is used for storing computer-executable program codes, and the program codes are used for implementing the data packet processing method as shown in Fig.3 .
  • the processor is used for implementing the data packet processing method as shown in Fig.3 according to the computer-executable program code stored in the memory.
  • a flow entry addition indication message, a flow entry modification indication message or a feature request message is sent by the processor to the switching device through the network interface.
  • the switching device may generate the flow entry provided by the embodiment of the present invention, thus flexible positioning of a particular bit field of a data packet is achieved, and then flexible custom processing of the data packet can be achieved, standardized extension of a newly added protocol is avoided, and the processing of the data packet is more universal.
  • the disclosed system, apparatus and method may be implemented in other manners.
  • the apparatus embodiments described above are merely exemplary, e.g., the division of the units is only a logic function division, other division manners may exist in practical implementation, for example, a plurality of units or components may be combined or integrated to another system, or some features may be omitted or not implemented.
  • the displayed or discussed mutual coupling or direct coupling or communication connection may be indirect coupling or communication connection of devices or units through some interfaces, and may be in electrical, mechanical or other forms.
  • the units described as separate components may be separated physically or not, components displayed as units may be physical units or not, namely, may be located in one place, or may be distributed on a plurality of network units. A part of or all of the units may be selected to achieve the purposes of the solutions in the embodiments according to actual demand.
  • the functional units in the embodiments of the present invention may be integrated in a processing unit, or the units singly exist physically, or two or more units are integrated in one unit.
  • the function is implemented in the form of a software functional unit and is sold or used as an independent product, it may be stored in a computer readable storage medium.
  • the technical solutions of the present invention substantially, or the part contributing to the related art, or a part of the technical solutions may be implemented in the form of a software product
  • the computer software product is stored in a storage medium, and includes a plurality of instructions enabling computer device (may be a personnel computer, a server, or network device, etc.) to execute all or a part of the steps of the methods in the embodiments of the present invention.
  • the foregoing storage medium includes a variety of media capable of storing program codes, such as a USB disk, a mobile hard disk, a read-only memory (ROM, Read-Only Memory), a random access memory (RAM, Random Access Memory), a magnetic disk, an optical disk or the like.
EP12882133.7A 2012-08-02 2012-08-02 Procédé, appareil et système de traitement de paquet de données Active EP2869509B1 (fr)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/CN2012/079602 WO2014019205A1 (fr) 2012-08-02 2012-08-02 Procédé, appareil et système de traitement de paquet de données

Publications (3)

Publication Number Publication Date
EP2869509A1 true EP2869509A1 (fr) 2015-05-06
EP2869509A4 EP2869509A4 (fr) 2015-06-03
EP2869509B1 EP2869509B1 (fr) 2019-01-02

Family

ID=50027128

Family Applications (1)

Application Number Title Priority Date Filing Date
EP12882133.7A Active EP2869509B1 (fr) 2012-08-02 2012-08-02 Procédé, appareil et système de traitement de paquet de données

Country Status (4)

Country Link
US (1) US9894003B2 (fr)
EP (1) EP2869509B1 (fr)
CN (1) CN103718520B (fr)
WO (1) WO2014019205A1 (fr)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3166265A4 (fr) * 2014-08-06 2017-08-16 Huawei Technologies Co., Ltd. Procédé, appareil et système de traitement de paquet de données dans un réseau défini par logiciel (sdn)
EP3190751A4 (fr) * 2014-09-05 2017-08-23 Huawei Technologies Co., Ltd. Procédé et dispositif de délivrance de paramètres de transfert

Families Citing this family (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9246847B2 (en) * 2012-12-17 2016-01-26 Telefonaktiebolaget L M Ericsson (Publ) Extending the reach and effectiveness of header compression in access networks using SDN
US20160094357A1 (en) * 2013-04-24 2016-03-31 Nec Corporation Control apparatus, computer system, communication control method, and program
US9674315B2 (en) * 2013-05-07 2017-06-06 Futurewei Technologies, Inc. Methods for dynamically binding header field identifiers in a network control protocol
CN103428094B (zh) * 2013-08-12 2016-08-17 杭州华三通信技术有限公司 开放流OpenFlow系统中的报文转发方法及装置
CN105531967B (zh) * 2014-04-21 2020-06-16 华为技术有限公司 一种报文传输方法、设备及通信系统
WO2015184584A1 (fr) * 2014-06-03 2015-12-10 华为技术有限公司 Procédé, contrôleur, commutateur, et système de transmission d'informations entre des tables openflow
CN105245455B (zh) * 2014-07-11 2019-01-01 中国移动通信集团公司 软件定义网络中的流表下发方法、报文转发方法及设备
CN105453497B (zh) * 2014-08-06 2019-03-08 华为技术有限公司 一种软件定义网络sdn中处理数据包的方法、装置及系统
WO2016131422A1 (fr) * 2015-02-17 2016-08-25 Hangzhou H3C Technologies Co., Ltd. Génération d'entrée de flux et traitement de paquets sur la base de l'entrée de flux
US20170359259A1 (en) * 2016-06-09 2017-12-14 Hewlett Packard Enterprise Development Lp Packet field matching in openflow
US11159427B2 (en) * 2017-03-31 2021-10-26 Intel Corporation Single lookup entry for symmetric flows
CN107426180B (zh) * 2017-06-15 2020-05-05 西安微电子技术研究所 一种以太网数据帧覆盖性的检测装置
CA3066826C (fr) * 2017-06-30 2023-06-27 Huawei Technologies Co., Ltd. Methode de traitement de donnees reseau, carte d'interface reseau et serveur
CN109495387A (zh) * 2017-09-13 2019-03-19 中兴通讯股份有限公司 流表匹配方法、装置、系统及计算机可读存储介质
US11444877B2 (en) * 2019-03-18 2022-09-13 At&T Intellectual Property I, L.P. Packet flow identification with reduced decode operations
US11470009B2 (en) * 2019-10-18 2022-10-11 Arista Networks, Inc. Implementing multi-table OpenFlow using a parallel hardware table lookup architecture
US11601491B2 (en) * 2020-03-30 2023-03-07 Tencent America LLC Network-based media processing (NBMP) workflow management direct access in 5G framework for live uplink streaming (FLUS)
CN111583147B (zh) * 2020-05-06 2023-06-06 北京字节跳动网络技术有限公司 图像处理方法、装置、设备及计算机可读存储介质
CN114079674B (zh) * 2020-08-10 2023-02-21 大唐移动通信设备有限公司 一种数据处理方法、用户面功能及装置
CN115314447B (zh) * 2021-05-08 2024-03-26 中国科学院声学研究所 一种SDN环境中packet-in消息的处理方法及系统
CN116455997B (zh) * 2023-06-12 2023-08-22 深圳华锐分布式技术股份有限公司 Step行情多路转发方法、装置、设备及介质

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2408155A4 (fr) 2009-03-09 2015-01-28 Nec Corp Système de communication openflow et procédé de communication openflow
CN101594355B (zh) * 2009-06-17 2012-11-07 华为技术有限公司 一种实现软件跨版本交互的方法及装置
US8762501B2 (en) * 2011-08-29 2014-06-24 Telefonaktiebolaget L M Ericsson (Publ) Implementing a 3G packet core in a cloud computer with openflow data and control planes
CN102333039B (zh) * 2011-10-25 2014-09-17 华为技术有限公司 一种转发报文的方法、生成表项的方法及装置
CN102594689B (zh) * 2012-02-22 2015-06-10 中兴通讯股份有限公司 一种分布式网络控制方法及装置
US10390259B2 (en) * 2012-02-28 2019-08-20 Nokia Solutions And Networks Oy Data forwarding in a mobile communications network system with centralized gateway apparatus controlling distributed gateway elements
KR101761702B1 (ko) * 2012-03-30 2017-08-04 노키아 솔루션스 앤드 네트웍스 오와이 분산된 게이트웨이들을 위한 중앙집중화된 ip 어드레스 관리 방법 및 장치

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3166265A4 (fr) * 2014-08-06 2017-08-16 Huawei Technologies Co., Ltd. Procédé, appareil et système de traitement de paquet de données dans un réseau défini par logiciel (sdn)
US10200289B2 (en) 2014-08-06 2019-02-05 Huawei Technologies Co., Ltd. Data packet processing method, apparatus, and system in software defined network SDN
US10764195B2 (en) 2014-08-06 2020-09-01 Huawei Technologies Co., Ltd. Data packet processing method, apparatus, and system in software defined network SDN
EP3190751A4 (fr) * 2014-09-05 2017-08-23 Huawei Technologies Co., Ltd. Procédé et dispositif de délivrance de paramètres de transfert
US10320660B2 (en) 2014-09-05 2019-06-11 Huawei Technologies Co., Ltd. Method and device for transmitting forwarding parameter

Also Published As

Publication number Publication date
CN103718520B (zh) 2017-07-21
US9894003B2 (en) 2018-02-13
EP2869509B1 (fr) 2019-01-02
CN103718520A (zh) 2014-04-09
EP2869509A4 (fr) 2015-06-03
US20150146718A1 (en) 2015-05-28
WO2014019205A1 (fr) 2014-02-06

Similar Documents

Publication Publication Date Title
US9894003B2 (en) Method, apparatus and system for processing data packet
US10038766B2 (en) Partial reassembly and fragmentation for decapsulation
EP2928123B1 (fr) Procédé de traitement d'unités de données VxLAN
CN109936492B (zh) 一种通过隧道传输报文的方法、装置和系统
US10003503B2 (en) Tunnel type selection method and apparatus
CN111698162A (zh) 一种信息同步的方法,装置及系统
US20220255772A1 (en) Packet sending method, apparatus, and system
EP3644559A1 (fr) Procédé de transmission de paquet, dispositif d'acheminement, contrôleur et système
WO2016131422A1 (fr) Génération d'entrée de flux et traitement de paquets sur la base de l'entrée de flux
US11356372B2 (en) Data traffic processing method, device, and system
WO2021088813A1 (fr) Procédé et appareil d'encapsulation de paquets, et procédé et appareil de décapsulation de paquets
WO2015172675A1 (fr) Procédé et dispositif de traitement de paquet
WO2022142390A1 (fr) Procédé et dispositif d'encapsulation et de désencapsulation de paquet, support de stockage, et dispositif électronique
JP6222505B2 (ja) 入力パラメータを生成するための方法および装置
US20210084125A1 (en) Managing layer two network extension communications using maximum segment size (mms) modifications
WO2016017737A1 (fr) Commutateur, système de réseau superposé, procédé de communications et programme
JP4340651B2 (ja) ネットワーク・トンネリング装置
CN110505137B (zh) 功能扩展式有线网络装置
EP4207705A1 (fr) Procédé, dispositif et système d'acheminement de paquets sur la base d'un groupe d'utilisateurs
WO2024041064A1 (fr) Procédé de transmission de paquets quic et dispositif associé
WO2023005620A1 (fr) Procédé et appareil de traitement de message, et système de communication
WO2022135321A1 (fr) Procédé, dispositif et système de transmission de paquets
WO2016031923A1 (fr) Commutateur, système de réseau superposé, procédé et programme de changement de configuration de tunnel
CN105991307B (zh) 一种远程控制路由器的方法和装置
CN115733790A (zh) 报文转发方法、装置、设备及存储介质

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20150129

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

AX Request for extension of the european patent

Extension state: BA ME

RA4 Supplementary search report drawn up and despatched (corrected)

Effective date: 20150507

RIC1 Information provided on ipc code assigned before grant

Ipc: H04L 12/717 20130101ALN20150429BHEP

Ipc: H04L 12/741 20130101AFI20150429BHEP

Ipc: H04L 12/715 20130101ALI20150429BHEP

DAX Request for extension of the european patent (deleted)
RAP1 Party data changed (applicant data changed or rights of an application transferred)

Owner name: HUAWEI TECHNOLOGIES CO., LTD.

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: EXAMINATION IS IN PROGRESS

17Q First examination report despatched

Effective date: 20170929

GRAP Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOSNIGR1

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: GRANT OF PATENT IS INTENDED

RIC1 Information provided on ipc code assigned before grant

Ipc: H04L 12/741 20130101AFI20180613BHEP

Ipc: H04L 12/715 20130101ALI20180613BHEP

Ipc: H04L 12/717 20130101ALN20180613BHEP

Ipc: H04L 12/721 20130101ALI20180613BHEP

RIC1 Information provided on ipc code assigned before grant

Ipc: H04L 12/717 20130101ALN20180705BHEP

Ipc: H04L 12/721 20130101ALI20180705BHEP

Ipc: H04L 12/741 20130101AFI20180705BHEP

Ipc: H04L 12/715 20130101ALI20180705BHEP

INTG Intention to grant announced

Effective date: 20180718

RIC1 Information provided on ipc code assigned before grant

Ipc: H04L 12/717 20130101ALN20180706BHEP

Ipc: H04L 12/721 20130101ALI20180706BHEP

Ipc: H04L 12/741 20130101AFI20180706BHEP

Ipc: H04L 12/715 20130101ALI20180706BHEP

GRAS Grant fee paid

Free format text: ORIGINAL CODE: EPIDOSNIGR3

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE PATENT HAS BEEN GRANTED

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

REG Reference to a national code

Ref country code: GB

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: CH

Ref legal event code: EP

Ref country code: AT

Ref legal event code: REF

Ref document number: 1085842

Country of ref document: AT

Kind code of ref document: T

Effective date: 20190115

REG Reference to a national code

Ref country code: IE

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: DE

Ref legal event code: R096

Ref document number: 602012055568

Country of ref document: DE

REG Reference to a national code

Ref country code: NL

Ref legal event code: MP

Effective date: 20190102

REG Reference to a national code

Ref country code: LT

Ref legal event code: MG4D

REG Reference to a national code

Ref country code: AT

Ref legal event code: MK05

Ref document number: 1085842

Country of ref document: AT

Kind code of ref document: T

Effective date: 20190102

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: NL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: ES

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: PL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: NO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190402

Ref country code: SE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: PT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190502

Ref country code: FI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: LT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IS

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190502

Ref country code: BG

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190402

Ref country code: HR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: RS

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: GR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190403

Ref country code: LV

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

REG Reference to a national code

Ref country code: DE

Ref legal event code: R097

Ref document number: 602012055568

Country of ref document: DE

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: CZ

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: RO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: AL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: SK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: IT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: DK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: EE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: AT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SM

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

26N No opposition filed

Effective date: 20191003

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

REG Reference to a national code

Ref country code: DE

Ref legal event code: R119

Ref document number: 602012055568

Country of ref document: DE

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: TR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: LU

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190802

Ref country code: MC

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: CH

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190831

Ref country code: LI

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190831

REG Reference to a national code

Ref country code: BE

Ref legal event code: MM

Effective date: 20190831

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190802

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20200303

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190831

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: BE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190831

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: CY

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: MT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

Ref country code: HU

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO

Effective date: 20120802

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: MK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20190102

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20230629

Year of fee payment: 12