The following description relates to telecommunications in general and to cable networks in particular.
The CABLELABS(R) consortium (referred to here as “CABLELABS”) is a consortium of members of the cable industry. CABLELABS has promulgated a set of specifications and other documents (referred to here collectively as “Data Over Cable Service Interface Specification” or “DOCSIS”) that define a bi-directional, internet protocol (IP) cable network (referred to here as a “DOCSIS network”). CABLELABS also has promulgated a set of specifications and other documents (referred to here collectively as “PACKETCABLE”) that define an architecture for delivering real-time multimedia services (for example, voice telephony, voice conferencing, and gaming) over a DOCSIS network.
Among other things, PACKETCABLE specifies interfaces between the various elements of the PACKETCABLE architecture. One such interface is an “authorization interface” between a gate controller (GC) of a call management server (CMS) and a cable modem termination system (CMTS). This interface is also referred to as the “pkt-q6” interface.
In one embodiment, access switch includes at least one cable modem termination system. The cable modem termination system, when coupled to a hybrid-fiber coaxial cable network, is in communication with a media terminal adapter. The cable modem termination system includes a gate manager executing thereon. The access switch further includes a route server, in communication with the cable modem termination system, that includes a common open policy service client executing on the route server. The access switch further includes a network interface module, in communication with the cable modem termination system and the route server, that, when the network interface module is coupled to a network, communicates common open policy service messages between the common open policy service client and a call management server included in the network. When a first common open policy service message that includes a gate command is received by the common open policy service client, the common open policy service client sends a second message derived from the first common open policy service message to the gate manager. The gate manager receives the second message and processes the gate command.
Another embodiment is a route server for use in an access switch that includes at least one cable modem termination system and a network interface module for coupling the route server and the cable modem termination system to a network. The cable modem termination system includes a gate manager executing thereon. The route server includes a route look-up subsystem, and a common open policy service client. When the common open policy service client receives, from a call management server included in the network, a common open policy service message that includes a gate command, the common open policy service client sends a second message derived from the common open policy service message to the gate manager. The gate manager process the gate command.
In another embodiment, a method of processing common open policy service messages includes receiving a common open policy service message from a call management server. The common open policy service message includes a gate command. The method further includes assembling a second message that includes the gate command. The second message is derived from the common open policy service message. The method further includes sending the second message to a gate manager executing on a cable modem termination system. The method further includes, when a valid response message is received from the gate manager, assembling an acknowledgement common open policy service message derived from the valid response message and sending the acknowledgement common open policy service message to the call management server.
Another embodiment is a route server for use in an access switch that includes at least one cable modem termination system and a network interface module for coupling the route server and the cable modem termination system to a network. The cable modem termination system includes a gate manager executing thereon. The route server includes a route look-up subsystem. The route server further includes a common open policy service client that receives a common open policy service message from the call management server. The common open policy service message includes a gate command. The common open policy service client assembles a second message that includes the gate command. The second message is derived from the common open policy service message. The common open policy service client sends the second message to the gate manager, and, when a valid response message is received from the gate manager, assembles an acknowledgement common open policy service message derived from the valid response message and sends the acknowledgement common open policy service message to the call management server.
Another embodiment is a cable modem termination system for use in an access switch that includes a route server on which a common open policy service client executes and a network interface module for coupling the route server and the cable modem termination system to a network. The cable modem termination system includes a data over cable service interface specification subsystem that, when the cable modem termination system is coupled to a hybrid-fiber coaxial cable network, communicates with at least one cable modem over the hybrid-fiber coaxial cable network, and that, when the network module is coupled the managed internet protocol network, communicates with the managed internet protocol network via the network module. The data over cable service interface specification subsystem includes a quality-of-service policy manager subsystem, a classifier subsystem, and a protocol header suppression subsystem. The cable modem termination system further includes a gate manager that receives a message from the common open policy service client. The message includes a gate command derived from a common open policy service message received by the common open policy service client. The gate manager processes the gate command.
The details of one or more embodiments of the claimed invention are set forth in the accompanying drawings and the description below. Other features and advantages will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
In the embodiment shown in
In the embodiment shown in
Each CMTS 102 is also coupled to an upstream network. For example, in the embodiment shown in
In the embodiment shown in
Managed IP network 112 also includes a public switched telephone network (PSTN) interface 128 or PSTN gateway. The PSTN interface 128 includes a media gateway controller (MGC) 130, a media gateway (MG) 132, and a signaling gateway (SG) 134. The MGC 130 is the overall controller for the PSTN interface 128. The MGC 130 receives and mediates call-signaling information between the cable network 100 and a PSTN 136. The MGC 130 maintains and controls the overall call state for calls requiring PSTN interconnection. The MG 132 provides bearer connectivity between the PSTN 136 and the managed IP network 112. The MGC 130 also instructs the MG 132 to detect and to generate events and signals relevant to the call state known to the MGC 128. The SG 134 sends and receives circuit-switched network signaling at the edge of the managed IP network 112. In one embodiment, the SG 134 supports non-facility associated signaling in the form of signaling system 7 (SS7).
The managed IP network 112 communicates with various components of an operation support system (OSS) 138. For example, a record keeping server (RKS) 140 included in OSS 138 receives PACKETCABLE event messages from other PACKETCABLE network elements such as the CMS 122, CMTS 102, and MGC 130. The RKS 140 assembles the event messages into coherent sets, or call detail records (CDRs), which are then made available to other back office systems, such as billing, fraud detection, and other systems. Further information regarding the components of a managed IP network 112 are found in the PACKETCABLE specifications and documents.
The PACKETCABLE Dynamic Quality-of-Service Specification defines an “authorization interface” (also referred to as the “PKT-Q6” interface) between the GC 126 and a CMTS 102. The GC 126 of the CMS 122 uses the Common Open Policy Service (COPS) protocol to manipulate “gates” that reside logically on the CMTS 102. A “gate” is a policy control entity implemented at the CMTS 102 to control access to a QOS-guaranteed flow in the cable network 100. In the embodiment shown in
The gate manager 160 interacts with the DOCSIS 1.1 subsystem 161 of the CMTS 102. The DOCSIS 1.1 subsystem 161 includes the functionality of the CMTS 102 that manages QOS, that manages classifiers, and implements packet header suppression. For example, in the embodiment shown in
In the embodiment shown in
The route server 152 includes a route lookup subsystem 153 that provides routing functionality for the modules housed within the integrated IP access switch 104. In addition, in the embodiment shown in
The COPS client 154 listens for new COPS connections, establishes and maintains COPS connections, parses incoming COPS messages for errors, passes all GATE control messages to an appropriate CMTS 102. The COPS client 154 also receives outgoing messages from the CMTSs 102, formats appropriate COPS messages for the GC 126 based on the received messages, and forwards the outgoing COPS message to the GC 126. In effect, the COPS client 154 acts as a COPS proxy between the GC 126 and the CMTSs 102.
In one embodiment, the COPS client 154 maintains no state or information about GATEs. All such GATE information is maintained by the various CMTSs 102, as described below. In order to facilitate a clean delineation between COPS function and GATE function, the COPS client 154 parses out all GATE information from COPS messages that the COPS client 154 receives. The COPS client 154 passes the parsed GATE information to an appropriate CMTS 102. Messages sent between the CMTS 102 and the COPS client 154 are formatted in a canonical form. In the embodiment shown in
A gate identifier (also known as a “gate ID”) is a unique 32-bit identifier that is locally allocated by the CMTS 102 where an associated gate or gates reside. PACKETCABLE specifies that up to two gates may share the same gate ID. Typically, a gate ID identifies and is associated with a single upstream flow and a single downstream flow and corresponds to a single multi-media session. PACKETCABLE specifies that the gate ID must be unique among all current gates allocated by a given CMTS 102. The value of the 32-bit quantity should not be chosen from a set of small integers, since possession of the gate ID value is a key element in the authentication of the COMMIT messages from the MTA (one embodiment of which is described below). PACKETCABLE indicates that the CMTS 102 should attempt to minimize the possibility of gate ID ambiguities by ensuring that no gate ID gets reused within three minutes of its prior closure or deletion.
Advantages of the architecture described here include the following. By incorporating the gate manager 160 in the CMTS 102, when a CMTS 102 receives a Dynamic Service Delete message, the gate manager 160 is able to delete the gate indicated by the message without performing any special communications with the COPS client 154 executing on the route server 152.
Moreover, in the embodiment shown in
Similarly, when the primary route server 152 is rebooted, the COPS client 154 executing on that route server 152 will lose the current state information. When the route server 152 finishes rebooting, the CMS 122 will reestablish a TCP connection with the route server 152. The CMS 122 maintains its previously allocated gates and assumes those previously allocated gates are still operating on the CMTS 102. Again, since the gate ID knowledge is maintained by the gate managers 160 executing on the cable modem termination systems 102, no additional recovery processing is necessary in order for the COPS client 154 on the rebooted route server 152 to restart. The COPS client 154 is able to determine which CMTS 102 is associated with a particular gate ID based on the slot number that is embedded in the gate ID.
In one embodiment of the integrated IP access switch 104 shown in
In one embodiment of the access switch 104, the PACKETCABLE functionality is implemented in a manner that does not require any configuration.
In such an embodiment, each of the route server 752 and the cable modem termination systems 702 include a DOCSIS 1.1 service subsystem 770 and 772, respectively, and a PACKETCABLE (or other multimedia) service subsystem 774 and 776, respectively. For example, the DOCSIS 1.1. service subsystem 770 of the route server 752 includes the underlying DOCSIS packet routing functionality (for example, the route lookup subsystem 153 described above in connection with
In the embodiment shown in
The PACKETCABLE service subsystems 774 and 776 include one or more pre-configured parameters 788 and 790, respectively. Appropriate values for the pre-configured parameters 788 and 790 are supplied by the manufacturer of the route server 752 and the cable modem termination system 702, for example, during the manufacturing process or during a system upgrade (for example, via a software or firmware upgrade).
In operation, the access switch 704 is configured by an end user to provide DOCSIS 1.1 service by using the management application 782 to view and modify the user configurable parameters 778 and 780. After such configuration is done, the PACKETCABLE functionality is automatically provided with no additional configuration beyond that required to provide DOCSIS 1.1 service. This is because the PACKETCABLE service subsystems 774 and 776 are preconfigured. This improves the ease with which PACKETCABLE functionality can be incorporated into a cable network.
The COPS client 154 exchanges COPS messages with the GC 126 of the CMS 122 and exchanges message (referred to here as MR messages) with the various gate managers 160 running on respective cable modem termination systems 102 housed within the integrated IP access switch 104.
The MR message header 402 also includes a message type field 408 that indicates to what type of COPS message the MR message corresponds. For example, in one such embodiment, the message type field 408 contains a value corresponding to one of the following COPS message types: GATE-ALLOC, GATE-ALLOC-ACK, GATE-ALLOC-ERR, GATE-SET, GATE-SET-ACK, GATE-SET-ERR, GATE-INFO, GATE-INFO-ACK, GATE-INFO-ERR, GATE-DELETE, GATE-DELETE-ACK, or GATE-DELETE-ERR.
The MR message header 402 also includes a COPS session context field 410 that contains a unique identifier for each existing COPS connection between route server 152 and the CMS 122. This identifier is chosen by the route server 152 to authenticate messages being exchanged from various call management servers 122. The COPS client 154, in MR messages to be sent to the gate manager 160, populates the COPS session context field 410 based on the respective COPS connection identifier information. The gate manager 160, in MR messages sent from the gate manager 160 to the COPS client 154, uses the COPS session context supplied in a corresponding MR message received from the COPS client 154.
The MR message header 402 also includes a route server chassis address field 412. The route server chassis address field 412 contains an address of the card (or other module) on which the COPS client 154 executes. In the embodiment, shown in
The MR message header 402 also includes a flow direction field 414 that indicates the direction (for example, upstream, downstream, or both) of the flow or flows associated with the particular message. The COPS client 154 and the gate manager 160 set the flow direction field based on the direction of the flow or flows associated with the particular message. MR message also includes CMS IP address information that provides a security mechanism such that only a particular CMS can operate on that CMS's respective gates.
The format of the message relay COPS object 404, shown in
If the TCP message is a TCP data message, the TCP message is converted into a COPS message (block 508). Only the processing for COPS decisions messages (that is, COPS messages having an op-code field 308 indicates that a DECISION operation is to be performed) is shown in detail in
If the COPS message is a decision COPS message, it is determined if the handle for the current COP session matches the handle included in the COPS message (checked in blocked 514). If the handles do not match, the COPS message is discarded (block 516). If the handles match, it is determined if the appropriate object types are included in the COPS message for the type of gate command specified in the gate command field 354 of the transaction (checked in block 518 shown in
If all of the expected COPS objects are included in the COPS message, the CMTS 102 that processes gate commands for the subscriber specified in the subscriber ID COPS object or gate ID specified in the gate ID object is identified (block 522). For example, in one embodiment, if a gate ID has been generated in the manner described in connection with
If an appropriate CMTS 102 is identified, a message relay message is assembled and sent to the identified CMTS 102 (block 528). A message relay message is formatted with the information described above in connection with
After the MR message is sent, the COPS client 154 waits to receive a valid response from the CMTS 102 to which the MR message was sent (checked in block 530). The response will be in the form of a MR message sent from the gate manager 160 of the CMTS 102 to the message relay 156 of the COPS client 154. If an improper response is received or if no response is received within a predetermined time period, an appropriate error message is assembled by the COPS client 154 and sent to the GC 126 (block 532). After the error message is sent, the method 500 waits for the next TCP message (looping back to block 502). In alternative embodiment (not shown in
In the embodiment shown in
Initially, the state machine 600 is in a START state 602. While the state machine 600 is in the START state 602, when the gate manager 160 receives from the COPS client 154 a MR message that has a message type of GATE-ALLOC (that is, a GATE-ALLOC MR message), the gate manager 160 verifies that the number of gates already allocated for the subscriber ID specified in the subscriber ID field 422 of the GATE-ALLOC MR message has not exceeded the gate limit for that subscriber ID (contained in the activity count field 424 of the GATE-ALLOC MR message, which is derived from an activity count object included in a corresponding GATE-ALLOC COPS message received by the COPS client 154). In some instances, the gate manager 160 does not check the number of gates already allocated. The gate controller 126, in such instances, does not include an activity count COPS object in the corresponding to GATE-ALLOC COPS message sent to the COPS client 154. In such a case, the activity count field 424 of the corresponding GATE-ALLOC MR message is not populated and the check is not performed. If the gate limit has not been exceeded or if the gate limit check is not be performed by the gate manager 160, the gate manager 160 allocates a gate and a locally unique gate ID (for example, as illustrated above in connection with
A timer T0 is started when the state machine 600 enters the ALLOCATED state 604. Timer T0 is a countdown timer that is initialized with a predetermined initial period. Timer T0 limits the amount of time the gate ID will remain in the ALLOCATED state 604 without any specified gate parameters. If timer T0 expires while the state machine 600 is in the ALLOCATED state 604, the gate is freed, the COPS client 154 sends a GATE-CLOSE COPS message to the CMS 122, and the state machine 600 enters an END state 612.
While the state machine 600 is in the START state 602, when the gate manager 160 receives a MR message that has a message type of GATE-SET (that is, a GATE-SET MR message), the gate manager 160, the gate manager 160 verifies that the number of gates already allocated for the subscriber ID specified in the subscriber ID field 422 of the GATE-SET MR message has not exceeded the gate limit for that subscriber ID contained in the activity count field 424 of the MR message. If the gate limit has not been exceeded, the gate manager 160 allocates a gate and a locally unique gate ID. The gate manager 160 also performs a gate set integrity check. For example, in one such embodiment, the gate set integrity check includes verifying that the gate limit is not exceeded, performing a range check on the flow direction field 414, checking that the T1 and T2 values match across all gate specs, and checking that there is at least one gate spec. The gate set integrity check also includes, when there are two gate specs, checking that the two gate specs have different directions.
If the number of gate already allocated for the subscriber ID exceeds the gate limit or if an error is discovered as a part of the gate set integrity check, a GATE-SET-ERROR MR message is sent by the gate manager 160 to the COPS client 154 specifying an appropriate error code in the error field 436 and the state machine 600 transitions to the END state 612.
If no such error is discovered, a GATE-SET-ACK MR message is sent from the gate manager 160 to the COPS client 154, which sends a GATE-SET-ACK COPS message to the CMS 122 based on the received MR message. Also, the state machine 600 enters the AUTHORIZED state 606. After the state machine 600 enters the AUTHORIZED state 606, the gate manager 160 starts a countdown timer T1. Also, the gate manager 160 notifies the QPM 162, the CLS 164, and the PHS 166 of the existence of the authorized gate. Notifying the QPM 162 allows the QPM 162 to watch for, receive, and properly respond to a DSA-Request message from the MTA 108. The timer T1 is initially set to a predetermined starting value. This timer can be provisioned in the CMTS. In case the timer is not provisioned, then the CMTS starts the timer based on the value specified in the GATE-SET message. Timer T1 limits the amount of time the authorization will remain valid without being committed.
While the state machine 600 is in the ALLOCATED state 604, when the gate manager 160 receives a MR message that has a message type of GATE-SET (that is, a GATE-SET MR message), the gate manager 160 performs a gate set integrity check. If an error is discovered as a part of the gate set integrity check, a GATE-SET-ERROR MR message is sent by the gate manager 160 to the COPS client 154 specifying an appropriate error code in the error field 436 and the state machine 600 remains in the ALLOCATED state 604.
If no such error is discovered, a GATE-SET-ACK MR message is sent from the gate manager 160 to the COPS client 154, which sends a GATE-SET-ACK COPS message to the CMS 122 based on the received MR message. Also, the T0 timer is stopped and the state machine 600 enters the AUTHORIZED state 606. After the state machine 600 enters the AUTHORIZED state 606, the gate manager 160 starts the countdown timer T1. Also, the gate manager 160 notifies the QPM 162, the CLS 164, and the PHS 166 of the existence of the authorized gate.
While the state machine 600 is in the AUTHORIZED state 606, if a subsequent GATE-SET MR message is sent from the COPS client 154 to the gate manager 160 (in response to a GATE-SET COPS message from the CMS 122), the gate set integrity check is performed for the information supplied in the subsequent GATE-SET MR message. If an error is discovered by the gate set integrity check, a SET-ERR MR message is sent by the gate manager 160 to the COPS client 154 specifying an appropriate error code in the error field 436 and the state machine 600 remains in the AUTHORIZED state 606 and the timer T1 is not restarted. The COPS client 154, in such a case, sends a GATE-SET-ERR COPS message to the CMS 122 based on the information supplied in the SET-ERR MR message.
If no such error is discovered, a GATE-SET-ACK MR message is sent from the gate manager 160 to the COPS client 154, which sends a GATE-SET-ACK COPS message to the CMS 122 based on the received MR message. Also, the state machine 600 remains in the AUTHORIZED state 606 and the T1 timer continues to run.
While the state machine 600 is in the AUTHORIZED state 606, it is expected that the MTA 108 will attempt to reserve resources at some point prior to the expiration of the timer T1. The MTA 108 does this by exchanging DOCSIS 1.1 Dynamic Service Add (DSA) messages with the DSX 165 (that is, DSA Request, DSA Response, and DSA Acknowledgement messages).
If timer T1 expires while the state machine 600 is in the AUTHORIZED state 606, the gate manager 160 frees the resources associated with the gate ID, sends a GATE-CLOSE MR message to the COPS client 154, and the state machine 600 enters an END state 612.
When the DSX 165 receives a DSA Request message from the MTA 108, the QPM 162 inspects the authorization block of the DSA Request. The gate ID for the gate is encoded in the authorization block. The QPM 162 performs the admission control for the flows associated with that gate ID. If QPM 162 admits the flows associated with that gate ID, the QPM 162 reserves appropriate QOS resources for the flows. In other words, the flows are reserved but not yet available for the MTA 108 to use. This includes having the CLS 164 add an appropriate classifier for the flows and the PHS 166 add an appropriate PHS rule for the flows. A DSA Response message is sent from the DSX 165 to the MTA 108, which in return sends a DSA Acknowledgement message back to the DSX 165. Then, QPM 162 signals to the gate manager 160 that the flows have been admitted. The gate manager 160 causes the state machine 600 to enter the RESERVED state 608. If the QPM 162 does not admit the flow, the DSX 165 does not send a DSA Response message to the MTA 108 and the state machine 600 remains in the AUTHORIZED state 606. As noted above, if the timer T1 expires while the state machine 600 remains in the AUTHORIZED state 606, the gate manager 160 frees the gate, sends a GATE-CLOSE MR message to the COPS client 154, and the state machine 600 enters an END state 612.
While the state machine 600 is in the RESERVED state 608, it is expected that the MTA 108 will attempt to commit the reserved resources at some point prior to the expiration of the timer T1. The MTA 108 does this by exchanging DOCSIS 1.1 Dynamic Service Change (DSC) messages with the DSX 165 (that is, DSC Request, DSC Response, and DSC Acknowledgement messages). If timer T1 expires while the state machine 600 is in the RESERVED state 608, the gate manager 160 frees the resources associated with the gate ID, sends a GATE-CLOSE MR message to the COPS client 154, and informs the QPM 162 to send a DSD message and the state machine 600 enters an END state 612.
When the DSX 165 receives a DSC Request message from the MTA 108, the QPM 162 commits the reserved QOS resources so that the MTA 108 is free to use the flow. If the QPM 162 successfully commits the QOS resources, the DSX 165 then sends a DSC Response to the MTA 108, which the MTA 108 responds to by sending to the DSX 165 a DSC Acknowledgement after receipt of the DSC-Response message. The QPM 162 signals to the gate manager 160 that the flow associated with the gate ID has been activated. The gate manager 160 stops the timer T1 timer. Then, gate manager 160 causes the state machine 600 to enter the COMMITTED state 610. If the QPM 162 is unable to commit the QOS resources, the DSX 165 does not send a DSC Response message to the MTA 108 and the state machine 600 remains in the RESERVED state 608. As noted above, if the timer T1 expires while the state machine 600 remains in the RESERVED state 608, the gate manager 160 frees the resources associated with the gate ID, sends a GATE-CLOSE MR message to the COPS client 154, and the state machine 600 enters an END state 612.
In the embodiment shown in
While the state machine 600 is in the COMMITTED state 610, when the users complete the call and hang-up, the MTA 108 sends a Dynamic Service Delete (DSD) Request message to the DSX 165. The DSX 165 receives the DSD Request message. In response, the QPM 162 deletes the underlying flows associated with the gate ID, and the other DOCSIS 1.1 subsystems free the resources allocated for that gate ID. The DSX 165 sends a DSD Response message to the MTA 108, to which the MTA 108 responds by sending to the DSX 165 a DSD Acknowledgement after receipt of the DSD-Response message. The QPM 162 notifies the gate manager 160 of the deletion of the underlying flows and the gate manager 160 causes the state machine 500 to enter the END state 612.
While the state machine 600 is in any state (shown with by the ANY STATE state 614 in
While the state machine 600 is in any state (shown with by the ANY STATE state 614 in
By having the DOCSIS 1.1. subsystem (for example, the QPM 162 and DSX 165) process the DSX messages (DSA, DSC, and DSD) messages prior to having the gate manager 160 change the state of the associated gate, improper state transitions can be avoided. Moreover, embodiments of state machine 600 virtualize the management of the state of a gate. In other words, the state machine 600 is implemented on top of the underlying DOCSIS 1.1 subsystem, which manages the underlying flows associated with the gate. This, in some situations, reduces the amount of changes necessary to implement the PACKETCABLE functionality on top of an existing DOCSIS 1.1 code base.
Those skilled in the art will recognize that the techniques and methods described here are implemented, in some embodiment, by programming a programmable processor (for example, a microprocessor included on a route server, CMTS, or other device) with appropriate instructions to implement the functionality described here. In such embodiments, such program instructions are stored in a suitable memory device (for example, read-only memory and/or random-access memory) from which the program instructions are retrieved during execution. Also, suitable data structures are stored in memory in such embodiments. For example, in one such embodiment, the techniques and methods described here are implemented by programming one or more of the processors described in the '039 application.
The methods and techniques described here may be implemented in digital electronic circuitry, or with a programmable processor (for example, a special-purpose processor or a general-purpose processor such as a computer) firmware, software, or in combinations of them. Apparatus embodying these techniques may include appropriate input and output devices, a programmable processor, and a storage medium tangibly embodying program instructions for execution by the programmable processor. A process embodying these techniques may be performed by a programmable processor executing a program of instructions to perform desired functions by operating on input data and generating appropriate output. The techniques may advantageously be implemented in one or more programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and DVD disks. Any of the foregoing may be supplemented by, or incorporated in, specially-designed application-specific integrated circuits (ASICs).
A number of embodiments of the invention defined by the following claims have been described. Nevertheless, it will be understood that various modifications to the described embodiments may be made without departing from the spirit and scope of the claimed invention. Accordingly, other embodiments are within the scope of the following claims.