Communication of a module to a datapath node is disclosed. A controller node receives connection information identifying a first datapath node in communication with a network. The controller node obtains operations, Administration, and Management (oam) information including an oam action set that identifies one or more oam actions the first datapath node is capable of implementing at the first datapath node. A first oam tool module is determined that is operative to perform at least one of the one or more oam actions identified in the oam action set to implement a first oam tool function. The first oam tool module is communicated to the first datapath node.
|
1. A method for obtaining an operations, administration, and management (oam) tool module, comprising:
communicating, by a datapath node to a controller node, connection information that identifies the datapath node and oam information including an oam action set that identifies one or more oam actions the datapath node is capable of implementing at the datapath node; and
receiving an oam tool module from the controller node for execution on the datapath node that is operative to perform at least one of the one or more oam actions identified in the oam action set to implement a first oam tool function.
21. A method for obtaining an operations, administration, and management (oam) tool module, comprising:
communicating, by a datapath node to a controller node, connection information that identifies the datapath node and oam information including an oam action set that identifies one or more oam actions the datapath node is capable of implementing at the datapath node;
receiving an oam tool module from the controller node for execution on the datapath node that is operative to perform at least one of the one or more oam actions identified in the oam action set to implement a first oam tool function; and
executing, by the datapath node, the oam tool module.
13. A datapath node, comprising:
a transceiver subsystem configured to communicate with a network; and
a processing subsystem coupled to the transceiver subsystem and configured to:
communicate, to a controller node, connection information identifying the datapath node and operations, administration, and management (oam) information including an oam action set that identifies one or more oam actions the datapath node is capable of implementing at the datapath node; and
receive an oam tool module from the controller node for execution on the datapath node that is operative to perform at least one of the one or more oam actions identified in the oam action set to implement a first oam tool function.
2. The method of
3. The method of
sending, to the controller node, flow information that identifies a flow, wherein the oam tool module is received from the controller node in response to sending the flow information.
4. The method of
receiving a direction from the controller node to implement the first oam tool function in conjunction with an identified flow.
5. The method of
6. The method of
generating an oam flow table at the datapath node; and
generating a first oam flow table entry based on the oam parameters.
7. The method of
8. The method of
9. The method of
10. The method of
11. The method of
12. The method of
14. The datapath node of
15. The datapath node of
16. The datapath node of
17. The datapath node of
generate an oam flow table at the datapath node; and
generate a first oam flow table entry based on the oam parameters.
18. The datapath node of
19. The datapath node of
20. The datapath node of
|
This application is a divisional of U.S. patent application Ser. No. 14/417,916, entitled “OPERATIONS, ADMINISTRATION, AND MANAGEMENT (OAM) FUNCTIONS IN A SOFTWARE DEFINED NETWORK,” now U.S. Pat. No. 9,680,698, which is a 35 U.S.C. § 371 national phase filing of International Application No. PCT/IB2012/053946, filed on Aug. 1, 2012, which is hereby incorporated herein by reference in its entirety.
The present disclosure relates to implementing Operations, Administration, and Management (OAM) functionality in a communications network, and in particular to the implementation of OAM functions in a software defined networking environment.
Software defined networking (SDN) is a network architecture where the forwarding plane (sometimes referred to as the data plane) and the control plane, which are conventionally implemented in a single network node, are separated and implemented in two distinct network nodes. Such distinct network nodes may be referred to as a datapath node and a controller node, respectively. An example of an SDN architecture, or specification, is the OpenFlow Switch Specification, version 1.1.0.
Theoretically, by implementing the forwarding function and the control function in different network nodes, multiple relatively inexpensive datapath nodes may be coupled together and controlled by a single controller node, resulting in an overall lower network cost. Another supposed advantage of SDN is that a single controller node can be more easily programmed to implement new network functionality than would be possible by programming multiple conventional network nodes that combine the control plane and the forwarding plane, thereby simplifying the implementation of additional networking functions in the network.
Moving data from source nodes to destination nodes across multiple network nodes involves complex technology, and conventional network nodes implement multiple Operations, Administration, and Management (OAM) functions that permit an operator to resolve problems, monitor the network, and otherwise operate, administer, or manage the network.
Currently, the datapath nodes of a software defined network do not have the intelligence required to implement OAM functions under the control of the controller node. Even if a datapath node is specially programmed to implement an OAM function, doing so runs counter to the notion of SDN, in that the datapath nodes must again become specially programmed on a datapath-node-by-datapath-node basis, which is what SDN desires to avoid.
The present disclosure relates to the implementation of Operations, Administration, and Management (OAM) functions in a software defined networking (SDN) architecture. A controller node determines which OAM actions a datapath node is capable of implementing, and determines an OAM tool module that is operative to perform one or more of the OAM actions to implement an OAM tool function at the datapath node. The controller node communicates the OAM tool module to the datapath node, and the datapath node may subsequently execute the OAM tool module to implement the OAM tool function under the control of the controller node.
In one embodiment, the controller node receives connection information that identifies the first datapath node in communication with a network. The controller node obtains OAM information that includes an OAM action set that identifies one or more OAM actions the first datapath node is capable of implementing at the first datapath node. The controller node determines a first OAM tool module that is operative to perform at least one of the one or more OAM actions to implement a first OAM tool function. The controller node communicates the first OAM tool module to the first datapath node. Among other advantages, the controller node is capable of communicating OAM tool modules to multiple different types of datapath nodes.
In one embodiment, the controller node identifies a flow in the network, and directs the first datapath node to implement the first OAM tool function in conjunction with the flow. In one embodiment, the flow is identified by the receipt of operator input that identifies the flow from a plurality of flows in the network. In another embodiment, the flow is identified based on a request to establish a new flow in the network.
When directing the first datapath element to implement the first OAM tool function in conjunction with the flow, the controller node may send OAM parameters to the first datapath node that identify the first OAM tool module and the flow. In one embodiment, the OAM parameters identify an OAM packet template that defines the structure of a packet to be created by the first OAM tool function on the first datapath node. The OAM parameters may also define one or more values to be inserted into the packet. The OAM parameters may further identify a node in the network to which information should be sent by the first OAM tool module.
The controller node may also direct a second datapath node to implement a second OAM tool function in conjunction with the flow. The first datapath node may comprise, for example, an ingress datapath node and the second datapath node may comprise, for example, an egress datapath node. The first OAM tool function and the second OAM tool function may collectively implement an OAM function in conjunction with the flow. In one embodiment, the controller node receives, from the second datapath node, a packet generated by the first datapath node, and may process information contained in the packet based on the OAM function.
In one embodiment, the connection information provided by the first datapath node includes the OAM action set that identifies the one or more OAM actions that first datapath element is capable of implementing at the first datapath node. In another embodiment, the controller node, in response to receiving the connection information, sends a communication to the first datapath node requesting an identification of the one or more OAM actions the first datapath node is capable of implementing at the first datapath node.
In one embodiment, the OAM information includes interface information that identifies interfaces on the first datapath node to the one or more OAM actions identified in the OAM action set. The controller node may modify a first OAM tool source code based on the interface information, and process the first OAM tool source code to generate the first OAM tool module.
In one embodiment, a controller node includes a transceiver subsystem that is configured to communicate with a network. The controller node further includes a processing subsystem coupled to the transceiver subsystem, and is configured to receive connection information identifying a first datapath node in communication with the network. The controller node obtains OAM information including an OAM action set that identifies one or more OAM actions the first datapath node is capable of implementing at the first datapath node. The controller node determines a first OAM tool module that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement a first OAM tool function, and communicates the first OAM tool module to the first datapath node. As discussed above, among other advantages, the controller node is capable of communicating OAM tool modules to multiple different types of datapath nodes.
In one embodiment, a datapath node communicates, to a controller node, connection information that identifies the datapath node and OAM information including an OAM action set that identifies one or more OAM actions the datapath node is capable of implementing at the datapath node. The datapath node receives an OAM tool module from the controller node for execution on the datapath node that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement a first OAM tool function. Among other advantages, the datapath node need not be specially programmed with multiple different OAM tool modules, and can obtain different OAM tool modules from a centralized controller node without any such special programming.
In one embodiment, a datapath node includes a transceiver subsystem configured to communicate with a network and a processing subsystem coupled to the transceiver subsystem. The processing subsystem is configured to communicate, to a controller node, connection information identifying the datapath node and OAM information including an OAM action set that identifies one or more OAM actions the datapath node is capable of implementing at the datapath node. The processing subsystem is further configured to receive an OAM tool module from the controller node for execution on the datapath node that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement a first OAM tool function. In practice, among other advantages, different types of datapath nodes may be relatively easily connected to the network and run-time loaded with pertinent OAM tool modules without a need to specially program each datapath node in accordance with a manufacturer's proprietary protocols.
In one embodiment, a system includes a controller node that includes a first transceiver subsystem configured to communicate with a network and a first processing subsystem coupled to the first transceiver subsystem. The first processing subsystem is configured to receive, from a first datapath node, connection information identifying the first datapath node, and to obtain OAM information including an OAM action set that identifies one or more OAM actions the first datapath node is capable of implementing at the first datapath node. The first processing subsystem is further configured to determine a first OAM tool module that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement a first OAM tool function, in order to communicate the first OAM tool module to the first datapath node.
The system further includes the first datapath node, which includes a second transceiver subsystem configured to communicate with the network, and a second processing subsystem coupled to the second transceiver subsystem. The second processing subsystem is configured to communicate, to the controller node, the connection information identifying the first datapath node and the OAM information including the OAM action set that identifies the one or more OAM actions the first datapath node is capable of implementing at the first datapath node. The second processing subsystem is further configured to receive the first OAM tool module from the controller node for execution on the first datapath node that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement the first OAM tool function. Among other advantages, the system facilitates the programming of a single node, in particular the controller node, with multiple different OAM tool modules, to reduce or eliminate a need to program multiple different datapath nodes.
Those skilled in the art will appreciate the scope of the present disclosure and realize additional aspects thereof after reading the following detailed description of the preferred embodiments in association with the accompanying drawing figures.
The accompanying drawing figures incorporated in and forming a part of this specification illustrate several aspects of the disclosure, and together with the description serve to explain the principles of the disclosure.
The embodiments set forth below represent the necessary information to enable those skilled in the art to practice the embodiments and illustrate the best mode of practicing the embodiments. Upon reading the following description in light of the accompanying drawing figures, those skilled in the art will understand the concepts of the disclosure and will recognize applications of these concepts not particularly addressed herein. It should be understood that these concepts and applications fall within the scope of the disclosure and the accompanying claims.
The phrase “OAM function” is used herein to refer to any function, or functions, that may be implemented in conjunction with a flow in a network for purposes of operations, administration, or management of the flow, or of the network in which the flow exists. Non-limiting examples of OAM functions include functions for proactive or on-demand fault management, such as continuity checks, loopbacks, and link traces; and functions for on-demand or proactive performance measurements, such as loss measurements, delay measurements, or throughput measurements. In the context of an Ethernet network, specific non-limiting examples of OAM functions include continuity checks for fault detection, loopback messages for fault verification, and multicast link trace messages for performing path discovery and fault isolations. Examples of Ethernet service performance measurement OAM functions include delay measurement and loss measurement. In the context of a Multiprotocol Label Switching (MPLS) network, non-limiting examples of OAM functions include label-switched path (LSP) ping functions for providing basic connectivity checks, which may be run periodically or on-demand, traceroute functionality, and loopback functionality. While specific example of OAM functions have been provided, the embodiments are not limited to the implementation of any particular OAM function, and may be used to implement any desired function with respect to the operations, administration, or management of a flow, or of a network in which the flow exists.
The use herein of ordinals, such as “first,” “second,” and “third” in conjunction with an element name, such as “datapath node,” is solely for distinguishing what might otherwise be similar or identical element names, such as “first datapath node” and “second datapath node,” and does not imply a priority, a hierarchy, an importance, nor does it contain any temporal or sequential meaning, unless otherwise stated herein.
The network 10 includes a controller node 12 and a plurality of datapath nodes 14-1-14-3 (generally, datapath nodes 14). While in practice the network 10 may comprise multiple controller nodes 12 and many, many datapath nodes 14, for purposes of illustration only one controller node 12 and three datapath nodes 14 are depicted. Each of the datapath nodes 14 is in communication with the controller node 12 via a communication link 16, and in communication with each other via communication links 18. The datapath nodes 14 may include respective flow tables 20-1-20-3 (generally, flow tables 20). A flow table 20 may maintain information about each flow handled by the respective datapath node 14. As used herein, the term “flow” refers to a path of data packets through the network 10 communicated between a source node (not illustrated) and a destination node (not illustrated). Each datapath node 14 may be associated with many flows, and typically processes such flows under the control of the controller node 12.
In one embodiment, each of the datapath nodes 14 also includes an OAM structure such as an OAM flow table 22-1-22-3 (generally, OAM flow tables 22), each of which stores information regarding OAM functionality implemented by the respective datapath node 14 in conjunction with a particular flow. Other elements of the datapath nodes 14, as shown in particular with respect to the datapath node 14-1, may include a ternary content-addressable memory (TCAM) 24 in which the flow table 20 and the OAM flow table 22 are implemented. In one embodiment, the datapath node 14-1 also includes a forwarding engine 26 for handling the forwarding of packets associated with flows in accordance with the flow table 20-1. The forwarding engine 26 includes one or more network processing units (NPUs) 28; a random access memory (RAM) 30, which may be used, for example, to store software instructions associated with an OAM tool module for implementing an OAM tool function in conjunction with a flow; and one or more registers 32. The datapath node 14-1 may also include a clock 34, which is used, for example, to generate timestamps associated with packets generated or processed by an OAM tool module. A management central processing unit (CPU) 36 may be used for overall control and management of the datapath node 14-1. The datapath node 14-1 may also include one or more transceivers 38 configured to communicate via, for example, the communication links 16, 18.
The controller node 12 may include an OAM application function 40 which implements the OAM functionality described herein with respect to the controller node 12. The OAM application function 40 may include, or be associated with, an OAM tool determination function 42, which, as described in greater detail herein, determines OAM tool modules for communication to respective datapath nodes 14. A network operating system (OS) and controller function 44 may be responsible for the overall functionality of the controller node 12, and communication with the datapath nodes 14.
Embodiments will now be discussed in greater detail with reference to
The controller node 12 also receives from the datapath node 14-1 OAM information that includes an OAM action set that identifies one or more OAM actions that the datapath node 14-1 is capable of implementing at the datapath node 14-1 (
The controller node 12 determines an OAM tool module that is operative to perform at least one of the one or more OAM actions identified in the OAM action set to implement an OAM tool function at the datapath node 14-1 (
The controller node 12 communicates the OAM tool module to the datapath node 14-1 (
The controller node 12 determines an OAM function to implement in conjunction with the flow 48 (
Assume that the controller node 12 determines that a particular OAM function should be implemented in conjunction with the flow 48. The particular OAM function is implemented via an OAM tool module 50 that executes in conjunction with the flow 48 at the datapath node 14-1, an OAM tool module 52 that executes in conjunction with the flow 48 at the datapath node 14-2, and an OAM tool module 54 that executes in conjunction with the flow 48 at the datapath node 14-3. For example, the OAM tool module 50 implements an OAM tool module function wherein a packet is created at an ingress datapath node 14, such as the datapath node 14-1, an initial timestamp is put into the newly created packet, and the packet is transmitted along the same communications path as the flow 48 to an intermediate datapath node 14, such as the datapath node 14-2. The OAM tool module 52 on the datapath node 14-2 implements an OAM tool module function wherein when the packet is received, the OAM tool module 52 inserts a second timestamp into the packet, and the OAM tool module 52 transmits the packet along the same communications path as the flow 48 to an egress datapath node 14, such as the datapath node 14-3. The OAM tool module 54 on the datapath node 14-3 implements an OAM tool module function wherein when the packet is received, the OAM tool module 54 inserts a third timestamp into the packet, and the OAM tool module 54 transmits the packet to the controller node 12, where the controller node 12 may examine the timestamps and make conclusions therefrom.
In one embodiment, the datapath node 14-1 already has the OAM tool module 50 stored in a storage 56, as part of an initial connection phase. In another embodiment, the controller node 12 may not communicate the OAM tool module 50 to the datapath node 14-1 until the controller node 12 determines that the OAM tool function that is implemented by the OAM tool module 50 is to be performed at the datapath node 14-1 in order to implement an OAM function on the flow 48. Thus, in such embodiment, the controller node 12 communicates the OAM tool module 50 to the datapath node 14-1 in response to identifying the flow 48, and determining to implement the OAM function on the flow 48. Similarly, the OAM tool module 52 may already be stored in a storage 58 of the datapath node 14-2, or may be communicated to the datapath node 14-2 upon the identification of the flow 48 and the determination to implement the OAM function on the flow 48. Similarly, the OAM tool module 54 may already be stored in a storage 60 of the datapath node 14-3, or may be communicated to the datapath node 14-3 upon the identification of the flow 48 and the determination to implement the OAM function on the flow 48.
Assume that each of the datapath nodes 14-1-14-3 is configured to handle the flow 48, typically under the control of the controller node 12. The datapath node 14-1 has a flow table entry 62 in the flow table 20-1 identifying the flow 48, and data regarding how the flow 48 should be handled; the datapath node 14-2 has a flow table entry 64 in the flow table 20-2 identifying the flow 48, and data regarding how the flow 48 should be handled; and the datapath node 14-3 has a flow table entry 66 in the flow table 20-3 identifying the flow 48, and data regarding how the flow 48 should be handled.
In order to implement the determined OAM function on the flow 48, the controller node 12 sends a communication that includes OAM parameters which direct the datapath node 14-1 to implement the OAM tool function associated with the OAM tool module 50 in conjunction with the flow 48 (
The datapath node 14-1 receives the OAM parameters and generates an OAM flow table entry 68 that identifies the OAM tool module 50, the flow 48, and the additional parameters associated with implementing the desired OAM tool function on the flow 48.
The controller node 12 also sends a communication that includes OAM parameters which direct the datapath node 14-2 to implement the OAM tool function associated with the OAM tool module 52 in conjunction with the flow 48 (
The controller node 12 further sends a communication that includes OAM parameters which direct the datapath node 14-3 to implement the OAM tool function associated with the OAM tool module 54 in conjunction with the flow 48 (
Assume that the OAM tool function associated with the OAM tool module 50 comprises generating an OAM packet, inserting a first timestamp into the OAM packet, and forwarding the OAM packet to the datapath node 14-2. The datapath node 14-1, using an OAM packet template identified in the OAM parameters received from the controller node 12, generates a new OAM packet, generates a timestamp identifying a current time, and inserts the timestamp at an identified location in the OAM packet (
Assume that the OAM tool function associated with the OAM tool module 52 comprises receiving the OAM packet generated by the datapath node 14-1, inserting additional data into one more identified fields in the OAM packet, and forwarding the OAM packet to the datapath node 14-3. The datapath node 14-2 receives the OAM packet generated by the datapath node 14-1, generates or obtains the identified additional data, and inserts such data into particular fields in the OAM packet (
Assume that the OAM tool function associated with the OAM tool module 54 comprises receiving the OAM packet generated by the datapath node 14-1, inserting a second timestamp into an identified field of the OAM packet, and communicating the OAM packet to the controller node 12. The datapath node 14-3 receives the OAM packet generated by the datapath node 14-1 and modified by the datapath node 14-2, generates a second timestamp identifying a current time, and inserts the second timestamp at an identified location in the OAM packet (
While for purposes of illustration the OAM flow tables 22 are depicted as having a single flow table entry, it should be apparent that each OAM flow table 22 may have a plurality of flow table entries, each flow table entry identifying a particular flow, and an OAM tool module for implementing an OAM tool function in conjunction with the flow.
While for purposes of illustration a relatively simple OAM function was described as being collectively implemented by the OAM tool modules 50-54, the embodiments are not limited to any particular OAM functionality, and can be used to implement any desired OAM function in the network 46.
Additional, non-limiting examples of OAM functions include a one-way delay measurement OAM function for MPLS-TP using Internet Engineering Task Force (IETF) RFC6374 and the interpretation of the Y.1731 standard from draft-bhh-mpls-tp-oam-y1731-08. In this example, an OAM tool module could be implemented on the ingress datapath node 14-1 that implements the following OAM tool function:
An intermediary datapath node, such as the datapath node 14-2, may execute an OAM tool module that implements the following OAM tool function:
An egress datapath node, such as the datapath node 14-3, may execute an OAM tool module that implements the following OAM tool function:
Another example of an OAM function comprises a Y.1731 one-way delay. The ingress datapath node, such as the datapath node 14-1, may execute an OAM tool module that implements the following OAM tool function:
An intermediary datapath node, such as the datapath node 14-2, may execute an OAM tool module that implements the following OAM tool function:
An egress datapath node, such as the datapath node 14-3, may execute an OAM tool module that implements the following OAM tool function:
Those skilled in the art will appreciate that the block diagram of the controller node 12 necessarily omits numerous features that are not necessary to a complete understanding of this disclosure. Although all of the details of the processing subsystem 82 are not illustrated, the processing subsystem 82 comprises one or several general-purpose or special-purpose processors 84 or other microcontrollers programmed with suitable software programming instructions and/or firmware to carry out some or all of the functionality of the network nodes described herein. In addition, or alternatively, the processing subsystem 82 comprise various digital hardware blocks (e.g., one or more Application Specific Integrated Circuits (ASICs), one or more off-the-shelf digital or analog hardware components, or a combination thereof) configured to carry out some or all of the functionality of the network nodes described herein. The controller node 12 may also include one or more storage media for storing data necessary and/or suitable for implementing the functionality described herein, as well as for storing complex programming instructions which, when executed on the processor 84, may implement all or part of the functionality described herein. One embodiment of the present disclosure may be implemented as a computer program product that is stored on a computer-readable storage medium, the computer program product including complex programming instructions that are configured to cause a processor, such as the processor 84, to carry out the steps described herein.
Those skilled in the art will appreciate that the block diagram of the datapath node 14 necessarily omits numerous features that are not necessary to a complete understanding of this disclosure. Although all of the details of the processing subsystem 88 are not illustrated, the processing subsystem 88 comprises one or several general-purpose or special-purpose processors, such as, for example, the management CPU 36 and NPU 28, or other microcontrollers programmed with suitable software programming instructions and/or firmware to carry out some or all of the functionality of the network nodes described herein. In addition, or alternatively, the processing subsystem 88 comprise various digital hardware blocks (e.g., one or more Application Specific Integrated Circuits (ASICs), one or more off-the-shelf digital or analog hardware components, or a combination thereof) configured to carry out some or all of the functionality of the network nodes described herein. The datapath node 14 may also include one or more storage media for storing data necessary and/or suitable for implementing the functionality described herein, as well as for storing complex programming instructions which, when executed on the management CPU 36 or the NPU 28, may implement all or part of the functionality described herein. One embodiment of the present disclosure may be implemented as a computer program product that is stored on a computer-readable storage medium, the computer program product including complex programming instructions that are configured to cause a processor, such as the management CPU 36 or NPU 28, to carry out the steps described herein.
The following acronyms are used throughout this disclosure:
ASIC
Application Specific Integrated Circuit
CPU
central processing unit
FPGA
field-programmable gate array
G-ACH
Generic Associated Channel
GAL
Generic Associated Channel Label
LSP
label-switched path
MPLS
Multiprotocol Label Switching
NPU
network processing units
OAM
Operations, Administration, and Management
OS
operating system
RAM
random access memory
SDN
software defined networking
TCAM
ternary content-addressable memory
TLV
type-length-value
TTL
time to live
Those skilled in the art will recognize improvements and modifications to the preferred embodiments of the present disclosure. All such improvements and modifications are considered within the scope of the concepts disclosed herein and the claims that follow.
John, Wolfgang, Meirosu, Catalin
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6590895, | Oct 15 1998 | Oracle America, Inc | Adaptive retransmission for error control in computer networks |
7190896, | May 04 2000 | RPX CLEARINGHOUSE LLC | Supervisory control plane over wavelength routed networks |
9680698, | Aug 01 2012 | TELEFONAKTIEBOLAGET L M ERICSSON PUBL | Operations, administration, and management (OAM) functions in a software defined network |
20020067729, | |||
20110293988, | |||
20110317559, | |||
20120082161, | |||
20130010600, | |||
20130176850, | |||
20130266012, | |||
20140169179, | |||
CN1551577, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 05 2017 | Telefonaktiebolaget L M Ericsson (publ) | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Jan 03 2023 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
Jul 02 2022 | 4 years fee payment window open |
Jan 02 2023 | 6 months grace period start (w surcharge) |
Jul 02 2023 | patent expiry (for year 4) |
Jul 02 2025 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 02 2026 | 8 years fee payment window open |
Jan 02 2027 | 6 months grace period start (w surcharge) |
Jul 02 2027 | patent expiry (for year 8) |
Jul 02 2029 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 02 2030 | 12 years fee payment window open |
Jan 02 2031 | 6 months grace period start (w surcharge) |
Jul 02 2031 | patent expiry (for year 12) |
Jul 02 2033 | 2 years to revive unintentionally abandoned end. (for year 12) |