The rate at which packets are provided to a cryptographic engine of a cryptographic system may be adjusted using a feedback mechanism to increase the output of the cryptographic system. data is classified and queued on a per class/flow basis and stored in input queues prior to being processed by the cryptographic engine. A class based queue scheduler is implemented to select data from the input queues to be transmitted to the cryptographic engine. The cryptographic engine operates in processing cycles. At each cycle, an amount of data is transferred from the input queues to a cryptographic engine input queue. A cryptographic accelerator in the cryptographic engine processes the data on the cryptographic engine input queue during the cycle. The output rate of the cryptographic accelerator is measured during the cycle and this value is used as feedback to determine how much data should be passed to the cryptographic engine for a subsequent cycle.
| 
 | 9.  A cryptographic system, comprising:
 a plurality of input queues; a packet classifier to classify received packets and cause each packet received by the cryptographic system to be stored in an appropriate input queue; a cryptographic accelerator to process packets by encrypting or decrypting the packets; a cryptographic accelerator input queue to store packets for processing by the cryptographic accelerator during a processing cycle; a class based queue scheduler to select data from the input queues to be processed by the cryptographic accelerator according to a cryptographic accelerator processing rate; a dynamic bandwidth calculator to use an output rate at which the cryptographic accelerator processes packets during a preceding cycle as feedback to set the cryptographic accelerator processing rate for a subsequent cycle. 1.  A non-transitory tangible computer readable storage medium having stored thereon a computer program for adjusting a rate at which packets are provided to a cryptographic engine having a cryptographic accelerator input queue and a cryptographic accelerator, the computer program comprising a set of instructions which, when executed by a computer, cause the computer to perform a method comprising the steps of:
 providing the cryptographic engine with a group of packets to be encrypted or decrypted during a processing cycle, an amount of data contained in the group of packets being determined according to an estimation of a likely amount of data able to be processed by the cryptographic accelerator during the processing cycle; measuring an output bandwidth of the cryptographic accelerator during the processing cycle; and using the output bandwidth of the cryptographic accelerator during the processing cycle as feedback to adjust an amount of data input to the cryptographic accelerator to be processed by the cryptographic accelerator during a subsequent processing cycle. 2.  The non-transitory tangible computer readable storage medium of  3.  The non-transitory tangible computer readable storage medium of  4.  The non-transitory tangible computer readable storage medium of  5.  The non-transitory tangible computer readable storage medium of  6.  The non-transitory tangible computer readable storage medium of  7.  The non-transitory tangible computer readable storage medium of  8.  The non-transitory tangible computer readable storage medium of  11.  The cryptographic system of  12.  The cryptographic system of  13.  The cryptographic system of  14.  The cryptographic system of  15.  The cryptographic system of  16.  The cryptographic system of  17.  The cryptographic system of  18.  The cryptographic system of  | |||||||||||||||||||||||||||
The present invention relates to encryption acceleration and, more particularly, to a method and apparatus for increasing the output of a cryptographic system.
Data communication networks may include various computers, servers, hubs, switches, nodes, routers, proxies, and other devices coupled to and configured to pass data to one another. These devices will be referred to herein as “network elements”. Data is communicated through the data communication network by passing protocol data units, such as frames, packets, cells, or segments, between the network elements by utilizing one or more communication links. A particular protocol data unit may be handled by multiple network elements and cross multiple communication links as it travels between its source and its destination over the network.
It is often desirable to encrypt the data before the data is transmitted on to the communication network by the end user 12 or at the ingress network element 14, so that it may be protected from being viewed and/or modified as it crosses the network 10. Thus, in the reference network of 
As shown in 
Once data has been received by the network element 20, it will be processed by a network processor 24 and optionally may be encrypted/decrypted by an cryptographic system 26. The data may be passed through a switch fabric 28 before or after being encrypted/decrypted and optionally may be processed by a different network processor 24 or the same network processor a second time before being output by the same I/O card or a different I/O card. Many network element architectures have been developed over time and, thus, the network element shown in 
When data is to be encrypted or decrypted, the data will be passed to the cryptographic system 26 for processing. The amount of data that a cryptographic system can handle in a given period of time is not constant, but rather is a function of the size of the packets that are being input to the cryptographic system, the transform algorithm being used by the cryptographic system, and whether the cryptographic system is encrypting the data or decrypting the data. Packet size is of particular importance when determining the throughput of a cryptographic system, as a cryptographic system may be able to handle a significantly higher volume of data formed as large sized packets than it can when the data is formed as smaller sized packets.
Cryptographic processing may be a relatively slow process and, hence, the cryptographic system may form a bottleneck on the amount of data a network element is able to handle. Accordingly, optimizing the use of the cryptographic system to output as much data as possible is important to the overall performance of the network element. Previously attempts have been made to optimize the output of the cryptographic system by queuing the data before sending the data to the cryptographic system, and then inputting the data at a steady rate from the input queue to the cryptographic system. This allows data to be available for the cryptographic system so that the cryptographic system has a steady stream of data to encrypt/decrypt and thus is more likely to be able to operate efficiently. Unfortunately, as discussed above, the amount of data a cryptographic system is able to process may vary dramatically depending on the format/size of the input data and the process to be implemented on the data. Thus, inputting the data at a steady state results in either under-utilization of the cryptographic system if the steady-state value of the amount of data to be input is selected based on the lowest sustained throughput, or oversubscription of the cryptographic system if the steady-state value of the amount of data to be input is selected based on the highest sustained throughput. In either case performance is not optimal, because either the cryptographic system is underutilized, or is occasionally overutilized which can cause packets to be dropped.
The rate at which packets are provided to a cryptographic engine of a cryptographic system may be adjusted using a feedback mechanism to increase the output of the cryptographic system. Data is classified and queued on a per class/flow basis and stored in input queues prior to being processed by the cryptographic engine. A class based queue scheduler is implemented to select data from the input queues to be transmitted to the cryptographic engine. The cryptographic engine operates in processing cycles. At each cycle, an amount of data is transferred from the input queues to a cryptographic engine input queue. A cryptographic accelerator in the cryptographic engine processes the data on the cryptographic engine input queue during the cycle. The output rate of the cryptographic accelerator is measured during the cycle and this value is used as feedback to determine how much data should be passed to the cryptographic engine for a subsequent cycle. Feedback may be implemented using an exponential weighted moving average or another weighted moving average algorithm.
Aspects of the present invention are pointed out with particularity in the appended claims. The present invention is illustrated by way of example in the following drawings in which like references indicate similar elements. The following drawings disclose various embodiments of the present invention for purposes of illustration only and are not intended to limit the scope of the invention. For purposes of clarity, not every component may be labeled in every figure. In the figures:
In addition to determining the class of traffic by looking at the DS field, the QoS classifier may look at other aspects of the traffic to determine how the traffic should be handled. For example, the QoS classifier may classify traffic on a per-flow basis to separate flows of traffic on the network so that different flows may be treated differently by the network element. Additionally, the QoS classifier may determine the type of traffic being carried by the incoming packets and sort the incoming packets according to the latency sensitivity or other characteristics of the packets. For example, voice traffic is generally more sensitive to latency than data traffic. Accordingly, the QoS traffic may separate voice traffic or other traffic that needs to be handled on an expedited basis from traffic that is less sensitive to latency and classify the traffic on that basis.
The QoS classifier 310 thus takes the input data 312, classifies the input data, and stores the data in a plurality of input queues 314. A separate input queue may be used for each class of traffic so that the different types of traffic (green, yellow, red) are stored in such a manner as to be selectable for processing by the remaining components of the cryptographic system 300. Similarly, individual queues 314 may be provided for different flows of traffic so that different flows of data may be queued separately and treated individually by the network element. Multiple queues may be used depending on how the network element is required to handle data and prioritize particular types of traffic. Thus, many different queues may be used and the QoS classifier may cause traffic to be placed into the queues to allow the network element to implement the particular policy required for the various types of traffic on the network.
The cryptographic system 300 also includes a Class Based Queuing (CBQ) scheduler 320 that selects data from the input queues 314 to be processed by a cryptographic engine 330. Since the QoS classifier is able to cause different classes and/or flows of data to be stored in different queues for processing by the cryptographic engine 330, the CBQ scheduler is able to schedule data on a per-flow or per-class basis. Accordingly, the CBQ scheduler may prioritize latency sensitive traffic, may be used to guarantee bandwidth for different traffic flows, or to otherwise implement differential treatment for different classes and/or flows of traffic on the network.
The CBQ scheduler is also responsible for shaping traffic by adjusting the size of the input queues 314. Specifically, the CBQ scheduler may adjust the size of the input queues 314 dynamically to allow different amounts of data to be stored in each of the input queues 314. By adjusting the size of the input queues, the CBQ scheduler can dictate how much traffic of a particular type may be stored for that class/flow. Similarly the CBQ scheduler may control the rate at which data is read from a particular input queue 314. These two values may be adjusted dynamically and together allow the CBQ scheduler to perform traffic shaping to control the volume and rate at which data of a particular class/flow is transmitted on the network. The CBQ scheduler thus performs traffic shaping and policing by causing the size of the input queues to be adjusted according to network policy.
As shown in 
In the example shown in 
The cryptographic accelerator 330, in one embodiment, operates to encrypt/decrypt batches of data in cycles. Specifically, a batch of data 352 will be input to the cryptographic accelerator input queue 332 and the cryptographic accelerator will operate on that data during the processing cycle. Thus, the cryptographic accelerator input queue serves to store the data for processing by the cryptographic accelerator during one processing cycle. The processing cycle may be 5 ms in duration or some other cycle depending on the particular cryptographic engine 330 selected to implement an embodiment of the invention. In operation, the CBQ scheduler 320 will select data to be transferred from the class based input queues 314 to the cryptographic accelerator input queue 332. The cryptographic accelerator 334 will then process the data at its maximum rate until it runs out of data in the input queue.
According to an embodiment of the invention, the rate at which data is processed and output from the cryptographic accelerator 334 may be measured and used to adjust the amount of data that is fed by the CBQ scheduler 320 to the cryptographic accelerator input queue 332, so that the amount of data that is provided to the cryptographic engine during a processing cycle closely approximates the amount of data that the cryptographic accelerator is likely to be able to handle during that cycle. Alternatively, in another embodiment, a fixed amount of data may be input to the cryptographic engine during a processing cycle, but the duration of the processing cycle may be adjusted (shortened or lengthened) to allow the cryptographic accelerator to receive data sooner or later depending on the rate at which the cryptographic accelerator is able to process the data. Thus, by using a closed loop feedback system, using feedback from the output of the cryptographic accelerator 330, the amount of data input to the cryptographic accelerator during a subsequent cycle is more likely to more closely approximate the amount of data likely to be able to be processed by the cryptographic accelerator during that subsequent cycle. In the alternative embodiment, the amount of time allocated to the cryptographic accelerator may be adjusted so that the cryptographic accelerator is kept close to continuously busy. This may increase the output of the cryptographic engine by making a maximum amount of data available for processing by the cryptographic accelerator without significantly risking passing too much data to the cryptographic accelerator.
Periodically, the CBQ scheduler will select data 352 to be transmitted from the class based input queues 314 to the cryptographic accelerator input queue 332. The CBQ scheduler may use any one of a number of known ways of selecting data from the various input queues. For example, the CBQ scheduler may use a simple round robin approach to select data from the queues, may use a weighted round robin approach, or any other desired approach. The invention is not limited by the particular method implemented by the CBQ scheduler to select data from the various input queues for transmission.
In the example shown in 
Once the data has been received in the cryptographic accelerator input queue 332, the cryptographic accelerator 334 will operate on the data to encrypt/decrypt or otherwise process the data, and output the data as encrypted/decrypted data 338. As noted above, the data may be placed in a raster and retrieved by being polled by the other components of the network element or alternatively placed in a cryptographic accelerator output queue for subsequent transmission to the remaining systems of the network element. However, since the cryptographic accelerator is generally a bottleneck in the network element, the data may generally output directly to the network element without implementing an output queue structure. The output queue illustrated in the drawings is therefore intended to merely convey that the data is output at that point and the invention is not limited to an embodiment that utilizes an output queue at the output of the cryptographic accelerator.
The cryptographic accelerator 334 will process whatever data 352 is in the cryptographic accelerator input queue 332 during the processing cycle which, in this example, is 5 ms. If there is too much data 352 in the cryptographic accelerator input queue 332, the cryptographic accelerator will not be able to process all the input data 402 and, hence, some of the packets transferred to the cryptographic accelerator input queue may be dropped. Conversely, if not enough data 352 is input to the cryptographic accelerator input queue 332, the cryptographic accelerator will be able to process the data in less than the 5 ms scheduling period and, hence, will remain idle for a portion of the processing cycle. Either option is less than ideal. In the first instance, where too much data is input, the additional data may end up being dropped, whereas in the second instance the full ability of the cryptographic accelerator is not being utilized to thereby slow down the overall rate at which the network element is able to handle data.
According to an embodiment of the invention, the cryptographic system 300 includes a dynamic bandwidth calculator 340 configured to monitor the output of the cryptographic accelerator 334 and determine, from the output bandwidth, how much data should be transferred by the CBQ scheduler 320 from the class based input queues 314 to the cryptographic accelerator input queue 332 in the subsequent cycle.
As noted above, during every processing cycle, a given quantity of data will be transmitted into the cryptographic accelerator input queue 332 and, assuming that the cryptographic accelerator is able to handle that quantity of data, the cryptographic accelerator will also output the same quantity of data during the 5 ms processing period. However, the rate at which the data is made available at the output 336 of the cryptographic accelerator 334 is not likely to be constant during the 5 ms processing cycle.
For example, assume that the cryptographic accelerator input queue 332 is only provided with enough data to occupy the cryptographic accelerator for part of the processing cycle. The cryptographic accelerator is not aware that there is insufficient data in the cryptographic accelerator input queue 332 and will therefore process the data at the maximum rate. Accordingly, the cryptographic accelerator will process the data from the cryptographic accelerator input queue 332 and output the data at the maximum possible rate for the beginning part of the processing cycle. Once the cryptographic accelerator runs out of data in the cryptographic accelerator input queue, it will stop working and wait for a new batch of data to be delivered to the cryptographic accelerator input queue. The particular rate at which the cryptographic accelerator outputs data (before it runs out of data) will depend on the particular mix of small and large packets, the type of traffic, whether the cryptographic accelerator is encrypting/decrypting the packets, and other similar factors. The rate at which the cryptographic accelerator outputs data may be used as feedback by the cryptographic system to determine how much data should be transmitted into the cryptographic accelerator input queue during the next processing cycle.
In the embodiment shown in 
The dynamic bandwidth calculator 340 dynamically estimates the cryptographic accelerator bandwidth for the upcoming cycle based on the observed bandwidth of the cryptographic accelerator bandwidth for the previous cycle and the history of how much bandwidth the cryptographic accelerator has exhibited in the recent past. For example, the dynamic bandwidth calculator 340 may use an algorithm such as the exponential weighted moving average in which the value of an estimate for an upcoming cycle is calculated according to the following formula (Equation #1):
BWa=(1−W)*BWa+W*BWc  (Equation #1)
in which BWa is the average bandwidth of the cryptographic accelerator (this value is used to set the amount of data that is to be transferred by the CBQ scheduler from the class based input queues 314 to the cryptographic accelerator input queues during a given cycle); BWc is the current measured output bandwidth of the cryptographic accelerator from the previous cycle; and W is the weight to be afforded the current bandwidth of the cryptographic accelerator relative to the historic bandwidth of the cryptographic accelerator 334. For example, assume a weight W=0.25. The new bandwidth for a given processing cycle will be determined by adding 0.75 the bandwidth of the previous cycle, plus 0.25 the bandwidth measured at the output of the cryptographic accelerator during the previous cycle. Thus, as the cryptographic accelerator starts to process data faster, for example if the average packet size being input to the cryptographic accelerator increases, the higher output bandwidth from the cryptographic accelerator will cause the BWa value to increase which, in turn, will cause a larger amount of data to be transferred by the CBQ scheduler from the class based queues 314 into the input queue 332. Other weighting formulas may be used to adjust the moving average as well.
The dynamic bandwidth calculator may calculate a new bandwidth estimate during every cycle, or alternatively may perform a threshold analysis first to determine if the bandwidth should be changed. For example, the dynamic bandwidth calculator may determine if the observed bandwidth BWc for the previous cycle was within 5% or another threshold of the input bandwidth BWa and, if so, determine that no change should be made to the bandwidth estimation for the subsequent cycle. Different threshold values may be chosen depending on how often it is determined to be desirable to change the amount of data being transferred by the CBQ scheduler.
At the start of the cycle, the cryptographic accelerator will start to process packets in the cryptographic accelerator input queue (504). The encrypted/decrypted packets will be passed to the cryptographic accelerator output (506). The network element will poll the cryptographic accelerator output for processed packets (508) and pass the encrypted/decrypted packets to the remaining portion of the network element for subsequent processing. For example, the encrypted/decrypted packets may be passed to the switch fabric to be switched within the network element and then output from the network element.
The dynamic bandwidth calculator will measure the rate (BWc) at which data comes out of the cryptographic accelerator (510) and use the measured output rate (BWc) to adjust the current estimated bandwidth value (BWa) so that the new estimate may be used in a subsequent cycle when selecting data by the CBQ scheduler (512).
The functions described above may be implemented as a set of program instructions that are stored in a computer readable memory and executed on one or more processors on the computer platform. However, it will be apparent to a skilled artisan that all logic described herein can be embodied using discrete components, integrated circuitry such as an Application Specific Integrated Circuit (ASIC), programmable logic used in conjunction with a programmable logic device such as a Field Programmable Gate Array (FPGA) or microprocessor, a state machine, or any other device including any combination thereof. Programmable logic can be fixed temporarily or permanently in a tangible medium such as a read-only memory chip, a computer memory, a disk, or other storage medium. Programmable logic can also be fixed in a computer data signal embodied in a carrier wave, allowing the programmable logic to be transmitted over an interface such as a computer bus or communication network. All such embodiments are intended to fall within the scope of the present invention.
It should be understood that various changes and modifications of the embodiments shown in the drawings and described in the specification may be made within the spirit and scope of the present invention. Accordingly, it is intended that all matter contained in the above description and shown in the accompanying drawings be interpreted in an illustrative and not in a limiting sense. The invention is limited only as defined in the following claims and the equivalents thereto.
Dattatreya, Mohan, Posam, Mohana, Jain, Abha, Yang, Ayfang
| Patent | Priority | Assignee | Title | 
| 10963295, | Sep 08 2017 | Oracle International Corporation | Hardware accelerated data processing operations for storage data | 
| 11394700, | Jan 31 2020 | PENSANDO SYSTEMS INC | Proxy service through hardware acceleration using an IO device | 
| 11431681, | Apr 07 2020 | PENSANDO SYSTEMS INC | Application aware TCP performance tuning on hardware accelerated TCP proxy services | 
| 11936561, | May 17 2019 | Pensando Systems, Inc. | Rate-optimized congestion management | 
| 9912644, | Aug 05 2014 | MAGENTA SECURITY HOLDINGS LLC; MAGENTA SECURITY INTERMEDIATE HOLDINGS LLC | System and method to communicate sensitive information via one or more untrusted intermediate nodes with resilience to disconnected network topology | 
| Patent | Priority | Assignee | Title | 
| 5938749, | Jun 03 1996 | Whittaker Communications Inc. | Queue measurement apparatus and methodology | 
| 5953318, | Dec 04 1996 | WSOU Investments, LLC | Distributed telecommunications switching system and method | 
| 5999518, | Dec 04 1996 | ALCATEL USA SOURCING, L P | Distributed telecommunications switching system and method | 
| 6052786, | Jul 22 1997 | Fujitsu Limited | Secrecy communication system | 
| 6141323, | Jun 03 1996 | Whittaker Corporation | Closed loop congestion control using a queue measurement system | 
| 6148082, | Jan 14 1998 | SKYSTREAM NETWORKS INC | Scrambling and descrambling control word control in a remultiplexer for video bearing transport streams | 
| 6577679, | Sep 30 1999 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method and apparatus for transcoding coded picture signals from object-based coding to block-based coding | 
| 6606666, | Nov 09 1999 | GOOGLE LLC | Method and system for controlling information flow between a producer and a buffer in a high frequency digital system | 
| 6794893, | Feb 05 2002 | VIA Technologies, Inc. | Pad circuit and method for automatically adjusting gain for the same | 
| 6990113, | Sep 08 2000 | Mitsubishi Electric Research Labs., Inc. | Adaptive-weighted packet scheduler for supporting premium service in a communications network | 
| 7536560, | Apr 18 2003 | VIA Technologies, Inc. | Microprocessor apparatus and method for providing configurable cryptographic key size | 
| 7734950, | Jan 24 2007 | Hewlett-Packard Development Company, L.P. | Bandwidth sizing in replicated storage systems | 
| 7779232, | Aug 28 2007 | International Business Machines Corporation | Method and apparatus for dynamically managing instruction buffer depths for non-predicted branches | 
| 7904711, | Oct 24 2007 | CROGA INNOVATIONS LIMITED | Scaleable architecture to support high assurance internet protocol encryption (HAIPE) | 
| 20020114451, | |||
| 20020116562, | |||
| 20030074388, | |||
| 20030074473, | |||
| 20030160651, | |||
| 20040052375, | |||
| 20050076228, | |||
| 20050157871, | |||
| 20060056300, | |||
| 20060062319, | |||
| 20060083489, | |||
| 20060143473, | |||
| 20070014400, | |||
| 20070076802, | |||
| 20070076803, | |||
| 20070098153, | |||
| 20070250554, | |||
| 20080028233, | |||
| 20080052537, | |||
| 20080117913, | |||
| 20080170630, | |||
| 20090063819, | |||
| 20090113201, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Dec 31 2007 | Rockstar Consortium US LP | (assignment on the face of the patent) | / | |||
| Jan 23 2008 | JAIN, ABHA | Nortel Networks Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020724/ | 0978 | |
| Jan 23 2008 | POSAM, MOHANA | Nortel Networks Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020724/ | 0978 | |
| Jan 23 2008 | DATTATREYA, MOHAN | Nortel Networks Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020724/ | 0978 | |
| Jan 23 2008 | YANG, AYFANG | Nortel Networks Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020724/ | 0978 | |
| Jul 29 2011 | Nortel Networks Limited | Rockstar Bidco, LP | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027143/ | 0717 | |
| May 09 2012 | Rockstar Bidco, LP | Rockstar Consortium US LP | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 029235/ | 0241 | |
| Jan 28 2015 | ROCKSTAR CONSORTIUM LLC | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Jan 28 2015 | MOBILESTAR TECHNOLOGIES LLC | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Jan 28 2015 | NETSTAR TECHNOLOGIES LLC | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Jan 28 2015 | Rockstar Consortium US LP | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Jan 28 2015 | Constellation Technologies LLC | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Jan 28 2015 | Bockstar Technologies LLC | RPX CLEARINGHOUSE LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034924/ | 0779 | |
| Feb 26 2016 | RPX CLEARINGHOUSE LLC | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT | 038041/ | 0001 | |
| Feb 26 2016 | RPX Corporation | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT | 038041/ | 0001 | |
| Dec 22 2017 | JPMORGAN CHASE BANK, N A | RPX Corporation | RELEASE REEL 038041 FRAME 0001 | 044970/ | 0030 | |
| Dec 22 2017 | JPMORGAN CHASE BANK, N A | RPX CLEARINGHOUSE LLC | RELEASE REEL 038041 FRAME 0001 | 044970/ | 0030 | 
| Date | Maintenance Fee Events | 
| Sep 16 2016 | REM: Maintenance Fee Reminder Mailed. | 
| Feb 05 2017 | EXP: Patent Expired for Failure to Pay Maintenance Fees. | 
| Date | Maintenance Schedule | 
| Feb 05 2016 | 4 years fee payment window open | 
| Aug 05 2016 | 6 months grace period start (w surcharge) | 
| Feb 05 2017 | patent expiry (for year 4) | 
| Feb 05 2019 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Feb 05 2020 | 8 years fee payment window open | 
| Aug 05 2020 | 6 months grace period start (w surcharge) | 
| Feb 05 2021 | patent expiry (for year 8) | 
| Feb 05 2023 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Feb 05 2024 | 12 years fee payment window open | 
| Aug 05 2024 | 6 months grace period start (w surcharge) | 
| Feb 05 2025 | patent expiry (for year 12) | 
| Feb 05 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |