Movatterモバイル変換


[0]ホーム

URL:


US7340535B1 - System and method for controlling routing in a virtual router system - Google Patents

System and method for controlling routing in a virtual router system
Download PDF

Info

Publication number
US7340535B1
US7340535B1US10/163,071US16307102AUS7340535B1US 7340535 B1US7340535 B1US 7340535B1US 16307102 AUS16307102 AUS 16307102AUS 7340535 B1US7340535 B1US 7340535B1
Authority
US
United States
Prior art keywords
packet
vre
flow
vres
functions
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime, expires
Application number
US10/163,071
Inventor
Naveed Alam
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fortinet Inc
Original Assignee
Fortinet Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Fortinet IncfiledCriticalFortinet Inc
Priority to US10/163,071priorityCriticalpatent/US7340535B1/en
Assigned to COSINE COMMUNICATIONS, INC.reassignmentCOSINE COMMUNICATIONS, INC.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: ALAM, NAVEED
Priority to PCT/US2003/017674prioritypatent/WO2003103237A1/en
Priority to AU2003238894Aprioritypatent/AU2003238894A1/en
Assigned to FORTINET, INCreassignmentFORTINET, INCASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: COSINE COMMUNICATIONS, INC.
Application grantedgrantedCritical
Publication of US7340535B1publicationCriticalpatent/US7340535B1/en
Adjusted expirationlegal-statusCritical
Expired - Lifetimelegal-statusCriticalCurrent

Links

Images

Classifications

Definitions

Landscapes

Abstract

One or more functions are applied to network data packets in a virtual router. A packet comprising part of a packet flow is received, and the packet is evaluated to determine which of the one or more functions are to be applied to the flow. The results of the evaluation are stored in a record, and the functions indicated in the stored record are applied to subsequent packets in the packet flow.

Description

FIELD OF THE INVENTION
The invention relates generally to computerized networks, and more specifically to a system and method for controlling routing in a virtual routing system.
BACKGROUND OF THE INVENTION
Computer networks are becoming increasingly important to the way computers are used for business, recreation, and communication. The ability of a computer network to easily and efficiently move data from a sender to the intended destination is critical to the usefulness of computer networks, and to their ability to handle the large amount of varying traffic that is encountered in modem network environments.
Networks are often characterized as local area networks (LANs) or wide area networks (WANs). LANs typically comprise anywhere from a few computers sharing a common network to large groups of computers located physically near each other such as an entire building's network. WANs are larger in scope, and include networks that have geographically dispersed computers such as the Internet. Networks can be further characterized by the types of data that they carry or the protocols they use, such as IPX networks that are often found in Novell local area networks, and TCP/IP networks that are often found in the Internet and in other LANs and WANs. Also, different physical network connections and media such as Ethernet, Token Ring, Asynchronous Transfer Mode (ATM), and Frame Relay exist, and can be carried over copper, optical fiber, via radio waves, or through other media.
Networks of different types or that are geographically dispersed can be interconnected via technologies, such as routers, switches, and bridges. Bridges simply translate one network protocol to another and provide a communications “bridge” between different types of networks. Switches allow connectivity of a number of switched devices on a network to a single network connection, and in effect filter and forward packets between the network connection and the various attached devices. Routers typically do little filtering of data, but receive data from one network and determine how to direct the data to the intended destination networked device. Routers typically use headers of a packet, such as an IP packet header for Internet communication to determine the intended destination for a packet, and communicate with other routers using protocols, such as the Internet Control Messaging Protocol (ICMP), to determine a desired route for a packet to travel from one network device to another. Routers therefore are primarily responsible for receiving network traffic and routing it across multiple LANs or across a WAN to the intended destination.
Data packet routing is a critical element of network performance, and can become a problem if large local area networks send a lot of network traffic through a single router connection to other networks. Factors such as transforming data of one type or in one protocol to another protocol or format can require significant processing, and serve to further tax the ability of routers to connect various types of networks. Some routers incorporate multiple processors to handle different data protocols and formats, and are configured by the manufacturer by specially configuring the hardware or by hard-coding elements of software to meet specific requirements of a specific customer application. Unfortunately, using such a router in a changed environment is often less than optimal, and reconfiguration of the router would require re-coding the control software or replacement of hardware elements. Further, performance of the various functions performed on each packet in a stream of packets is often not optimal, both because certain parts of the packet forwarding process are repeated and because the various resources available may not be allocated in a manner efficient for some situations.
It is therefore generally desirable to have a system or method for controlling routing of network data that provides efficient configuration of routing functionality and that optimizes use of available resources.
SUMMARY OF THE INVENTION
A system for applying one or more functions to network data packets in a virtual router is provided. A packet comprising part of a packet flow is received, and the packet is evaluated to determine which of the one or more functions are to be applied to the flow. The results of the evaluation are stored in a record, and the functions indicated in the stored record are applied to subsequent packets in the packet flow.
BRIEF DESCRIPTION OF THE FIGURES
FIG. 1 shows a block diagram of the Internet Protocol Service Generator router architecture, consistent with an embodiment of the present invention.
FIG. 2 shows a block diagram illustrating packet flow in the Internet Protocol Service Generator, consistent with an embodiment of the present invention.
FIG. 3 shows a block diagram illustrating operation of the Internet Protocol Network Operating System in the context of the Internet Protocol Service Generator, consistent with an embodiment of the present invention.
FIG. 4 illustrates the hardware architecture of a packet forwarding engine, consistent with an embodiment of the present invention.
FIG. 5 illustrates the forwarding data structures stored in system memory and the packet forwarding ingress and egress processing method of one embodiment of he present invention.
DETAILED DESCRIPTION
In the following detailed description of sample embodiments of the invention, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific sample embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical, and other changes may be made without departing from the spirit or scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the invention is defined only by the appended claims.
The present invention comprises in one embodiment a system for applying one or more functions to network data packets in a virtual router. A packet comprising part of a packet flow is received, and the packet is evaluated to determine which of the one or more functions are to be applied to the flow. The results of the evaluation are stored in a record, and the functions indicated in the stored record are applied to subsequent packets in the packet flow.
Application of these functions occurs in one embodiment in the context of a virtual router operating on a user-configurable and scalable virtual router system. Examples of such a system are described in detail herein to provide context for understanding operation of the invention, but are only examples of one of many possible implementations of the present invention.
FIG. 1 shows a block diagram of the Internet Protocol Service Generator (IPSG) router architecture, consistent with an exemplary embodiment of the present invention. The IPSG architecture is an architecture that manages switching, routing, and computing resources within a user-configurable hardware router architecture. The architecture provides user-level service customization and configuration, and provides scalability for future expansion and reconfiguration. The IPSG, shown generally inFIG. 1, comprises one or morevirtual routing engines101 that provide routing capability in the virtual services environment of the IPSG architecture. One or morevirtual service engines102 provide packet processing capability in a virtual services environment. Theadvanced security engine103 provides processing capability specifically directed to security functionality for security protocols such as IPSec. The functions provided may include, but are not limited to, 3DES/RC4 SHA, MD5, PKI, RSA, Diffie-Hellman, or other encryption, decryption, or verification functions.Midplane interface104 provides connectivity between the IPSG and other system hardware.
These elements are tied together byservice generator fabric105, which manages and controls the other elements of the IPSG. Theline interface106 provides connectivity between the IPSG and one or more networked devices via one or more types of network connection. The network connection types may include, but are not limited to, Gigabit Ethernet, DS3/E3, POS, and ATM.
In some embodiments of the invention, multiple IPSG modules can be installed in a single router hardware chassis, and can provide functionality that supports a variety of network connection interfaces and protocols as well as a scalable increase in routing capacity.
FIG. 2 shows a block diagram illustrating flow of a typical example packet in the Internet Protocol Service Generator, consistent with an embodiment of the present invention. At201, a packet is received via the network connection line interface, and is directed by theflow manager202 which utilizes a steering table to determine which Virtual Local Area Network (VLAN) data is sent to which Virtual Routing Engine (VRE). Theflow manager202 tags the packet with an internal control header and transfers it across theservice generator fabric203 to the selected VRE at204.
Upon arrival at the VRE, the packet enters avirtual services controller205 for packet classification. Various packet fields, such as IP source and destination, UDP/TCP source and destination port numbers, IP protocol field, TOS field, IPSec header, and SPI field information are extracted. A flow cache is checked to determine whether the packet is to be processed in hardware or in software, and the packet is routed accordingly. In this example, the packet is to be processed in hardware, and so is passed on tomain memory206 from which it can be accessed by Virtual Routing Processor (VRP)207. TheVRP207 retrieves the packet, identifies the packet processing actions that can be achieved in hardware, and performs those processes, which include such things as checksum adjustment, time-to-live adjustment, and other packet actions.
The example packet is then forwarded to the Advanced Security Engine (ASE)208, where the packet is encrypted. The ASE208 performs the encryption and prepends an IPSec tunnel header to the packet before routing the packet back to theVRP207. TheVRP207 then forwards the packet to a second Virtual Routing Engine (VRE)209, where a virtual router routes the packet throughnetwork interface connection210.
FIG. 3 shows a block diagram illustrating operation of the Internet Protocol Network Operating System (IPNOS) in the context of the Internet Protocol Service Generator (IPSG), consistent with an embodiment of the present invention. The IPNOS provides customizable subscriber-level IP services through Virtual Router (VR) elements. The IPNOS creates a VR as an object group, where the objects include application layer, network layer, transport layer, data link layer, physical layer, and other objects. For example, a firewall may exist in a VR as an application layer object, and TCP/IP objects may exist as transport or network layer objects. Data link layer objects include VLAN or other such data link layer objects, and physical layer objects include ATM, DS3, or other physical layer objects.
These objects comprise various data definitions and methods, and so are capable of invoking methods in response to events, such as the arrival of a data packet. These objects can invoke their own methods, or other methods from other objects, and so can interact with each other, such as to perform task sharing. According to one embodiment, one element of each object type is required to execute. The object manager can then draw from available resources to provide the appropriate processing, and can manage the various resources such as the engines ofFIGS. 1 and 2 to draw from resources tailored to a specific function.
The line interfaces and thenetwork module301 inFIG. 3 are tailored to handle data link and physical link layer tasks, such as providing avirtual interface302 andvirtual layer2switch303. TheVirtual Service Engine304 is tailored to provide specific application layer, presentation layer, session layer, and transport layer functions, such as anapplication layer firewall305 or ananti-virus module306. TheAdvanced Security Engine307 provides IPSec encryption, decryption, and verification via amodule308, which operates on network layer objects to provide security functionality. TheVirtual Routing Engine309 providesrouting services310,network address translation311, Multi-Protocol Label Switching (MPLS)312, and other network and transport layer functions. Because VR requests for a new object or resource are managed by the IPNOS, the IPNOS can dynamically allocate resources to optimize utilization of available processing resources.
FIG. 4 illustrates the hardware architecture of a packet forwarding engine400, consistent with an example embodiment of the the present invention. The packet forwarding engine400 performs hardware-assisted packet forwarding for a variety of network and transport layer packets, and includes functions such as flow cache route lookup forwarding and IP/MPLS forwarding of packets as well as packet header processing functions. The packet forwarding engine400 ofFIG. 4 is partitioned into ingress and egress portions, both for the switch fabric data interface and for the DMA memory interface.
Packets are received at theswitch fabric interface401, and are forwarded to one of a plurality ofingress processors402. Theingress processors402 are specially microcoded for ingress processing functionality, just asegress processors403 are specially microcoded for egress processing. In one embodiment of the invention, eachingress processor402 operates on one incoming packet and eachegress processor403 operates on one outgoing packet, and hardware interlocks maintain packet order.
The packet forwarding engine400ingress processors402 pass the packet forwarding state parameters to the DMA engine orDMA interface ingress404 that incorporates these state parameters into the packet receive descriptor. This forwarding state indicates whether theprocessor407 should software forward the packet or whether the packet can bypass software processing and can be hardware processed. The forwarding state also includes an index into a forwarding transform cache that describes packet forwarding engine processing applied to each type of received packet.
For software forwarded packets, the receive descriptor for the packet is pushed into a DMA ingress descriptor queue such as inmemory405. Then, the software processing is performed inprocessor407, and the result of processing the packet receive descriptor is routed to theDMA interface egress406 as a packet transmit descriptor. For hardware forwarded packets, the receive descriptor bypasses the ingress descriptor queue and is pushed directly onto a DMA egress descriptor queue associated with the DMAinterface egress module406 as a packet transmit descriptor via a hardware forwarding engine.
FIG. 5 illustrates in greater detail the forwarding data structures stored in system memory at501, and illustrates the packet forwarding ingress and egress processing method at502. The data structure elements and ingress and egress processing are described in greater detail in a specific embodiment of the present invention described later in this document.
While the hardware forwarding engine on the IP Service Generator provides the fundamental packet forwarding functions and capability, IPNOS, or any other network operating system, needs to be able to take advantage of this capability to relieve itself of the burden of providing the basic forwarding and other IP services. The Packet Forwarding Engine Driver (PFED) API provides IPNOS a flexible interface to the PFE hardware.
The Hardware Forwarding Engine can operate either in Prefix mode or Flow mode. In prefix mode the forwarding is based on some number of bits of the destination IP address of the packet itself; no other IP services, such as filtering are available. In Flow mode, the forwarding is still based on the destination address but, for the purpose of providing IP services, packets are classified into “flows,” a flow being characterized by many parameters associated with it.
The PFE driver, as well as the IP stack, treats the first packet of each new flow in a very special way, and that is because it is used to gather information about any packet filters, NAT rules, QoS, Metering and IP forwarding functions5 that the user has chosen for this flow. According to the present example, there are three major elements to the process of pushing flows into hardware by the PFE driver:
(a) New flow identification
(b) Learning
(c) Flow setup
Additionally, PFE also supports an API to accomplish:
(d) CPU Forwarding Bandwidth Allocation
(e) PFE Forwarding Bandwidth Allocation
These two features of the PFE/PFED are powerful tools that allow creating virtual routers whose software or hardware forwarding bandwidth allocation remains unaffected by other virtualized routers in IPNOS.
New flow identification and flow setup for a new flow are transparent to IPNOS except that the software, given a learning packet, must either send the packet out or decide to terminate the flow. Both these cases are supported by the API.
Learning is accomplished as the packet traverses the software IP forwarding stack using the PFED API functions. The information collected is held in a buffer referred to as an ‘annotation buffer’ which is allocated and attached to all learning packets before being passed to the software stack. Flow setup is automatically handled by PFE driver when a learning packet is being forwarded.
Even though packet forwarding is handled by the PFE, the user may wish to have policies that specify that some flows be handled in software. In order to ensure that one virtualized IPNOS router is not starved by another more active router, the user may specify a certain CPU resource level per router at the time of its creation.
The PFE driver provides an interface to allow the user to allocate the PFE's forwarding capacity much like the CPU bandwidth allocation to ensure that one active router doesn't consume all the hardware PFE resources.
According to the present example, the API itself is broadly broken down into the following areas:
1. Statistics—The basic mechanism available to the OS to collect statistics is via a Statistics Control Block (SCB) allocated by the PFE driver, and then associating this SCB(s) to Ingress or Egress side.
2. Filter functions—Once it is determined that packets belonging to a particular flow qualify for discard action, the user can tag them such that they are discarded in the PFE itself.
3. QoS functions—The purpose of this function is to allow software to map IP QoS to different traffic classes.
4. Metering Functions—Metering functions allow the OS to apply QoS at the traffic level such that traffic for a given flow doesn't exceed the provisioned traffic parameters. As with statistics, one needs to create a Metering Control Block and associate an MCB to a flow such that the PFE can support metering.
5. NAT/IP/MPLS forwarding—This set of functions allows the PFE driver to capture basic IP forwarding functions and NAT specific parameters.
6. Software Forwarding—Packets belonging to some flows may need to be always handled in software as determined by criteria set by the user. This is accomplished by specifically using the function to tag packets as software-forwarded.
7. IPSEC flows—Packets that need to be encrypted/decrypted need to be processed appropriately to allow the PFE driver to collect IPSEC-specific parameters that are necessary to encrypt/decrypt the packets.
8. Stateful Packet Filter (SPF) flows—The Stateful Packet Filter feature allows applications to allow sessions based on policies configured by the user, and this means that user can take advantage of the PFE hardware to create events based on TCP flags to let software see only packets with specified flags. This requires that software first of all tag them as SPF-aware flows.
9. Driver Initialization—Since the driver can operate in three different modes—pass-thru, flow, and prefix mode, the driver exposes a function to allow a user to initialize the driver appropriately.
10. Receive—A packet received by the PFE must be first passed to PFE driver for handling. The driver will call a function to send packets that need to be handled outside of the driver.
11. Transmit—A packet that needs to be forwarded needs to be sent to the driver for learning termination and forwarding by calling a driver function, and the driver, in turn, will call a function to send the packet out.
12. PFE/IPNOS Forwarding Bandwidth allocation—The processors and the hardware forwarding engine collectively are single resources that are shared among all the virtual routers. This API provides the mechanism to distribute these resources to ensure fairness.
In one specific embodiment of the present invention described in the remainder of this specification in greater detail, the PFE maintains a table of Transform Control Blocks (TCBs), which direct how the egress controller processes outgoing packets. The egress controller uses the 20-bit forwarding index, carried by the DMA descriptor, to select a transform control block from the table before processing packets. Each transform control block entry contains 64-bytes formatted as described in the table below.
TABLE 10
Transform Control Block
WordBitsNameDescription
 031:28PktCmdPacket forwarding command:
0: Discard packet.
1: Forward packet.
2: Return packet to CPU.
3-15: Reserved
27:20Reserved
19:16PktDstForwarding destination for
the packet:
0: Processor Engine
1: Security Engine
2: Line Interface
3: PPPoE Interface
4: Tunnel Interface
6-15: Reserved
15:0PktMTUPacket MTU
 131NAT_IPPerform NAT on IP addresses.
30DropCpuPktIf this bit is set and the Pkt desc is
HW_COH the packet is dropped
29NAT_TCPPerform NAT on TCP/UDP
port addresses.
28ReplaceRMReplace Rate-Marking field
in SF header.
27ReplaceIDReplace IP header ID field with
incremented PktID.
26ValidCRCValidate IP header checksum.
25DecrTTLDecrement the IP or MPLS header
TTL value.
24ReplacePRIReplace Priority field in SF header.
23:16TOS/EXPIP TOS/MPLS EXP replacement
value
15:8TOS/EXPEnables for IP TOS/MPLS EXP
Enablesreplacement. (Set high to replace bit)
 7:4MPLSMPLS Operation Code
Operation0: NOP
1: PUSH
2: POP_PEEK
3: POP_FWD
4: SWAP
5: POP_L2VPN_NULL
6:POP_L2VPN_CTRL
 3PWE3PWE3 special case handling of
EnableL2 packets.
 2PWE3PWE3 control word should be added.
ControlUsed when CW is “optional”.
 1:0Reserved
 231:0StatsOutPtr0Memory pointer to egress statistics
block 0.
 331:0StatsOutPtr1Memory pointer to egress statistics
block 1 (Always assumed enabled)
 431:16HdrOffsetIndicates the number of bytes before
the start of payload when an
application specific header is located.
Used for PPPoE. Also used for
detunneling, indicates the number of
bytes to strip before detunneling.
15:0HdrLenByte length of the transform header.
 531:0HdrPtrMemory pointer to the transform
header data.
 631:0NAT.IPSrcIP source address NAT replacement
value.
 731:0NAT.IPDstIP destination address NAT
replacement value.
 831:16NAT.TCPSrcTCP/UDP source Port NAT
replacement value.
15:0NAT.TCPDstTCP/UDP destination port
NAT replacement value.
 931:0PktIdPtrMemory pointer to packet ID value.
1031:0MeterOutPtr0Memory pointer to egress metering
control block 0.
1131:0MeterOutPtr1Memory pointer to egressmetering
control block
1.
1231:8Reserved
 7:0EgressQosIndexMode and memory pointer to the
egress QOS translation table
1331:0L3 HeaderPtrMemory pointer to the L3
encapsulation header
1431:0L3 HeaderSizeSize of the L3 encapsulation header
1531:16FCBTagThe value of the corresponding FCB
pending tag must be written here to
associate the TCB with the flow.
A value of 0 needs to be written
in prefix mode.
15:0TCPChkAdjTCP Checksum adjustment for
TCP transforms.
To update a Transform Control Block (TCB), host software sends a control packet containing a PFE_EGRESS_WR message with an address parameter that points to the new TCB. Software should issue the TCB update control packet before issuing the packet being forwarded. This ensures that the forwarded packet is processed according to the updated TCB.
There are a couple fields used to maintain packet order and associate the TCB with a specific flow. In flow mode, where several NEW packets for a flow could be sent to the CPU, there is a danger that once the CPU updates the TCB and FCB a packet could be hardware forwarded while the CPU still has packets for that flow. In one embodiment, packet order is maintained by a conflict cache in the DMA engine. Alternatively, packet order may be enforced by the TCB. When the TCB is written the DropCpuPkt bit should be zero, this will allow the CPU to send the NEW packets it has for that flow. However, when the first FWD_HW packet is seen with this bit clear, the forward engine will update the TCB and set this bit. Subsequent packets from the CPU (recognized because they are marked FWD_HW_COH) will be dropped.
There is also a consistency check performed between the FCB and the TCB. On ingress, the SF header SrcChan is replaced with the PendingTag field of the FCB. On egress, the SrcChan is compared against the FCBTag field of the TCB. If the tags mismatch, the packet is dropped. For prefix mode the SrcChan is replaced with zero, and the FCBTag field is initialized to zero.
In its simplest form, the packet header transformation involves the replacement of some number of header bytes of an ingress packet with some number of bytes of replacement header data. Under the control of a Transform Control Block, the PFE egress unit can selectively replace and recompute specific fields in a small set of protocol headers.
The PFE egress unit begins the header transform by stripping the incoming packet's SF header along with the number of bytes indicated by the SF header offset field. At that point, the controller will begin copying bytes from the buffer pointed to by the TCB's HDRPTR field into the egress packet buffer. The PFE will copy the number of new header bytes defined by the TCB's HDRLEN field.
After performing this header replacement, the PFE then goes through the TCB enable bits to determine what other header transformations need to be made. The sections below explain some of these transformations.
The PFE uses the TCB HDRLEN field to update the SF header length field for outgoing packets. By default, the PFE retains the SF header RM (rate marking) and PRI (priority) fields from the incoming packet in the outgoing packet. When the associated TCB's ReplaceQOS field is set, the PFE replaces the incoming RM and PRI fields with the values set in the TCB's header block. The PFE also replaces the RM field for outgoing packets when rate marking is enabled in the TCB. In cases where the hardware detects an exception that requires software processing, the PFE returns packet to the CPU and sets the SF header error code to 0x7.
The PFE egress controller supports independent replacement of the IP source and destination addresses to support IP NAT. It also supports replacement of the IP Type-of-Service (TOS) field. When enabled, the PFE egress controller will decrement the IP Time-To-Live Field and can conditionally replace the IP identification field based on the Transform Control Block's ReplaceID field. For a particular flow with the TCB ReplaceID field enabled, the PFE fetches the ID from the memory location pointed to by the TCB's PktIdPtr field. PFE increments the stored ID value after it replaces a packet's ID field.
For each IP header field transform, the PFE computes and applies an adjustment to the IP header checksum field. With a separate bit in the TCB, host software can request that the PFE validate the ingress IP header checksum field.
If the TCB PktDst field indicates that the packet is destined to the Security Engine, then the PFE egress controller replaces the security engine header Fragment Size field. If the TCB ReplaceID field is also set, the PFE performs packet ID replacement in the security engine header instead of the egress packet IP header.
If the TCB PktDst field indicates that the packet includes a PPPoE header, then the PFE egress unit must update the PPPoE payload length field before transmitting the packet. Software indicates the location of the PPPoE header by setting the TCB HdrOffset field to the number of bytes between the start of the PPPoE Header and the start of the L3 packet payload. The PFE egress unit will then update the last 2 bytes of the 6-byte PPPoE header with the packet's payload length. It computes the PPPoE payload using the following formula:
PPPoE Payload Length=L3 Payload Length+TCB HdrOffset Value−PPPoE header length (6 bytes).
In the event that the hardware detects an exceptional packet that requires software processing, the PFE controllers will return the packet to the CPU with the packet's SF Header Error field set to 0x6 and set the SF SrcChld to an error code. The Switch Fabric Document lists the possible error codes to get placed in the SF SrcChld.
The PFE egress unit independently rate limits ingress and egress packets, if enabled. As part of rate limiting, the PFE meters, marks and drops packets. The PFE performs ingress rate limiting before header transformation and performs egress rate limiting after header transformation. Software controls metering and rate marking using a combination of Metering Control Blocks (MCBs) and fields in the TCB and ingress Statistics Blocks.
The PFE implements both ingress and egress rate metering and marking according to the two-rate three color marker (trTCM) definition in RFC 2698. Per this definition, in color-blind mode the PFE marks the drop precedence color of a packet as Green if it does not exceed the CBS, Yellow if it exceeds the CBS but not the PBS, and Red if it exceeds both CBS and PBS. The packet's color is encoded into the rm field of the LQ header. The PFE increments the C and P buckets by the CIR and PIR values, respectively, in 1 ms intervals.
The PFE egress unit may optionally drop Yellow or Red packets or may color packets for a downstream dropper. The RateInCtl and RateOutCtl fields of the TCB control whether and how to drop packets on ingress and egress rate limiting.
A set of Metering Control Blocks (MCBs) maintained in system memory contain per flow (VR, VI, or ACL) trTCM parameters. Table 11 defines the MCB data structure in accordance with one embodiment of the present invention. Hardware provides three logical metering units: VI-based ingress metering, flow-based ingress metering, and flow-based egress metering. The TCB contains two MCB pointers for flow-based metering. The VI-based MCB pointer is contained in the VI-based stats block and will be discussed in more detail below.
TABLE 11
Metering Control Block
WordBitsNameDescription
 031:0Green_bytesBottom 32 bits of green-metered
(lower)bytes count.
 131:0CtokensNumber of bytes in Ctoken bucket
 231:0PtokensNumber of bytes in Ptoken bucket
 331:0Metered_pktsBottom 32 bits of metered packet count.
(lower)
 431:0Yellow_bytesBottom 32 bits of yellow-metered
(lower)bytes count.
 531:0Red_bytesBottom 32 bits of red-metered
(lower)bytes count.
 631:0Timeslot1ms timeslot value.
 731:0Reserved
 831:0CIRCommitted information rate in
bytes/timeslot.
 931:0PIRPeak information rate in
bytes/timeslot.
1031:0CBSCommitted burst size in bytes.
1131:0PBSPeak burst size in bytes.
1263:32Metered_pktsUpper 32 bits of metered packet count.
(upper)
1363:32Green_bytesUpper 32 bits of green-metered
(upper)byte count.
1463:32Yellow_bytesUpper 32 bits of yellow-metered
(upper)byte count.
1563:32Red_bytesUpper 32 bits of red-metered
(upper)byte count.
Software controls where and how the hardware accesses MCBs by setting up arrangements of MCB pointers. In the present example, the MCB pointer data structure contains a 32-Byte aligned memory pointer along with mode control bits as detailed in the table below. In its simplest form, the pointer field indicates the memory location of a single MCB. In its most complex mode, the pointer indicates the location of an ordered array of up to 8 MCB pointers. When the hardware loads an MCB pointer array, it performs metering and rate marking starting with the first MCB pointer and continuing as directed by the Next Pointer field in the MCB pointer. Software can disable rate marking completely by setting all 4 bytes of the MCB pointer0. The lowest 5 bits should be masked out before using this 4-byte word as the memory pointer.
TABLE 12
MCB Pointer Format
Bit
FieldNameDescription
31:5MemoryThis field contains a memory pointer to an MCB, an
PointerMCB pointer array, or a Rate Marking Translation
Table. The Metering Mode field determines which
mode to use. This pointer must be 32-byte aligned.
 4:3MeteringThis fields determines to what structure the Memory
ModePointer field points:
0: MCB - Color Blind
1: MCB - Color Aware
2: MCB Array
3: Reserved
 2:1Drop PolicyThis field indicates the traffic policy:
0: No dropping
1: Drop on red marking only
2: Drop on yellow or red marking
3: Reserved
 0Next PointerThis field indicates whether the hardware should
continue to the next MCB pointer in an array:
0: Stop after the current pointer
1: Continue to the next MCB pointer in the array
As a special optimization, software embeds the MCB pointer for the VI-based ingress metering in a reserved field of the VI-based ingress stats block. Software must guarantee that this reserved field of the stats block is always initialized to 0 in the case where metering is not enabled.
The VI-based statistics block also contains two MCB pointers for metering traffic bound for software. One pointer is for best effort traffic and the other is for control traffic. Software must initialize these pointers to 0 if metering is not enabled.
When IP/MPLS packets arrive at the ingress, the PFE uses the QOS pointer in the VI-based ingress stats block. This pointer indicates how the hardware translates the incoming TOS/EXP field into the LQ header's PRI and RM fields. If the pointer is NULL then the translation is skipped.
Similarly, as a final step before transmitting an IP/MPLS packet, the hardware takes the updated LQ header PRI and RM fields an reverse translates these back to the packet's TOS/EXP field. Again, if the QOS pointer is NULL then the translation is skipped.
The ingress QOS translation pointer resides in the last 4 bytes of the VI-based ingress stats block. For IP packets, the ingress table consists of 256 entries, indexed by the incoming packet's IP header TOS field. For MPLS packets, the ingress table consists of 8 entries, indexed by the incoming packet's MPLS EXP field. Each entry is 8 bytes wide (4 B mask, 4 B value). The ingress table entry format, in accordance with one embodiment, is described below:
TABLE 13
Ingress QOS Translation Table Entry Format for IP and MPLS
Bit
WordFieldNameDescription
031:25ReservedShould be zero
24:25RM MaskRate Marking Mask. Only bits to be replaced
are high.
22:20PRI MaskPriority Mask. Only bits to be replaced should
be high.
19:0ReservedShould be zero.
131:25ReservedShould be zero
24:23RM ValueNew Rate Marking value
22:20PRI ValueNew Priority value
19:0ReservedShould be zero.
The egress QOS translation pointer resides in word12 of the associated TCB. The egress table consists of 32 entries indexed by the concatenation of the outgoing packet's {RM, PRII} SF header fields (the RM bits reside in the MSB of the table index). Each entry is 8 bytes wide (4 B mask, 4 B value). Exemplary egress table entry formats for IP and MPLS packets are described below:
TABLE 14
Egress QOS Table Entry Format for IP
Bit
WordFieldNameDescription
031:24ReservedShould be zero.
23:16TOS MaskTOS Mask. Only bits to be replaced should
be high.
15:0ReservedShould be zero.
131:24ReservedShould be zero.
23:16TOS ValueNew TOS value
15:0ReservedShould be zero.
TABLE 15
Egress QOS Table Entry Format for MPLS
Bit
WordFieldNameDescription
031:12ReservedShould be zero.
11:9EXP MaskEXP Mask. Only bits to be replaced should
be high.
 8:0ReservedShould be zero.
131:12ReservedShould be zero.
11:9EXP ValueNew EXP value
 8:0ReservedShould be zero.
The PFE hardware maintains packet statistics for all packets in Statistics Block data structures. The PFE updates both statsOutPtr0 and statsOutPtr1 egress packet statistics after header transformation. Along with the TCB stats block pointers for egress statsOutPtr0 and statsOutPtr1 flow statistics, the PFE also maintains per-VI ingress statistics using per-protocol tables indexed by LQID.
According to one embodiment, each statistics block contains three sets of counters, one set for normal packets and bytes, another for dropped packets and bytes and a third for packets with errors. The stats block also contains a field for counting the number of packets sent out as a fragmentation. There is a reserved field at the bottom of the stats block may be used for indicating ingress-VI metering control information. It should be initialized to 0 when the stats block is allocated.
TABLE 16
Ingress LQID Statistics Block
WordBitsNameDescription
 0:163:0Trans_pktsNumber of packets transmitted.
 2:363:0Trans_bytesNumber of bytes transmitted.
 4:563:0Dropped_pktsNumber of packets dropped.
 6:763:0Dropped_bytesNumber of bytes dropped.
 8:963:0Error_pktsNumber of packet with errors.
10:1163:0Error_bytesNumber of bytes with errors.
1231:0MeterSwBEPtrPointer to meter block for software bound
best effort traffic
1331:0MeterSwCtlPtrPointer to meter block for software bound
control traffic
1431:0LQIDPointer to Ingress VI rate-limiting
control block.
Metering PtrSoftware should initialize this field to 0
when allocating the stats block.
1531:8FlowCapIndexIndex into table of Flow cap structures.
15:10Flag bitsMode dependent
 9:8Mode0 - Normal, 1 - L2 VPN, 2:3 - Reserved.
 7:0IngressQosIndIndex into an array to TOS to RM/PRI
xtranslation tables. Software should
initialize this field to 0 (disabled) when
allocating the stats block.
TABLE 17
Egress Flow Statistics Bytes
WordBitsNameDescription
 0:163:0Trans_pktsNumber of packets transmitted.
 2:363:0Trans_bytesNumber of bytes transmitted.
 4:563:0Dropped_pktsNumber of packets dropped.
 6:763:0Dropped_bytesNumber of bytes dropped.
 8:963:0Error_pktsNumber of packets with errors.
10:1163:0Error_bytesNumber of bytes with errors.
12:1363:0Frag_pktsNumber of fragment packets transmitted
14:1563:0Frag_bytesNumber of fragment bytes transmitted..
The stats block pointer is bimodal in that it can points to single stats block or in the future to an array of stats block pointers. In array mode, the host software can associate up to 8 stats blocks with each of the TCB stats pointer fields. The PFE will traverse the table of pointers starting at the first entry and continuing as directed by the Next Pointer field. Software disables a table entry by setting all 4-bytes of the stats block pointer to 0. StatsOutPtr1 of the TCB is always assumed to be enabled to save instructions. If the either StatsOutPtr0 or StatsOutPtr is setup to point to something other than a stats block, then there can be dangerous memory corruption of that block and eventually other memory blocks.
TABLE 18
Statistics Block Pointer Format
Bit
FieldNameDescription
31:5PointerPFE memory address to the associated stats block. The
stats block is assumed to be 64-byte aligned.
 4:2Reserved
 1PointerDefines whether the pointer field points to a stats block
Modeor to an array of stats block pointers:
0: Stats Block
1: Stats Block Pointer Array
 0NextThis field indicates whether the hardware should
Pointercontinue to the next stats block pointer in array:
0: Stop after the current pointer.
1: Continue to the next stats block pointer.
In both prefix-mode and flow-mode, the PFE hardware maintains per-VI ingress statistics in a set of tables of stats blocks indexed by the packets LQID and LQ protocol. The hardware selects a table using the packet's LQ protocol field and then selects the table entry using the LQID as an index. Per-VI ingress statistics are maintained for every packet.
The PFE hardware supports Network Address Translation for IP addresses and for TCP/UDP port addresses. When software enables IP or TCP/UDP NAT, it must also provide the associated replacement addresses and checksum adjustments in the corresponding TCB fields. When the hardware detects one of the NAT enable bits is set to ‘1’, it will always replace both the source and destination addresses. If software intends to translate only the source address, it must still supply the correct destination address in the TCB replacement field. Similarly, the software must also supply the correct source address in the TCB replacement field when it is just replacing the destination address.
The checksum adjustment should be computed as follows:
ChkAdj=aNew+˜aOld+bNew+˜bOld+cNew+˜cOld
where the + is a one's complement addition (meaning any carry bits are looped back and added to the LSB) and ˜ is the inversion of all.
In one embodiment, on the ingress side, alllayer2 packets are distinguished bybit5 of the SF header protocol field being set. The PFE micro-code checks this bit and jumps to separate L2 header loading logic when it is set. Separate code-points for each L2/L3 protocol are defined in the SF spec, jumping to the proper parsing logic is done by using the entire SF protocol (including the L2 bit) field as an index into a jump table and jumping to that instruction which causes a jump to the proper code segment. One of the functions of the L2 parsing logic is to determine the size of the variable length L2 headers and increment the SF offset field by that amount (in some cases, such asde-tunneling 2ndpass) so that the PFE egress will strip off that part of the header. In addition, the SF protocol field may be changed (also 2ndpass de-tunneling) to another protocol type depending what the underlying packet type is. This is also determined by the parsing logic and causes the proper egress code path to be taken.
Tunneling is the trivial case for L2 packet transformation. On the ingress side, a PPP packet arrives (LAC case), is parsed to get the protocol field for the hash, and the flow hash performed to determine the flow index. No SF header offset or protocol modification is done in this case. The actual tunneling is performed via the TCB on the egress side.
On the egress side, a new header is appended to the packet via normal TCB processing. In this case, the header would include IP/UDP/L2TP headers. Then all IP/MPLS specific transform logic is skipped and statistics, metering, etc is performed. The only new processing on the egress side is to update the ID field of the newly added IP header, and re-compute the IP checksum. To support this, a new PktDst code-point “Tunnel Interface” has been added. When the micro-code detects this code-point, the IP header (assumed to be just after the SF header) ID field is modified in a similar fashion as for “Security Engine” destined packets. The PktIdPtr field in the TCB is used to point to the current packet ID, the ID is read from memory, used to modify the IP header, incremented, and written back to memory. In this way, all that software needs to do to set-up for a tunnel is to set the TCB up with the properly formatted header block, ID header pointer, initialized ID value, and set the PktDst field to Tunnel.
For the LNS case, an IP packet is received on the ingress side and goes through normal IP header parsing logic and egress IP processing. According to one embodiment, the only difference is that the added TCB header must contain IP/UDP/L2TP/PPP in its contents. Everything else is as described above for the LAC case.
The De-Tunneling case is much tougher and involves two pass processing as well as two stage flow learning. In this case the incoming packet consists of IP-UDP-L2TP-PPP-IP-XXX-payload. The first pass is just like any normal IP packet, on the ingress the IP header is parsed and the flow hash is performed to determine a flow index. On the egress side normal IP TCB processing will be performed. Software must set-up the new header block with a new SF header such that the packet comes back (via the SF destination fields) to the ingress side of the PFE again for the second pass. In addition this new SF header must contain one of the newly defined L2 protocol code-points L2TP_LAC (41 including L2 bit), or L2TP_LNS (42 including L2 bit), and the SF offset field should be set with the proper offset to cause the 2ndpass processing to look at the L2TP header.
According to the present example, on the second pass, the SF offset field now points to the L2TP-PPP-IP-XXX-payload part of the packet. Depending on the L2 protocol code-point the L2 parsing logic will go to different depths into the packet to gather the hash words for the flow hash. In the L2TP13LAC case only the L2TP header is parsed. In the L2TP_LNS case, the parsing goes into the encapsulated IP and even TCP/UDP headers, if present. This parsing again tells the egress logic how many bytes to adjust the SF offset field and which protocol to change the SF protocol field. For the LAC case, the protocol field will be changed to PPP and the offset field adjusted to point at the PPP header. For LNS it is changed to IP and the offset adjusted to point at the IP header. Changing of the protocol and offset fields in this manner causes the egress side to process what is left of the packet in the proper manner. The LAC case results in a PPP packet being sent to the egress logic, in this case all IP/MPLS specific logic is skipped and only stats/metering micro-code is executed. In the LNS case, an IP packet is presented to the egress and processed the same way as any other IP packet.
Tunneling packets via GRE is performed in exactly the same manner as for L2TP. IP/MPLS or some other packet type is received on the ingress side and processed normally by the ingress micro-code. On the egress side normal TCB header processing adds a SF/IP/GRE header to the packet. The PktDst “Tunnel” is detected which tells the egress micro-code to modify the outer IP header of the outgoing packet (in the same manner as described for L2TP) and the tunneling is complete.
De-Tunneling of GRE packets is done in the same two pass manner as L2TP with only the 2ndpass parsing logic being different. On the ingress side, an IP packet is received (with protocol=47) and processed normally. On the egress side, the TCB adds a new SF header containing the L2 protocol type GRE, and a SF Dst field which causes the packet to be switched back to the ingress for a 2ndpass. Again, this SF header should also contain an offset field that points 2ndpass processing to the embedded GRE header.
On the 2ndpass, the GRE parsing logic is executed (via the SF protocol jump table) to gather the required fields for the flow hash and to determine the size of the L2 header and what underlying protocol is being tunneled. Which fields are used in the flow hash is determined by the parsing logic depending on what is being tunneled. The SF offset field is incremented to point at the tunneled packet; and for IP or MPLS the SF protocol field is changed to those corresponding code-points.
On the 2ndpass egress side, the underlying tunneled packet is processed depending on the SF protocol field. If an IP or MPLS packet was tunneled, then they are processed as any IP or MPLS packet would. If some other protocol was tunneled, then the protocol field was not changed by the 2ndpass ingress micro-code and the code-point still is L2 GRE. This packet is processed as any L2 packet, skipping all IP/MPLS specific transforms and jumping straight to stats/metering. In this case, the underlying tunneled packet is just forwarded as is, without any special processing.
PWE3 tunneling is a special case, which is done on an LQ basis. In this case, the ingress packet will be received with some L2 protocol (Ethernet, VLAN, PPP, AAL5, Frame Relay) but will not be processed as such, instead a per LQ enable is provided in the statistics block which will tell the micro-code that special handling is required. According to one embodiment, this feature is enabled when the 2 bit mode field in the stats block is set to 1 (L2 VPN mode). When this is detected by the ingress micro-code, it causes the flow hash to be computed using only the LQID.
In one embodiment, on the egress side, 2 bits are provided in the TCB, one for PWE3 enable, and one for control word tag enable. The egress micro-code will check the PWE3 enable bit for all L2 packets and if it is enabled will perform special PWE3 handling. This includes stripping of any required headers from the L2 packet and tagging on of the control word between the SF/Tunnel/VC header added by the TCB and the remainder of the L2 packet. When the egress micro-code detects an L2 packet with the PWE3 enable bit set in the TCB, it looks at the SF protocol field to determine a further course of action. For AAL5 and Frame Relay, the control word is required and some of the L2 packet must be discarded. In these cases, the micro-code will load the proper amount of header (2 byte frame header for frame relay, and 16 byte Maker header for AAL5) to construct the control word. After creating the control word, the header is discarded by subtracting the correct amount from the packet length. The control word is then added to the packet at the proper location on transmit by putting it in the new L3 header. For all other protocols, the control word is optional, so the control word enable bit is checked and if set a “dummy” control word will be added in the same manner as before.
De-Tunneling of PWE3 packets is performed on the egress side with the addition of a couple of new MPLS operation code-points (POP_L2VPN_NULL and POP_L2VPN_CTRL). On the ingress side, an MPLS packet is received and hashed normally to determine the flow index. In one embodiment, the MPLS tag is actually a “Martini” VC header and is popped in a special way by the egress micro-code. When one of these two MPLS operations is encountered, the micro-code will look at the new SF header (added via the TCB) protocol field to determine what to do next. If the protocol is AAL5 or Frame Relay, then a control word is present and is pulled off and used to modify the L2 header template following the SF header in the TCB header block. Any other protocol field, such as VLAN, Ethernet, or PPP, for example, will cause the MPLS operation to be looked at again. If the operation is POP-L2VPN_NULL, then de-tunneling is complete, if it is POP_L2VPN_CTRL, then the “dummy” optional control word is pulled off and discarded before de-tunneling is complete.
The embodiments of the invention described above are provided for completeness and sake of illustration. Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations of the invention. It is intended that this invention be limited only by the claims, and the full scope of equivalents thereof.

Claims (16)

The invention claimed is:
1. A method comprising:
receiving a packet by a flow manager associated with a network interface connection of an Internet Protocol Service Generator (IPSG), the IPSG including
a plurality of virtual routing engines (VREs) coupled to the network interface connection via a service generator fabric, each VRE of the plurality of VREs providing one or more network layer and transport layer functions corresponding to the Open Systems Interconnection (OSI) model, including one or more of routing services, network address translation (NAT) and Multi-Protocol Label Switching (MPLS), and
a plurality of virtual service engines (VSEs) coupled to the network interface connection and the plurality of VREs via the service generator fabric, each VSE of the plurality of VSEs tailored to provide one or more specific application layer, presentation layer, session layer and transport layer functions corresponding to the OSI model, including one or more of encryption, packet filtering and anti-virus scanning;
the flow manager selecting a VRE of the plurality of VREs to which to direct the packet based on a steering table, which contains a mapping of Virtual Local Area Networks (VLANs) to the plurality of VREs;
the flow manager directing the packet to the selected VRE by tagging the packet with an internal control header and transferring the packet across the service generator fabric;
responsive to receiving the packet at the selected VRE, the selected VRE determining whether the packet is to be processed in hardware or in software by performing packet classification and a flow cache lookup;
if the flow cache lookup indicates the packet is a first packet of a new flow and is therefore to be processed in software, then the VRE (i) causing a plurality of functions at a plurality of OSI model layers to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs and (ii) performing flow learning by tracking the plurality of functions applied and storing information regarding the plurality of functions in a transform control block (TCB) record corresponding to the new flow;
if the flow cache lookup indicates the packet is associated with a previously learned flow and is therefore to be processed in hardware, then the VRE causing a plurality of functions identified in a previously created TCB record to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs; and
a VRE of the one or more VREs routing the packet through the network interface.
2. The method ofclaim 1, wherein the plurality of VSEs include at least one advanced security engine configured to provide security functionality for one or more security protocols.
3. The method ofclaim 1, wherein the flow cache lookup is based upon various fields of the packet including one or more of Internet Protocol (IP) source, IP destination, Universal Datagram Protocol (UDP)/Transmission Control Protocol (TCP) source port number, UDP/TCP destination port number, IP protocol field, type of service (TOS) field, Internet Protocol Security (IPSec) header and Security Parameters Index (SPI) field information.
4. The method ofclaim 1, further comprising maintaining a set of metering control blocks for use in connection with enforcing provisioned traffic parameters on traffic flows.
5. A machine-readable medium with instructions stored thereon, the instructions when executed by an Internet Protocol Service Generator (IPSG) operable to cause application of functions to network data packets received by the IPSG by:
receiving a packet by a flow manager associated with a network interface connection of the IPSG, the IPSG including
a plurality of virtual routing engines (VREs) coupled to the network interface connection via a service generator fabric, each VRE of the plurality of VREs providing one or more network layer and transport layer functions corresponding to the Open Systems Interconnection (OSI) model, including one or more of routing services, network address translation (NAT) and Multi-Protocol Label Switching (MPLS), and
a plurality of virtual service engines (VSEs) coupled to the network interface connection and the plurality of VREs via the service generator fabric, each VSE of the plurality of VSEs tailored to provide one or more specific application layer, presentation layer, session layer and transport layer functions corresponding to the OSI model, including one or more of encryption, packet filtering and anti-virus scanning;
the flow manager selecting a VRE of the plurality of VREs to which to direct the packet based on a steering table, which contains a mapping of Virtual Local Area Networks (VLANs) to the plurality of VREs;
the flow manager directing the packet to the selected VRE by tagging the packet with an internal control header and transferring the packet across the service generator fabric;
responsive to receiving the packet at the selected VRE, the selected VRE determining whether the packet is to be processed in hardware or in software by performing packet classification and a flow cache lookup;
if the flow cache lookup indicates the packet is a first packet of a new flow and is therefore to be processed in software, then the VRE (i) causing a plurality of functions at a plurality of OSI model layers to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs and (ii) performing flow learning by tracking the plurality of functions applied and storing information regarding the plurality of functions in a transform control block (TCB) record corresponding to the new flow;
if the flow cache lookup indicates the packet is associated with a previously learned flow and is therefore to be processed in hardware, then the VRE causing a plurality of functions identified in a previously created TCB record to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs; and
a VRE of the one or more VREs routing the packet through the network interface.
6. The machine-readable medium ofclaim 5, wherein the plurality of VSEs include at least one advanced security engine configured to provide security functionality for one or more security protocols.
7. The machine-readable medium ofclaim 5, wherein the flow cache lookup is based upon various fields of the packet including one or more of Internet Protocol (IP) source, IP destination, Universal Datagram Protocol (UDP)/Transmission Control Protocol (TCP) source port number, UDP/TCP destination port number, IP protocol field, type of service (TOS) field, Internet Protocol Security (IPSec) header and Security Parameters Index (SPI) field information.
8. The machine-readable medium ofclaim 5, wherein the instructions further cause a set of metering control blocks to be maintained for use in connection with enforcing provisioned traffic parameters on traffic flows.
9. An Internet Protocol Service Generator (IPSG) system comprising:
a flow manager means, associated with a network interface connection of the IPSG, for receiving packets;
a plurality of virtual routing engine (VRE) means coupled to the network interface connection via a service generator fabric, each VRE means of the plurality of VRE means for providing one or more network layer and transport layer functions corresponding to the Open Systems Interconnection (OSI) model, including one or more of routing services, network address translation (NAT) and Multi-Protocol Label Switching (MPLS),
a plurality of virtual service engine (VSE) means coupled to the network interface connection and the plurality of VRE means via the service generator fabric, each VSE means of the plurality of VSE means for providing one or more specific tailored application layer, presentation layer, session layer and transport layer functions corresponding to the OSI model, including one or more of encryption, packet filtering and anti-virus scanning;
wherein the flow manager means is further for
selecting a VRE means of the plurality of VRE means to which to direct the received packets based on a steering table, which contains a mapping of Virtual Local Area Networks (VLANs) to the plurality of VRE means; and
directing the received packets to the selected VRE means by tagging the packets with internal control headers and transferring the received packets across the service generator fabric; and
wherein the VRE means are further for
determining whether the received packets are to be processed in hardware or in software by performing packet classification and a flow cache lookup;
causing a plurality of functions at a plurality of OSI model layers to be applied to the received packets by internally routing the received packets to one or more of the plurality of VSE means and one or more of the plurality of VRE mean and (ii) performing flow learning by tracking the plurality of functions applied and storing information regarding the plurality of functions in a transform control block (TCB) record corresponding to a new flow if the flow cache lookup indicates the received packets are a first packet of the new flow and are therefore to be processed in software;
causing a plurality of functions identified in a previously created TCB record to be applied to the received packets by internally routing the received packets to one or more of the plurality of VSE means and one or more of the plurality of VRE means, if the flow cache lookup indicates the received packets are associated with one of a plurality of previously learned flows and are therefore to be processed in hardware; and
routing the received packets through the network interface.
10. The IPSG system ofclaim 9, wherein the plurality of VSEs include at least one advanced security engine configured to provide security functionality for one or more security protocols.
11. The IPSG system ofclaim 9, wherein the flow cache lookup is based upon various fields of the packet including one or more of Internet Protocol (IP) source, IP destination, Universal Datagram Protocol (UDP)/Transmission Control Protocol (TCP) source port number, UDP/TCP destination port number, IP protocol field, type of service (TOS) field, Internet Protocol Security (IPSec) header and Security Parameters Index (SPI) field information.
12. The IPSG system ofclaim 9, wherein the flow manager means is further for maintaining a set of metering control blocks for use in connection with enforcing provisioned traffic parameters on traffic flows.
13. A method comprising:
a step for receiving a packet by a flow manager associated with a network interface connection of an Internet Protocol Service Generator (IPSG), the IPSG including
a plurality of virtual routing engines (VREs) coupled to the network interface connection via a service generator fabric, each VRE of the plurality of VREs providing one or more network layer and transport layer functions corresponding to the Open Systems Interconnection (OSI) model, including one or more of routing services, network address translation (NAT) and Multi-Protocol Label Switching (MPLS), and
a plurality of virtual service engines (VSEs) coupled to the network interface connection and the plurality of VREs via the service generator fabric, each VSE of the plurality of VSEs tailored to provide one or more specific application layer, presentation layer, session layer and transport layer functions corresponding to the OSI model, including one or more of encryption, packet filtering and anti-virus scanning;
a step for selecting, by the flow manager, a VRE of the plurality of VREs to which to direct the packet based on a steering table, which contains a mapping of Virtual Local Area Networks (VLANs) to the plurality of VREs;
a step for directing, by the flow manager, the packet to the selected VRE by tagging the packet with an internal control header and transferring the packet across the service generator fabric;
a step, responsive to receiving the packet at the selected VRE, for determining, by the selected VRE, whether the packet is to be processed in hardware or in software by performing packet classification and a flow cache lookup;
if the flow cache lookup indicates the packet is a first packet of a new flow and is therefore to be processed in software, then the VRE (i) causing a plurality of functions at a plurality of OSI model layers to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs and (ii) performing flow learning by tracking the plurality of functions applied and storing information regarding the plurality of functions in a transform control block (TCB) record corresponding to the new flow;
if the flow cache lookup indicates the packet is associated with a previously learned flow and is therefore to be processed in hardware, then the VRE causing a plurality of functions identified in a previously created TCB record to be applied to the packet by internally routing the packet to one or more of the plurality of VSEs and one or more of the plurality of VREs; and
a step for routing, by a VRE of the one or more VREs, the packet through the network interface.
14. The method ofclaim 13, wherein the plurality of VSEs include at least one advanced security engine configured to provide security functionality for one or more security protocols.
15. The method ofclaim 13, wherein the flow cache lookup is based upon various fields of the packet including one or more of Internet Protocol (IP) source, IP destination, Universal Datagram Protocol (UDP)/Transmission Control Protocol (TCP) source port number, UDP/TCP destination port number, IP protocol field, type of service (TOS) field, Internet Protocol Security (IPSec) header and Security Parameters Index (SPI) field information.
16. The method ofclaim 13, further comprising a step for maintaining a set of metering control blocks for use in connection with enforcing provisioned traffic parameters on traffic flows.
US10/163,0712002-06-042002-06-04System and method for controlling routing in a virtual router systemExpired - LifetimeUS7340535B1 (en)

Priority Applications (3)

Application NumberPriority DateFiling DateTitle
US10/163,071US7340535B1 (en)2002-06-042002-06-04System and method for controlling routing in a virtual router system
PCT/US2003/017674WO2003103237A1 (en)2002-06-042003-06-04System and method for controlling routing in a virtual router system
AU2003238894AAU2003238894A1 (en)2002-06-042003-06-04System and method for controlling routing in a virtual router system

Applications Claiming Priority (1)

Application NumberPriority DateFiling DateTitle
US10/163,071US7340535B1 (en)2002-06-042002-06-04System and method for controlling routing in a virtual router system

Publications (1)

Publication NumberPublication Date
US7340535B1true US7340535B1 (en)2008-03-04

Family

ID=29709913

Family Applications (1)

Application NumberTitlePriority DateFiling Date
US10/163,071Expired - LifetimeUS7340535B1 (en)2002-06-042002-06-04System and method for controlling routing in a virtual router system

Country Status (3)

CountryLink
US (1)US7340535B1 (en)
AU (1)AU2003238894A1 (en)
WO (1)WO2003103237A1 (en)

Cited By (76)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US20040165581A1 (en)*2002-11-202004-08-26Minoru OogushiVirtual access router
US20050083955A1 (en)*2003-09-292005-04-21Guichard James N.Methods and apparatus to support routing of information
US20050220098A1 (en)*2004-03-312005-10-06Naoki OguchiHierarchical packet processing system and method, relay device and server
US20060265519A1 (en)*2001-06-282006-11-23Fortinet, Inc.Identifying nodes in a ring network
US20060288418A1 (en)*2005-06-152006-12-21Tzu-Jian YangComputer-implemented method with real-time response mechanism for detecting viruses in data transfer on a stream basis
US20070064704A1 (en)*2002-06-042007-03-22Fortinet, Inc.Methods and systems for a distributed provider edge
US20070083528A1 (en)*2000-09-132007-04-12Fortinet, Inc.Switch management system and method
US20070104119A1 (en)*2000-09-132007-05-10Fortinet, Inc.System and method for managing and provisioning virtual routers
US20070109968A1 (en)*2002-06-042007-05-17Fortinet, Inc.Hierarchical metering in a virtual router-based network switch
US20070115979A1 (en)*2004-11-182007-05-24Fortinet, Inc.Method and apparatus for managing subscriber profiles
US20070121579A1 (en)*2000-09-132007-05-31Fortinet, Inc.Packet routing system and method
US20070127382A1 (en)*2002-06-042007-06-07Fortinet, Inc.Routing traffic through a virtual router-based network switch
US20070147368A1 (en)*2002-06-042007-06-28Fortinet, Inc.Network packet steering via configurable association of processing resources and netmods or line interface ports
US20070274312A1 (en)*2004-02-132007-11-29Patrik SalmelaAddressing Method and Method and Apparatus for Establishing Host Identity Protocol (Hip) Connections Between Legacy and Hip Nodes
US20070291752A1 (en)*2006-06-162007-12-20Cisco Technology, Inc.Communicating packets between forwarding contexts using virtual interfaces
US20070291755A1 (en)*2002-11-182007-12-20Fortinet, Inc.Hardware-accelerated packet multicasting in a virtual routing system
US20080008099A1 (en)*2004-03-302008-01-10Parker David KPacket processing system architecture and method
US20080016389A1 (en)*2002-08-292008-01-17Fortinet, Inc.Fault tolerant routing in a network routing system based on a passive replication approach
US20080259934A1 (en)*2000-09-132008-10-23Fortinet, Inc.Distributed virtual system to support managed, network-based services
US20080259936A1 (en)*2002-06-042008-10-23Fortinet, Inc.Service processing switch
US7499419B2 (en)2004-09-242009-03-03Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US20090092136A1 (en)*2007-10-092009-04-09Broadcom CorporationSystem and method for packet classification, modification and forwarding
US20090147683A1 (en)*2007-12-102009-06-11Shakeel MustafaFlow based data packet processing
US7558195B1 (en)*2002-04-162009-07-07Foundry Networks, Inc.System and method for providing network route redundancy across layer 2 devices
US20090201959A1 (en)*2008-02-072009-08-13Board Of Regents, The University Of Texas SystemWavelength and Intensity Monitoring of Optical Cavity
US7606229B1 (en)*2002-11-082009-10-20Cisco Technology, Inc.Generic bridge packet tunneling
US7613209B1 (en)*2004-03-302009-11-03Extreme Networks, Inc.System and method for egress packet marking
US20090274153A1 (en)*2002-10-012009-11-05Andrew Tai-Chin KuoSystem and method for implementation of layer 2 redundancy protocols across multiple networks
WO2009151848A1 (en)*2008-06-122009-12-17Optimum Communications Services, Inc.Packet-layer transparent packet-switching network
US20100027545A1 (en)*2008-07-312010-02-04Broadcom CorporationData path acceleration of a network stack
US7664823B1 (en)*2003-09-242010-02-16Cisco Technology, Inc.Partitioned packet processing in a multiprocessor environment
US7675915B2 (en)2004-03-302010-03-09Extreme Networks, Inc.Packet processing system architecture and method
US20100124191A1 (en)*2008-11-172010-05-20Sierra Wireless, IncMethod and apparatus for facilitating push communication across a network boundary
US7761595B1 (en)*2006-01-252010-07-20Sprint Communications Company L.P.Dynamic server addition using virtual routing
US20100205260A1 (en)*2009-02-122010-08-12Sierra Wireless, Inc.Method and system for aggregating communications
US7808904B2 (en)2004-11-182010-10-05Fortinet, Inc.Method and apparatus for managing subscriber profiles
GB2473990A (en)*2008-06-122011-03-30Optimum Comm Services IncPacket layer transparent packet switching network
US8161270B1 (en)2004-03-302012-04-17Extreme Networks, Inc.Packet data modification processor
US20120254397A1 (en)*2011-03-302012-10-04Fujitsu Network Communications, Inc.Method and System for Frame Discard on Switchover of Traffic Manager Resources
US8441961B1 (en)2012-12-242013-05-14Sideband Networks, Inc.Metadata-driven switch network control
US8605732B2 (en)2011-02-152013-12-10Extreme Networks, Inc.Method of providing virtual router functionality
US8650390B2 (en)2000-09-132014-02-11Fortinet, Inc.Tunnel interface for securing traffic over a network
US8654630B2 (en)2010-03-192014-02-18Brocade Communications Systems, Inc.Techniques for link redundancy in layer 2 networks
US8724626B1 (en)*2013-10-072014-05-13tw telecom holdings inc.Redirecting network traffic based on content
US8812730B2 (en)2008-11-172014-08-19Sierra Wireless, Inc.Method and apparatus for network port and network address translation
US20140250239A1 (en)*2013-03-042014-09-04Dell Products, LpSystem and Method for Routing Data to Devices within an Information Handling System
US20140280717A1 (en)*2013-03-132014-09-18Cisco Technology, Inc.Framework for Dynamically Programmed Network Packet Processing
US20140359094A1 (en)*2007-12-142014-12-04Nant Holdings Ip, LlcHybrid Transport - Application Network Fabric Apparatus
US9037724B2 (en)2011-02-082015-05-19Sierra Wireless, Inc.Method and system for forwarding data between network devices
US9253028B2 (en)2013-12-132016-02-02International Business Machines CorporationSoftware-defined networking tunneling extensions
US9385912B1 (en)*2010-09-172016-07-05Amazon Technologies, Inc.Framework for stateless packet tunneling
US20160212047A1 (en)*2013-08-292016-07-21Kt CorporationPacket output controlling method and network device using same
US9509638B2 (en)2003-08-272016-11-29Fortinet, Inc.Heterogeneous media packet bridging
US9800514B1 (en)2016-12-152017-10-24Red Hat, Inc.Prioritizing data packets in a network
US10027584B2 (en)*2011-08-172018-07-17Nicira, Inc.Distributed logical L3 routing
US10212076B1 (en)2012-12-272019-02-19Sitting Man, LlcRouting methods, systems, and computer program products for mapping a node-scope specific identifier
US10367737B1 (en)2012-12-272019-07-30Sitting Man, LlcRouting methods, systems, and computer program products
US10374938B1 (en)2012-12-272019-08-06Sitting Man, LlcRouting methods, systems, and computer program products
US10397100B1 (en)2012-12-272019-08-27Sitting Man, LlcRouting methods, systems, and computer program products using a region scoped outside-scope identifier
US10397101B1 (en)2012-12-272019-08-27Sitting Man, LlcRouting methods, systems, and computer program products for mapping identifiers
US10404582B1 (en)2012-12-272019-09-03Sitting Man, LlcRouting methods, systems, and computer program products using an outside-scope indentifier
US10404583B1 (en)2012-12-272019-09-03Sitting Man, LlcRouting methods, systems, and computer program products using multiple outside-scope identifiers
US10411997B1 (en)2012-12-272019-09-10Sitting Man, LlcRouting methods, systems, and computer program products for using a region scoped node identifier
US10411998B1 (en)2012-12-272019-09-10Sitting Man, LlcNode scope-specific outside-scope identifier-equipped routing methods, systems, and computer program products
US10419335B1 (en)2012-12-272019-09-17Sitting Man, LlcRegion scope-specific outside-scope indentifier-equipped routing methods, systems, and computer program products
US10419334B1 (en)2012-12-272019-09-17Sitting Man, LlcInternet protocol routing methods, systems, and computer program products
US10447575B1 (en)2012-12-272019-10-15Sitting Man, LlcRouting methods, systems, and computer program products
US10476787B1 (en)2012-12-272019-11-12Sitting Man, LlcRouting methods, systems, and computer program products
US10587505B1 (en)2012-12-272020-03-10Sitting Man, LlcRouting methods, systems, and computer program products
US10809080B2 (en)2020-03-232020-10-20Alipay Labs (singapore) Pte. Ltd.System and method for determining routing by learned selective optimization
US10977067B2 (en)2011-11-152021-04-13Nicira, Inc.Control plane interface for logical middlebox services
US11490432B1 (en)2021-05-282022-11-01T-Mobile Usa, Inc.Unified query tool for network function virtualization architecture
US20220368601A1 (en)*2021-05-122022-11-17L3Harris Technologies, Inc.Modeling multiple hardware routers in custom hardware
US11509704B1 (en)2021-05-282022-11-22T-Mobile Usa. Inc.Product validation based on simulated enhanced calling or messaging communications services in telecommunications network
US11546243B1 (en)2021-05-282023-01-03T-Mobile Usa, Inc.Unified interface and tracing tool for network function virtualization architecture
US20230095149A1 (en)*2021-09-282023-03-30Fortinet, Inc.Non-interfering access layer end-to-end encryption for iot devices over a data communication network

Families Citing this family (42)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US7444398B1 (en)2000-09-132008-10-28Fortinet, Inc.System and method for delivering security services
US7340535B1 (en)2002-06-042008-03-04Fortinet, Inc.System and method for controlling routing in a virtual router system
US8331234B1 (en)2004-09-082012-12-11Q1 Labs Inc.Network data flow collection and processing
US7675854B2 (en)2006-02-212010-03-09A10 Networks, Inc.System and method for an adaptive TCP SYN cookie with time validation
US8584199B1 (en)2006-10-172013-11-12A10 Networks, Inc.System and method to apply a packet routing policy to an application session
US8312507B2 (en)2006-10-172012-11-13A10 Networks, Inc.System and method to apply network traffic policy to an application session
US7881324B2 (en)*2009-03-252011-02-01International Business Machines CorporationSteering data communications packets for transparent bump-in-the-wire processing among multiple data processing applications
US8018875B2 (en)2009-05-182011-09-13International Business Machines CorporationSource-based steering data communications packets for transparent, bump-in-the-wire processing among multiple service applications
US8170038B2 (en)2009-05-272012-05-01International Business Machines CorporationTwo-layer switch apparatus to avoid first layer inter-switch link data traffic in steering packets through bump-in-the-wire service applications
US8289977B2 (en)2009-06-102012-10-16International Business Machines CorporationTwo-layer switch apparatus avoiding first layer inter-switch traffic in steering packets through the apparatus
US9960967B2 (en)2009-10-212018-05-01A10 Networks, Inc.Determining an application delivery server based on geo-location information
US9215275B2 (en)2010-09-302015-12-15A10 Networks, Inc.System and method to balance servers based on server load status
US9609052B2 (en)2010-12-022017-03-28A10 Networks, Inc.Distributing application traffic to servers based on dynamic service response time
US8897154B2 (en)2011-10-242014-11-25A10 Networks, Inc.Combining stateless and stateful server load balancing
US9386088B2 (en)2011-11-292016-07-05A10 Networks, Inc.Accelerating service processing using fast path TCP
US9094364B2 (en)2011-12-232015-07-28A10 Networks, Inc.Methods to manage services over a service gateway
US10044582B2 (en)2012-01-282018-08-07A10 Networks, Inc.Generating secure name records
US8782221B2 (en)2012-07-052014-07-15A10 Networks, Inc.Method to allocate buffer for TCP proxy session based on dynamic network conditions
US9106561B2 (en)*2012-12-062015-08-11A10 Networks, Inc.Configuration of a virtual service network
US9843484B2 (en)2012-09-252017-12-12A10 Networks, Inc.Graceful scaling in software driven networks
US10021174B2 (en)2012-09-252018-07-10A10 Networks, Inc.Distributing service sessions
KR101692751B1 (en)2012-09-252017-01-04에이10 네트워크스, 인코포레이티드Load distribution in data networks
US10002141B2 (en)2012-09-252018-06-19A10 Networks, Inc.Distributed database in software driven networks
US9338225B2 (en)2012-12-062016-05-10A10 Networks, Inc.Forwarding policies on a virtual service network
US9531846B2 (en)2013-01-232016-12-27A10 Networks, Inc.Reducing buffer usage for TCP proxy session based on delayed acknowledgement
US9900252B2 (en)2013-03-082018-02-20A10 Networks, Inc.Application delivery controller and global server load balancer
WO2014144837A1 (en)2013-03-152014-09-18A10 Networks, Inc.Processing data packets using a policy based network path
US10027761B2 (en)2013-05-032018-07-17A10 Networks, Inc.Facilitating a secure 3 party network session by a network device
US10038693B2 (en)2013-05-032018-07-31A10 Networks, Inc.Facilitating secure network traffic by an application delivery controller
US10230770B2 (en)2013-12-022019-03-12A10 Networks, Inc.Network proxy layer for policy-based application proxies
US10020979B1 (en)2014-03-252018-07-10A10 Networks, Inc.Allocating resources in multi-core computing environments
US9942152B2 (en)2014-03-252018-04-10A10 Networks, Inc.Forwarding data packets using a service-based forwarding policy
US9942162B2 (en)2014-03-312018-04-10A10 Networks, Inc.Active application response delay time
US9806943B2 (en)2014-04-242017-10-31A10 Networks, Inc.Enabling planned upgrade/downgrade of network devices without impacting network sessions
US9906422B2 (en)2014-05-162018-02-27A10 Networks, Inc.Distributed system to determine a server's health
US10129122B2 (en)2014-06-032018-11-13A10 Networks, Inc.User defined objects for network devices
US9986061B2 (en)2014-06-032018-05-29A10 Networks, Inc.Programming a data network device using user defined scripts
US9992229B2 (en)2014-06-032018-06-05A10 Networks, Inc.Programming a data network device using user defined scripts with licenses
US10581976B2 (en)2015-08-122020-03-03A10 Networks, Inc.Transmission control of protocol state exchange for dynamic stateful service insertion
US10243791B2 (en)2015-08-132019-03-26A10 Networks, Inc.Automated adjustment of subscriber policies
US10318288B2 (en)2016-01-132019-06-11A10 Networks, Inc.System and method to process a chain of network applications
US10389835B2 (en)2017-01-102019-08-20A10 Networks, Inc.Application aware systems and methods to process user loadable network applications

Citations (136)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4667287A (en)1982-10-281987-05-19Tandem Computers IncorporatedMultiprocessor multisystem communications network
US5400331A (en)*1993-04-281995-03-21Allen-Bradley Company, Inc.Communication network interface with screeners for incoming messages
US5442708A (en)1993-03-091995-08-15Uunet Technologies, Inc.Computer network encryption/decryption device
US5473599A (en)1994-04-221995-12-05Cisco Systems, IncorporatedStandby router protocol
US5490252A (en)1992-09-301996-02-06Bay Networks Group, Inc.System having central processor for transmitting generic packets to another processor to be altered and transmitting altered packets back to central processor for routing
US5581705A (en)1993-12-131996-12-03Cray Research, Inc.Messaging facility with hardware tail pointer and software implemented head pointer message queue for distributed memory massively parallel processing system
US5606668A (en)*1993-12-151997-02-25Checkpoint Software Technologies Ltd.System for securing inbound and outbound data packet flow in a computer network
US5633866A (en)1995-11-171997-05-27Bay Networks, Inc.Method and apparatus for routing packets in networks having connection-oriented subnetworks
US5745778A (en)1994-01-261998-04-28Data General CorporationApparatus and method for improved CPU affinity in a multiprocessor system
US5812779A (en)1994-10-211998-09-22Modulus Technologies, Inc.Storage medium and system for managing and distributing data objects of different types between computers connected to a network
US5825891A (en)1996-01-161998-10-20Raptor Systems, Inc.Key management for network communication
US5825772A (en)1995-11-151998-10-20Cabletron Systems, Inc.Distributed connection-oriented services for switched communications networks
US5835726A (en)*1993-12-151998-11-10Check Point Software Technologies Ltd.System for securing the flow of and selectively modifying packets in a computer network
US5841973A (en)1996-03-131998-11-24Cray Research, Inc.Messaging in distributed memory multiprocessing system having shell circuitry for atomic control of message storage queue's tail pointer structure in local memory
US5875290A (en)1997-03-271999-02-23International Business Machines CorporationMethod and program product for synchronizing operator initiated commands with a failover process in a distributed processing system
US5963555A (en)1996-09-031999-10-05Hitachi LtdRouter apparatus using ATM switch
US5987521A (en)1995-07-101999-11-16International Business Machines CorporationManagement of path routing in packet communications networks
US6014382A (en)1996-04-042000-01-11Hitachi, Ltd.ATM switching system including a switching control portion for distributing call set-up requirement signals
US6032193A (en)1997-03-202000-02-29Niobrara Research And Development CorporationComputer system having virtual circuit address altered by local computer to switch to different physical data link to increase data transmission bandwidth
US6047330A (en)1998-01-202000-04-04Netscape Communications CorporationVirtual router discovery system
US6069895A (en)1997-08-292000-05-30Nortel Networks CorporationDistributed route server
US6085238A (en)1996-04-232000-07-04Matsushita Electric Works, Ltd.Virtual LAN system
US6098110A (en)1996-12-302000-08-01Compaq Computer CorporationNetwork switch with a multiple bus structure and a bridge interface for transferring network data between different buses
WO2000051290A2 (en)1999-02-232000-08-31Alcatel Internetworking, Inc.Multi-service network switch
US6118791A (en)1995-12-202000-09-12Cisco Technology, Inc.Adaptive bandwidth allocation method for non-reserved traffic in a high-speed data transmission network, and system for implementing said method
US6137777A (en)1997-05-272000-10-24Ukiah Software, Inc.Control tool for bandwidth management
US6147976A (en)*1996-06-242000-11-14Cabletron Systems, Inc.Fast network layer packet filter
WO2000076152A1 (en)1999-06-032000-12-14Fujitsu Network Communications, Inc.Method and system for transmitting traffic in a virtual tunnel of a transmission line
US6169793B1 (en)1996-12-242001-01-02Evolving Systems, Inc.Systems and methods for providing order and service mediation for telecommunications systems
US6169739B1 (en)1997-01-082001-01-02Nec CorporationATM VLAN multi-protocol client-server system using layer-3 header of packets for transporting connectionless and connection-oriented traffic
US6173399B1 (en)1997-06-122001-01-09Vpnet Technologies, Inc.Apparatus for implementing virtual private networks
US6173333B1 (en)1997-07-182001-01-09Interprophet CorporationTCP/IP network accelerator system and method which identifies classes of packet traffic for predictable protocols
US6175867B1 (en)1998-03-232001-01-16Mci World Com, Inc.System and method for managing networks addressed via common network addresses
US6192051B1 (en)1999-02-262001-02-20Redstone Communications, Inc.Network router search engine using compressed tree forwarding table
US6220768B1 (en)1996-06-282001-04-24Sun Microsystems, Inc.Network asset survey tool for gathering data about node equipment
US6226788B1 (en)1998-07-222001-05-01Cisco Technology, Inc.Extensible network management system
US6243580B1 (en)1995-11-302001-06-05Amsc Subsidiary CorporationPriority and preemption service system for satellite related communication using central controller
US6249519B1 (en)1998-04-162001-06-19Mantra CommunicationsFlow based circuit steering in ATM networks
US6260073B1 (en)1996-12-302001-07-10Compaq Computer CorporationNetwork switch including a switch manager for periodically polling the network ports to determine their status and controlling the flow of data between ports
US6260072B1 (en)1997-06-122001-07-10Lucent Technologies IncMethod and apparatus for adaptive routing in packet networks
US6266695B1 (en)1997-12-232001-07-24Alcatel Usa Sourcing, L.P.Telecommunications switch management system
US6278708B1 (en)1998-04-102001-08-21Cisco Technology, Inc.Frame relay access device with user-configurable virtual circuit bundling
WO2001063809A1 (en)2000-02-232001-08-30Nisco Systems, Inc.Methods and apparatus for controlling internet protocol traffic in a wan or lan
US6286038B1 (en)1998-08-032001-09-04Nortel Networks LimitedMethod and apparatus for remotely configuring a network device
US6295297B1 (en)1997-12-292001-09-25Samsung Electronics Co., Ltd.Gateway for connecting ATM-based access network to existing network
US6298130B1 (en)1997-09-302001-10-02Genesys Telecommunications Laboratories Inc.Metadata-based network routing
US6304975B1 (en)*1996-10-072001-10-16Peter M. ShipleyIntelligent network security device and method
US6320859B1 (en)1997-10-312001-11-20Nortel Networks LimitedEarly availability of forwarding control information
US20010043571A1 (en)2000-03-242001-11-22Saqib JangMultiple subscriber videoconferencing system
US20010048661A1 (en)2000-05-242001-12-06David ClearMethod and apparatus for multi-protocol redundant router protocol support
US6330602B1 (en)1997-04-142001-12-11Nortel Networks LimitedScaleable web server and method of efficiently managing multiple servers
US20010052013A1 (en)1997-09-262001-12-13Wayne J. MunguiaIntegrated proxy interface for web based telecommunications network management
US6338092B1 (en)1998-09-242002-01-08International Business Machines CorporationMethod, system and computer program for replicating data in a distributed computed environment
US20020062344A1 (en)*1998-09-112002-05-23Tatu YlonenMethod and arrangement for secure tunneling of data between virtual routers
US20020066034A1 (en)2000-10-242002-05-30Schlossberg Barry J.Distributed network security deception system
US6405262B1 (en)1995-07-142002-06-11Microsoft CorporationEfficient inter-process object and interface pinging
US20020075901A1 (en)2000-12-192002-06-20Bruce PerlmutterBandwidth management for tunneling servers
US6414595B1 (en)2000-06-162002-07-02Ciena CorporationMethod and system for processing alarm objects in a communications network
US20020097872A1 (en)2001-01-242002-07-25Maliszewski Richard L.Method of providing secure content-based user experience enhancement within a content protection architecture
US20020099849A1 (en)2001-01-252002-07-25Crescent Networks, Inc.Dense virtual router packet switching
US6434619B1 (en)1998-04-292002-08-13Alcatel Canada Inc.Internet-enabled service management system and method
US20020116501A1 (en)*2001-02-212002-08-22Ho Chi FaiService tunnel over a connectionless network
US6449650B1 (en)1999-02-012002-09-10Redback Networks Inc.Methods and apparatus for deploying quality of service policies on a data communication network
US20020126672A1 (en)*2001-01-102002-09-12Nelson ChowMethod and apparatus for a flexible and reconfigurable packet classifier using content addressable memory
US6459682B1 (en)1998-04-072002-10-01International Business Machines CorporationArchitecture for supporting service level agreements in an IP network
US6463061B1 (en)1997-12-232002-10-08Cisco Technology, Inc.Shared communications network employing virtual-private-network identifiers
US6466976B1 (en)1998-12-032002-10-15Nortel Networks LimitedSystem and method for providing desired service policies to subscribers accessing the internet
US20020150114A1 (en)*2001-03-192002-10-17Yoshitaka SainomotoPacket routing apparatus and a method of routing a packet
US20020152373A1 (en)*2000-09-132002-10-17Chih-Tang SunTunnel interface for securing traffic over a network
US20020188657A1 (en)2001-01-222002-12-12Traversat Bernard A.Resource identifiers for a peer-to-peer environment
US20020186661A1 (en)2001-05-042002-12-12Terago Communications, Inc.System and method for hierarchical policing of flows and subflows of a data stream
US6496935B1 (en)*2000-03-022002-12-17Check Point Software Technologies LtdSystem, device and method for rapid packet filtering and processing
US20020194378A1 (en)*2001-04-052002-12-19George FotiSystem and method of hiding an internet protocol (IP) address of an IP terminal during a multimedia session
US20020191604A1 (en)2001-05-022002-12-19Mitchell Oscar R.Application-specific information-processing method, system, and apparatus
WO2003010323A1 (en)2001-06-212003-02-06T + T Oleochemie GmbhMethod and device for obtaining fatty acid esters from native oils and fats by means of the enzymatic separation thereof
US20030033401A1 (en)1999-04-022003-02-13Matthew W. PoissonMonitoring a virtual private network
US20030043792A1 (en)*2001-08-312003-03-06Carpini Walter JosephLabel switched communication network, a method of conditioning the network and a method of data transmission
WO2002023855A3 (en)2000-09-132003-03-06Cosine Communications IncSystem and method for delivering security services
US6532088B1 (en)1999-09-102003-03-11AlcatelSystem and method for packet level distributed routing in fiber optic rings
US20030051048A1 (en)*2001-06-292003-03-13Watson Thomas LeeSystem and method for router virtual networking
US6542466B1 (en)1999-05-202003-04-01Motorola, Inc.Communication network method and apparatus
US6549954B1 (en)1997-01-162003-04-15Advanced Micro Devices, Inc.Object oriented on-chip messaging
US20030074473A1 (en)*2001-10-122003-04-17Duc PhamScalable network gateway processor architecture
US20030076838A1 (en)*1998-06-292003-04-24Jack ShaioMethod of implementing quality-of-service data communications over a short-cut path through a routed network
US6556544B1 (en)1999-10-222003-04-29Nortel Networks LimitedMethod and system for provisioning network resources for dynamic multicast groups
US20030081559A1 (en)2001-10-252003-05-01Makoto MatuokaBand guarantee system, relay device, and network management server
US20030091021A1 (en)2001-11-132003-05-15Nokia CorporationPhysically scoped multicast in multi-access networks
US20030108041A1 (en)*2001-12-072003-06-12Nortell Networks LimitedTunneling scheme optimized for use in virtual private netwoks
US20030115308A1 (en)2001-12-192003-06-19Michael BestNetwork management system architecture
US20030117954A1 (en)2001-12-202003-06-26AlcatelTelecommunications system employing virtual service network architecture
US20030131228A1 (en)2002-01-102003-07-10Twomey John E.System on a chip for network storage devices
US6606315B1 (en)*1999-07-022003-08-12Cisco Technology, Inc.Synchronizing service instructions among forwarding agents using a service manager
US6609153B1 (en)1998-12-242003-08-19Redback Networks Inc.Domain isolation through virtual network machines
US6608816B1 (en)1998-11-182003-08-19Nortel Networks LimitedMethod and apparatus for providing differentiated services using a multi-level queuing mechanism
US20030169747A1 (en)2002-03-012003-09-11Yang WangResource allocation in virtual routers
US20030185226A1 (en)2002-03-272003-10-02Puqi TangSystems and methods for updating routing and forwarding information
US6631519B1 (en)2000-03-302003-10-07Microsoft CorporationAutomated schema and interface generation
US6636516B1 (en)1999-03-172003-10-21Nec CorporationQOS-based virtual private network using ATM-based internet virtual connections
US20030200295A1 (en)2002-04-192003-10-23Roberts David GaryNetwork system having a virtual-service-module
US6639897B1 (en)1998-04-222003-10-28Nippon Telegraph And Telephone CorporationCommunication network of linked nodes for selecting the shortest available route
US20030212735A1 (en)*2002-05-132003-11-13Nvidia CorporationMethod and apparatus for providing an integrated network of processors
US6658013B1 (en)1999-03-232003-12-02Nortel Networks LimitedMethod and apparatus for ensuring survivability of inter-ring traffic
US20030223418A1 (en)2002-06-042003-12-04Sachin DesaiNetwork packet steering
US20030223456A1 (en)2002-06-042003-12-04Dimambro Francesco R.Apparatus and method for steering a communication to an open stream
US20030223406A1 (en)2002-06-042003-12-04Rajesh BalayMethods and systems for a distributed provider edge
WO2003103237A1 (en)2002-06-042003-12-11Cosine Communications, Inc.System and method for controlling routing in a virtual router system
US6674756B1 (en)1999-02-232004-01-06AlcatelMulti-service network switch with multiple virtual routers
US6687220B1 (en)1999-09-282004-02-03Ericsson Inc.Quality of service management in a packet data router having multiple virtual router instances
US6697359B1 (en)1999-07-022004-02-24Ancor Communications, Inc.High performance switch fabric element and switch systems
US6697360B1 (en)1998-09-022004-02-24Cisco Technology, Inc.Method and apparatus for auto-configuring layer three intermediate computer network devices
US20040042416A1 (en)2002-08-272004-03-04Ngo Chuong NgocVirtual Local Area Network auto-discovery methods
US6738371B1 (en)*1999-09-282004-05-18Ericsson Inc.Ingress data queue management in a packet data router
US20040095934A1 (en)2002-11-182004-05-20Cosine Communications, Inc.System and method for hardware accelerated packet multicast in a virtual routing system
US6775284B1 (en)2000-01-072004-08-10International Business Machines CorporationMethod and system for frame and protocol classification
US6775267B1 (en)1999-12-302004-08-10At&T CorpMethod for billing IP broadband subscribers
US20040160900A1 (en)2003-02-182004-08-19Martin LundSystem and method for communicating using a multiserver platform
US6850531B1 (en)*1999-02-232005-02-01AlcatelMulti-service network switch
US6856676B1 (en)1998-10-152005-02-15AlcatelSystem and method of controlling and managing voice and data services in a telecommunications network
US20050047407A1 (en)2003-08-272005-03-03Cosine Communications, Inc.Heterogeneous media packet bridging
US6868082B1 (en)1999-08-302005-03-15International Business Machines CorporationNetwork processor interface for building scalable switching systems
US6883170B1 (en)2000-08-302005-04-19Aspect Communication CorporationMethod and system to maintain a hierarchy of instantiated application objects and to enable recovery from an applications failure
US6901517B1 (en)*1999-07-162005-05-31Marconi Communications, Inc.Hardware based security groups, firewall load sharing, and firewall redundancy
US20050188106A1 (en)2004-02-112005-08-25AlcatelManaging L3 VPN virtual routing tables
US6938097B1 (en)1999-07-022005-08-30Sonicwall, Inc.System for early packet steering and FIFO-based management with priority buffer support
US6938095B2 (en)2000-06-282005-08-30Pluris, Inc.Method and apparatus for establishing and sharing a virtual change notification list among a plurality of peer nodes
US6944168B2 (en)2001-05-042005-09-13Slt Logic LlcSystem and method for providing transformation of multi-protocol packets in a data stream
US6954429B2 (en)2000-04-052005-10-11Dyband CorporationBandwidth control system
US6985438B1 (en)1999-09-202006-01-10Christian TschudinMethod and apparatus for processing and forwarding data packets
US6999454B1 (en)2001-02-092006-02-14Nortel Networks LimitedInformation routing system and apparatus
US7020143B2 (en)2001-06-182006-03-28Ericsson Inc.System for and method of differentiated queuing in a routing system
US7039053B1 (en)*2001-02-282006-05-023Com CorporationPacket filter policy verification system
US7042843B2 (en)2001-03-022006-05-09Broadcom CorporationAlgorithm for time based queuing in network traffic engineering
US20060140185A1 (en)2001-07-272006-06-29Norman Richard SMethods and apparatus for storage and processing of routing information
US7096383B2 (en)2002-08-292006-08-22Cosine Communications, Inc.System and method for virtual router failover in a network routing system
US7111072B1 (en)2000-09-132006-09-19Cosine Communications, Inc.Packet routing system and method
US7161904B2 (en)2002-06-042007-01-09Fortinet, Inc.System and method for hierarchical metering in a virtual router based network switch

Patent Citations (148)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4667287A (en)1982-10-281987-05-19Tandem Computers IncorporatedMultiprocessor multisystem communications network
US5490252A (en)1992-09-301996-02-06Bay Networks Group, Inc.System having central processor for transmitting generic packets to another processor to be altered and transmitting altered packets back to central processor for routing
US5442708A (en)1993-03-091995-08-15Uunet Technologies, Inc.Computer network encryption/decryption device
US5400331A (en)*1993-04-281995-03-21Allen-Bradley Company, Inc.Communication network interface with screeners for incoming messages
US5581705A (en)1993-12-131996-12-03Cray Research, Inc.Messaging facility with hardware tail pointer and software implemented head pointer message queue for distributed memory massively parallel processing system
US5606668A (en)*1993-12-151997-02-25Checkpoint Software Technologies Ltd.System for securing inbound and outbound data packet flow in a computer network
US5835726A (en)*1993-12-151998-11-10Check Point Software Technologies Ltd.System for securing the flow of and selectively modifying packets in a computer network
US5745778A (en)1994-01-261998-04-28Data General CorporationApparatus and method for improved CPU affinity in a multiprocessor system
US5473599A (en)1994-04-221995-12-05Cisco Systems, IncorporatedStandby router protocol
US5812779A (en)1994-10-211998-09-22Modulus Technologies, Inc.Storage medium and system for managing and distributing data objects of different types between computers connected to a network
US5987521A (en)1995-07-101999-11-16International Business Machines CorporationManagement of path routing in packet communications networks
US6405262B1 (en)1995-07-142002-06-11Microsoft CorporationEfficient inter-process object and interface pinging
US5825772A (en)1995-11-151998-10-20Cabletron Systems, Inc.Distributed connection-oriented services for switched communications networks
US5633866A (en)1995-11-171997-05-27Bay Networks, Inc.Method and apparatus for routing packets in networks having connection-oriented subnetworks
US6243580B1 (en)1995-11-302001-06-05Amsc Subsidiary CorporationPriority and preemption service system for satellite related communication using central controller
US6118791A (en)1995-12-202000-09-12Cisco Technology, Inc.Adaptive bandwidth allocation method for non-reserved traffic in a high-speed data transmission network, and system for implementing said method
US5825891A (en)1996-01-161998-10-20Raptor Systems, Inc.Key management for network communication
US5841973A (en)1996-03-131998-11-24Cray Research, Inc.Messaging in distributed memory multiprocessing system having shell circuitry for atomic control of message storage queue's tail pointer structure in local memory
US6014382A (en)1996-04-042000-01-11Hitachi, Ltd.ATM switching system including a switching control portion for distributing call set-up requirement signals
US6085238A (en)1996-04-232000-07-04Matsushita Electric Works, Ltd.Virtual LAN system
US6147976A (en)*1996-06-242000-11-14Cabletron Systems, Inc.Fast network layer packet filter
US6220768B1 (en)1996-06-282001-04-24Sun Microsystems, Inc.Network asset survey tool for gathering data about node equipment
US5963555A (en)1996-09-031999-10-05Hitachi LtdRouter apparatus using ATM switch
US6304975B1 (en)*1996-10-072001-10-16Peter M. ShipleyIntelligent network security device and method
US6169793B1 (en)1996-12-242001-01-02Evolving Systems, Inc.Systems and methods for providing order and service mediation for telecommunications systems
US6098110A (en)1996-12-302000-08-01Compaq Computer CorporationNetwork switch with a multiple bus structure and a bridge interface for transferring network data between different buses
US6260073B1 (en)1996-12-302001-07-10Compaq Computer CorporationNetwork switch including a switch manager for periodically polling the network ports to determine their status and controlling the flow of data between ports
US6169739B1 (en)1997-01-082001-01-02Nec CorporationATM VLAN multi-protocol client-server system using layer-3 header of packets for transporting connectionless and connection-oriented traffic
US6549954B1 (en)1997-01-162003-04-15Advanced Micro Devices, Inc.Object oriented on-chip messaging
US6032193A (en)1997-03-202000-02-29Niobrara Research And Development CorporationComputer system having virtual circuit address altered by local computer to switch to different physical data link to increase data transmission bandwidth
US5875290A (en)1997-03-271999-02-23International Business Machines CorporationMethod and program product for synchronizing operator initiated commands with a failover process in a distributed processing system
US6330602B1 (en)1997-04-142001-12-11Nortel Networks LimitedScaleable web server and method of efficiently managing multiple servers
US6137777A (en)1997-05-272000-10-24Ukiah Software, Inc.Control tool for bandwidth management
US6173399B1 (en)1997-06-122001-01-09Vpnet Technologies, Inc.Apparatus for implementing virtual private networks
US6260072B1 (en)1997-06-122001-07-10Lucent Technologies IncMethod and apparatus for adaptive routing in packet networks
US6173333B1 (en)1997-07-182001-01-09Interprophet CorporationTCP/IP network accelerator system and method which identifies classes of packet traffic for predictable protocols
US6069895A (en)1997-08-292000-05-30Nortel Networks CorporationDistributed route server
US20010052013A1 (en)1997-09-262001-12-13Wayne J. MunguiaIntegrated proxy interface for web based telecommunications network management
US6381644B2 (en)1997-09-262002-04-30Mci Worldcom, Inc.Integrated proxy interface for web based telecommunications network management
US6298130B1 (en)1997-09-302001-10-02Genesys Telecommunications Laboratories Inc.Metadata-based network routing
US6320859B1 (en)1997-10-312001-11-20Nortel Networks LimitedEarly availability of forwarding control information
US6266695B1 (en)1997-12-232001-07-24Alcatel Usa Sourcing, L.P.Telecommunications switch management system
US6526056B1 (en)1997-12-232003-02-25Cisco Technology, Inc.Virtual private network employing tag-implemented egress-channel selection
US6463061B1 (en)1997-12-232002-10-08Cisco Technology, Inc.Shared communications network employing virtual-private-network identifiers
US6295297B1 (en)1997-12-292001-09-25Samsung Electronics Co., Ltd.Gateway for connecting ATM-based access network to existing network
US6047330A (en)1998-01-202000-04-04Netscape Communications CorporationVirtual router discovery system
US6175867B1 (en)1998-03-232001-01-16Mci World Com, Inc.System and method for managing networks addressed via common network addresses
US6459682B1 (en)1998-04-072002-10-01International Business Machines CorporationArchitecture for supporting service level agreements in an IP network
US6278708B1 (en)1998-04-102001-08-21Cisco Technology, Inc.Frame relay access device with user-configurable virtual circuit bundling
US6249519B1 (en)1998-04-162001-06-19Mantra CommunicationsFlow based circuit steering in ATM networks
US6639897B1 (en)1998-04-222003-10-28Nippon Telegraph And Telephone CorporationCommunication network of linked nodes for selecting the shortest available route
US6434619B1 (en)1998-04-292002-08-13Alcatel Canada Inc.Internet-enabled service management system and method
US20030076838A1 (en)*1998-06-292003-04-24Jack ShaioMethod of implementing quality-of-service data communications over a short-cut path through a routed network
US6226788B1 (en)1998-07-222001-05-01Cisco Technology, Inc.Extensible network management system
US6286038B1 (en)1998-08-032001-09-04Nortel Networks LimitedMethod and apparatus for remotely configuring a network device
US6697360B1 (en)1998-09-022004-02-24Cisco Technology, Inc.Method and apparatus for auto-configuring layer three intermediate computer network devices
US20020062344A1 (en)*1998-09-112002-05-23Tatu YlonenMethod and arrangement for secure tunneling of data between virtual routers
US6438612B1 (en)1998-09-112002-08-20Ssh Communications Security, Ltd.Method and arrangement for secure tunneling of data between virtual routers
US6338092B1 (en)1998-09-242002-01-08International Business Machines CorporationMethod, system and computer program for replicating data in a distributed computed environment
US6856676B1 (en)1998-10-152005-02-15AlcatelSystem and method of controlling and managing voice and data services in a telecommunications network
US6944128B2 (en)1998-11-182005-09-13Nortel Networks LimitedMethod and apparatus for providing differentiated services using a multi-level queuing mechanism
US6608816B1 (en)1998-11-182003-08-19Nortel Networks LimitedMethod and apparatus for providing differentiated services using a multi-level queuing mechanism
US6466976B1 (en)1998-12-032002-10-15Nortel Networks LimitedSystem and method for providing desired service policies to subscribers accessing the internet
US6609153B1 (en)1998-12-242003-08-19Redback Networks Inc.Domain isolation through virtual network machines
US6449650B1 (en)1999-02-012002-09-10Redback Networks Inc.Methods and apparatus for deploying quality of service policies on a data communication network
US6850531B1 (en)*1999-02-232005-02-01AlcatelMulti-service network switch
US6674756B1 (en)1999-02-232004-01-06AlcatelMulti-service network switch with multiple virtual routers
WO2000051290A2 (en)1999-02-232000-08-31Alcatel Internetworking, Inc.Multi-service network switch
US6192051B1 (en)1999-02-262001-02-20Redstone Communications, Inc.Network router search engine using compressed tree forwarding table
US6636516B1 (en)1999-03-172003-10-21Nec CorporationQOS-based virtual private network using ATM-based internet virtual connections
US6658013B1 (en)1999-03-232003-12-02Nortel Networks LimitedMethod and apparatus for ensuring survivability of inter-ring traffic
US20030033401A1 (en)1999-04-022003-02-13Matthew W. PoissonMonitoring a virtual private network
US6542466B1 (en)1999-05-202003-04-01Motorola, Inc.Communication network method and apparatus
WO2000076152A1 (en)1999-06-032000-12-14Fujitsu Network Communications, Inc.Method and system for transmitting traffic in a virtual tunnel of a transmission line
US6697359B1 (en)1999-07-022004-02-24Ancor Communications, Inc.High performance switch fabric element and switch systems
US6938097B1 (en)1999-07-022005-08-30Sonicwall, Inc.System for early packet steering and FIFO-based management with priority buffer support
US20040141521A1 (en)1999-07-022004-07-22Ancor Communications, Inc.High performance switch fabric element and switch systems
US6606315B1 (en)*1999-07-022003-08-12Cisco Technology, Inc.Synchronizing service instructions among forwarding agents using a service manager
US6901517B1 (en)*1999-07-162005-05-31Marconi Communications, Inc.Hardware based security groups, firewall load sharing, and firewall redundancy
US6868082B1 (en)1999-08-302005-03-15International Business Machines CorporationNetwork processor interface for building scalable switching systems
US6532088B1 (en)1999-09-102003-03-11AlcatelSystem and method for packet level distributed routing in fiber optic rings
US6985438B1 (en)1999-09-202006-01-10Christian TschudinMethod and apparatus for processing and forwarding data packets
US6687220B1 (en)1999-09-282004-02-03Ericsson Inc.Quality of service management in a packet data router having multiple virtual router instances
US6738371B1 (en)*1999-09-282004-05-18Ericsson Inc.Ingress data queue management in a packet data router
US6556544B1 (en)1999-10-222003-04-29Nortel Networks LimitedMethod and system for provisioning network resources for dynamic multicast groups
US6775267B1 (en)1999-12-302004-08-10At&T CorpMethod for billing IP broadband subscribers
US6775284B1 (en)2000-01-072004-08-10International Business Machines CorporationMethod and system for frame and protocol classification
WO2001063809A1 (en)2000-02-232001-08-30Nisco Systems, Inc.Methods and apparatus for controlling internet protocol traffic in a wan or lan
US6496935B1 (en)*2000-03-022002-12-17Check Point Software Technologies LtdSystem, device and method for rapid packet filtering and processing
US20010043571A1 (en)2000-03-242001-11-22Saqib JangMultiple subscriber videoconferencing system
US6631519B1 (en)2000-03-302003-10-07Microsoft CorporationAutomated schema and interface generation
US6954429B2 (en)2000-04-052005-10-11Dyband CorporationBandwidth control system
US20010048661A1 (en)2000-05-242001-12-06David ClearMethod and apparatus for multi-protocol redundant router protocol support
US6414595B1 (en)2000-06-162002-07-02Ciena CorporationMethod and system for processing alarm objects in a communications network
US6938095B2 (en)2000-06-282005-08-30Pluris, Inc.Method and apparatus for establishing and sharing a virtual change notification list among a plurality of peer nodes
US6883170B1 (en)2000-08-302005-04-19Aspect Communication CorporationMethod and system to maintain a hierarchy of instantiated application objects and to enable recovery from an applications failure
WO2002023855A3 (en)2000-09-132003-03-06Cosine Communications IncSystem and method for delivering security services
US7111072B1 (en)2000-09-132006-09-19Cosine Communications, Inc.Packet routing system and method
US20020152373A1 (en)*2000-09-132002-10-17Chih-Tang SunTunnel interface for securing traffic over a network
US20020066034A1 (en)2000-10-242002-05-30Schlossberg Barry J.Distributed network security deception system
US20020075901A1 (en)2000-12-192002-06-20Bruce PerlmutterBandwidth management for tunneling servers
US20020126672A1 (en)*2001-01-102002-09-12Nelson ChowMethod and apparatus for a flexible and reconfigurable packet classifier using content addressable memory
US20020188657A1 (en)2001-01-222002-12-12Traversat Bernard A.Resource identifiers for a peer-to-peer environment
US20020097872A1 (en)2001-01-242002-07-25Maliszewski Richard L.Method of providing secure content-based user experience enhancement within a content protection architecture
US20020099849A1 (en)2001-01-252002-07-25Crescent Networks, Inc.Dense virtual router packet switching
US6999454B1 (en)2001-02-092006-02-14Nortel Networks LimitedInformation routing system and apparatus
US20020116501A1 (en)*2001-02-212002-08-22Ho Chi FaiService tunnel over a connectionless network
US7039053B1 (en)*2001-02-282006-05-023Com CorporationPacket filter policy verification system
US7042843B2 (en)2001-03-022006-05-09Broadcom CorporationAlgorithm for time based queuing in network traffic engineering
US20020150114A1 (en)*2001-03-192002-10-17Yoshitaka SainomotoPacket routing apparatus and a method of routing a packet
US20020194378A1 (en)*2001-04-052002-12-19George FotiSystem and method of hiding an internet protocol (IP) address of an IP terminal during a multimedia session
US20020191604A1 (en)2001-05-022002-12-19Mitchell Oscar R.Application-specific information-processing method, system, and apparatus
US20020186661A1 (en)2001-05-042002-12-12Terago Communications, Inc.System and method for hierarchical policing of flows and subflows of a data stream
US6944168B2 (en)2001-05-042005-09-13Slt Logic LlcSystem and method for providing transformation of multi-protocol packets in a data stream
US7042848B2 (en)2001-05-042006-05-09Slt Logic LlcSystem and method for hierarchical policing of flows and subflows of a data stream
US20060087969A1 (en)2001-05-042006-04-27Slt Logic LlcSystem and method for hierarchical policing of flows and subflows of a data stream
US7020143B2 (en)2001-06-182006-03-28Ericsson Inc.System for and method of differentiated queuing in a routing system
WO2003010323A1 (en)2001-06-212003-02-06T + T Oleochemie GmbhMethod and device for obtaining fatty acid esters from native oils and fats by means of the enzymatic separation thereof
US20030051048A1 (en)*2001-06-292003-03-13Watson Thomas LeeSystem and method for router virtual networking
US20060140185A1 (en)2001-07-272006-06-29Norman Richard SMethods and apparatus for storage and processing of routing information
US20030043792A1 (en)*2001-08-312003-03-06Carpini Walter JosephLabel switched communication network, a method of conditioning the network and a method of data transmission
US20030074473A1 (en)*2001-10-122003-04-17Duc PhamScalable network gateway processor architecture
US20030081559A1 (en)2001-10-252003-05-01Makoto MatuokaBand guarantee system, relay device, and network management server
US20030091021A1 (en)2001-11-132003-05-15Nokia CorporationPhysically scoped multicast in multi-access networks
US20030108041A1 (en)*2001-12-072003-06-12Nortell Networks LimitedTunneling scheme optimized for use in virtual private netwoks
US20030115308A1 (en)2001-12-192003-06-19Michael BestNetwork management system architecture
US20030117954A1 (en)2001-12-202003-06-26AlcatelTelecommunications system employing virtual service network architecture
US20030131228A1 (en)2002-01-102003-07-10Twomey John E.System on a chip for network storage devices
US20030169747A1 (en)2002-03-012003-09-11Yang WangResource allocation in virtual routers
US20030185226A1 (en)2002-03-272003-10-02Puqi TangSystems and methods for updating routing and forwarding information
US20030200295A1 (en)2002-04-192003-10-23Roberts David GaryNetwork system having a virtual-service-module
US20030212735A1 (en)*2002-05-132003-11-13Nvidia CorporationMethod and apparatus for providing an integrated network of processors
US20030223406A1 (en)2002-06-042003-12-04Rajesh BalayMethods and systems for a distributed provider edge
WO2003103237A1 (en)2002-06-042003-12-11Cosine Communications, Inc.System and method for controlling routing in a virtual router system
US7203192B2 (en)2002-06-042007-04-10Fortinet, Inc.Network packet steering
US20030223456A1 (en)2002-06-042003-12-04Dimambro Francesco R.Apparatus and method for steering a communication to an open stream
US20030223418A1 (en)2002-06-042003-12-04Sachin DesaiNetwork packet steering
US7161904B2 (en)2002-06-042007-01-09Fortinet, Inc.System and method for hierarchical metering in a virtual router based network switch
US7116665B2 (en)2002-06-042006-10-03Fortinet, Inc.Methods and systems for a distributed provider edge
US20040042416A1 (en)2002-08-272004-03-04Ngo Chuong NgocVirtual Local Area Network auto-discovery methods
US7096383B2 (en)2002-08-292006-08-22Cosine Communications, Inc.System and method for virtual router failover in a network routing system
US20040095934A1 (en)2002-11-182004-05-20Cosine Communications, Inc.System and method for hardware accelerated packet multicast in a virtual routing system
US20040160900A1 (en)2003-02-182004-08-19Martin LundSystem and method for communicating using a multiserver platform
US20040199568A1 (en)2003-02-182004-10-07Martin LundSystem and method for communicating between servers using a multi-server platform
US20040199569A1 (en)2003-02-182004-10-07Mohan KalkunteMethod and system for handling traffic for server systems
US20040199567A1 (en)2003-02-182004-10-07Martin LundSystem and method for integrating multiserver platforms
US20050047407A1 (en)2003-08-272005-03-03Cosine Communications, Inc.Heterogeneous media packet bridging
US20050188106A1 (en)2004-02-112005-08-25AlcatelManaging L3 VPN virtual routing tables

Non-Patent Citations (17)

* Cited by examiner, † Cited by third party
Title
"International Search Report", for PCT application PCT/US 03/ 17674, 6 Pages.
Chan, M. C., et al., "Customer Management and Control of Broadband VPN Services", Proc. Fifth IFIP/IEEE International Symposium on Integrated Network Management, (May 1997),301-314.
Chan, Mun C., et al., "An architecture for broadband virtual networks under customer control", IEEE Network Operations and Management Symposium, (Apr. 15-19, 1996), 135-144.
European Search Report for PCT/US03/37009 (Jul. 4, 2004) 2 pgs.
Gasparro, D. M., "Next-Gen VPNs: The Design Challenge", Data Communications, (Sep. 1999),83-95.
Hanaki, M , et al., "LAN/WAN management integration using ATM CNM interface", IEEE Network Operations and Management Symposium, vol. 1, (Apr. 15-19, 1996),12-21.
Hussain, Z. , et al., "System and Method for Routhing Traffic Through a Virtual Router-Based Network Switch", U.S. App. No. 10/163,079, filed Jun. 4, 2002.
Hussain, Z., "Service Processing Switch", U.S. Appl. No. 10/163,260, filed Jun. 4, 2002.
International Search Report for PCT/US03/17674, 6 pgs.
Kapustka, K. , et al., "CoSine Communications Moves VPNs 'Into the Cloud' with the Leading Managed IP Service Delivery Platform", http://www.cosinecom.com/news/pr<SUB>-</SUB>5<SUB>-</SUB>24.html, Press Release, CoSine Communications,(1999),5 p.
Kapustka, K. , et al., "CoSine Communications Moves VPNs ‘Into the Cloud’ with the Leading Managed IP Service Delivery Platform", http://www.cosinecom.com/news/pr—5—24.html, Press Release, CoSine Communications,(1999),5 p.
Keshav, Srinivsan, "An Engineering Approach to Computer Networking: ATM networks, the internet, and the telephone network", Reading, Mass. : Addison-Wesley, Addison-Wesley Professional Computing Series,(1992),318-324.
Kim, E. C., et al., "The Multi-Layer VPN Management Architecture", Proc. Sixth IFIP/IEEE International Symposium on Integrated Network Management, (May 1999), 187-200.
Knight et al. "Virtual Router Redundancy Protocol" RFC 2338, Apr. 1998.*
Matthews, A. R., "System and Method for Delivering Security Services", U.S. Appl. No. 09/661,637, filed Sep. 13, 2000.
Rao, J. R., "Intranets and VPNs: Strategic Approach", 1998 Annual Review of Communications, (1998),669-674.
Tanenbaum, A. S., "Computer Networks", Upper Saddle River, N.J. : Prentice Hall PTR, 3rd Edition,(1996),348-364.

Cited By (190)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US8650390B2 (en)2000-09-132014-02-11Fortinet, Inc.Tunnel interface for securing traffic over a network
US20080259934A1 (en)*2000-09-132008-10-23Fortinet, Inc.Distributed virtual system to support managed, network-based services
US9160716B2 (en)2000-09-132015-10-13Fortinet, Inc.Tunnel interface for securing traffic over a network
US9667604B2 (en)2000-09-132017-05-30Fortinet, Inc.Tunnel interface for securing traffic over a network
US9853948B2 (en)2000-09-132017-12-26Fortinet, Inc.Tunnel interface for securing traffic over a network
US9124555B2 (en)2000-09-132015-09-01Fortinet, Inc.Tunnel interface for securing traffic over a network
US7639632B2 (en)2000-09-132009-12-29Fortinet, Inc.System and method for managing and provisioning virtual routers
US20070083528A1 (en)*2000-09-132007-04-12Fortinet, Inc.Switch management system and method
US20070104119A1 (en)*2000-09-132007-05-10Fortinet, Inc.System and method for managing and provisioning virtual routers
US8069233B2 (en)2000-09-132011-11-29Fortinet, Inc.Switch management system and method
US8583800B2 (en)2000-09-132013-11-12Fortinet, Inc.Packet routing system and method
US20070121579A1 (en)*2000-09-132007-05-31Fortinet, Inc.Packet routing system and method
US9391964B2 (en)2000-09-132016-07-12Fortinet, Inc.Tunnel interface for securing traffic over a network
US8260918B2 (en)2000-09-132012-09-04Fortinet, Inc.Packet routing system and method
US9258280B1 (en)2000-09-132016-02-09Fortinet, Inc.Tunnel interface for securing traffic over a network
US7818452B2 (en)2000-09-132010-10-19Fortinet, Inc.Distributed virtual system to support managed, network-based services
US20070058648A1 (en)*2001-06-282007-03-15Fortinet, Inc.Identifying nodes in a ring network
US7890663B2 (en)2001-06-282011-02-15Fortinet, Inc.Identifying nodes in a ring network
US9998337B2 (en)2001-06-282018-06-12Fortinet, Inc.Identifying nodes in a ring network
US7580373B2 (en)2001-06-282009-08-25Fortinet, Inc.Identifying nodes in a ring network
US9143351B2 (en)2001-06-282015-09-22Fortinet, Inc.Identifying nodes in a ring network
US8208409B2 (en)2001-06-282012-06-26Fortinet, Inc.Identifying nodes in a ring network
US9602303B2 (en)2001-06-282017-03-21Fortinet, Inc.Identifying nodes in a ring network
US20060265519A1 (en)*2001-06-282006-11-23Fortinet, Inc.Identifying nodes in a ring network
US9450893B2 (en)2002-04-162016-09-20Brocade Communications Systems, Inc.System and method for providing network route redundancy across layer 2 devices
US8014301B2 (en)2002-04-162011-09-06Brocade Communications Systems, Inc.System and method for providing network route redundancy across layer 2 devices
US20090296565A1 (en)*2002-04-162009-12-03Foundry Networks, Inc.System and method for providing network route redundancy across layer 2 devices
US7558195B1 (en)*2002-04-162009-07-07Foundry Networks, Inc.System and method for providing network route redundancy across layer 2 devices
US8593987B2 (en)2002-04-162013-11-26Brocade Communications Systems, Inc.System and method for providing network route redundancy across layer 2 devices
US8542595B2 (en)*2002-06-042013-09-24Fortinet, Inc.Service processing switch
US20080259936A1 (en)*2002-06-042008-10-23Fortinet, Inc.Service processing switch
US8064462B2 (en)*2002-06-042011-11-22Fortinet, Inc.Service processing switch
US20160197836A1 (en)*2002-06-042016-07-07Fortinet, IncService processing switch
US7522604B2 (en)2002-06-042009-04-21Fortinet, Inc.Routing traffic through a virtual router-based network switch
US20070127382A1 (en)*2002-06-042007-06-07Fortinet, Inc.Routing traffic through a virtual router-based network switch
US9967200B2 (en)*2002-06-042018-05-08Fortinet, Inc.Service processing switch
US20150229567A1 (en)*2002-06-042015-08-13Fortinet, IncService processing switch
US20070064704A1 (en)*2002-06-042007-03-22Fortinet, Inc.Methods and systems for a distributed provider edge
US20120057460A1 (en)*2002-06-042012-03-08Fortinet, Inc.Service processing switch
US20070147368A1 (en)*2002-06-042007-06-28Fortinet, Inc.Network packet steering via configurable association of processing resources and netmods or line interface ports
US7668087B2 (en)2002-06-042010-02-23Fortinet, Inc.Hierarchical metering in a virtual router-based network switch
US20130308460A1 (en)*2002-06-042013-11-21Fortinet, Inc.Service processing switch
US9019833B2 (en)*2002-06-042015-04-28Fortinet, Inc.Service processing switch
US7720053B2 (en)*2002-06-042010-05-18Fortinet, Inc.Service processing switch
US20070109968A1 (en)*2002-06-042007-05-17Fortinet, Inc.Hierarchical metering in a virtual router-based network switch
US8085776B2 (en)2002-06-042011-12-27Fortinet, Inc.Methods and systems for a distributed provider edge
US8068503B2 (en)2002-06-042011-11-29Fortinet, Inc.Network packet steering via configurable association of processing resources and netmods or line interface ports
US20100220732A1 (en)*2002-06-042010-09-02Fortinet, Inc.Service processing switch
US7587633B2 (en)2002-08-292009-09-08Fortinet, Inc.Fault tolerant routing in a network routing system based on a passive replication approach
US20080016389A1 (en)*2002-08-292008-01-17Fortinet, Inc.Fault tolerant routing in a network routing system based on a passive replication approach
US8412982B2 (en)2002-08-292013-04-02Google Inc.Fault tolerant routing in a non-hot-standby configuration of a network routing system
US8819486B2 (en)2002-08-292014-08-26Google Inc.Fault tolerant routing in a non-hot-standby configuration of a network routing system
US8462668B2 (en)2002-10-012013-06-11Foundry Networks, LlcSystem and method for implementation of layer 2 redundancy protocols across multiple networks
US20090274153A1 (en)*2002-10-012009-11-05Andrew Tai-Chin KuoSystem and method for implementation of layer 2 redundancy protocols across multiple networks
US9391888B2 (en)2002-10-012016-07-12Foundry Networks, LlcSystem and method for implementation of layer 2 redundancy protocols across multiple networks
US7606229B1 (en)*2002-11-082009-10-20Cisco Technology, Inc.Generic bridge packet tunneling
US10200275B2 (en)2002-11-182019-02-05Fortinet, Inc.Hardware-accelerated packet multicasting
US20110200044A1 (en)*2002-11-182011-08-18Fortinet, Inc.Hardware-accelerated packet multicasting in a virtual routing system
US7933269B2 (en)*2002-11-182011-04-26Fortinet, Inc.Hardware-accelerated packet multicasting in a virtual routing system
US20070291755A1 (en)*2002-11-182007-12-20Fortinet, Inc.Hardware-accelerated packet multicasting in a virtual routing system
US8644311B2 (en)*2002-11-182014-02-04Fortinet, Inc.Hardware-accelerated packet multicasting in a virtual routing system
US9407449B2 (en)2002-11-182016-08-02Fortinet, Inc.Hardware-accelerated packet multicasting
US9014186B2 (en)2002-11-182015-04-21Fortinet, Inc.Hardware-accelerated packet multicasting
US20040165581A1 (en)*2002-11-202004-08-26Minoru OogushiVirtual access router
US7489700B2 (en)*2002-11-202009-02-10Hitachi Communication Technologies, Ltd.Virtual access router
US9509638B2 (en)2003-08-272016-11-29Fortinet, Inc.Heterogeneous media packet bridging
US9853917B2 (en)2003-08-272017-12-26Fortinet, Inc.Heterogeneous media packet bridging
US7664823B1 (en)*2003-09-242010-02-16Cisco Technology, Inc.Partitioned packet processing in a multiprocessor environment
US7698456B2 (en)*2003-09-292010-04-13Cisco Technology, Inc.Methods and apparatus to support routing of information
US20050083955A1 (en)*2003-09-292005-04-21Guichard James N.Methods and apparatus to support routing of information
US7827313B2 (en)*2004-02-132010-11-02Telefonaktiebolaget Lm Ericsson (Publ)Addressing method and method and apparatus for establishing host identity protocol (HIP) connections between legacy and HIP nodes
US20070274312A1 (en)*2004-02-132007-11-29Patrik SalmelaAddressing Method and Method and Apparatus for Establishing Host Identity Protocol (Hip) Connections Between Legacy and Hip Nodes
US20080008099A1 (en)*2004-03-302008-01-10Parker David KPacket processing system architecture and method
US7613209B1 (en)*2004-03-302009-11-03Extreme Networks, Inc.System and method for egress packet marking
US8161270B1 (en)2004-03-302012-04-17Extreme Networks, Inc.Packet data modification processor
US7822038B2 (en)2004-03-302010-10-26Extreme Networks, Inc.Packet processing system architecture and method
US8924694B2 (en)2004-03-302014-12-30Extreme Networks, Inc.Packet data modification processor
US7675915B2 (en)2004-03-302010-03-09Extreme Networks, Inc.Packet processing system architecture and method
US7613825B2 (en)*2004-03-312009-11-03Fujitsu LimitedHierarchical packet processing system and method, relay device and server
US20050220098A1 (en)*2004-03-312005-10-06Naoki OguchiHierarchical packet processing system and method, relay device and server
US9319303B2 (en)2004-09-242016-04-19Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US7499419B2 (en)2004-09-242009-03-03Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US9167016B2 (en)2004-09-242015-10-20Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US8213347B2 (en)2004-09-242012-07-03Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US10038567B2 (en)2004-09-242018-07-31Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US8953513B2 (en)2004-09-242015-02-10Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US9166805B1 (en)2004-09-242015-10-20Fortinet, Inc.Scalable IP-services enabled multicast forwarding with efficient resource utilization
US7808904B2 (en)2004-11-182010-10-05Fortinet, Inc.Method and apparatus for managing subscriber profiles
US20070115979A1 (en)*2004-11-182007-05-24Fortinet, Inc.Method and apparatus for managing subscriber profiles
US20060288418A1 (en)*2005-06-152006-12-21Tzu-Jian YangComputer-implemented method with real-time response mechanism for detecting viruses in data transfer on a stream basis
US7761595B1 (en)*2006-01-252010-07-20Sprint Communications Company L.P.Dynamic server addition using virtual routing
US7522595B2 (en)*2006-06-162009-04-21Cisco Technology, Inc.Communicating packets between forwarding contexts using virtual interfaces
US20070291752A1 (en)*2006-06-162007-12-20Cisco Technology, Inc.Communicating packets between forwarding contexts using virtual interfaces
US20090092136A1 (en)*2007-10-092009-04-09Broadcom CorporationSystem and method for packet classification, modification and forwarding
US20090147683A1 (en)*2007-12-102009-06-11Shakeel MustafaFlow based data packet processing
US8365045B2 (en)*2007-12-102013-01-29NetCee Systems, Inc.Flow based data packet processing
US20140359094A1 (en)*2007-12-142014-12-04Nant Holdings Ip, LlcHybrid Transport - Application Network Fabric Apparatus
US10721126B2 (en)2007-12-142020-07-21Nant Holdings Ip, LlcHybrid transport—application network fabric apparatus
US9736052B2 (en)*2007-12-142017-08-15Nant Holdings Ip, LlcHybrid transport—application network fabric apparatus
US20090201959A1 (en)*2008-02-072009-08-13Board Of Regents, The University Of Texas SystemWavelength and Intensity Monitoring of Optical Cavity
WO2009151848A1 (en)*2008-06-122009-12-17Optimum Communications Services, Inc.Packet-layer transparent packet-switching network
GB2473990B (en)*2008-06-122012-09-26Optimum Comm Services IncPacket layer transparent packet switching network
GB2473990A (en)*2008-06-122011-03-30Optimum Comm Services IncPacket layer transparent packet switching network
KR101115436B1 (en)*2008-07-312012-02-20브로드콤 코포레이션Data path acceleration of a network stack
CN101645843B (en)*2008-07-312015-11-25美国博通公司The device and method that a kind of data channel for network stack is accelerated
TWI423616B (en)*2008-07-312014-01-11Broadcom Corp Device and method for data channel acceleration for network stacking
US7908376B2 (en)*2008-07-312011-03-15Broadcom CorporationData path acceleration of a network stack
EP2150023A3 (en)*2008-07-312014-08-27Broadcom CorporationData path acceleration of a network stack
US20100027545A1 (en)*2008-07-312010-02-04Broadcom CorporationData path acceleration of a network stack
US8812730B2 (en)2008-11-172014-08-19Sierra Wireless, Inc.Method and apparatus for network port and network address translation
US8228848B2 (en)2008-11-172012-07-24Sierra Wireless, Inc.Method and apparatus for facilitating push communication across a network boundary
US20100124191A1 (en)*2008-11-172010-05-20Sierra Wireless, IncMethod and apparatus for facilitating push communication across a network boundary
US20100205260A1 (en)*2009-02-122010-08-12Sierra Wireless, Inc.Method and system for aggregating communications
US8924486B2 (en)2009-02-122014-12-30Sierra Wireless, Inc.Method and system for aggregating communications
US8654630B2 (en)2010-03-192014-02-18Brocade Communications Systems, Inc.Techniques for link redundancy in layer 2 networks
US9385912B1 (en)*2010-09-172016-07-05Amazon Technologies, Inc.Framework for stateless packet tunneling
US9037724B2 (en)2011-02-082015-05-19Sierra Wireless, Inc.Method and system for forwarding data between network devices
US8605732B2 (en)2011-02-152013-12-10Extreme Networks, Inc.Method of providing virtual router functionality
US20120254397A1 (en)*2011-03-302012-10-04Fujitsu Network Communications, Inc.Method and System for Frame Discard on Switchover of Traffic Manager Resources
US20190028389A1 (en)*2011-08-172019-01-24Nicira, Inc.Logical l3 daemon
US10027584B2 (en)*2011-08-172018-07-17Nicira, Inc.Distributed logical L3 routing
US10868761B2 (en)*2011-08-172020-12-15Nicira, Inc.Logical L3 daemon
US11695695B2 (en)2011-08-172023-07-04Nicira, Inc.Logical L3 daemon
US10977067B2 (en)2011-11-152021-04-13Nicira, Inc.Control plane interface for logical middlebox services
US8441961B1 (en)2012-12-242013-05-14Sideband Networks, Inc.Metadata-driven switch network control
US10389625B1 (en)2012-12-272019-08-20Sitting Man, LlcRouting methods, systems, and computer program products for using specific identifiers to transmit data
US10652134B1 (en)2012-12-272020-05-12Sitting Man, LlcRouting methods, systems, and computer program products
US12058042B1 (en)2012-12-272024-08-06Morris Routing Technologies, LlcRouting methods, systems, and computer program products
US11784914B1 (en)2012-12-272023-10-10Morris Routing Technologies, LlcRouting methods, systems, and computer program products
US11196660B1 (en)2012-12-272021-12-07Sitting Man, LlcRouting methods, systems, and computer program products
US11012344B1 (en)2012-12-272021-05-18Sitting Man, LlcRouting methods, systems, and computer program products
US10862791B1 (en)2012-12-272020-12-08Sitting Man, LlcDNS methods, systems, and computer program products
US10841198B1 (en)2012-12-272020-11-17Sitting Man, LlcRouting methods, systems, and computer program products
US10805204B1 (en)2012-12-272020-10-13Sitting Man, LlcRouting methods, systems, and computer program products
US10212076B1 (en)2012-12-272019-02-19Sitting Man, LlcRouting methods, systems, and computer program products for mapping a node-scope specific identifier
US10367737B1 (en)2012-12-272019-07-30Sitting Man, LlcRouting methods, systems, and computer program products
US10374938B1 (en)2012-12-272019-08-06Sitting Man, LlcRouting methods, systems, and computer program products
US10382327B1 (en)2012-12-272019-08-13Sitting Man, LlcMethods, systems, and computer program products for routing using headers including a sequence of node scope-specific identifiers
US10785143B1 (en)2012-12-272020-09-22Sitting Man, LlcRouting methods, systems, and computer program products
US10389624B1 (en)2012-12-272019-08-20Sitting Man, LlcScoped identifier space routing methods, systems, and computer program products
US10397100B1 (en)2012-12-272019-08-27Sitting Man, LlcRouting methods, systems, and computer program products using a region scoped outside-scope identifier
US10397101B1 (en)2012-12-272019-08-27Sitting Man, LlcRouting methods, systems, and computer program products for mapping identifiers
US10404582B1 (en)2012-12-272019-09-03Sitting Man, LlcRouting methods, systems, and computer program products using an outside-scope indentifier
US10404583B1 (en)2012-12-272019-09-03Sitting Man, LlcRouting methods, systems, and computer program products using multiple outside-scope identifiers
US10411997B1 (en)2012-12-272019-09-10Sitting Man, LlcRouting methods, systems, and computer program products for using a region scoped node identifier
US10411998B1 (en)2012-12-272019-09-10Sitting Man, LlcNode scope-specific outside-scope identifier-equipped routing methods, systems, and computer program products
US10419335B1 (en)2012-12-272019-09-17Sitting Man, LlcRegion scope-specific outside-scope indentifier-equipped routing methods, systems, and computer program products
US10419334B1 (en)2012-12-272019-09-17Sitting Man, LlcInternet protocol routing methods, systems, and computer program products
US10447575B1 (en)2012-12-272019-10-15Sitting Man, LlcRouting methods, systems, and computer program products
US10476787B1 (en)2012-12-272019-11-12Sitting Man, LlcRouting methods, systems, and computer program products
US10476788B1 (en)2012-12-272019-11-12Sitting Man, LlcOutside-scope identifier-equipped routing methods, systems, and computer program products
US10498642B1 (en)2012-12-272019-12-03Sitting Man, LlcRouting methods, systems, and computer program products
US10764171B1 (en)2012-12-272020-09-01Sitting Man, LlcRouting methods, systems, and computer program products
US10574562B1 (en)2012-12-272020-02-25Sitting Man, LlcRouting methods, systems, and computer program products
US10587505B1 (en)2012-12-272020-03-10Sitting Man, LlcRouting methods, systems, and computer program products
US10594594B1 (en)2012-12-272020-03-17Sitting Man, LlcRouting methods, systems, and computer program products
US10652133B1 (en)2012-12-272020-05-12Sitting Man, LlcRouting methods, systems, and computer program products
US10652150B1 (en)2012-12-272020-05-12Sitting Man, LlcRouting methods, systems, and computer program products
US10757020B2 (en)2012-12-272020-08-25Sitting Man, LlcRouting methods, systems, and computer program products
US10708168B1 (en)2012-12-272020-07-07Sitting Man, LlcRouting methods, systems, and computer program products
US10721164B1 (en)2012-12-272020-07-21Sitting Man, LlcRouting methods, systems, and computer program products with multiple sequences of identifiers
US10757010B1 (en)2012-12-272020-08-25Sitting Man, LlcRouting methods, systems, and computer program products
US10735306B1 (en)2012-12-272020-08-04Sitting Man, LlcRouting methods, systems, and computer program products
US20140250239A1 (en)*2013-03-042014-09-04Dell Products, LpSystem and Method for Routing Data to Devices within an Information Handling System
US9467368B2 (en)*2013-03-042016-10-11Dell Products, LpSystem and method for routing data to devices within an information handling system
US9462043B2 (en)*2013-03-132016-10-04Cisco Technology, Inc.Framework for dynamically programmed network packet processing
US20140280717A1 (en)*2013-03-132014-09-18Cisco Technology, Inc.Framework for Dynamically Programmed Network Packet Processing
US20160212047A1 (en)*2013-08-292016-07-21Kt CorporationPacket output controlling method and network device using same
US10103987B2 (en)*2013-08-292018-10-16Kt CorporationPacket output controlling method and network device using same
US10523564B2 (en)2013-10-072019-12-31Level 3 Communications, LlcRedirecting network traffic based on content
US9621456B2 (en)2013-10-072017-04-11Level 3 Communications, LlcRedirecting network traffic based on content
US10164882B2 (en)2013-10-072018-12-25Level 3 Communications, LlcRedirecting network traffic based on content
US8724626B1 (en)*2013-10-072014-05-13tw telecom holdings inc.Redirecting network traffic based on content
WO2015053874A1 (en)*2013-10-072015-04-16Level 3 Communications, LlcRedirecting network traffic based on content
US9923817B2 (en)2013-10-072018-03-20Level 3 Communications, LlcRedirecting network traffic based on content
US9253028B2 (en)2013-12-132016-02-02International Business Machines CorporationSoftware-defined networking tunneling extensions
US9800514B1 (en)2016-12-152017-10-24Red Hat, Inc.Prioritizing data packets in a network
US11092448B2 (en)2020-03-232021-08-17Alipay Labs (singapore) Pte. Ltd.System and method for determining routing by learned selective optimization
US10809080B2 (en)2020-03-232020-10-20Alipay Labs (singapore) Pte. Ltd.System and method for determining routing by learned selective optimization
US12284084B2 (en)*2021-05-122025-04-22L3Harris Technologies, Inc.Modeling multiple hardware routers in custom hardware
US20220368601A1 (en)*2021-05-122022-11-17L3Harris Technologies, Inc.Modeling multiple hardware routers in custom hardware
US11509704B1 (en)2021-05-282022-11-22T-Mobile Usa. Inc.Product validation based on simulated enhanced calling or messaging communications services in telecommunications network
US11770323B2 (en)2021-05-282023-09-26T-Mobile Usa, Inc.Unified interface and tracing tool for network function virtualization architecture
US11811844B2 (en)2021-05-282023-11-07T-Mobile Usa, Inc.Product validation based on simulated enhanced calling or messaging communications services in telecommunications network
US11849492B2 (en)2021-05-282023-12-19T-Mobile Usa, Inc.Unified query tool for network function virtualization architecture
US11490432B1 (en)2021-05-282022-11-01T-Mobile Usa, Inc.Unified query tool for network function virtualization architecture
US11546243B1 (en)2021-05-282023-01-03T-Mobile Usa, Inc.Unified interface and tracing tool for network function virtualization architecture
US20230095149A1 (en)*2021-09-282023-03-30Fortinet, Inc.Non-interfering access layer end-to-end encryption for iot devices over a data communication network
US12063207B2 (en)*2021-09-282024-08-13Fortinet, Inc.Non-interfering access layer end-to-end encryption for IOT devices over a data communication network
US12355740B2 (en)2021-09-282025-07-08Fortinet, Inc.Non-interfering access layer end-to-end encryption for IOT devices over a data communication network

Also Published As

Publication numberPublication date
AU2003238894A1 (en)2003-12-19
WO2003103237A1 (en)2003-12-11

Similar Documents

PublicationPublication DateTitle
US7340535B1 (en)System and method for controlling routing in a virtual router system
US7720053B2 (en)Service processing switch
US7161904B2 (en)System and method for hierarchical metering in a virtual router based network switch
US7177311B1 (en)System and method for routing traffic through a virtual router-based network switch
US7738457B2 (en)Method and system for virtual routing using containers
Nichols et al.Definition of the differentiated services field (DS field) in the IPv4 and IPv6 headers
US7630368B2 (en)Virtual network interface card loopback fastpath
US8472444B2 (en)Method and apparatus for handling traffic in a data communication network
US9521079B2 (en)Packet forwarding between packet forwarding elements in a network device
US11616717B2 (en)Service function chaining network services
US8630296B2 (en)Shared and separate network stack instances
US20240163230A1 (en)Systems and methods for using a packet processing pipeline circuit to extend the capabilities of rate limiter circuits
US7577737B2 (en)Method and apparatus for controlling data to be routed in a data communications network
US10291517B1 (en)Generating a dummy VLAN tag for indicating quality of service classification information in a distributed routing system
Kind et al.The role of network processors in active networks
US12308999B2 (en)X-over-Y tunnel signaling and configuration, and use of configured X-over-Y tunnel(s)
JP2002135309A (en) Bandwidth control device and bandwidth control network using the same

Legal Events

DateCodeTitleDescription
ASAssignment

Owner name:COSINE COMMUNICATIONS, INC., CALIFORNIA

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ALAM, NAVEED;REEL/FRAME:013482/0530

Effective date:20021010

ASAssignment

Owner name:FORTINET, INC, CALIFORNIA

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:COSINE COMMUNICATIONS, INC.;REEL/FRAME:017962/0682

Effective date:20060214

Owner name:FORTINET, INC,CALIFORNIA

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:COSINE COMMUNICATIONS, INC.;REEL/FRAME:017962/0682

Effective date:20060214

STCFInformation on status: patent grant

Free format text:PATENTED CASE

FPAYFee payment

Year of fee payment:4

REMIMaintenance fee reminder mailed
FPAYFee payment

Year of fee payment:8

SULPSurcharge for late payment

Year of fee payment:7

MAFPMaintenance fee payment

Free format text:PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment:12


[8]ページ先頭

©2009-2025 Movatter.jp