US 6973088 B2
This disclosure describes techniques for establishing a PPP data session between a user terminal (UT) and an Interworking Function (IWF). The process involves establishing a PPP2 link with the IWF in response to detecting a mobile IP data session request from the UT, detecting a PPP1 link with the UT in response to the PPP2 link being established, detecting that a PPP2 link failure has occurred, and reconfiguring at least one of the WCD and the UT to an initial state.
1. A wireless communication device (WCD) for establishing a PPP data session between a user terminal (UT) and an Interworking Function (IWF), comprising:
means for establishing a PPP2 link with the IWF in response to detecting a mobile IP data session request from the UT;
means for detecting a PPP1 link with the UT in response to the PPP2 link being established;
means for detecting that a PPP2 link failure has occurred; and
means for reconfiguring at least one of the WCD and the UT to an initial state.
2. The WCD of
3. The WCD of
4. The WCD of
5. The WCD of
6. The WCD of
7. The WCD of
8. The WCD of
9. The WCD of
10. In a wireless communication device (WCD), a method of establishing a PPP data session between a user terminal (UT) and an Interworking Function (IWF), comprising:
establishing a PPP2 link with the IWF in response to detecting a mobile IP data session request from the UT;
detecting a PPP1 link with the UT in response to the PPP2 link being established;
detecting that a PPP2 link failure has occurred; and
reconfiguring at least one of the WCD and the UT to an initial state.
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. The method of
17. The method of
18. The method of
This application claims the benefit of provisional U.S. Application Ser. No. 60/370,033 filed on Apr. 3, 2002, assigned to the assignee of the present application, and incorporated herein by reference in its entirety for all purposes.
This application is related to co-pending patent application filed on Jan. 21, 2003, entitled “SYSTEM AND METHOD FOR TRANSPARENT MOBILE IP REGISTRATION,” Ser. No. 10/348,937, assigned to the same Assignee as the present application.
This disclosure relates to wireless data services, more particularly to PPP link negotiations in mobile IP systems.
Internetworking, i.e., the connection of individual local area networks (LANs), has rapidly become very popular. The infrastructure and associated protocols commonly referred to as the “Internet” have become well known and widely used. At the heart of the Internet is the Internet Protocol (IP) which supports the routing of datagrams between the LANs as is well known in the art, and further described in Request For Comment (RFC) 791 entitled, “INTERNET PROTOCOL DARPA INTERNET PROGRAM PROTOCOL SPECIFICATION,” dated September 1981.
IP is a datagram-oriented protocol that provides several services, including addressing. The IP protocol encapsulates data into an IP packet for transmission, and affixes addressing information to the header of the packet. IP headers contain 32-bit addresses that identify the sending and receiving hosts. These addresses are used by intermediate routers to select a path for the packet through the network towards its ultimate destination at the intended address. A basic concept of IP addressing is that initial prefixes of the IP address can be used for generalized routing decisions. For example, the first 16 bits of an address might identify Company A, the first 20 bits identify Company A's main office, the first 26 bits identify a particular Ethernet in that office, and the entire 32 bits identify a particular host on that Ethernet. As a further example, every address in Company A's IP network might be of the form (in “dotted-quad notation”): 129.46.xxx.xxx, where “xxx” refers to any allowable integer between zero and 255.
As is evident by this prefix-based routing characteristic of IP, the IP addresses contain implied geographical information about the location of a particular host on the Internet. In other words, whenever any router on the Internet receives a packet having a destination IP address that begins “129.46” the router forwards that packet in a particular direction towards Company A's network in San Diego, Calif., USA. Thus, the IP protocol allows datagrams originating at any Internet node in the world to be routed to any other Internet node in the world, given that the originating party knows the IP address of the destination party.
As mobile computing and mobile Internet access have grown in popularity, a need has arisen to provide mobile data support for mobile terminals such as laptop or palmtop computers using the IP protocol. However, as just mentioned, the IP addressing scheme used for Internet routing contains implied geographic information. In other words, if a user desires to use a fixed IP address to identify his mobile terminal, the IP packets intended for that mobile terminal will not be routed to that mobile terminal when it is away from its “home” network (i.e., the network which encompasses its fixed IP address) in the absence of some technique for “forwarding” IP packets to the mobile terminal.
For example, suppose a user decides to remove his mobile user terminal from its “home” IP network at Company A in San Diego, and take it with him on a trip to Palo Alto, Calif., and there connect to Stanford University's IP network while still keeping his Company assigned fixed IP address. Any IP datagram intended for the mobile user terminal will still be routed to Company A's IP network because of the geographical location information implicit in the mobile user terminal's fixed IP address. Such IP packets will not be delivered to the mobile user terminal while away from its “home” network unless some mechanism is in place to forward IP packets from Company A's IP network to the mobile user terminal at its current point of attachment to the Internet at Stanford University's IP network in Palo Alto.
In order to meet this need, RFC 2002, entitled “IP Mobility Support,” Network Working Group, Ed., C. Perkins, IBM, dated October 1996 (available on the world wide web at http://www.rfc.net/rfc2002.html), specifies protocol enhancements that allow transparent routing of IP datagrams to mobile nodes in the Internet. Using the techniques described in RFC 2002, each mobile node may always be identified by its “home” IP address, regardless of its current point of attachment to the Internet. While situated away from its home IP network, a mobile user terminal may become associated with a “care-of” address, thereby providing forwarding information necessary to route IP datagrams to its current point of attachment to the Internet. RFC 2002 accomplishes this by providing for registration of the care of address with a “home agent.” This home agent forwards IP datagrams intended for the mobile terminal by using a technique called “IP tunneling.” IP tunneling involves the home agent attaching a new IP header which contains the care-of address to any arriving IP packet which has a destination address corresponding to the mobile user terminal's home IP address. After arriving at the care-of address, a “foreign agent” at the care-of address strips off the IP tunneling header, and delivers the IP packet to the mobile user terminal at its current point of attachment to the Internet.
In this way, the techniques of RFC 2002 provide mobile data services for users who desire to relocate their mobile terminal's point of attachment to the Internet without having to change the mobile terminal's IP address. This ability has several advantages. First, it allows originating nodes elsewhere on the Internet to send periodic “push” services to the mobile user terminal regardless of where it is. Such services might include stock quotes or e-mail. This obviates the need for the mobile user to “dial in” or otherwise contact his home network in order to retrieve information. Furthermore, it allows the mobile terminal to relocate as often as desired, without any originating parties having to keep track of where the mobile terminal is currently located.
To increase the freedom of mobility of the mobile user terminal, many mobile users will typically use wireless communication devices (sometimes referrred to as “WCDs”, such as cellular or portable phones, or analogous wireless communication devices, commonly referred to as “mobile stations,” as the point of access to the land-based Internet network. As used herein, “mobile station” will refer to any subscriber station in the public wireless radio network that is intended to be used while in motion or during halts at unspecified points. Mobile stations include portable units (e.g., hand-held personal phones, wireless modems, etc.) and units installed in vehicles, as well as wireless local loop (WLL) telephones.
Many protocols exist which allow data communication between a mobile user terminal and an Interworking Function (IWF), or internal interface. For example, Telecommunications Industry Association (TIA)/Electronics Industries Association (EIA) Interim Standard IS-707.5, entitled “Data Service Options for Wideband Spread Spectrum Systems: Packet Data Services,” published February 1998, defines requirements for support of packet data transmission capability on TIA/EIA IS-95 wideband spread spectrum systems. IS-707.5 specifies a packet data bearer service that may be used for communication between a mobile terminal and an IWF via a Base Station/Mobile Switching Center (BS/MSC). It provides procedures that can apply to multiple packet data services, including the Mobile IP service of RFC 2002, as well as Cellular Digital Packet Data (CDPD) which is described in CDPD-1995, entitled “Cellular Digital Packet Data System Specification, Version 1.1,” published Jan. 29, 1995 by the CDPD Forum, Inc.
CDPD is an Analog Mobile Phone System (AMPS) cellular data service, which includes some of its own support for mobility. CDPD differs from Mobile IP in several significant ways. Most notably, a CDPD modem has an assigned IP address that belongs to the CDPD network. So although a CDPD modem may roam within the CDPD network, it may not use its IP address outside of the CDPD network in the same way that a Mobile IP supported terminal may use its “home” IP address outside of its “home” network.
IS-707.5 also provides the requirements for communication protocols on the links between a mobile user terminal and a wireless communications device (the Rm interface), between the wireless communications device and the BS/MSC (the Um interface), and between the BS/MSC and the IWF.
Wireless communications networks offer much flexibility to the user, in that they allow users of portable communications devices, such as personal digital assistants, laptop computers, telephones, and other appliances to connect to the Internet from any location within the region served by the wireless network. For example, in a personal communication system by which a mobile user terminal uses an RF link to communicate with an intelligent base station, the intelligent base station provides the mobile terminal with access to a Packet Data Switched Network (PDSN), through which a connection to the IWF is made.
The PDSN provides access to the Internet, intranets and Wireless Application Protocol (WAP) servers. The PDSN acts as an access gateway for simple Internet Protocol and Mobile Internet Protocol users. It provides foreign agent support and packet transport for virtual private networking. It also acts as an Authentication, Authorization, and Accounting (AAA) client.
IPv4 (Internet Protocol version 4) assumes that a node's Internet Protocol (IP) address uniquely identifies the node's point of attachment to the Internet. Therefore, a node must be located on the network indicated by its IP address in order to receive datagrams destined to it; otherwise, datagrams destined to the node would be undeliverable.
For a node to change its point of attachment without losing its ability to communicate, currently one of the two following mechanisms must typically be employed: a) the node must change its IP address whenever it changes its point of attachment, or b) host-specific routes must be propagated throughout much of the Internet routing fabric. Both of these alternatives are often unacceptable. The first makes it impossible for a node to maintain transport and higher-layer connections when the node changes location. The second has obvious and severe scaling problems, especially relevant considering the explosive growth in sales of mobile computers equipped with wireless communication devices.
Mobile IP is a protocol that allows laptop computers or other mobile computer units (referred to as “Mobile Nodes” herein) to roam between various sub-networks at various locations—while maintaining Internet and/or WAN connectivity. Without Mobile IP or related protocol, a Mobile Node would be unable to stay connected while roaming through various sub-networks. This is because the IP address required for any node to communicate over the Internet is location specific. Each IP address has a field that specifies the particular sub-network on which the node resides. If a user desires to take a computer that is normally attached to one node and roam with it so that it passes through different sub-networks, it cannot use its home base IP address. As a result, a business person traveling across the country cannot merely roam with his or her computer across geographically disparate network segments or wireless nodes while remaining connected over the Internet. This is not an acceptable state-of-affairs in the age of portable computational devices.
To address this problem, the Mobile IP protocol has been developed and will soon be implemented. An implementation of Mobile IP is described in RFC 2002 of the Network Working Group, C. Perkins, Ed., October 1996. Mobile IP is also described in the text “Mobile IP Unplugged” by J. Solomon, Prentice Hall. Both of these references are incorporated herein by reference in their entireties and for all purposes.
Mobile IP provides a method to allow IP traffic to find nodes whose point of attachment to the Internet changes. An IP address implies a geographical/topological location for a particular node; for example, all of the IP packets with a destination address of 129.46.x.x will be forwarded to San Diego. If a mobile user wanted to use one of these addresses and connect to the Internet via some other Internet service provider, that address would be topologically incorrect, and the packets would never find the mobile in question, as they would be sent to the corporate network, and not to the network belonging to the Internet Service Provider (ISP) where the mobile has attached itself. Mobile IP provides a mechanism for forwarding these packets to the mobile node, regardless of its location.
The most significant differences between simple IP and Mobile IP is that simple IP calls require only that Point-to-Point Protocol (PPP) be negotiated, while Mobile IP calls require that PPP be established and the mobile node registration occur. Simple IP calls have IP address assignment made during PPP negotiation, while Mobile IP calls have an IP address assignment made during Mobile IP Registration.
The PPP protocol is described in detail in the publication entitled “The Point-to-Point Protocol (PPP),” Simpson, W., Editor, STD 51, RFC 1661, July, 1994.
To maintain connectivity, as a mobile user moves within and without cellular boundaries, in either satellite or terrestrial cellular networks, the wireless link must be disconnected from the old transceiver and relinked to the new transceiver. To initiate a new link, the mobile user and the cell transceiver pass link control messages, negotiating link options for the subsequent data between the mobile user and the cell transceiver to negotiate the options to be used on the new link. Several link control signals exchange data and negotiate the parameters to be used to pass data. After the negotiations are completed, the mobile user can communicate using the wireless signal. Unfortunately, the relinking process can fail, resulting in no connection to the mobile user. When that happens, the mobile user terminal may lock up. This will prevent new calls from being established until the user terminal is rebooted.
There is a need for performing Mobile IP registration of a mobile user terminal more efficiently, with the wireless communications device acting as a proxy for the user terminal, in order to establish Mobile IP support for the user terminal and to avoid problems associated with conventional techniques.
This disclosure describes techniques for establishing a PPP data session between a user terminal (UT) and an Interworking Function (IWF). The process involves establishing a PPP2 link with the IWF in response to detecting a mobile IP data session request from the UT, detecting a PP1 link with the UT in response to the PP2 link being established, detecting that a PPP2 link failure has occurred, and reconfiguring at least one of the WCD and the UT to an initial state.
The Mobile IP process and environment includes the Internet over which a Mobile Node (e.g., a laptop computer) can communicate remotely via mediation by a Home Agent and a Foreign Agent. Typically, the Home Agent and Foreign Agent are routers or other network connection devices performing appropriate Mobile IP functions as implemented by software, hardware, and/or firmware. A Home Agent is the router or other Internet connection device located at the place where the user terminal normally resides. A Foreign Agent is any other router or other Internet connection device. A particular Mobile Node plugged into its home network segment connects with the Internet through its designated Home Agent. When such a Mobile Node roams, it communicates via the Internet through an available Foreign Agent. Presumably, there are many Foreign Agents available at geographically disparate locations to allow wide spread Internet connection via the Mobile IP protocol.
A Mobile Node normally resides on (or is “based at”) a network segment that allows its network entities to communicate over the Internet through the Home Agent. The Home Agent need not directly connect to the Internet.
The Mobile Node may be removed from its home base network segment and roam to a remote network segment. The remote network segment will typically communicate with the Internet through a router acting as a Foreign Agent. The Mobile Node may identify the Foreign Agent through various solicitations and advertisements that form part of the Mobile IP protocol. When the Mobile Node engages with the remote network segment, the Foreign Agent relays a registration request to the Home Agent. The Home and Foreign Agents may then negotiate the conditions of the Mobile Node's attachment to the Foreign Agent. For example, the attachment may be limited to a period of time, such as two hours. When the negotiation is successfully completed, the Home Agent updates an internal “mobility binding table” which specifies the Foreign Agent's IP address in association with the identity of the Mobile Node. Further, the Foreign Agent updates an internal “visitor table” which specifies the Mobile Node address, Home Agent address, etc. In effect, the Mobile Node's home base IP address has been shifted to the Foreign Agent's IP address.
Now, suppose that the Mobile Node wishes to send a message to a corresponding node from its new location. An output message from the Mobile Node is then packetized and forwarded through the Foreign Agent over the Internet to the corresponding node according to a standard Internet protocol. If the corresponding node wishes to send a message to the Mobile Node—whether in reply to a message from the Mobile Node or for any other reason—it addresses that message to the IP address of the Mobile Node at its Home Agent. The packets of that message are then forwarded over the Internet ultimately to the Home Agent. From its mobility binding table, the Home Agent recognizes that the Mobile Node is no longer attached to the home network segment. It then encapsulates the packets from the corresponding node (which are addressed to the Mobile Node on the home network segment) according to a Mobile IP protocol and forwards these encapsulated packets to a “care of” (C.O.) address for the Mobile Node. The C.O. address is the IP address of the Foreign Agent. The Foreign Agent then strips the encapsulation and forwards the message to the Mobile Node at the Foreign Agent.
User terminal 102 is coupled to wireless communication device 104, typically via a wired serial connection. Communication device 104 is in wireless communication with PDSN 106 and IWF 108.
An example of the operation of
The TCP protocol, also an upper layer protocol 202, opens a connection to the IP address specified by DNS port 80, and transmits the HTTP GET message. The TCP protocol specifies that the IP protocol will be used for message transport. The IP protocol 204 transmits the TCP packets to the IP address specified. The Point to Point Protocol (PPP), a link layer protocol 206, encodes the IP/TCP/HTTP packets and transmits them across the Rm interface using relay layer EIA-232 protocol 208 to the EIA-232-compatible port on wireless communication device 104. PPP contains two protocols: the link control protocol (LCP) and Internet protocol control protocol (IPCP). These two protocols have to be negotiated independently. The LCP protocol is negotiated first. Once that is set up, then the IPCP protocol is negotiated. Once IPCP negotiation has been completed, Mobile IP Registration is conducted, at which time an IP address is assigned to user terminal 102 by PDSN 106.
An EIA-232 protocol 210 on wireless communication device 104 passes the transmitted PPP packet to a combination of a Radio Link Protocol (RLP) 212 and an IS-95 protocol 214 for transmission to PDSN 106 over the Um air interface. RLP protocol 212 is defined in IS-707.2, and the IS-95 protocol 214 is defined in IS-95 mentioned above. A complementary relay layer protocol stack on PDSN 106, including a combination of RLP protocol 216 and IS-95 protocol 218 receives the PPP packets over the Um air interface, and passes them to a wireless communication relay layer protocol 220 over the wired PDSN-IWF interface L to an IWF relay layer protocol 228. Wireless communication relay layer protocol 220 and IWF relay layer protocol 228 are described in TIA/EIA IS-658 entitled, “Data Services Interworking Function Interface Standard for Wideband Spread Spectrum Digital Cellular System.”
A PPP protocol 226 in the link layer of IWF 108 decodes the PPP packets from user terminal 102, and serves to terminate the PPP connection between user terminal 102 and IWF 108. The decoded packets are passed from PPP protocol 226 to the IP protocol in network layer protocols 224 of IWF 108 for examination, and further routing to the IP address specified by user terminal 102 in the IP packet header (here, the IP address for www.companya.com). If there are any upper layer protocol tasks to be performed at IWF 108, such as TCP, they are performed by upper layer protocols 222.
Assuming that the ultimate destination of the IP packets generated by user terminal 102 is not IWF 108, the packets are forwarded through network layer protocols 224, PPP protocols 226 and relay layer protocols 228 of IWF 108 to the next router (not shown) on the Internet. In this manner, IP packets from user terminal 102 are communicated through wireless communication device 104, PDSN 106, and IWF 108 towards their ultimate intended destination on the Internet, thereby providing wireless packet data services for user terminal 102 according to the IS-707.5 standard relay model.
As illustrated in
In order to establish communications over a point-to-point link, each end of the PPP link must first send link layer control protocol (LCP) packets to configure and test the data link. After the link has been established, the peer may be authenticated. Then, PPP must send network layer control protocol (NCP) packets to choose and configure one or more network-layer protocols. Once each of the chosen network-layer protocols has been configured, datagrams from each network-layer protocol can be sent over the link. The link will remain configured for communications until explicit LCP or NCP packets close the link down, or until some external event occurs (an inactivity timer expires or network administrator intervention).
Establishing the Mobile IP Connection
User terminal 102 may move from one PDSN to another PDSN. This can happen, for example, if user terminal 102 is a laptop computer that is being operated on a train or airplane in motion. It is highly desirable to maintain the same IP address for the user terminal and to ensure that the handoffs or transfers between different PDSNs be transparent to the user and allow the user to continue to run programs over the Internet without interruption.
Conventionally, when the user terminal received a connect signal, this would immediately trigger a PPP negotiation session on the Rm interface. Once the PPP had been negotiated on the Rm link, then a PPP negotiation session would take place over the Um interface.
In known systems, an Internet data session begins when user terminal 102 issues a command to wireless communication device 104 to initiate a data session. This command may typically comprise an “ATDT#777” or equivalent command signal. This command alerts wireless communication device 104 to commence a sequence of instructions to establish a connection between user terminal 102 and PDSN 106. During call setup, a PPP session or link goes through a negotiating phase to establish the proper communication protocols at each end of a link (i.e., the Rm link and the Um link). The link between user terminal 102 and wireless communication device 104 is called the PPP1 link. The link between wireless communication device 104 and PDSN 106 is called the PPP2 link.
Once the communication link between terminal 102 and device 104 is established, device 104 communicates with PDSN 106 over the Um air interface to establish a PPP2 link. Device 104 and PDSN 106 conduct LCP and IPCP negotiations over the Um air interface. Upon completion of the LCP and IPCP negotiations, a Mobile IP (MIP) registration is communicated over the Um link. During the MIP registration process, an IP address is assigned to terminal 102.
Following IPCP negotiation over the Um link, a further IPCP negotiation may be required to be conducted over the PPP1 link. This further negotiation may be needed in the event that the PPP2 protocols established between wireless communication device 104 and PDSN 106 are different than PPP1 protocols established between user terminal 102 and wireless communication device 104.
Once all of the negotiations are completed over the Rm and Um links, the flow control is removed and data can be transferred between user terminal 102 and PDSN 106.
One of the problems with this approach has been that there are great difficulties in terminating the call connection at the user terminal if the PDSN and/or base station either refuse to accept the initial call from the wireless communication device or the call is dropped for some reason, due for example, to a poor radio link. One result is that subsequent calls from that mobile device can not be made without first rebooting user terminal 102 because system resources cannot be cleared properly. This condition holds true for both voice and data calls.
Upon receipt of the MIP registration information by wireless communication device 104, a connect command is sent by device 104 to user terminal 102 over the Rm interface. Terminal 102 and device 104 then conduct LCP and IPCP negotiations to establish a PPP1 protocol link over the Rm interface. The MIP IP address for user terminal 102 established by PDSN 106 is sent to terminal 102 as part of the IPCP negotiation session. Once the PPP1 protocol link has been established, the PPP1 protocol options are compared to the PPP2 protocol options established over the Um interface. If the PPP1 and PPP2 protocol options match each other, an IP data session is established between user terminal 102 and PDSN 106.
If the PPP1 and PPP2 options do not match each other, a further LCP and IPCP negotiation session is conducted over the Um interface. The new PPP2 options are then compared to the PPP1 protocol options. If the PPP1 and new PPP2 protocol options match each other, an IP data session is established between user terminal 102 and PDSN 106. If the respective protocol options still do not match, a “tear down” signal is sent by PDSN 106 to terminate the connection between user terminal 102 and PDSN 106.
In the illustrative embodiment, when user terminal 102 initiates a dial-up networking session, no connect signal is sent back to user terminal 102 until the Um negotiation session has been completed and an address has been assigned for user terminal 102. Once the address is assigned, that information is then sent to wireless communication device 104 and a connect signal is sent from device 104 to user terminal 102 to begin the process of setting up the PPP1 protocols. User terminal 102 can then maintain an IP session and transmit and receive data over the wireless link to and from PDSN 106.
If, during the IP session, the link over the Um interface is broken, a “no carrier” signal is returned to wireless communication device 104 but no user terminal settings are affected. Terminal 102 may continue to transmit data to wireless communication device 104. Device 104 will store the transmitted data in a data buffer until a connection over air interface Um is re-established. In this way, wireless communication device 104 and air interface Um are effectively transparent to user terminal 102.
One advantage of the illustrative embodiment is realized during handoffs between networks. There are, typically, a plurality of PDSNs which service different geographic regions. For example, there may be three or four PDSNs in the continental United States alone. User terminal 102 and its associated wireless communication device 104 may be located in a moving vehicle such as a car, train, or airplane. User terminal 102 may therefore move between PDSNs, for example from PDSN1 to PDSN2. There must be a smooth handoff from PDSN 1 to PDSN 2 to minimize the likelihood of a connection being dropped. In such a situation, it is necessary to hand off the PPP2 link from PDSN 1 to PDSN 2. A new PPP2 link must be established on PDSN 2. This also requires a new mobile IP registration on PDSN 2. If the options negotiated on PDSN 1 do not change for PDSN 2, there is no need to resynch the PPP2 link over the Rm interface. Thus, the fact that there has been a handoff from PDSN 1 to PDSN 2 is totally transparent to user terminal 102.
The state diagram of
Each of the links represents an error state condition at various stages of the set up process. If an error occurs at any point along the process in which the call is dropped, the system knows to return to state zero (circle 510) along the corresponding error path. Once the system returns to state zero, wireless connection device 104 is ready and available to receive a new call.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example, and not limitation. It will be apparent to persons skilled in the relevant art(s) that various changes in form and detail can be made therein without departing from the spirit and scope of the invention.
For example, in addition to configurations using hardware, implementation of the invention may be embodied in software, disposed, for example, in a computer usable (e.g., readable) medium configured to store the software (i.e., a computer readable program code). The program code causes the enablement of the functions or fabrication, or both, of the systems and techniques disclosed herein. For example, this can be accomplished through the use of general programming languages (e.g., C or C++), hardware description languages (HDL) including Verilog HDL, VHDL, and so on, or other available programming and/or circuit (i.e., schematic) capture tools. The program code can be disposed in any known computer usable medium including semiconductor, magnetic disk, optical disk (e.g., CD-ROM, DVD-ROM) and as a computer data signal embodied in a computer usable (e.g., readable) transmission medium (e.g., carrier wave or any other medium including digital, optical, or analog-based medium). As such, the code can be transmitted over communication networks including the Internet and intranets.
It is understood that the functions accomplished and/or structure provided by the systems and techniques described above can be represented in a core (e.g., A microprocessor core) that is embodied in program code and may be transformed to hardware as part of the production of integrated circuits. In addition, the system and techniques may be embodied as a combination of hardware and software. Thus, the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.