×

Methods of structuring data, pre-compiled exception list engines and network appliances

  • US 9,225,593 B2
  • Filed: 04/02/2013
  • Issued: 12/29/2015
  • Est. Priority Date: 04/21/2009
  • Status: Active Grant
First Claim
Patent Images

1. A method of sorting a plurality of internet protocol (IP) addresses and filtering packets over a network connection based on the sorted IP addresses, each IP address having a numeric value within a range of numeric values, the method comprising:

  • dividing the range into a plurality of clusters representing a plurality of contiguous sub-ranges, each sub-range encompassing substantially the same number of numeric values of the range and each sub-range associated with a different cluster;

    assigning each IP address to the cluster associated with the sub-range that includes the numeric value of said IP address, each cluster having a cluster size defined by the number of IP addresses assigned to that cluster;

    assigning the IP addresses in each cluster to one of a plurality of pages, each page having a page size limit defining the maximum number of IP addresses that can be assigned to that page, and each page having a page size defined by the number of IP addresses assigned to that page, wherein at least one of the plurality of pages is assigned the IP addresses of a plurality of clusters such that the sum of the cluster sizes of the clusters of the assigned IP addresses is less than or equal to the page size limit of the page to which the IP addresses are assigned;

    if one of said pages has a page size less than its page size limit, duplicating on said page at least one of the IP addresses assigned to that page to increase the page size of said page; and

    ordering, for each page, the IP addresses assigned to said page by numeric value;

    receiving, over the network connection, a packet having a source IP address;

    identifying one page of the plurality of pages assigned the IP addresses of a cluster associated with a sub-range that includes the source IP address;

    searching the identified page to determine if the source IP address is assigned to the identified page;

    determining whether to allow the packet to proceed over the network based on if the source IP address is an allowable IP address in the identified page and to deny the packet from proceeding based on if the IP address is a blocked IP address in the identified page.

View all claims
  • 6 Assignments
Timeline View
Assignment View
    ×
    ×