A method (400, 610) for handling information about packet data connections arriving at a security gateway element, in order to have in a connection data structure information about packet data connections in accordance with current screening information is presented. In the method, data packet header information about packet data connections in accordance with first screening information is stored (401) in said connection data structure, and updated screening information, said updated screening information forming either by itself or in connection with said first screening information second screening information, is being received (402). After receiving said updated screening information, entries of said connection data structure are compared (403) to said second screening information, resulting in a classification of said entries as entries representing packet data connections in accordance with said second screening information and as entries representing packet data connections in conflict with said second screening information. Corresponding security gateway element, management system, computer program and connection data structures are also presented.
| 
 | 19.  A security gateway element comprising
 means for processing data packets so that data packet connections in accordance with current screening information are allowed to proceed, means for storing first screening information used as current screening information, means for storing in a connection data structure information about packet data connections in accordance with the first screening information, and means for receiving updated screening information, which by itself or together with the first screening information forms second screening information, means for comparing entries in said connection data structure to second screening information, resulting in a classification of said entries as first entries, said first entries representing packet data connections in accordance with said second screening information, and as second entries, said second entries representing packet data connections in conflict with said second screening information. 1.  A method for handling information about packet data connections, which arrive at a security gateway element, in order to have in a connection data structure information about packet data connections in accordance with current screening information, said connection data structure comprising a number of entries representing a number of packet data connections, said method comprising the steps of:
 storing data packet header information about packet data connections, which are in accordance with first screening information, in said connection data structure, and receiving updated screening information, said updated screening information forming either by itself or in connection with said first screening information second screening information, after receiving said updated screening information, comparing entries of said connection data structure to said second screening information, resulting in a classification of said entries as first entries, said first entries representing packet data connections in accordance with said second screening information, and as second entries, said second entries representing packet data connections in conflict with said second screening information. 23.  A computer program product comprising program code means stored on a computer readable medium for performing when said program product is run on a computer, a process for handling information about packet data connections, which arrive at a security gateway element, in order to have in a connection data structure information about packet data connections in accordance with current screening information, said connection data structure comprising a number of entries representing a number of packet data connections, said process comprising routines of:
 storing data packet header information about packet data connections, which are in accordance with first screening information, in said connection data structure, and receiving updated screening information, said updated screening information forming either by itself or in connection with said first screening information second screening information, after receiving said updated screening information, comparing entries of said connection data structure to said second screening information, resulting in a classification of said entries as first entries, said first entries representing packet data connections in accordance with said second screening information, and as second entries, said second entries representing packet data connections in conflict with said second screening information. 2.  A method according to  storing for a packet data connection acceptance information relating to grounds for accepting that packet data connection, using said acceptance information is used in comparing entries of said connection data structure to said second screening information. 3.  A method according to  4.  A method according to  5.  A method according to  6.  A method according to  7.  A method according to  8.  A method according to  9.  A method according to  10.  A method according to  deleting at least one of said second entries from said connection data structure. 11.  A method according to  modifying at least one of said first entries in said connection data structure. 12.  A method according to  storing contents of said connection data structure at a certain time in order to use the stored contents in comparing of entries of said connection data structure. 13.  A method according to  storing in a connection data structure entry information indicating current screening information version at the time of adding a connection data structure entry, and comparing to second screening information, only entries of said connection data structure specifying first screening information as current screening information. 14.  A method according to  indicating to a management system all or some of the packet data connections conflicting the second screening information and represented by said the second entries, and requesting a confirmation from the management system whether to reject packet data connections conflicting said second screening information. 15.  A method according to  16.  A method according to  receiving information indicating that the second screening information is only for test use, and transmitting information about results of said comparison. 17.  A method according to  storing said first screening information as a precaution, enabling the return to using said first screening information as current screening information. 18.  A method according to  modifying said connection data structure based on said comparison. 20.  A security gateway element according to  21.  A security gateway element according to  means for indicating to a management system all or some of the packet data connections conflicting the second screening information, and means for receiving a confirmation from the management system whether to reject all or some of the packet data connections conflicting the second screening information. 22.  A security gateway element according to  24.  A computer program product according to  25.  A computer program product according to  26.  A computer program product according to  27.  A computer program product according to  28.  A computer program product according to  29.  A computer program product according to  30.  A computer program product according to  31.  A computer program product according to  32.  A computer program product according to  33.  A computer program product according to  | |||||||||||||||||||||||||
1. Field of the Invention
The invention relates in general to handling in a security gateway element a connection data structure, in which information about allowed packet data connections is stored. In particular the invention relates to handling the connection data structure in a flexible way.
2. Description of Related art
The local networks of various organizations and enterprises are nowadays connected to the public Internet. To protect a local network, special gateway is usually used to connect the local network to a public network. This special gateway is often called a security gateway or a firewall, and the purpose of a security gateway is to prevent authorized access to the local network. Typically there is need to restrict access to a local network from a public network and/or to restrict access from the local network to the public network or further networks connected to the public network. On data packet level this means that data packets, which are entering and/or exiting a local network, are screened or filtered in a security gateway. In addition to filtering data packets a security gateway may secure data packets transmitted between, for example, some communication entities. In this case the security gateway is both a firewall and a VPN (Virtual Private Network) gateway.
Screening of data packets in a network element may be stateless or stateful. Stateless screening refers to packet filtering, where each packet is handled according to a set of rules (or other screening information, see below) without any information about history of packets. Stateless screening is typically used, for example, in routers. Stateful screening refers to a situation, where a data packet initiating a packet data connection is accepted using a set of rules, and consequently information about an accepted packet data connection is stored in the network element for handling the rest of the data packets belonging to the opened packet data connection. Security gateways typically perform stateful screening of data packets. The main reason for using stateful screening is security. Typically, it is required to restrict access from a public network to a local network while allowing entities in the local network to access public network. In stateless screening there must be rules, which allow possible reply packets from the public network to the local network to pass a network element. Many other data packets than proper reply packets may be accepted using such rules. When stateful packet screening is used only those data packets, which are really part of an opened packet data connection, can be accepted.
The screening of first data packets in stateful screening is usually done using information specifying at least parts of allowed data packet headers and corresponding instructions for processing a data packet. The screening information is usually an ordered set of rules. 
A typical format for the rules is the following: header information, action. The header information typically involves source address (src), destination address (dst) and protocol (prot) relating to a data packet, and a rule typically has the following form: src, dst, prot, action. This means that for a data packet, which has the indicated header information, the indicated action is carried out. Typically the action defines whether the data packet is discarded or allowed to proceed. As a data packet is processed, its header information is compared to the header information indicated by the rules; the rules are processed in the order defined by the ordered set. Typically the last rule in the ordered set of rules (e.g. RuleN in 
In stateful screening information about ongoing data packet connections or about packet data connections relating to ongoing connections is typically stored in a data structure, which is here called a connection data structure. A data packet initiating a packet data connection and arriving at a security gateway element, is compared to the screening information. If a rule allowing the data packet to traverse the security gateway element is found, a corresponding entry is made to the connection data structure. Typically, a connection data structure entry comprises some header information of the corresponding data packet and possibly further additional information. Data packets other than packets initiating a packet data connection are then compared to the connection data structure and, if a corresponding entry is found, the packet is allowed to traverse the security gateway element. Thus, only data packets relating to open packet data connections are accepted. As a further advantage, stateful screening may require less processing power than stateless screening, as data packets of an open packet data connection are checked only against the connection data structure, and there is no need to check if the data packets are in accordance with the given, possibly long, set of rules.
The part of the connection data structure that is related to one currently open packet data connection traversing a security gateway element is called an entry. When a packet data connection is closed, the corresponding entry is typically removed (or deleted or cleared) from the connection data structure. The number of entries having information about packet data connections thus typically varies as function of time.
Information about other data packets, which a security gateway element should allow to proceed, may also be dynamically updated to the connection data structure. In many cases a given set of rules is just basic information for making a decision about allowing a certain data packet to proceed. Additional information may also be needed. Consider, for example, FTP (File Transfer Protocol), which has a control connection and the files are transferred using a separate data connection. This separate data connection should be allowed even though a network element outside the local network initiates the FTP data connection, if a related control connection has been established and a request for opening the data connection has been detected within the control connection before the data connection is attempted. A security gateway element should thus be prepared to receive a data packet initiating such a FTP data connection and to allow such a data packet to proceed. Typically, such a data packet initiating a FTP data connection would not be allowed to proceed on the basis of the rules. It is only allowed on the basis of the prior information transferred within the FTP control connection.
The connection data structure, where information about data packets that are allowed to arrive and be processed in a security gateway element, may be, for example, a connection data structure 30 described in 
The set of rules, or other screening information, is updated every now and then. It may be updated, for example, periodically to ensure that too old screening information is not used. Alternatively, new screening information may be delivered to a security gateway element from a management system after the screening information has been modified, that is, new screening information is pushed to the security gateway element from the management system.
In current security gateway elements, when screening information is updated, a connection data structure is typically cleared. Clearing the connection data structure causes established connections to fail since the connection data structure entry which is required for accepting the packets other that the packet initiating a connection are lost. This is a problem especially in circumstances, where connections should be as reliable as possible.
A second way to handle ongoing packet data, when screening information is updated, is to maintain information about the open connections in the connection data structure. This way existing packet data connections survive, and the packet data connections are as reliable as possible. There may, however, be existing packet data connections which are not in accordance with the updated screening information, and this may cause security risks. Some security gateways give the user a possibility to select between dropping all existing packet data connections and allowing all existing packet data connections. Such a selection is a selection between security and network usability.
A further way to handle ongoing packet data connections when screening information is updated may have, for example, the following features. Before clearing a connection data structure, the connection data structure is copied to a previous connection data structure. The connection data structure is then cleared, and therefore all arriving data packets are handled using the updated screening information. Typically only data packets initiating a packet data connection may be compared to screening information. It is possible, however, to make an exception to this rule. In this case, all arriving data packets are compared to the screening information. If the updated screening information contains a rule allowing said data packet to pass but the packet is not a packet initiating a new connection, it is checked if the previous connection data structure contains an entry allowing the data packet to proceed. If such entry is found, an entry relating to this packet data connection is added to the connection data structure. These features prevent some existing packet data connections to be dropped. For example FTP data connection is, however, dropped, as it is accepted on the basis of the FTP control connection, not directly on the basis of a rule.
Object of the invention is to present a flexible method and arrangement for handling information about existing packet data connections in a security gateway element. A further object is to present such a method and arrangement for handling information about existing packet data connections which allows packet data connections via a security gateway element to be reliable even when screening information is updated.
Objects of the invention are achieved by classifying, after screening information is updated, packet data connections to packet data connections in accordance with new screening information and packet data connections in conflict with new screening information.
A method according to the invention is a method for handling information about packet data connections, which arrive at a security gateway element, in order to have in a connection data structure information about packet data connections in accordance with current screening information, said connection data structure comprising a number of entries representing a number of packet data connections, said method comprises the step of:
A security gateway element according to the invention is a gateway element comprising
The invention further relates to a management system relating to at least one security gateway element, said management system comprising
The invention relates also to a computer program comprising program code for performing all the steps of a method in accordance with the invention, when said program is run on a computer.
The invention further relates to a computer program product comprising program code means stored on a computer readable medium for performing a method according to the invention, when said program product is run on a computer.
A connection data structure according to the invention is a data structure comprising a number of entries representing a number of packet data connections, said entries comprising header information of data packets, and the connection data structure is characterized in that at least one of said entries further involves acceptance information relating to grounds for accepting the represented packet data connection to traverse a security gateway element.
Alternatively, a connection data structure according to the invention is a data structure comprising a number of entries representing a number of packet data connections, said entries comprising header information of data packets, said connection data structure being characterized in that at least one of said entries further comprises information indicating the current screening information at the time of creation of said entry.
The appended dependent claims describe some preferred embodiments of the invention. The features described in one dependent claim may be further combined with features described in another dependent claim to produce further embodiments of the invention.
The packet data connections discussed here are typically packet data connections on IP protocol. In this specification and in the appended claims, the term packet data connection refers here to a bi-directional flow of data packets. Examples of such packet data connections are TCP connections, bidirectional UDP packet fows, UDP queries, ICMP (Internet Control Message Protocol) queries and replies.
In this specification and in the appended claims, the term entry refers to a piece of information relating to one packet data connection. An entry typically comprises information at least about data packet headers. The term connection data structure refers to a data structure, whose entries represent packet data connections arriving at a security gateway. A connection data structure may be, for example, a table or a linked list or any other more versatile data structure.
According to the invention, packet data connections represented in a connection data structure are classified as packet data connections in accordance with updated screening information and as packet data connections in conflict updated screening information. After this classification it is possible to ensure that packet data connections in accordance with updated screening information are allowed to traverse a security gateway element. This is the main advantage of the invention. Furthermore, it is possible to inspect the packet data connections in conflict with updated screening information before possibly rejecting part or all of these packet data connections. This can be made, for example, by representing a list of existing packet data connections that are not allowed with new set of rules to the administrator, who can then decide if he or she wants to terminate those or not.
The screening information is typically a set of rules. It may be, for example, an ordered sequence of rules, and a data packet is processed by comparing header information of the data packet to the rules, rule by rule, in the order dictated by the sequence numbers. Alternatively, screening information may be a hierarchically ordered, so that a certain rule may have a number of subrules and, typically, header information common to all said subrules is specified in said certain rule. In this case data packets are compared to subrules only if the header information of a data packet matches first the header information specified in the rule, to which the subrules are subordinates.
The invention is now described in more detail with reference to the accompanying drawing, where
In step 403 entries of said connection data structure are compared to new (second) screening information. As a result, the entries are classified as first entries representing packet data connections in accordance with said second screening information or as second entries representing packet data connections in conflict with said second screening information.
Steps 404–406 relate to interaction between a management system and a security gateway element. In step 404, security gateway element indicates the packet data connections, which are mentioned in a connection data structure and which are conflicting with the new screening information. In step 405, a security gateway element requests, either implicitly by indicating the packet data connections in step 404 or explicitly, a confirmation whether to reject the conflicting packet data connections. A user of a management system may at this point decide, which packet data connections are rejected or, for example, if the entries corresponding to those packet data connections are modified. If a confirmation is received (step 406), the conflicting packet data connections and relating connection data structure entries are processed according to said confirmation. If a confirmation is not received, a security gateway element may, for example, reject the conflicting packet data connections. Typically data packets relating to conflicting packet data connections are allowed to proceed until a confirmation to reject those data packets is received or a timeout occurs.
Method 400 and especially the steps relating to interaction between a management system and a security gateway element are presented here as an example. The details of methods employed in management systems and security gateway elements in accordance with the invention may vary from those presented above.
Typically all elements of a connection data structure 50 according to the invention comprise acceptance information 55, as illustrated in 
If the acceptance information is a rule identifier, in step 602 it is typically checked that a rule having the same identifier is present also in the new (second) screening information and that it is not preceded by a rule inhibiting said packet data connection to be accepted based on the specific, identified rule. If the acceptance information is a user identifier, it typically implies that this specific user has been validly authenticated. Therefore it is checked if a rule allowing a packet data connection by the specified user is present in the new (second) screening information. If the acceptance information indicates a relating packet data connection, it is typically checked if the relating connection still exists and if it is allowed according to the new (second) screening information. If the acceptance information is a relating secure tunnel, e.g. a VPN tunnel, it is checked, if a rule allowing a connection using said specified tunnel is present in the new (second) screening information and if the encrypting methods are still valid.
In many cases, it is advantageous to use the method of 
The above example of providing a snapshot of a connection data structure to a user process is given as an example of implementing a method in accordance with the invention. Some operating systems have functionality to provide to various processes various views about a certain object.
In method 710, which is illustrated in 
It is possible to interrupt the processing of those data packets, which do not initiate packet data connections, for the duration of the comparison in steps 403, 702, 712. This prevents data packets relating to packet data connections conflicting the new screening information from traversing the security gateway element. As the comparison typically takes only some milliseconds, a delay, which may be caused for data packets relating to packet data connections in accordance with the new screening information, is often practically negligible and should not affect these packet data connections.
The comparison (step 403) in methods 700 and 701 may be done, for example, by comparing header information stored in connection data structure entries to new screening information (cf. step 611) or by comparing acceptance information to new screening information (cf. step 602).
It is possible to combine the features presented in method 400 together with those features presented either in method 600 or 610 and/or together with those presented either in method 700 or 710. Additionally, it is not required to perform all the steps presented in the Figures in order to use the invention, but some of the steps may be optionally ignored. Furthermore, the order of the steps in Figures is not meant to be restrictive. For example, steps 702/712 and steps 703 and 704 may be performed in the order presented in Figures or, for example, by interleaving steps 712 and 703 so that after an entry conflicting new screening information is found, it is deleted and then a next entry conflicting new screening information is searched for. Similarly, steps 712 and 704 may be interleaved, as well as steps 702, 703 and 704.
The security gateway element 1000 is characterized in that it further comprises means 1005 for comparing entries of said connection data structure to second screening information, thus classifying entries in said connection data structure as first entries, said first entries representing packet data connections in accordance with said second screening information, or as second entries, said second entries representing packet data connections in conflict with said second screening information.
The security gateway element 1000 further comprises means 1006 for rejecting packet data connections conflicting with new (second) screening informtion, for example by deleting or modifying some of said second entries from said connection data structure. The security gateway element 1000 typically further comprises means 1007 for indicating to a management system all or some of the packet data connections conflicting with the second screening information, and means 1008 for receiving a confirmation from the management system whether to reject all or some of the packet data connections conflicting with the second screening information. Furthermore, it is possible that said means 1006 for rejecting packet data connections are arranged to delete all packet data connections conflicting with the second screening information, if a confirmation is not received within a predefined period of time.
A security gateway element according to the invention may further comprise any of the following means:
A management system according to the invention may further comprise any of the following means in addition or alternatively to means 105–055:
A security gateway element according to the invention may be one network node or a cluster of network nodes. The means 100–008 and 105–055, or any other means mentioned in connection with 
In the view of the foregoing description it will be evident to a person skilled in the art that various modification may be made within the scope of the invention. It should be apparent that many modifications and variations to the above described examples are possible, all of which fall within the true spirit and scope of the invention.
| Patent | Priority | Assignee | Title | 
| 7903566, | Aug 20 2008 | The Boeing Company | Methods and systems for anomaly detection using internet protocol (IP) traffic conversation data | 
| 7995496, | Aug 20 2008 | The Boeing Company | Methods and systems for internet protocol (IP) traffic conversation detection and storage | 
| 8190767, | Jun 24 2003 | Nvidia Corporation | Data structures and state tracking for network protocol processing | 
| 8726382, | Aug 20 2008 | The Boeing Company | Methods and systems for automated detection and tracking of network attacks | 
| 8738800, | Jun 24 2003 | Nvidia Corporation | Data structures and state tracking for network protocol processing | 
| 8762515, | Aug 20 2008 | The Boeing Company | Methods and systems for collection, tracking, and display of near real time multicast data | 
| 8813220, | Aug 20 2008 | The Boeing Company | Methods and systems for internet protocol (IP) packet header collection and storage | 
| 9146949, | Jun 24 2003 | Nvidia Corporation | Data structures and state tracking for network protocol processing | 
| 9848004, | Aug 20 2008 | The Boeing Company | Methods and systems for internet protocol (IP) packet header collection and storage | 
| Patent | Priority | Assignee | Title | 
| 5577209, | Jul 11 1991 | Round Rock Research, LLC | Apparatus and method for providing multi-level security for communication among computers and terminals on a network | 
| 5606668, | Dec 15 1993 | Checkpoint Software Technologies Ltd. | System for securing inbound and outbound data packet flow in a computer network | 
| 5781550, | Feb 02 1996 | Hewlett Packard Enterprise Development LP | Transparent and secure network gateway | 
| 5835726, | Dec 15 1993 | Check Point Software Technologies Ltd | System for securing the flow of and selectively modifying packets in a computer network | 
| 5905859, | Jan 09 1997 | TREND MICRO INCORPORATED | Managed network device security method and apparatus | 
| 5907602, | Mar 30 1995 | Azure Solutions Limited | Detecting possible fraudulent communication usage | 
| 6044402, | Jul 02 1997 | DEWAAY INVESTMENT PARTNERS, LLLP | Network connection blocker, method, and computer readable memory for monitoring connections in a computer network and blocking the unwanted connections | 
| 6092194, | Nov 06 1997 | FINJAN LLC | System and method for protecting a computer and a network from hostile downloadables | 
| 6130924, | Apr 20 1998 | Oracle America, Inc | Method and apparatus for administrative control over data transmission using dynamic filtering in a multicast network | 
| 6154844, | Dec 22 1997 | FINJAN LLC | System and method for attaching a downloadable security profile to a downloadable | 
| 6158010, | Oct 28 1998 | Oracle International Corporation | System and method for maintaining security in a distributed computer network | 
| 6167520, | Nov 08 1996 | FINJAN LLC | System and method for protecting a client during runtime from hostile downloadables | 
| 6480962, | Nov 08 1996 | FINJAN LLC | System and method for protecting a client during runtime from hostile downloadables | 
| 6510509, | Mar 29 1999 | PMC-SIERRA US, INC , A CORP OF DE | Method and apparatus for high-speed network rule processing | 
| 6606710, | Dec 03 1998 | WSOU Investments, LLC | Adaptive re-ordering of data packet filter rules | 
| 6611875, | Dec 31 1998 | PMC-SIERRA US, INC | Control system for high speed rule processors | 
| 6631466, | Dec 31 1998 | PMC-SIERRA US, INC , A DELAWARE CORPORATION | Parallel string pattern searches in respective ones of array of nanocomputers | 
| 6650660, | Jul 27 1999 | PARITY NETWORKS LLC | Apparatus and method for synchronization of multiple data paths and recovery from lost synchronization | 
| 6691168, | Dec 31 1998 | PMC-SIERRA US, INC | Method and apparatus for high-speed network rule processing | 
| 6804780, | Nov 08 1996 | FINJAN LLC | System and method for protecting a computer and a network from hostile downloadables | 
| EP856974, | |||
| EP909072, | |||
| EPO9807088, | |||
| WO5852, | |||
| WO62167, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Sep 21 2001 | Stonesoft Oy | (assignment on the face of the patent) | / | |||
| Sep 28 2001 | SYVANNE, TUOMO | Stonesoft Oy | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012712/ | 0708 | |
| Jan 13 2016 | Stonesoft Oy | WEBSENSE FINLAND OY | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037796/ | 0134 | |
| Feb 09 2016 | WEBSENSE FINLAND OY | Forcepoint Finland Oy | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 038447/ | 0441 | |
| Jul 28 2017 | Forcepoint Finland Oy | Forcepoint LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043156/ | 0547 | |
| Feb 12 2018 | Forcepoint LLC | Raytheon Company | PATENT SECURITY AGREEMENT SUPPLEMENT | 045312/ | 0043 | |
| Jan 08 2021 | REDOWL ANALYTICS, INC | CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 055052/ | 0302 | |
| Jan 08 2021 | Forcepoint LLC | CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 055052/ | 0302 | |
| Jan 08 2021 | Raytheon Company | Forcepoint LLC | RELEASE OF SECURITY INTEREST IN PATENTS | 055452/ | 0220 | |
| Apr 01 2021 | FORCEPOINT FEDERAL HOLDINGS LLC | Forcepoint LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 056272/ | 0475 | |
| Apr 01 2021 | Forcepoint LLC | FORCEPOINT FEDERAL HOLDINGS LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 056183/ | 0265 | |
| Apr 01 2025 | UBS AG, Stamford Branch | Forcepoint, LLC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 070706/ | 0263 | |
| Apr 01 2025 | UBS AG, Stamford Branch | Bitglass, LLC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 070706/ | 0263 | 
| Date | Maintenance Fee Events | 
| Apr 08 2010 | M2551: Payment of Maintenance Fee, 4th Yr, Small Entity. | 
| Feb 03 2014 | STOL: Pat Hldr no Longer Claims Small Ent Stat | 
| Mar 19 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. | 
| Jun 26 2014 | ASPN: Payor Number Assigned. | 
| Jun 26 2014 | RMPN: Payer Number De-assigned. | 
| Apr 12 2018 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. | 
| Date | Maintenance Schedule | 
| Oct 24 2009 | 4 years fee payment window open | 
| Apr 24 2010 | 6 months grace period start (w surcharge) | 
| Oct 24 2010 | patent expiry (for year 4) | 
| Oct 24 2012 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Oct 24 2013 | 8 years fee payment window open | 
| Apr 24 2014 | 6 months grace period start (w surcharge) | 
| Oct 24 2014 | patent expiry (for year 8) | 
| Oct 24 2016 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Oct 24 2017 | 12 years fee payment window open | 
| Apr 24 2018 | 6 months grace period start (w surcharge) | 
| Oct 24 2018 | patent expiry (for year 12) | 
| Oct 24 2020 | 2 years to revive unintentionally abandoned end. (for year 12) |