As the computing power of mobile end-user devices has increased, mobile devices have become capable of sending and receiving increasing amounts of data. In addition to e-mail and text messages, many of today's mobile devices can support a variety of applications that send large quantities of information to and from end users. For example, in addition to sending e-mail and text messages, many of today's mobile devices can deliver news, weather, sports, maps, social networking information, music, videos, high-resolution photographs, documents, presentations, and other kinds of information.
The ability of mobile devices to send and receive such a wide variety and large quantity of data has stressed wireless access network bandwidth capabilities. As a result, network operators are either eliminating service plans with unlimited data usage, or they are increasing the price of unlimited service plans so that such plans are not attractive to most consumers. Consequently, many users of mobile end-user devices subscribe to service plans that include only a limited amount of data per fixed time period (e.g., per month). Because today's mobile end-user devices can access (e.g., send or receive) large amounts of information, there is a potential for a user of a mobile device to exceed his or her data plan allowance without realizing it. It is well known that such “overages” in data usage can be very expensive because the billing rate for data usage exceeding the contracted service plan amount is often significantly higher than the billing rate under the service plan.
Because of their computing capabilities, many of today's mobile end-user devices can also participate in the implementation and enforcement of service policies associated with access network service plans, such as charging, control, and notification policies. Device-assisted services (DAS) have been described in the many prior applications listed in the “Cross Reference to Related Applications” section of this document. When end-user devices participate in implementing and enforcing access network policies, there is a potential for device users to attempt to, or to successfully, spoof or hack end-user device components to fraudulently obtain access to data services at incorrect, lower service usage billing rates. Likewise, highly motivated users might try to gain access to network elements that perform functions related to service policy implementation or enforcement associated with the end-user device's data usage.
Thus, there is a need to secure software and hardware, in both end-user devices and in network elements, involved in the provision of device-assisted services. In addition, there is a need to detect and mitigate fraudulent or potentially fraudulent activities.
The present invention, in accordance with one or more various embodiments, is described in detail with reference to the following figures. The drawings are provided for purposes of illustration only and merely depict typical or example embodiments of the invention. These drawings are provided to facilitate the reader's understanding of the invention and shall not be considered limiting of the breadth, scope, or applicability of the invention. It should be noted that for clarity and ease of illustration these drawings are not necessarily made to scale.
According to various embodiments, systems and methods are provided for securing device-assisted services (DAS) systems and for detecting and mitigating fraud in such systems.
In some embodiments, an end-user device comprises one or more modems to allow communications over a wireless access network, memory configured to store an application-specific network access policy to be applied when a particular application program attempts to communicate or successfully communicates over the wireless access network, and one or more device agents configured to detect attempted or successful activity by the particular application program and to apply the application-specific network access policy to the communication activity.
In some embodiments, the one or more device agents are configured to detect attempted or successful activity by the particular application program by flow-tagging a data flow associated with the particular application program, associating the flow tag with the application identifier, and applying the application-specific network access policy to the flow-tagged data flow.
In some embodiments, an end-user device comprises one or more modems to allow communications over a wireless access network, memory configured to store an application-specific network access policy to be applied when a particular application program attempts to communicate or successfully communicates over the wireless access network, and one or more device agents configured to use an application programming interface (API) to arrange an application setting to assist in implementing the application-specific network access policy.
In some embodiments, the application-specific network access policy comprises a control policy configured to assist in controlling transmissions or receptions over the wireless access network that are associated with the application program. In some embodiments, the application-specific network access policy comprises a charging policy configured to assist in accounting for transmissions or receptions over the wireless access network that are associated with the application program. In some embodiments, the end-user device has a user interface, and the application-specific network access policy comprises a notification policy configured to assist in presenting, through the user interface, a notification message, such as, for example: an offer or an advertisement, information about a network type (e.g., a home network, a roaming network, a cellular network, a wireless wide-area network (WWAN), a wireless local area network (WLAN), a wireless personal area network (WPAN), a 2G network, a 3G network, a 4G network, a WiMAX network, an Ethernet network, a DSL network, a DOCSIS network, a cable network, a WiFi network, etc.), an indication of an amount or cost of data usage associated with the application program, an indication of a projected amount or a projected cost of data usage associated with the application program (e.g., a projection based on a past or historical data usage associated with the application program), an indication of an amount or cost of data usage associated with the application program during a particular period of time (possibly user-configured or user-selected), an indication that an amount or cost of data usage associated with the application satisfies a condition relative to a limit setting (e.g., exceeds a threshold, meets a threshold, is less than a threshold, etc.), an indication of an amount or cost of background data usage by the application program, etc. In some embodiments, the policy is associated with an application identifier (e.g., a credential associated with the application, possibly stored on the end-user device). In some embodiments, the application program is secured by an application credential (which may be the application identifier). In some embodiments, the one or more device agents are further configured to prevent modifications, updates, or replacements of the application program unless software purporting to be a modification, update, or replacement of the application program is associated with a credential that is consistent with (e.g., matches) the application credential.
In some embodiments, at least one of the one or more device agents is secured by an agent credential, and one of the one or more device agents is configured to prevent modifications, updates, or replacements of the at least one of the one or more device agents unless software purporting to be a modification, update, or replacement of the at least one of the one or more device agents is associated with a credential that is consistent with (e.g., matches) the agent credential.
In some embodiments, the agent credential comprises one or more of agent kernel software present with a proper signature, certificate, or hash result; agent framework software present with a proper signature, certificate, or hash result; and agent application software present with a proper signature, certificate, or hash result.
In some embodiments, the end-user device is further secured by configuring the one or more device agents to perform one or more of the following checks: determining if a hosts file is present and properly configured; determining if a service processor on the end-user device successfully completed an authentication procedure with a service controller in the network; determining if the end-user device has been rooted.
In some embodiments, a network system is configured to provide access network services to an end-user device, and the end-user device is responsible for implementing an access network policy. In some embodiments, the network system is configured to obtain a trusted measure of access network usage by the end-user device and to use the trusted measure to confirm that the end-user device is properly implementing the access network policy, where the trusted measure is obtained from a network element, from a secure processor on the end-user device, or from a trusted third party.
In some embodiments, the network system is configured to apply a multi-tiered policy verification process comprising at least two of the following policy verification steps, performed in any order: (a) determining if the end-user device is failing to send service usage reports, even though the network system is receiving trusted reports of the end-user device's service usage; (b) comparing a trusted service usage measure to a limit or range of usage expected if the end-user device is properly implementing the access network policy; (c) comparing a trusted service usage measure to a non-secure (e.g., device-generated) usage measure to determine if the difference between the two usage measures is within a specified tolerance; (d) comparing a non-secure (e.g., device-based) service usage measure to a limit or range of usage expected if the end-user device is properly implementing the access network policy; (e) comparing a classification of the end-user device's usage to a limit or range of usage expected if the end-user device is properly implementing the access network policy; (f) comparing an aggregation of two or more classifications of the end-user device's usage to an aggregate limit on usage to determine if the difference between the two measures is within a specified tolerance; (g) comparing a trusted measure of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a limit or range of usage expected if the end-user device is properly implementing the access network policy; (h) comparing a trusted measure of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a non-secure (e.g., device-based) measure of usage of the same class to determine if the difference between the two measures is within a specified tolerance; (i) comparing a statistical characterization of usage by a population of end-user devices to a trusted measure of the end-user device's service usage to determine if the difference between the two measures is within a specified tolerance; (j) comparing a statistical characterization of usage of a particular class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) by a population of end-user devices to a trusted measure of the end-user device's usage of that same class to determine if the difference between the two measures is within a specified tolerance; (k) comparing a statistical characterization of usage by a population of end-user devices to a non-secure measure of the end-user device's service usage to determine if the difference between the two measures is within a specified tolerance; (l) comparing a statistical characterization of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a non-secure (e.g., device-based) measure of usage of the same class to determine if the difference between the two measures is within a specified tolerance; (m) comparing detailed class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) usage information in a usage report (trusted or non-secure) to determine whether the access network policy allows the classified activity; (n) determining whether a service processor on the end-user device successfully authenticated with a service controller in the network; (o) determining whether the end-user device is sending reports to a network element in an expected manner; (p) determining whether usage of one or more classes (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) is consistently slightly under particular limits that would indicate likely fraud on the part of the end-user device; (q) comparing an amount or percentage of unknown or unclassified data usage allocated by the end-user device to a particular class to an expected amount or percentage of unknown or unclassified data usage, where the expected amount or percentage is determined using information from a trusted source (e.g., a web crawler, domain object model, etc.).
In some embodiments, the result of one or more of the policy verification steps is a pass/fail criterion, and the overall pass criterion is a number of failures less than a limit on the number of failures. In some embodiments, the result of one or more of the policy verification steps is a quantized value associated with an error likelihood or non-error likelihood, and the overall fail/pass criterion is based on a combination of one or more quantized values. In some embodiments, a policy implementation error action is taken if an error occurs, where the error action comprises one or more of: flagging the end-user device or the user for further evaluation; charging for the end-user device's usage at a pre-defined rate associated with an error condition; notifying the user of the end-user device; notifying a network or system administrator; quarantining the end-user device or a user access to the access network; suspending the end-user device or user's access to the access network.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term “processor” refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
As illustrated in the embodiment of
In some embodiments, service processor 115 assists in classifying service usage by end-user device 100 into sub-categories (e.g., classes) for the purpose of assisting in usage accounting policy enforcement, access control policy enforcement, applying service usage limits, or notification policy enforcement that differs according to the category (or class). In some embodiments, the classification can be for one or more device applications (e.g., a class comprises one or more application programs). In some embodiments the classification can be for one or more network destinations (e.g., a class comprises one or more network destinations). In some embodiments the classification can be for one or more network types (e.g., a class comprises one or more network types). In some embodiments a classification of service usage referred to as a sponsored service (or an ambient service) can be performed to facilitate allocating access network costs, in whole or in part, associated with the sponsored service to a service sponsor, the service sponsor being an entity other than the user or subscriber associated with end-user device 100.
In some embodiments, the communication activity is classified for purposes of access policy enforcement by service processor 115, or by a network element, based on one or more network destinations associated with the communication activity, such as, for example, a collection of one or more of: a network address, a domain, a URL, a website, a WAP site, a server configured to communicate with a device application, a content distribution site, a network tunnel or tunnel server (such as, for example, a VPN, APN, or other tunnel), a network gateway, or a proxy server. In some embodiments, the communications activity is classified for the purposes of network access policy enforcement by service processor 115 or by a network element based on a collection of one or more device application programs or device operating system (OS) components participating in the communications activity.
Service processor 115 comprises one or more software or firmware programs that execute on end-user device 100. To aid in disclosure of the invention, service processor 115 is explained using the functional elements or agents shown in
In some embodiments, application interface agent 1693 monitors device application-layer communication activity to identify attempted or successful access network communication activity. In some embodiments, application interface agent 1693 monitors application layer access network communication activity to identify and classify the access network communication activity. In some embodiments, the monitoring of access network communication activity by application interface agent 1693 is reported to service monitor agent 1696. In some embodiments, the monitoring of access communications activity by application interface agent 1693 comprises classifying data traffic flows based on inspection and characterization of which application (e.g., TCP application 1604, IP application 1605, voice application 1602, or any other application on end-user device 100) each flow is associated with. In some embodiments, the monitoring of access communications activity by application interface agent 1693 comprises classifying data traffic flows based on inspection and characterization of which network destination each flow is associated with.
In some embodiments, service monitor agent 1696, application interface agent 1693, and/or other agents implement virtual traffic tagging by tracking or tracing packet flows through various communication stack formatting, processing and encryption steps, and providing the virtual tag information to the various agents that monitor, control, shape, throttle or otherwise observe, manipulate or modify the traffic. This tagging approach is referred to herein as virtual tagging, because there is not a literal data flow, traffic flow or packet tag that is attached to flows or packets, and the book-keeping to tag the packet is done through tracking or tracing the flow or packet through the stack instead.
In some embodiments, application interface agent 1693 and/or other agents identify a traffic flow, associate it with a service usage activity and cause a literal tag to be attached to the traffic or packets associated with the activity. This tagging approach is referred to herein as literal tagging. There are various advantages to both the virtual tagging and the literal tagging approaches. For example, it can be preferable in some embodiments to reduce the inter-agent communication required to track or trace a packet through the stack processing by assigning a literal tag so that each flow or packet has its own activity association embedded in the data. As another example, it can be preferable in some embodiments to re-use portions of standard communication stack software or components, enhancing the verifiable traffic control or service control capabilities of the standard stack by inserting additional processing steps associated with the various service agents and monitoring points rather than re-writing the entire stack to correctly process literal tagging information, and in such cases, a virtual tagging scheme may be desired. As yet another example, some standard communication stacks provide for unused, unspecified or otherwise available bit fields in a packet frame or flow, and these unused, unspecified or otherwise available bit fields can be used to literally tag traffic without the need to re-write all of the standard communication stack software, with only the portions of the stack that are added to enhance the verifiable traffic control or service control capabilities of the standard stack needing to decode and use the literal tagging information encapsulated in the available bit fields. In the case of literal tagging, in some embodiments, the tags are removed prior to passing the packets or flows to the network or to the applications utilizing the stack. In some embodiments, the manner in which the virtual or literal tagging is implemented can be developed into a communication standard specification so that various device or service product developers can independently develop the communication stack and/or service processor 115 hardware and/or software in a manner that is compatible with service controller 122 specifications and the products of other device or service product developers.
In some embodiments, an agent or combination of agents uses tags to assist in applying a policy (e.g., a notification, charging, or control policy) when an application program on end-user device 100 initiates communications or successfully communicates over an access network. In some such embodiments, the agent or combination of agents determines when an application program initiates or attempts to initiate a communication over the first wireless access network by: identifying a data flow comprising one or more related data transfers or attempted data transfers associated with the application program; assigning a flow tag to the data flow, where the flow tag is a traffic flow identifier; monitoring an access network service usage or attempted service usage associated with the flow tag; and, after identifying the data flow, applying the policy to the first wireless access network service usage or attempted service usage associated with the flow tag. As will be appreciated by a person having ordinary skill in the art, the steps of identifying, assigning, and monitoring can occur in any order.
In some embodiments, application interface agent 1693 applies, implements, or enforces service usage accounting or charging policy for application layer access network communication activity. In some embodiments, this policy implementation function is used to apply, implement, or enforce service usage accounting or charging policy that varies with the classification of the access communication activity as discussed above.
In some embodiments, application interface agent 1693 implements traffic control policy for application layer access network communication activity. In some embodiments, application interface agent 1693 implements application-level control policy to allow an application to execute on end-user device 100 or to prevent an application from executing. In some embodiments, application interface agent 1693 implements notification policy for application layer access network communication activity.
In some embodiments, application interface agent 1693 provides applications with an access network service application interface so that the application (e.g., TCP application 1604, IP application 1605, voice application 1602, etc.) can request or provision special access network service permissions such as, for example, an access network quality-of-service (QoS) channel class, a background service usage class, a service usage accounting particular to an application or application class, or a sponsored service usage particular to an application or application class, wherein a sponsor entity other than a user of the end-user device subsidizes an access network usage cost associated with the application or application class. In such embodiments, application interface agent 1693 can communicate with a counterpart in the access network to provide for provisioning of the special access network service permissions for a particular application or class of applications.
In some embodiments, application interface agent 1693 interacts with application programs (e.g., TCP application 1604, IP application 1605, voice application 1602, or another application on end-user device 100) to arrange application settings to aid in implementing application-level service policy implementation or billing. In some embodiments, application interface agent 1693 arranges an application setting by posting, sending, or otherwise communicating a message comprising a setting configuration. In some embodiments, the application setting assists in traffic control (e.g., allow, block, throttle, rate-limit, transmit on a particular network, background traffic control, etc.), notification (e.g., to a user of end-user device 100, to a network element such as service controller 122, etc.), or charging (e.g., to account for usage of access network resources by end-user device 100).
In some embodiments, application interface agent 1693 interacts with an application program stored on end-user device 100 and configured to access a data service over an access network. In some such embodiments, the application program has an associated policy (e.g., a notification [e.g., of an amount or cost of access network usage associated with the application program, an amount or cost of access network usage associated with the application program over a particular (possibly user-selected) period of time, background or foreground data usage information, etc.], charging, or control policy) to be applied when the application program initiates or attempts to initiate communications over the first access network, and application interface agent 1693 (or another agent on end-user device 100) assists in policy implementation by arranging a setting of the application program by posting, sending, or otherwise communicating the setting to the application program.
In some embodiments, one or more agents on end-user device 100 are configured to prevent unauthorized modifications, updates, or replacements of the application software by: detecting an attempted installation of update software on end-user device 100, where the update software purports to be a modification, update, or replacement of the application program; obtaining a credential associated with the application program; obtaining a credential associated with the update software; and allowing the update software to be installed on end-user device 100 if the credential associated with the purported modification, update, or replacement of the application program matches the credential associated with the application program.
In some embodiments, application interface agent 1693 is associated with or comprises a credential, and another agent on end-user device 100 (e.g., access control integrity agent 1694, policy control agent 1692, etc.) is configured to prevent unauthorized modifications, updates, or replacements of application interface agent 1693. In some embodiments, the other agent detects an attempted installation of software purporting to be a modification, update, or replacement of application interface agent 1693, obtains the credential associated with application interface agent 1693, obtains a credential associated with the software purporting to be a modification, update, or replacement of application interface agent 1693, and allows the software to be installed on end-user device 100 if the credential associated with the software matches the credential associated with application interface agent 1693.
In some embodiments, application interface agent 1693 intercepts certain application traffic to modify traffic application layer parameters, such as email file transfer options or browser headers. In some embodiments, application interface agent 1693 transmits or receives a service usage test element to aid in verifying service policy implementation, service monitoring or service billing. In some embodiments, application interface agent 1693 performs a transaction billing intercept function to aid the billing agent 1695 in transaction billing. In some embodiments, application interface agent 1693 transmits or receives a billing test element to aid in verifying transaction billing or service billing.
In some embodiments, policy implementation agent 1690 monitors device network traffic layer communication activity to identify attempted or successful access network communication activity. In some embodiments, policy implementation agent 1690 monitors network traffic layer communication activity to identify and classify the access communication activity. In some embodiments, the monitoring of access network communications activity by policy implementation agent 1690 is reported to service monitor agent 1696. Traffic layer communication monitoring can be conducted at one or more layers between the application layer (generally referred to as layer 7) and the access network media access control layer (generally referred to as layer 2). In some embodiments, traffic layer communication monitoring comprises classifying data traffic flows based on inspection and characterization of layer 7 communication traffic parameters (for example, one or more of application program identifier or credential, network destination classifiers, communication protocol parameters, communication content classifiers, or secure communication protocol parameters such as SSL or TLS connection parameters) and associating the classification with one or more resulting traffic flows, socket flows, or packet flows. In some embodiments, traffic layer communication monitoring comprises classifying data traffic flows based on inspection and characterization of layer 4 communication traffic parameters such as, for example, socket flow tuples. In some embodiments, traffic layer communication monitoring comprises classifying data traffic flows based on inspection and characterization of layer 3 communication traffic parameters (for example, IP addresses). In some embodiments, traffic layer communication monitoring comprises classifying data traffic flows based on inspection and characterization of VPN tunnel parameters, APN tunnel parameters, etc.
In some embodiments, policy implementation agent 1690 applies, implements, or enforces access network policy at one or more of the communications traffic layers of a device operating system. As discussed above, in some embodiments access network policy can be applied at one or more traffic layers. Traffic layer policy enforcement can be applied at any layer(s) between and including the application layer (generally referred to as layer 7) and the access network media access control layer (generally referred to as layer 2).
In some embodiments, communications traffic layer policy application comprises policy applied to a classification of data traffic flows based on inspection and characterization of layer 7 communication traffic parameters (for example, one or more of application program identifier or credential, network destination classifiers, communication protocol parameters, communication content classifiers, or secure communication protocol parameters such as SSL or TLS connection parameters) and associating the classification with one or more resulting traffic flows, socket flows, or packet flows. In some embodiments, communications traffic layer policy application comprises policy applied to a classification of data traffic flows based on inspection and characterization of layer 4 communication traffic parameters such as, for example, socket flow tuples. In some embodiments, communications traffic layer policy application comprises policy applied to a classification of data traffic flows based on inspection and characterization of layer 3 communication traffic parameters (e.g., IP addresses). In some embodiments, communications traffic layer policy application comprises policy applied to a classification of data traffic flows based on inspection and characterization of VPN tunnel parameters, APN tunnel parameters, etc.
Connection manager 1804 determines which access network the device is connected to and provides this information to other agents on end-user device 100. In some embodiments, connection manager 1804 also chooses a network connection based on available network connections and a network selection policy instruction from policy control agent 1692.
Service monitor agent 1696 is responsible for accounting and reporting the access network service usage for end-user device 100. In some embodiments, the service monitoring (e.g., a measure of the access network service usage) is reported to a user of end-user device 100. In some embodiments, the service monitoring is reported to a network element. In some embodiments, the access network service usage is classified by an application breakdown indicating the amount of service usage attributed to one or more applications. In some embodiments, the access network service usage is classified by a network destination or network service breakdown indicating the amount of service usage attributed to one or more network destinations or network services. In some embodiments, the access network service usage is classified by a network type breakdown indicating the amount of service usage attributed to one or more network types. In some embodiments, the network type breakdown includes a roaming network. In some embodiments, the network type breakdown includes a cellular network (e.g., 2G, 3G, 4G, etc.).
Policy control agent 1692 is responsible for monitoring application layer activity or traffic communication layer activity to identify conditions in which a network access policy should be implemented, and then causing a policy enforcement agent (for example application interface agent 1693 or policy implementation agent 1690) to apply the policy. In some embodiments, policy control agent 1692 receives information about an end-user device connection state from other device agents (e.g., connection manager 1804, one of modem drivers 1831, 1815, 1814, 1813, 1812, modem selection and control 1811, an operating system function, etc.) to aid in determining the access network policy settings that should be applied at a given time. For example, without limitation, device connection state information can comprise one or more of application classification information, network destination identifier information, network service identifier information, type of network information, time of day or day of week information, and geographic location information.
The access network policy instruction provided by policy control agent 1692 to a policy enforcement agent (for example, application interface agent 1693 or policy implementation agent 1690) can comprise a service usage accounting or charging policy in which the service usage is accounted and reported for the purpose of access network service usage accounting or billing. In some embodiments, the service usage is accounted to or billed to a device account or device user account. In some embodiments, the service usage accounting is accounted to or billed to a service sponsor account, where the service sponsor is an entity that is not the device user or a subscriber associated with end-user device 100. In some embodiments, the service usage accounting or charging policy includes modifications in accounting policy based on one or more classifications of service usage and one or more device connection states, with classifications of service usage and connection state including but not limited to those disclosed herein.
The access network policy instruction provided by policy control agent 1692 to a policy enforcement agent can comprise a service usage control policy wherein the service usage is governed, limited, or regulated according to a service plan policy. In some embodiments, the service usage control policy includes modifications in control policy based on one or more classifications of service usage and one or more device connection states, with classifications of service usage and connection state including but not limited to those disclosed herein.
The access network policy instruction provided by policy control agent 1692 to a policy enforcement agent can comprise a service notification policy in which a notification associated with the access network service is presented through a user interface of end-user device 100 (e.g., user interface 1697) when a pre-determined notification trigger condition is met. In some embodiments, the notification indicates an amount of service used. In some embodiments, the notification indicates an amount of service remaining. In some embodiments, the notification comprises an offer to acquire service. In some embodiments, the service notification policy includes modifications in control policy based on one or more classifications of service usage and one or more device connection states, with classifications of service usage and connection state including but not limited to those disclosed herein. In some embodiments, the notification includes an offer to acquire service based on the occurrence of a pre-determined attempted or successful device access to an application or combination of applications. In some embodiments, an offer to acquire service is based on the occurrence of a pre-determined attempted or successful device access to a network destination or combination of network destinations. In some embodiments, an offer to acquire service is based on detection of a condition in which a new service plan may be of interest to a device user who currently has an existing service plan or no service plan. In some embodiments, the notification comprises an offer to increase a service allowance. In some embodiments, the notification comprises an indication of potential or likely service usage. In some embodiments, the notification indicates a roaming service usage. In some embodiments, the notification comprises an offer to acquire roaming services. In some embodiments, the notification indicates that service authorization is about to expire under a current service plan.
In some embodiments, user interface 1697 provides a user of end-user device 100 with input capability to modify an access network service according to a user preference and/or to receive access network service notifications. In some embodiments, user interface 1697 accepts user inputs for modifying access network policy, such as limiting access by one or more applications or access to one or more network destinations. In some embodiments, user interface 1697 accepts user inputs for modifying end-user device 100's access to particular access networks (e.g., one or more roaming networks, one or more cellular networks, one or more WiFi networks, etc.). In some embodiments, user interface 1697 accepts user inputs for choosing or modifying a service plan.
Service control device link 1691 provides a secure communication link and heartbeat function between service processor 115 and service controller 122. In some embodiments, using the heartbeat function, agents on end-user device 100 provide certain reports to service controller 122 for the purpose of service policy implementation verification (e.g., verification-related reports on certain aspects of service processor 115) or for other purposes. Such agent heartbeat messages can be sent unencrypted or encrypted, signed, or otherwise secured. In some embodiments, these messages include one or more of an agent information message, an agent check-in message, and an agent cross check message.
In some embodiments, an agent information message is included in a agent heartbeat service policy implementation verification message, which includes, for example, any information the agent needs to communicate to service controller 122 as part of the operation of the service policy implementation system. For example, an agent response to a service controller challenge, as described below, can be included in the agent heartbeat service policy implementation verification message.
In some embodiments, an agent check-in message is included in an agent heartbeat service policy implementation verification message, which includes, for example, a transmission of a unique agent identifier, secure unique identifier, and/or hashed encrypted and signed message beginning with some shared secret or state variable for the hash. For example, an agent self-check can be included in the agent heartbeat service policy implementation verification message, which includes reporting on agent configuration, agent operation, agent code status, agent communication log, agent error flags, and/or other agent associated information potentially hashed, encrypted, signed or otherwise secured in the message (e.g., using a shared secret unique to that agent).
In some embodiments, an agent cross-check message is included in the agent heartbeat service policy implementation verification message, which includes, for example, reports on the status, configuration, operation observations, communication log or other aspects of another agent. For example, agent environment reports can be included in the agent heartbeat service policy implementation verification message, which includes, for example, reports on certain aspects of the service processor 115 operating environment, such as software presence (e.g., installation status of certain operating system and/or application software and/or components thereof), observed communication with agents or communication attempts, memory accesses or access attempts, network accesses or access attempts, software downloads or attempted downloads, software removal or download blocking, service policy implementation verification or compromise event error conditions with respect to the operating environment for service processor 115, and/or other messages regarding the verification or possibility of compromise associated with service processor 115 operating environment or agents.
In some embodiments, the agent heartbeat function also provides regular updates for information important to user service notification services. For example, the network-based elements can provide regular synchronization updates for the device based service usage or service activity counters in which service usage or service activity measures available from one or more network service history elements are transmitted to end-user device 100. This allows the service usage counter errors between the device service counter and the counters used for central billing to be minimized. A common service usage or service activity measure is total traffic usage associated with one or more applications or one or more network destinations measured to date within a time frame over which a service limit is applicable. Other service usage or service activity measures can also be tracked and reconciled in a similar manner.
In some embodiments of the heartbeat function, service controller 122 verifies that the scheduled agent reports are being received and that the reports are within expected parameters. In some embodiments, access control integrity server 1654 issues signed challenge/response sequences to policy implementation agent 1690. For example, the challenges can be asynchronous, issued when an event or error condition occurs, issued on a schedule, or issued when a certain amount of data has been used. This approach, for example, provides a second layer of service policy implementation verification that strengthens the service usage or service activity measurement verification. For example, a challenge/response can be sent over the heartbeat link for the purpose of verifying device agent integrity.
In some embodiments, the challenge/response heartbeat message can include sending any kind of command or query, transmitted securely or transmitted in the open, receiving a response from the agent and then evaluating the response to determine if the response is within a range of parameters expected for a correctly configured agent, an agent that is operating properly, an agent that is not partially compromised, or an agent that is not entirely compromised. In some embodiments, the agent is only required to respond with a simple acknowledgement of the challenge. In some embodiments, the agent is required to respond with a message or piece of information that is known by the agent. In some embodiments, the agent is required to respond with a message or piece of information that would be difficult for the agent to supply if it were to be partially or entirely compromised. In some embodiments, the agent is required to respond back with information regarding the operation or configuration of the agent that would be difficult for the agent to supply if the agent were not properly configured, not operating properly, partially compromised, or entirely compromised. In some embodiments, a first agent is required to respond back with information regarding the operation, configuration, status or behavior of a second agent, and this information is difficult for the first or second agent to supply if the first or second agent is not properly configured, not operating properly, is partially compromised or is entirely compromised. In some embodiments, the agent is required to respond with a response that includes a shared secret. In some embodiments, the agent is required to respond with information regarding the presence, configuration, operating characteristics or other information regarding other programs in the operating environment of the agent. In some embodiments, the agent is required to respond with hashed information of portions of code or a code sample (e.g., the code portion or code sample can be specified by service controller 122).
In some embodiments, the information the agent responds with is a response to a signed or encrypted message from service controller 122, and the agent must know how to decode the encrypted controller message in order to respond correctly, or it would be difficult for the agent to respond properly if the agent is not configured properly, is not operating within appropriate limits, is partially compromised, or is entirely compromised. In some embodiments, the agent signs or encrypts information in such a manner that it is difficult for the agent to respond correctly, and for service controller 122 to decode the message, unless the agent is configured properly, is operating within appropriate limits, is not partially compromised, and is not entirely compromised. In some embodiments, the agent is required to respond with a signed or encrypted hash of information that is difficult for the agent to generate unless the agent is configured properly, is operating within appropriate limits, is not partially compromised and is not entirely compromised. For example, the hashed information can be local device configuration information, portions of code, or all of the code, and/or the code portion to be used in the response can be specified by service controller 122. In another example, the hashed information the agent responds with can include a shared secret, and/or the hashed information can be information regarding the presence, configuration, operating characteristics or other information regarding other programs in the operating environment of the agent.
Accordingly, as described above, the agent heartbeat function provides an important and efficient system in some embodiments for verifying the service policy implementation or protecting against compromise events (e.g., fraud). There are many other functions the agent heartbeat service can perform; some are described herein, and others will be apparent to one of ordinary skill in the art given the principles, design background, and various embodiments provided herein.
In some embodiments, service downloader 1663 provides for one or more of: download of application programs that have an associated service policy; download of application credentials; and download of service processor 115 components or component updates. In some embodiments, service downloader 1663 requires a secure signed version of software before a download is accepted. For example, the download can require a unique key or credential. In some embodiments, service downloader 1663 is stored or executed in secure memory or executes in a secure memory partition in the CPU memory space. Those of ordinary skill in the art will appreciate that there are a variety of other security techniques that can be used to ensure the integrity of service downloader 1663.
Access control integrity agent 1694 monitors the operational integrity of one or more service processor 115 elements to determine if unauthorized user modification or unauthorized user software program modification of the service processor configuration or operation has occurred. In some embodiments, access control integrity agent 1694 collects device information on one or more of service policy, service usage, service activity, agent configuration, and agent behavior. In some embodiments, access control integrity agent 1694 also cross-checks this information to identify integrity breaches in the service policy implementation and control system. In some embodiments, access control integrity agent 1694 initiates action when a service policy violation or a system integrity breach is suspected. In some embodiments, access control integrity agent 1694 takes an action (e.g., generating a fraud alert, blocking end-user device 100 from accessing access network 10, blocking an application from accessing access network 10, directing the device to a quarantine network status in which end-user device 100 can, for example, only access functions generally controlled by the access network service provider or the central service provider, etc.) when unauthorized conditions are detected. In some embodiments, access control integrity agent 1694 also performs asynchronous or periodic agent checks to verify the presence, configuration, or proper operation of other agents. In some embodiments, access control integrity agent 1694 also performs challenge-response sequence verification of other agents.
In some embodiments, access control integrity agent 1694 monitors agent self-check reports to verify that agents are properly configured. In some embodiments, access control integrity agent 1694 reports the agent self check reports to service controller 122. In some embodiments, access control integrity agent 1694 performs a role in service usage test transmission, reception and/or monitoring, with the usage test being tailored to test monitoring or control aspects for any subset of service activities. In some embodiments, access control integrity agent 1694 performs a role in billing test event generation and/or monitoring. In some embodiments, access control integrity agent 1694 checks and reports the result of service usage monitoring verification tests, service usage billing verification tests and/or transaction billing verification tests.
In some embodiments, access control integrity agent 1694 receives agent access attempt reports to determine if unauthorized agent access attempts are occurring. In some embodiments, access control integrity agent 1694 acts as a central secure communications hub for agent-to-agent or service-controller-to-agent communication. For example, access control integrity agent 1694 can be used so that no other software or function can access agents or so that agents cannot access other agents except through a secure point-to-multipoint communications hub. In some embodiments, this approach further enhances compromise resistance for the agents. In some embodiments, some or all of the agent communications, including agent-to-agent or service-controller-to-agent communications, and possibly including unauthorized attempts to communicate with agents, are monitored and logged so that a trace log of some or all agent communications can be maintained. For example, the agent communication trace log can be summarized and/or compressed for transmission efficiency or regularly reported, such as through the heartbeat function, or the agent communication trace log can be reported only when service controller 122 requests the agent communication trace log or when there is a verification error event.
In some embodiments, access control integrity agent 1694 obtains service usage or service activity measures from service monitor agent 1696 and compares one or more first service usage measurement points against one or more second service usage measurement points to verify service policy implementation.
As illustrated in the embodiment of
In some embodiments, service history server 1650 records service usage reports for end-user device 100. In some embodiments, service history server 1650 collects and records service usage or service activity reports (e.g., accounting reports) from a network element (e.g., access network AAA server 1621) or end-user device 100 (e.g., service monitor agent 1696). In some embodiments, the service usage reports are generated by service processor 115. In some embodiments, the service usage reports include service usage classification information (e.g., usage per application, per group of applications, per network destination, per group of applications, per network type, etc.) as described herein.
Although service usage reports from the network elements can in certain embodiments be less detailed than service usage reports from end-user device 100, the reports from the network can provide a valuable source for verification of device service policy implementation, because, for example, it is unlikely that a device error or compromise event on end-user device 100 will compromise network-based equipment or software. In some embodiments, service history server 1650 provides the service history on request to other servers and/or one or more agents. In some embodiments, service history server 1650 provides the service usage history to device service history 1618.
In some embodiments, policy management server 1652 includes storage of access network service policies that are provided to service processor 115 from a network element. In some embodiments, policy management server 1652 provides known-application credentials to service processor 115. In some embodiments, policy management server 1652 evaluates run-time application credentials provided by service processor 115.
In some embodiments, policy management server 1652 transmits policies to service processor 115 via service control link 1653. In some embodiments, policy management server 1652 manages policy settings on end-user device 100 (e.g., various policy settings as described herein with respect to various embodiments) in accordance with a device service profile. In some embodiments, policy management server 1652 sets instantaneous policies on policy implementation agents (e.g., policy implementation agent 1690). For example, policy management server 1652 can issue policy settings, monitor service usage and, if necessary, modify policy settings.
In some embodiments, policy management server 1652 provides adaptive policy management on end-user device 100. For example, policy management server 1652 can issue policy settings and objectives and rely on the device-based policy management (e.g., by service processor 115) for some or all of the policy adaptation. This approach can require less interaction with end-user device 100, thereby reducing network chatter on service control link 1653 for purposes of device policy management. This approach can also provide robust user privacy embodiments by allowing the user to configure the device policy for user privacy preferences/settings so that, for example, sensitive information (e.g., geo-location data, website history) is not communicated to the network without the user's approval. In some embodiments, policy management server 1652 adjusts service policy based on time of day. In some embodiments, policy management server 1652 receives, requests or otherwise obtains a measure of network availability and adjusts traffic shaping policy and/or other policy settings based on available network capacity.
In some embodiments, policy management server 1652 performs a service control algorithm to assist in managing overall network capacity or application QoS. In some embodiments, policy management server 1652 performs an algorithm to determine which access network is best to connect to, such as based on network capacity or application QoS, service usage costs, and/or any other criteria.
In some embodiments, access control integrity server 1654 monitors the integrity of the access policy system to establish a trusted service policy implementation. In some embodiments, access control integrity server 1654 collects end-user device 100 information on service policy, service usage, agent configuration and/or agent behavior. In some embodiments, access control integrity server 1654 cross-checks this information to identify integrity breaches in the service policy implementation and control system.
In some embodiments, access control integrity server 1654 initiates action when a service policy violation or a system integrity breach or error is suspected or detected. In some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) acts on access control integrity agent reports and error conditions. In some embodiments, checks performed by access control integrity agent 1654 include one or more of the following: service usage measure against usage range consistent with policies (e.g., usage measure from the network and/or from the device); configuration of agents; operation of the agents; and/or dynamic agent download.
In some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) verifies device service policy implementations by comparing various service usage measures (e.g., based on network-monitored information and/or local service usage monitoring information) against expected service usage behavior given the policies that are intended to be in place. For example, device service policy implementations can include measuring total data passed, data passed that is associated with a particular application or group of applications, data passed that is associated with a particular network destination or group of network destinations, data passed in a period of time, IP addresses, data per IP address, data per network, data per network type, and/or other measures (such as location, downloads, email accessed, URLs, etc.), and comparing such measures to expected service usage behavior given the policies that are supposed to be in place.
In some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) verifies device service policy, and the verification error conditions that can indicate a mismatch in service measure and service policy include one or more of the following: unauthorized network access (e.g., access beyond sponsored service policy limits); unauthorized network speed (e.g., average speed beyond service policy limit); network data amount does not match policy limit (e.g., device not stopping at limit without re-up/revising service policy); unauthorized network address; unauthorized service usage (e.g., VOIP, email, and/or web browsing when not authorized); unauthorized application usage (e.g., email, VOIP, email, and/or web when not authorized); service usage rate too high for plan, and policy controller not controlling/throttling it down; and/or any other mismatch in service measure and service policy.
In some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) verifies device service policy based at least in part on, for example, various error conditions that indicate a mismatch in service measure and service policy. For example, various verification error conditions that can indicate a mismatch in service measure and service policy include one or more of the following: mismatch in one service measure and another service measure; agent failure to report in; agent failure to respond to queries (e.g., challenge-response sequence and/or expected periodic agent reporting); agent failure to respond correctly to challenge/response sequence; agent improperly configured; agent failure in self checks; agent failure in cross-checks; unauthorized agent communication or attempted unauthorized communication; failure in service policy implementation test; failure in service usage reporting test; failure in service usage billing test; failure in transaction billing test; failure in download sequence; environment compromise event, such as unauthorized software load or execution (or attempt), unauthorized memory access (or attempt), unauthorized agent access (or attempt), known harmful software, and/or known harmful communications signature; and/or failure to respond to various messages, such as send message and suspend and/or send message and quarantine.
In some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) verifies device service policy by performing automated queries and analysis, which are then reported (e.g., anomalous/suspicious report results can be reported for further analysis by a person responsible for determining whether such activities indicate out of policy activities or to provide information to the user to inform the user of such anomalous/suspicious report results that may indicate out-of-policy activities). For example, the user can review the report to authorize whether such activities were performed by the user (e.g., website access requests, specific transactions, and/or phone calls) and/or indicate that such activities were not authorized by the user (e.g., indicate a potential compromise of the device, such as by malware or other unauthorized software/user use of the device). As another example, the user can also be connected to communicate with service support of the service provider regarding such reported activities (e.g., by text/chat, voice/phone, and/or video conference to a service support). Accordingly, in some embodiments, access control integrity server 1654 (and/or some other agent of service controller 122) provides a policy/service control integrity service to verify (e.g., periodically and/or based on trigger events) that the service control of the device has not been compromised and/or is not behaving out of policy.
In some embodiments, upon detection of one or more service verification errors, such as the various service verification errors discussed above, end-user device 100 is directed to a quarantine network status in which end-user device 100 can, for example, only access network control plane functions, billing functions, and other functions generally controlled by the access network service provider or the central service provider. In some embodiments, end-user device 100 is completely suspended from the network. In some embodiments, end-user device 100's network access, service capabilities and/or traffic shaping are limited, partially restricted or completely restricted. For example, these limitations and/or restrictions can be implemented in the device and/or in the network. For example, implementing a device quarantine (e.g., using a RADIUS server to quarantine the device) can involve assigning the device to a different billing profile.
In some embodiments, service download control server 1660 provides for one or more of: download of application programs that have an associated service policy; download of application credentials; and download of service processor 115 components or component updates.
In some embodiments, billing event server 1662 provides for billing of access network service usage. In some embodiments, the billing is modified based on one or more of the classifications of access network service usage described herein. In some embodiments, the billing is modified based on one or more of the device connection state conditions described herein.
In some embodiments, device service history 1618 provides trusted (e.g., network-based, third-party-based, or certain device-based) service usage measures for billing purposes or for the purpose of verifying a trusted service policy implementation. In some embodiments, a trusted service policy implementation is verified by service controller 122 (e.g., access control integrity server 1654) by comparing the trusted service usage records with the usage limitations expected to be in place if the service policy is being properly implemented by end-user device 100. In some embodiments, these trusted service usage measures include a classification of service usage based on application. In some embodiments, these trusted service usage measures include a classification of service usage based on network destination or network service identifier. In some embodiments, these trusted service usage measures include a classification of service usage based on network type. In some embodiments, these trusted service usage measures include a classification of service usage based on time of day. In some embodiments, these trusted service usage measures include a classification of service usage based on QoS class. In some embodiments, these trusted service usage measures include a classification of service usage based on geography. In some embodiments, these trusted service usage measures include a classification of service usage based on a roaming network.
In some embodiments, central billing 1619 provides for billing of service usage. In some embodiments, central billing 1619 provides a mediation function for central provider billing events. For example, central billing 1619 can accept service plan changes. In some embodiments, central billing 1619 provides updates on device service usage, service plan limits and/or service policies. In some embodiments, central billing 1619 collects billing events, formulates bills, bills service users, provides certain billing event data and service plan information to the service controller 122 and/or end-user device 100.
In some embodiments, access network AAA server 1621 assists in authentication of service processor 115 by providing one or more of a device credential database, a user credential database, a service processor credential database, and an authentication service for the device. In some embodiments, access network AAA server 1621 provides the necessary access network AAA services (e.g., access control and authorization functions for the device access layer) to allow end-user devices 100 onto the central provider access network and the service provider network. In some embodiments, access network AAA server 1621 also provides the ability to suspend service for a device and resume service for a device based on communications received from service controller 122. In some embodiments, access network AAA server 1621 also provides the ability to direct routing for device traffic to a quarantine network or to restrict or limit network access when a device quarantine condition is invoked. In some embodiments, access network AAA server 1621 also records and reports device network service usage (e.g., to device service history 1618).
Although many of the embodiments disclosed herein include service controller 122, a service controller is not necessary in embodiments in which a user of end-user device 100 is in full control of access network policies via user interface 1697. For example, the user can determine access network service policies that limit service for end-user device 100 in general or for one or more of the access network service usage classifications described herein, including application limitations, network destination or network service limitations, network type limitations, etc. In some embodiments, based solely on user preferences input via user interface 1697 of end-user device 100, the service processor access network service policy limitations can specify blocking, allowing, or capping service usage according to, for example, application, application class, or destination. In some embodiments, these user-defined limitations can be modified based on the type of network the device is connected to. In some embodiments, these user defined limitations can be modified based on whether the user wishes to allow the access network communication activity for a given classification to occur in the background or not, or to cap such service usage when end-user device 100 is connected to a particular network type (e.g., a roaming network, a cellular network, a WiFi network, etc.). In some embodiments, these user-defined limitations can be modified based on whether the user wishes to allow the access network communication activity for a given classification to occur while end-user device 100 is connected to a roaming network, or to cap such service usage while end-user device 100 is roaming.
Internet 12 provides a connection to user device application program sources (e.g., third-party app stores 500) and user device application service destinations (e.g., app developer servers 600 and other websites, servers, or content sources connected to Internet 12). Application developer service design center (SDC) user interface (UI) 610 provides a user interface to allow application developers or website developers who choose to sponsor (e.g., partially or entirely subsidize) access network usage costs associated with particular applications and/or websites to define sponsored-service parameters. Usage or transaction monitors 620 track device usage of application developer servers 600 (e.g., by generating customer usage or transaction feedback 630) for the purpose of verifying access network service policy for sponsored services.
Authentication credential server 220 interfaces with application credential database 221, with application policy database 223, and with service controller 122. Authentication credential server 220 has at least three embodiments, each with a different mode of operation. In one embodiment or mode of operation, authentication credential server 220 provides application credentials and associated access network policies to end-user device 100 (e.g., to service processor 115) for the purpose of identifying a device application program and associating it with access network policies that are to be applied to attempted or successful access network communications associated with that application. A device application program credential can be a program identifier, a name, a signature, a certificate, a hash, or any other identifier that uniquely identifies the application. In another embodiment or mode of operation, authentication credential server 220 receives a device application credential from end-user device 100 (e.g., service processor 115), determines if the credential matches a known-application credential in application credential database 221, and, if so, provides the associated application access service policy from application policy database 223 to the device. In a variation of this embodiment, if authentication credential server 220 determines that the application credential does not match a known-application credential in application credential database 221, then, in some embodiments, authentication credential server 220 retrieves an access policy associated with unknown applications from application policy database 223 and provides it to end-user device 100. In some embodiments in which the application credential does not match a known-application credential, end-user device 100 is informed that no policy exists for the application associated with the credential. In some embodiments in which the application credential does not match a known-application credential, no action is taken.
Carrier core network usage monitors 640 monitor usage of access network resources by each end-user device 100. Carrier core network usage monitors 640 may include a deep packet inspection (DPI) element or any other network element capable of monitoring usage of access network resources by end-user devices.
Service design center 20 provides a means for specifying service plan policies for the access network service policy implementation system. Co-pending U.S. patent application Ser. No. 13/248,025, which is entitled “Service Design Center for Device Assisted Services” and is incorporated herein by reference, describes some of the information that may be configured via service design center 20. Examples of information that can be configured using service design center 20 include but are not limited to: a list of available service plans; the priorities of listed service plans, where the priorities identify the order in which the classification function on the end-user device should apply filters associated with the available, selected, or purchased service plans, e.g., to determine under which plan a particular service activity by an end-user device falls; how available service plans will be displayed on an end-user device, such as end-user device 100; a categorization of service plans (e.g., whether a service plan is a temporary activation plan, a sponsored plan subsidized or paid for by an entity other than a user or subscriber associated with the end-user device, a user-paid plan, etc.); promotional messages to be displayed on one or more end-user devices, such as end-user device 100; upsell offers (e.g., conditions that trigger the display of an upsell offer, information characterizing the upsell offer, etc.); events that cause a “no capable plan” notification (e.g., a notification that is presented when a user of an end-user device that is not associated with or subscribed to an applicable data plan attempts to access a data service, etc.) on the end-user device; templates for notification messages (e.g., message foregrounds and backgrounds, colors, logos, etc.); subscriber groups (e.g., by importing a list, manually typing individual subscriber identifiers, etc.); requests for reports containing information about a group of end-user devices or a group of subscribers; information about an end-user device associated with a subscriber (e.g., data usage measures, service plan information, cost or account balance information, notification settings for the end-user device, etc.).
In some embodiments, service usage reconciliation and fraud detection 642 provides service usage comparisons for the purpose of service fraud detection and corrective action. As disclosed herein, service usage measures used by service usage reconciliation and fraud detection 642 can originate from end-user device service usage measures, trusted service usage measures (e.g., measures from carrier core network usage monitors 640 or another trusted source), or both. As also disclosed herein, the service usage measures can be associated with various classifications (e.g., by application, network destination, device network connection state, network type, etc.). In some embodiments, a trusted service policy implementation is verified by service controller 122 by performing one or more of the following operations: (a) comparing the trusted access network usage records with the usage limitations expected to be in place if the service policy is being properly implemented; (b) comparing a trusted service usage measure against a device service processor-based service usage measure; (c) comparing a first device service processor service usage measure against a second device service processor service usage measure; (d) comparing device service usage against a population statistic for the device-based service usage measure.
In some embodiments, service usage reconciliation and fraud detection 642 uses customer usage or transaction feedback 630 from usage or transaction monitors 620 integrated into application developer servers 600 to aid in detection of service policy error events. In some embodiments, the service usage information provided from customer usage or transaction feedback 630 is used to determine the service usage that should be accounted to an application classification service, a website classification service, a network content classification service, or a network classification service defined by a connection to a network gateway, proxy server, or tunnel server (e.g., an APN tunnel server, a VPN tunnel server, etc.). In some embodiments, the service usage provided from customer usage or transaction feedback 630 is compared to device-based service usage measures to determine if the two measures are accurate to within a tolerance.
In some embodiments, third-party app stores 500 provide end-user device 100 with an application program source for downloading device application programs associated with an access network policy. In some embodiments, when (as disclosed herein) a device user interface notification offers a user a service plan comprising an application program and an associated access network policy for the application program, and the application program is not pre-loaded on the device, when the user selects the service plan, service processor 115 automatically downloads the application from one of third-party app stores 500.
In some embodiments, application developer service design center UI 610 allows application developers, website developers, or other Internet content providers or service providers to log into a sponsored service definition server in order to sign up for sponsored payments to subsidize user accounting for access network service usage for a certain application, certain website, certain content site, certain shopping site, or another Internet based service associated with a network destination, a group of network destinations, an application, a group of applications, a network type, etc. In some embodiments, an application credential can be uploaded or specified via application developer service design center UI 610 and associated with a sponsored service plan policy. In some embodiments, a network destination identifier can be uploaded or specified via application developer service design center UI 610 and associated with a sponsored service plan policy.
In some embodiments carrier billing 139 provides for billing of service usage.
Secure Service Controller Hardware Architectures
The elements of service controller 122 described herein can be implemented in various advantageous architectural embodiments to assist in securing device-assisted services (DAS).
In the embodiment of
In some embodiments, the file transfer function allows secure file transfers between a carrier (e.g., a service provider, an MVNO, a VSP, etc.) and the service controller. As illustrated in
In the embodiment of
In the embodiment of
In some service controller 122 embodiments, security is provided by making data flowing through the service controller accessible only to the functions and elements that process it. For example, in the embodiment of
The zone labeled “App VLAN” is the applications security zone. As illustrated in
Although
Although
Although
As illustrated in
Portal user 102, end-user device 100, and carrier file 118 access one or both of service controllers 162 and 164 through global load balancer 150, which routes carrier file 118 and communications to and from portal user 102 and end-user device 100. In some embodiments in which both of service controller 162 and service controller 164 are active, global load balancer 150 determines (e.g., based on the level of busyness or outage state of elements within service controller 162 and service controller 164) whether to route a particular communication to service controller 162 (potentially through optional load balancer 152) or to service controller 164 (potentially through optional load balancer 166). In some embodiments in which one of service controller 162 and service controller 164 is active and the other is in a stand-by state, global load balancer 150 routes communications to and from the active service controller unless or until there is a need to use functions in the stand-by service controller (e.g., if one or more elements in the active service controller fail, if the active service controller's ability to service communications becomes compromised for some reason, etc.). The architecture shown in
Portal user 102 accesses optional portal proxy server 108 (if present) through firewall 104 and (if present) optional load balancer 106. In some embodiments, portal user 102 establishes a virtual private network (VPN) connection over the Internet to communicate with optional portal proxy server 108. If present, optional portal proxy server 108 communicates with portal application server 112 through firewall 110.
As illustrated in
Portal application server 112 retrieves information from and stores information in database cluster 116 by establishing a connection through firewall 114. In some embodiments, portal application server 112 retrieves information requested by portal user 102 from database cluster 116. In some embodiments, portal application server 112 stores information entered by portal user 102 in database cluster 116.
Notification agent 180 and notification agent 182 provide information to monitoring element 188. In some embodiments, one or both of notification agents 180 and 182 are SNMP agents. In some embodiments, the information provided by one or both of notification agents 180 and 182 includes unsolicited notifications of events (e.g., disk full, memory error, SNMP traps, etc.). In some embodiments, information provided by one or both of notification agents 180 and 182 is in response to a request from monitoring element 188.
In some embodiments, monitoring element 188 responds to information sent by notification agent 180 or 182. For example, in some embodiments, monitoring element 188 sends notification agent 180 or 182 a message directing (respectively) portal proxy server 108 or portal application server 112 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.). In some embodiments, monitoring element 188 directs portal proxy server to test the communication path to portal application server 112.
Log forwarder 184 also sends information to monitoring element 188. In some embodiments, log forwarder 184 sends logs of accesses by or activities of portal users, such as portal user 102, to monitoring element 188. In some embodiments, portal application server 112 tracks system level commands and login attempts. In some embodiments, log forwarder 184 sends information about system-level commands and login attempts to monitoring element 188. In some embodiments, log forwarder 184 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, portal application server 112 generates log files, and log forwarder 184 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 184 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, monitoring element 188 includes a log file harvester. In some embodiments, portal application server 112 initiates the transfer of information from log forwarder 184 to monitoring element 188.
Carrier file 118 can contain various information, such as, for example: a measure of an access network usage by end-user device 100; information to provision an access network service for one or more end-user devices, such as end-user device 100; a list of end-user devices or subscribers authorized to use a particular service.
In some embodiments, carrier file 118 comprises a subscriber list. A subscriber list includes one or more subscriber identifiers, where a subscriber identifier is associated with a particular end user. As will be appreciated by a person having ordinary skill in the art, a subscriber identifier may also be associated with a particular end-user device or with a group of end-user devices, or the subscriber identifier may not be associated with any particular end-user device. Examples of subscriber identifiers are: an IMSI, an MSID, a MDN, an MSISDN, an MEID, an ESN, an IPv4/6 MAC or IP address, a key, a certificate, a globally unique identifier (GUID), a unique identifier (UID).
In some embodiments, carrier file 118 includes one or more flow data records (FDRs). A flow data record contains detailed information related to one or more network communications (e.g., source IP, source port, destination IP, destination port, bytes transmitted, bytes received, time flow started, time flow ended, traffic protocol (e.g., TCP/UDP), etc.).
In some embodiments, carrier file 118 includes a plan catalog that includes information about service plans for the access network that are available to one or more end-user devices. Examples of the information that may be included in a plan catalog are: a list of service plans and their characteristics (e.g., notification, charging, and control policies associated with each plan, access network activities qualifying for each plan, etc.); the priorities of the service plans, where the priorities identify the order in which the classification function on the end-user device should evaluate the filters associated with the available service plans; how the service plans are displayed on end-user devices (e.g., the order in which they are displayed, etc.); whether access network costs associated with a plan are paid by a sponsor entity or by a subscriber; whether a plan is an activation plan (e.g., a service plan that governs a device when a subscriber has not selected a plan); promotional messages; upsell offers; subscriber groups; notifications for which no service plan applies.
In some embodiments, carrier file 118 includes a list of end-user devices or subscribers authorized to use a particular service (e.g., a tethering service for sharing an access network connection with other devices through other input/output ports on the end-user device).
In some embodiments, carrier file 118 includes one or more classification rules. A classification rule is any rule that distinguishes between any characteristics of service plans, subscribers, end-user devices, network destinations, or network types. For example, a classification rule may distinguish between sponsor-paid and subscriber-paid service plans, between applications or groups of applications, between groups of subscribers, between end-user devices using valid profiles and those using fraudulent profiles, between authorized network destinations and unauthorized destinations, between network access types (e.g., home, roaming, 2G, 3G, WiFi, etc.), between time-of-day rules, etc.
In the embodiment shown in
In some embodiments, output file 120 is a batch report. In some embodiments, output file 120 is a real-time report. In some embodiments, output file 120 includes a measure of an access network usage or cost by an end-user device, such as end-user device 100. In some embodiments, output file 120 is a charging data report (CDR). In some embodiments, output file 120 includes a promotional message or advertisement. In some embodiments, output file 120 includes a subscriber list or an end-user device list. In some embodiments, output file 120 includes information about a service plan purchase made by a user of an end-user device, such as end-user device 100. In some embodiments, output file 120 includes information profiling an end-user device's usage of the access network or of an access network service. In some embodiments, output file 120 includes a fraud alert. A fraud alert is any indication that the service controller or an end-user device has detected activity or an event that suggests that an end-user device may be being used in a manner that violates a policy (e.g., a notification, control, or charging policy) that should be in effect or that the end-user device or device client has been tampered with in a way that compromises the security of the end-user device or an element of the end-user device (e.g., a software application, an agent, an operating system, etc.). A fraud alert may be in any form, for example, a simple flag or a message containing detailed information about the activity or event that caused the fraud alert to issue. A fraud alert can also include information such as, for example, the time the event was detected, the associated subscriber identifier, device identifier, suggested remediation actions, an error code, a rule to be added in the network elements that perform policy charging and rules function (PCRF) or policy charging and enforcement function (PCEF) tasks or to the gateway GPRS support node (GGSN), or any other information that could be useful to understand or mitigate fraudulent activity.
In some embodiments, EAI server 128 initiates the transfer of output file 120 to file server 126. In some embodiments, the transfer of output file 120 to file server 126 is initiated by file server 126. In some embodiments, output file transfer agent 203 establishes a connection to file transfer agent 213 to retrieve output file 120. In some embodiments, output file transfer agent 203 establishes a secure connection over the Internet to communicate with file transfer agent 213 through firewall 18. In some embodiments, file server 126 pushes output file 120 to output file transfer agent 203.
As illustrated in
Notification agent 196 provides information to monitoring element 188, communicating through firewall 186. In some embodiments, notification agent 196 is an SNMP agent. In some embodiments, the information provided by notification agent 196 includes unsolicited notifications of events (e.g., disk full, memory error, SNMP traps, etc.). In some embodiments, information provided by notification agent 196 is in response to a request from monitoring element 188.
File transfer agent 198 provides information to monitoring element 188 through firewall 186. This information can include, for example, file transfer activity, CPU load, disk usage, successful transfers, failed transfers, failed logins, operating environment info (e.g., ambient temperature, humidity, nominal voltage, etc.), system errors, etc. In some embodiments, monitoring element 188 initiates the transfer of information from file transfer agent 198.
In the embodiment shown in
In some embodiments, gateway application server 138 determines when to send information to end-user device 100. In some embodiments, gateway application server 138 sends information to end-user device 100 after completing an authentication protocol. In some embodiments, gateway application server 138 sends information to end-user device 100 in response to request or activity by another element or function in the service controller (e.g., EAI server 128, portal application server 112, fraud server 129, reconciliation server 131, or credentialing application server 146). In some embodiments, gateway application server 138 sends information to end-user device 100 in response to a communication from end-user device 100. In some embodiments, the communication from end-user device 100 is a message in an authentication protocol. In some embodiments, gateway application server 138 sends information to end-user device 100 over a secure communication link.
As illustrated in
As illustrated in
Gateway application server 138 retrieves information from and stores information in database cluster 116, communicating through firewall 114. In some embodiments, gateway application server 138 stores information from end-user device 100 in database cluster 116. In some embodiments, gateway application server 138 retrieves queued messages destined for end-user device 100 from database cluster 116. For example, gateway application server 138 may retrieve from database 116 and send to end-user device one or more of the following types of information: control, charging, or notification policies; promotional messages; service plan updates; end-user device configuration updates (e.g., related to the look and feel of a user interface on end-user device 100, etc.); a link to a software download.
In some embodiments, gateway application server 138 receives an authentication request from end-user device 100 and, based on the authentication request, retrieves a stored credential from database cluster 116 to assist in authenticating end-user device 100. In some embodiments, the authentication request from end-user device 100 comprises a credential associated with end-user device 100 or associated with a subscriber. In some embodiments, the credential is associated with a device identifier, or a subscriber identifier, or both a device identifier and a subscriber identifier. In some embodiments, the credential is one or more of a certificate, a key, a shared secret, a password, a hash, or a shared algorithm. In some embodiments, gateway application server 138 determines, based on the received credential and the stored credential, whether to proceed with communications with end-user device 100. In some embodiments, gateway application server 138 determines whether the credential sent by end-user device 100 is valid. In some embodiments, gateway application server 138 checks whether the credential sent by end-user device 100 has been revoked. In some embodiments, gateway application 138 determines whether the credential sent by end-user device 100 appears on a revocation list. In some embodiments, if the credential is a certificate, gateway application server 138 checks whether the certificate is on a certificate revocation list, where the certificate revocation list may be stored within or external to service controller 122 (e.g., in database cluster 116, in credentialing application server 146, in a separate certificate revocation list server, etc.).
In some embodiments, if the credential sent by end-user device 100 is valid, gateway application server 138 communicates with end-user device 100 using the credential for the purpose of exchanging service-related information or software. In some embodiments, the communication using the credential is over a secure communication link. In some embodiments, the secure communication link uses the SSL protocol. In some embodiments, the service-related information comprises a plan catalog. In some embodiments, the service-related information comprises a control, charging, or notification policy. In some embodiments, the service-related information comprises a promotional message or advertisement. In some embodiments, the service-related information comprises a usage measure or a cost measure. In some embodiments, the service-related information comprises an account balance. In some embodiments, the service-related information comprises a fraud alert. In some embodiments, the service-related information comprises a request from end-user device 100. In some embodiments, the service-related information comprises a response to a request from end-user device 100. In some embodiments, the service-related information comprises a request to end-user device 100. In some embodiments, the service-related information comprises a response to a request to end-user device 100. In some embodiments, the service-related information is configured to cause end-user device 100 to take a specific action. In some embodiments, the specific action is to be taken immediately. In other embodiments, the specific action is to be scheduled. In some embodiments, the specific action is to block, allow, rate-limit, or delay access to the access network by end-user device 100.
Notification agent 200 and notification agent 202 provide information to monitoring element 188. In some embodiments, one or both of notification agents 200 and 202 are SNMP agents. In some embodiments, the information provided by one or both of notification agents 200 and 202 includes unsolicited notifications of events (e.g., disk full, memory error, SNMP traps, etc.). In some embodiments, information provided by one or both of notification agents 200 and 202 is in response to a request from monitoring element 188.
In some embodiments, monitoring element 188 responds to information sent by notification agent 200 or 202. For example, in some embodiments, monitoring element 188 sends notification agent 200 or 202 a message directing (respectively) gateway proxy server 136 or gateway application server 138 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.). In some embodiments, monitoring element 188 directs gateway proxy server 136 to test the communication path to gateway application server 138.
Log forwarder 204 also sends information to monitoring element 188. In some embodiments, log forwarder 204 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, gateway application server 138 generates log files, and log forwarder 204 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 204 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, gateway application server 138 initiates the transfer of information from log forwarder 204 to monitoring element 188.
As described herein, the credentialing function enhances the security of DAS systems. In some embodiments, credentialing application server 146 receives a request from end-user device 100 (e.g., using service processor 115) for a credential. In some embodiments, the credential request from end-user device 100 to credentialing application server 146 includes a device identifier (e.g., any identifier associated with the end-user device) and a subscriber identifier (e.g., any identifier associated with the subscriber who uses or authorizes the use of the end-user device). In some embodiments, the credential request comprises a hash of a device identifier and a subscriber identifier. In some embodiments, the hash is salted. In some embodiments, credentialing application server 146 generates a credential based on the credential request from end-user device 100, stores the credential in database cluster 116, and sends the credential to end-user device 100. In some embodiments, credentialing application server 146 stores the device identifier and the new credential separately in database cluster 116. In some embodiments, credentialing application server 146 stores the device identifier and new credential as a single entry comprising their combination (e.g., a hash). In some embodiments, end-user device 100 stores the credential in local memory and thereafter uses the credential for secure communications with the service controller (e.g., with gateway application server 138).
Notification agent 210 and notification agent 212 provide information to monitoring element 188. In some embodiments, one or both of notification agents 210 and 212 are SNMP agents. In some embodiments, the information provided by one or both of notification agents 210 and 212 includes unsolicited notifications of events (e.g., disk full, memory error, SNMP traps, etc.). In some embodiments, information provided by one or both of notification agents 210 and 212 is in response to a request from monitoring element 188.
In some embodiments, monitoring element 188 responds to information sent by notification agent 210 and 212. For example, in some embodiments, monitoring element 188 sends notification agent 210 and 212 a message directing (respectively) credentialing proxy server 144 or credentialing application server 146 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.). In some embodiments, monitoring element 188 directs credentialing proxy server 144 to test the communication path to credentialing application server 146.
Log forwarder 214 also sends information to monitoring element 188. In some embodiments, log forwarder 214 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, credentialing application server 146 generates log files, and log forwarder 214 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 214 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, credentialing application server 146 initiates the transfer of information from log forwarder 214 to monitoring element 188.
EAI server 128 also communicates directly with portal application server 122 through web services interface 226. EAI server 128 communicates with carrier IT/billing 139 using EAI interface 231, with information passing through firewall 235.
EAI server 128 communicates through firewall 114 with database cluster 116. In some embodiments, EAI server 128 retrieves service-related information from database cluster 116 (e.g., information entered by or derived from information entered by portal user 102) and provides the information to gateway application server 138 for sending to end-user device 100.
In some embodiments, monitoring element 188 responds to information sent by notification agent 228. For example, in some embodiments, monitoring element 188 sends notification agent 228 a message directing EAI server 128 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.).
Log forwarder 230 also sends information to monitoring element 188. In some embodiments, log forwarder 230 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, EAI server 128 generates log files, and log forwarder 230 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 230 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, EAI server 128 initiates the transfer of information from log forwarder 230 to monitoring element 188.
As illustrated in
In some embodiments, monitoring element 188 responds to information sent by notification agent 234. For example, in some embodiments, monitoring element 188 sends notification agent 234 a message directing fraud server 129 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.).
Log forwarder 236 also sends information to monitoring element 188. In some embodiments, log forwarder 236 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, fraud server 129 generates log files, and log forwarder 236 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 236 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, fraud server 129 initiates the transfer of information from log forwarder 236 to monitoring element 188.
As illustrated in
In some embodiments, monitoring element 188 responds to information sent by notification agent 238. For example, in some embodiments, monitoring element 188 sends notification agent 238 a message directing reconciliation server 131 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.).
Log forwarder 240 also sends information to monitoring element 188. In some embodiments, log forwarder 240 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, reconciliation server 131 generates log files, and log forwarder 240 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 240 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, reconciliation server 131 initiates the transfer of information from log forwarder 240 to monitoring element 188.
As illustrated in
In some embodiments, monitoring element 188 responds to information sent by notification agent 244. For example, in some embodiments, monitoring element 188 sends notification agent 244 a message directing message bus 130 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.).
Log forwarder 246 also sends information to monitoring element 188. In some embodiments, log forwarder 246 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, message bus 130 generates log files, and log forwarder 246 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 246 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, message bus 130 initiates the transfer of information from log forwarder 246 to monitoring element 188.
As illustrated in
In some embodiments, monitoring element 188 responds to information sent by notification agent 266. For example, in some embodiments, monitoring element 188 sends notification agent 266 a message directing database node 260 to perform an action (e.g., run a program, run a test query to validate that the system is functional, run a program to determine whether a connected system is functional, etc.).
Log forwarder 268 also sends information to monitoring element 188. In some embodiments, log forwarder 268 sends information configured to assist in diagnosing problems with a system or service controller application. For example, in some embodiments, database node 260 generates log files, and log forwarder 268 sends the log files to monitoring element 188. In some embodiments, the log files are generated for individual service controller applications. In some embodiments, log forwarder 268 sends a system log, an information log, a debug log, an error log, information about a fatal event, etc. In some embodiments, database node 260 initiates the transfer of information from log forwarder 268 to monitoring element 188.
Secure Service Processor Operating Environments
In some embodiments, it is advantageous to store or implement certain portions or all of service processor 115 (e.g., agents, etc.) in protected or secure memory so that other undesired programs (and/or unauthorized users) have difficulty accessing the functions or software in service processor 115. In some embodiments, service processor 115, at least in part, is placed in a secure area of the operating system (e.g., in a kernel) so that it cannot be removed or, if it is removed, it must be replaced for proper device operation to resume. In some embodiments, service processor 115, at least in part, is implemented in and/or stored on secure non-volatile memory (e.g., non volatile memory can be secure non-volatile memory) that is not accessible without pass keys and/or other security mechanisms. In some embodiments, the ability to load at least a portion of service processor 115 software into protected non-volatile memory also requires a secure key and/or signature and/or requires that the service processor 115 software components being loaded into non-volatile memory are also securely encrypted and appropriately signed by an authority that is trusted by a secure software downloader function, such as service downloader 1663 shown in
Agent communication bus 1630 represents a functional description for providing communication for the various service processor 115 agents and functions. In some embodiments, such as the embodiment shown in
In some embodiments, there are multiple layers of security applied to agent communication bus 1630 communication protocols, such as including one or more of the following: point-to-point message exchange encryption using one or more keys that are partially shared or shared within the service processor 115 agent group and/or service controller 122, point-to-point message exchange that using one or more keys that are private to the two endpoints of the communication, a bus-level message exchange encryption that can be in place of or in addition to other encryption or security, or using one or more keys that are partially shared or shared within the service processor 115 agent group and/or service controller 122, a set of secure messages that can only be decoded or observed by the agents they are intended for, a set of secure messages that allow communication between certain agents or service processor functions and entities outside of the service processor operating environment. In some embodiments, and as described herein, service control device link 1691 is assumed to be equivalent to an agent for communication purposes, and, in the case of service control device link 1691, the communication is not restricted to agent communication bus 1630 but also extends to service control communications link 1653. In some embodiments, the system has the capability to replace keys or signatures on occasion or on a regular basis to further secure against monitoring, eavesdropping or compromise of the agent communication system.
Various forms of message encryption and security framework techniques can be applied to encrypt and/or secure agent communication bus 1630, including one or more of the following: agent bus encryption using shared key for all agents provided and updated by the secure server; agent bus encryption using point to point keys in which the secure server informs the bus and agents of keys and updates as appropriate; agent level encryption using agent to agent shared keys in which the secure server informs agents of the key and updates the key as appropriate; agent level encryption using agent to agent point to point key in which the secure server informs agent of the point to point keys that are required and updates the keys as appropriate; agent level access authorization, which only allows access to the agents that are on the secure authorization list and in which the list is provided by the secure server and signatures are provided by the secure server; user interface (UI) messages are only analyzed and passed, in which user interface 1697 cannot have access to configuration information and cannot issue challenges; agent level heartbeat encryption, which can be point to point or shared key for that agent; control link level heartbeat encryption; TLS (Transport Layer Security) communication protocols; server level heartbeat encryption, which can be point to point or shared key for that secure server; and/or access control integrity agent 1694 or heartbeat function can become point to multipoint secure communications hubs.
In some embodiments, the design of agent communication bus 1630 depends on the nature of the design embodiments for the agents and/or other functions. For example, if the agents are implemented largely or entirely in software, then agent communication bus 1630 can be implemented as an inter-process software communication bus. In some embodiments, such an inter-process software communication bus is a variant of D-bus (e.g., a message bus system for inter-process software communication that, for example, helps applications/agents to talk to one another), or another inter-process communication protocol or system, running a session bus in which all communications over the session bus can be secured, signed, encrypted or otherwise protected. For example, the session bus can be further protected by storing all software (e.g., software components, applications and/or agents) in secure memory, storing all software in encrypted form in secure memory, and/or executing all software and communications within a secure execution environment, hardware environment and/or protected memory space. In some embodiments, if the agents and other functions are designed with a mixture of software and hardware, or primarily with hardware, then the implementation of the bus design will vary, and the principles and embodiments described herein will enable one of ordinary skill in the art to design the specifics of agent communication bus 1630 to meet a particular set of product and desired functional requirements.
In some embodiments, service processor 115 includes a DDR processor located in a secure execution environment, and this DDR processor can be used advantageously to improve security of device-assisted services systems. Co-pending U.S. patent application Ser. No. 13/247,998, entitled “Secured Device Data Records” and incorporated by reference herein, describes embodiments of a DDR processor. In some embodiments, the DDR processor sends a sequence of secure device data records (DDRs) to a network element (e.g., via a secure channel). In some embodiments, the DDR processor is configured with an access controller that restricts end-user device 100's network access to a predetermined set of network destinations or functions if any of the DDR processor, service processor 115, or service controller 122 detects an error or potential fraud in one or more reports in the sequence of secure DDRs.
Service Processor Enrollment
In some embodiments, before service processor 115 of end-user device 100 participates in device-assisted services, it enrolls with service controller 122. In the enrollment process, service controller 122 (using, e.g., credentialing application server 146, a network element such as authentication credential server 220, etc.) allocates a device credential to service processor 115. In some embodiments, the credential is one or more of a certificate, a key, a shared secret, a password, a hash, a shared algorithm, or any other item of information that allows service controller 122 to confirm the identity of service processor 115. After service controller 122 has allocated the device credential, service controller 122 can use the device credential when it needs to authenticate service processor 115, such as, for example, before end-user device 100 sends device-based usage reports to gateway application server 138.
If end-user device 100 successfully verifies the service controller credential signing chain in step 1010, at step 1012 end-user device 100 generates a credential signing request using the service controller credential received in step 1008. In some embodiments, the credential signing request comprises a subscriber identifier and a device identifier. At step 1014, end-user device 100 sends the credential signing request to the service controller. In some embodiments, the credential signing request comprises a challenge password. At step 1016, end-user device 100 receives a device credential from service controller 122. At step 1018, end-user device 100 stores the device credential in local memory. In some embodiments, service controller 122 (e.g., credentialing application server 146) comprises a simple certificate enrollment protocol (SCEP) server, and the credential is a certificate. In some embodiments, messages sent and received by end-user device 100 are encrypted. In some embodiments, the service controller credential and device credential are 2048-bit RSA public key credentials. In some embodiments, service controller 122 and end-user device 100 communicate using a session key.
Although the steps are presented in
In some embodiments, service controller 122 is configured to allocate multiple credentials to different end-user devices associated with a single subscriber identifier.
Service Processor Authentication; Starting and Stopping a Data Session
To achieve an overall network service policy, the network portion of the access network service policy may be configured to work in conjunction with the device-based portion of the access network service policy to achieve an overall combined network service policy. If the device agents required to implement the device portion of the access network service policy are not present on the device or are not properly configured because of tampering or other undesirable activities, then the overall combined network service policy can be in error or may not be possible to achieve, potentially resulting in an undesired network service policy implementation. In such cases, it is desirable for a network system to be employed to detect this condition and modify the network portion of an access network service policy enforced by the network-based elements so that a desired network service policy enforcement may be achieved.
Examples of when it may be advantageous to adapt the network portion of an access network service policy in order to account for a missing or improperly configured service processor include but are not limited to: (i) a device credential has been moved to a device that does not have a service processor, (ii) a device credential has been moved to a device with a service processor with a different configuration than the service processor originally associated with the device credential, (iii) a device service processor has been tampered with or has an improper configuration.
In some embodiments, service controller 122 detects the presence and proper configuration of a service processor, or lack thereof, in the end-user device. If the service processor is present and properly configured, service controller 122 causes a first network portion of an access network service policy to be enforced in the network, the first network portion of an access network service policy being configured to provide counterpart policy enforcement to a device portion of an access network service policy to achieve a first desired overall access network service policy. If, on the other hand, the service processor is not both present and properly configured, service controller 122 causes a second network portion of an access network service policy to be enforced in the network, wherein the second network portion of the access network service policy is configured to operate without a device counterpart policy to achieve a second desired overall access network service policy.
In some embodiments, a trusted service policy implementation comprises service controller 122 authenticating and authorizing service processor 115. In some embodiments, the authentication comprises receiving and confirming a service processor certificate. In some embodiments, the authentication comprises receiving and confirming a service processor certificate that is based on a shared secret between service processor 115 and service controller 122. In some embodiments, the shared secret is unique for a given service processor 115.
In some embodiments, the process to establish a trusted service policy implementation comprises service processor 115 sharing two or more types of credentials with service controller 118, wherein the credentials include two or more of a service processor credential, a device credential, and a user or subscriber credential. In some embodiments, a portion of the process to establish a trusted service policy implementation includes end-user device 100 (e.g., service processor 115) sharing a service processor credential, a device credential, and a user or subscriber credential with service controller 122.
In some embodiments, establishing a trusted service policy implementation comprises service controller 122 receiving a certificate or hash result from a service processor element or agent acting on a portion of service processor 115 (for example, access control integrity agent 1694 performing a hash or certificate check on another service processor agent).
One or more authentication errors may occur when service controller 122 attempts to authenticate service processor 115. For example, service processor 115 may have invalid credentials. As another example, service processor 115 may send invalid application or kernel signatures. As another example, service processor 115 may report end-user device “root” detection errors. As another example, service processor 115 may contact service controller 122 using an identifier that is already in use by a different end-user device.
If service controller 122 does not receive the request from service processor 115 within the pre-determined time, or if service controller 122 is unable to authenticate service processor 115 for some reason, service controller 122 assumes that either (1) end-user device 100 does not contain a service processor, and is therefore unable to participate in device-assisted services, or (2) although end-user device 100 has a service processor, service processor 115 has been disabled. Service controller 122 sends a notification (“No active SP” message) to data rating element 2220 to indicate that end-user device 100 does not have the ability to provide the information necessary for data mediation element 2210 to generate detailed data usage reports (referred to herein as “micro-CDRs”). In some embodiments, service controller 122 sends a trigger to data mediation element 2210 to indicate that end-user device 100 should be charged for usage at “standard” bulk rates. In some embodiments, service controller 122 specifies a “standard” bulk rate charging code in the charging data records (CDRs) it sends to data mediation element 2210. In some embodiments, data rating element 2220 determines data usage by end-user device 100 based on carrier-based records (e.g., records of end-user device 100's usage of data over access network 10).
If service controller 122 receives the login or authentication request from service processor 115 within the pre-determined time and successfully authenticates service processor 115, service controller 122 sends a notification (“Device OK” message) to data rating element 2220 to indicate that end-user device 100 has a service processor and is capable of supporting device-assisted services. In some embodiments, data rating element 2220 expects to receive “micro-CDR” reports from data mediation element 2210 when service controller 122 has determined that end-user device 100 has an active service processor. In some embodiments, data rating element 2220 determines usage based on the micro-CDRs, which contain more granular information than ordinary CDRs. For example, whereas an ordinary CDR might simply report that an end-user device used 100 Megabytes (MB) of data, a set of micro-CDRs might report that the end-user device used 15 MB of e-mail, 35 MB of social networking, and 50 MB of streaming video.
In some embodiments, data mediation element 2210 sends carrier-based usage reports (e.g., CDRs) to service controller 122. Service controller 122 queries usage database 2200 for device-based usage reports (e.g., micro-CDRs) for end-user device 100. Service controller 122 determines the data usage of end-user device 100 from the carrier-based usage reports. Service controller 122 also determines the data usage of end-user device 100 from the device-based usage reports. In some embodiments, described in more detail below, service controller 122 compares the usage determined from the carrier-based usage reports to the usage determined from the device-based usage reports. If service controller 122 determines that the two usage measures do not match (e.g., are not identical or are not within a threshold of each other), service controller 122 sends a notification (e.g., a fraud alert) to data rating element 2220 to indicate that the end-user device is in a potential fraud state, and data rating element 2220 should bill usage for end-user device 100 based on carrier-based usage reports. Service controller 122 sends the carrier-based usage reports and device-based usage reports to data mediation element 2210.
When the “GPRS detach” message is received by SGSN 2230, SGSN 2230 sends a notification to service controller 122 that the data session for end-user device 100 is closed.
Service processor 115 may successfully authenticate with service controller 122 but then subsequently send one or more fraud notifications. Examples of device fraud notifications that service processor 115 might send are: invalid service processor kernel signature, invalid service processor framework signature, invalid service processor application signature, service processor application unable to connect to service processor kernel, service processor application not receiving heartbeat messages from service processor kernel, service processor kernel missing, service processor framework missing, service processor application missing, hosts file tampered with or missing, service processor to service controller encryption failure, or device “root” detected. In some embodiments, in response to receiving a device fraud notification from service processor 115, service controller 122 generates a fraud alert.
End-User Device Kernel/Software Component Verification
In some embodiments, establishing a trusted service policy implementation comprises two service processor 115 elements performing a mutual authentication of one another and then acting on an error result if one occurs.
At step 1100, a verifying software component obtains the public key of a to-be-verified software component. At step 1102, the verifying software component generates a random number. At step 1104, the verifying software component generates an encrypted challenge using the random number and the to-be-verified software component's public key. At step 1106, the verifying software component sends the encrypted challenge to the to-be-verified software component. At step 1108, the verifying software component obtains an encrypted response from the to-be-verified software component. At step 1110, the verifying software component obtains its own private key. At step 1112, the verifying software component uses its own private key and the encrypted response to obtain a first decoded random number. At step 1114, the verifying software component verifies that the first decoded random number matches the generated random number. In some embodiments, if the first decoded random number does not match the generated random number, the verifying software component takes an action. In some embodiments, if the to-be-verified software component is an application, the action comprises restricting the application's ability to communicate over an access network. In some embodiments, the action comprises notifying a user of end-user device 100. In some embodiments, the action comprises notifying a network administrator. In some embodiments, if the to-be-verified software component is an application, the action is to apply a policy to attempted or successful communications associated with the application. In some embodiments, the action is to take a countermeasure, such as, for example, preventing a user from accessing the to-be-verified software component, preventing the to-be-verified software component from executing, or terminating the to-be-verified software component (if it is running).
In some embodiments, if, in step 1114, the first decoded random number matches the generated random number, the verifying software component sends a message to service controller 122 (or another network element) indicating that the to-be-verified software component passed the test.
End-User Device Application Authentication
In some embodiments, an installed software application on end-user device 100 cannot be modified, updated, or replaced unless the software purporting to be a modification, update, or replacement includes a credential that matches a credential associated with the installed application. In some embodiments, the installed-application credential is a name identifier. In some embodiments, the installed-application credential is a secure signature, certificate, or hash of the installed software application. In some embodiments, the installed-application credential is stored on end-user device 100. In some embodiments, the installed-application credential is accessible to service processor 115 (for example, via policy control agent 1692). In some embodiments, when an attempt is made to modify, update, or replace the installed software application, service processor 115 and/or a device operating system (OS) obtains both the installed-application credential and a credential associated with the purported modification, update, or replacement. If the credential associated with the purported modification, update, or replacement matches the installed-application credential, service processor 115 allows the installed application to be modified, updated, or replaced.
If, at step 1304, the credential associated with the software purporting to be a modification, update, or replacement of the installed software application does not match the credential associated with the installed software application, then at step 1308, a component of end-user device 100 (e.g., service processor 115 or an operating system) takes a fraud action. In some embodiments, the fraud action comprises restricting end-user device 100's access to an access network. In some embodiments, the fraud action comprises restricting an application's (e.g., the installed software application's) ability to communicate over an access network. In some embodiments, the fraud action comprises notifying a user of end-user device 100. In some embodiments, the fraud action comprises notifying a network administrator or a network element of the credential mismatch. In some embodiments, the fraud action comprises applying a pre-determined billing rate for service usage by end-user device 100. In some embodiments, the fraud action comprises applying a pre-determined billing rate to service usage associated with the installed software application.
In some embodiments, end-user device 100 stores in memory (e.g., application program store 830 of
In some embodiments, end-user device 100 further comprises one or more device agents (e.g., service downloader 1663, access control integrity agent 1694, service monitor agent 1696, etc.) that detect when an entity (e.g., a user of end-user device 100, service controller 122, etc.) wishes or attempts to install update software on end-user device 100, where the update software purports to be a modification, update, or replacement of the application program. To improve security, the one or more device agents prevent modifications, updates, and replacements of the application software unless a credential associated with the purported update matches a credential of the installed application. For example, the one or more device agents obtain a credential associated with the application program that is already installed on end-user device 100, and a credential associated with a purported update to the installed application program. If the one or more device agents determine that the credentials match, they allow the update software to be installed or to execute on end-user device 100.
In some embodiments, security of end-user device 100 is enhanced using agents on end-user device 100. In some embodiments, an agent on end-user device 100 (e.g., policy implementation agent 1690, policy control agent 1692, access control integrity agent 1694, or any other agent that can perform verification functions) determines if a hosts file is present on the end-user device and configured in an expected manner. If the hosts file is not present or is not configured in an expected manner, in some embodiments, the agent takes an action. In some embodiments, the action is to generate a fraud alert. In some embodiments, the action is to take a countermeasure, such as, for example, to block, delay, rate-limit, or quarantine access to the access network by end-user device 100. In some embodiments, the action is to provide a notification to a user of end-user device 100. In some embodiments, the action is to send a message to service controller 122.
In some embodiments, an agent on end-user device 100 (e.g., policy implementation agent 1690, policy control agent 1692, access control integrity agent 1694, or any other agent that can perform verification functions) determines if service processor 115 successfully completed the authentication procedure with service controller 122. In some embodiments, if the agent determines that service processor 115 has failed to complete the authentication procedure, the agent takes an action. In some embodiments, the action is to generate a fraud alert. In some embodiments, the action is to take a countermeasure, such as, for example, to block, delay, rate-limit, or quarantine access to the access network by end-user device 100. In some embodiments, the action is to provide a notification to a user of end-user device 100. In some embodiments, the action is to send a message to service controller 122.
In some embodiments, an agent on end-user device 100 (e.g., policy implementation agent 1690, policy control agent 1692, access control integrity agent 1694, or any other agent that can perform verification functions) determines whether the end-user device has been “rooted” or “jailbroken.” As will be appreciated by a person having ordinary skill in the art, rooting (or “jailbreaking”) is a process that allows a user of a mobile device to attain privileged access (known as “root access”) to the device's operating system, thereby potentially circumventing various limitations that might otherwise govern operation of the device. In some embodiments, if the agent determines that end-user device 100 has been rooted or jailbroken, the agent takes an action. In some embodiments, the action is to generate a fraud alert. In some embodiments, the action is to take a countermeasure, such as, for example, to block, delay, rate-limit, or quarantine access to the access network by end-user device 100. In some embodiments, the action is to provide a notification to a user of end-user device 100. In some embodiments, the action is to send a message to service controller 122.
In embodiments in which service processor 115 applies an access network policy that includes classification of attempted or successful service usage attributed to a device software application program, the identification of the software application program and association of the access network policy to the software application program comprises associating the access network policy with a known-application credential. In some embodiments, the credential is a name identifier. In some embodiments, the credential is a secure signature, certificate, or hash of the software application program. In some embodiments, the credential is stored on end-user device 100 by service processor 115 (for example, by policy control agent 1692), and service processor 115 and/or a device operating system (OS) obtains a run-time application credential for an application that intends to initiate execution and obtain access network service or has successfully initiated execution and obtained access network service usage. Policy control agent 1692 compares the run-time credential to the stored known-application credential, and if there is a credential match the access network policy associated with the known-application credential is applied to the application access network service usage.
In some embodiments, the known-application credential is stored on end-user device 100 and used for the comparison with the run-time application credential. In some embodiments, the run-time application credential is provided to an element of service controller 122 (for example, policy management server 1652) that in turn determines if it matches a known-application credential and, if so, the element of service controller 122 provides the appropriate policy to service processor 115 (e.g., using gateway application server 138). In some embodiments, service processor 115 performs an application identity check on the run-time software program (for example, a secure hash, a secure hash based on a key provided by an element of service controller 122, or a signature check), and the result of this identity check is provided to the element of service controller 122, which in turn determines if it matches a known-application credential; if so, the element of service controller 122 provides the appropriate policy to service processor 115.
In some embodiments, if service processor 115 determines that a run-time application credential is intended, or may indicate an attempt, to spoof a known-application credential, a fraud action is taken. In some embodiments, if service controller 122 determines that a run-time application credential is intended, or may indicate an attempt, to spoof a known-application credential, a fraud action is taken. In some embodiments, the fraud action comprises restricting access to an access network for end-user device 100. In some embodiments, the fraud action comprises restricting an application's ability to communicate over an access network. In some embodiments, the fraud action comprises notifying a user of end-user device 100. In some embodiments, the fraud action comprises notifying a network administrator. In some embodiments, the fraud action comprises applying a pre-determined billing rate for service usage by end-user device 100. In some embodiments, the fraud action comprises applying a pre-determined billing rate for run-time application service usage by end-user device 100.
If, in step 1162, the credentials match, the end-user device takes a second action at step 1166. In some embodiments, the second action is to apply a policy associated with the installed application. In some embodiments, the second action is to send a message to a server indicating that the end-user device is in a healthy state.
Application execution environment 850 retrieves the run-time application program from memory and executes it, determines a run-time application credential associated with the run-time application program, and associates the run-time application credential with a run-time communication activity comprising a run-time application program's use of or intended use of the first access network. Application policy control 820 receives the run-time application credential, receives information associated with the run-time application communication activity, and determines whether the run-time application credential matches the known-application credential. If so, application policy control 820 causes the known application access network policy to be applied to the run-time application communication activity.
In some embodiments, end-user device 100 is further configured to provide the run-time application credential to a network element by way of a secure data connection between end-user device 100 and the network element. In some embodiments, end-user device 100 is further configured to receive information from the network element indicating the validity of the run-time application credential. In some embodiments, end-user device 100 is further configured to receive the information about the application policy from the network element by way of a secure data connection between end-user device 100 and the network element.
In some embodiments, end-user device 100 protects particular elements (e.g., software) from unauthorized user modification or unauthorized application program modification. For example, in some embodiments, end-user device 100 stores the known-application credential and the known application access network policy in a secure location. In some embodiments, end-user device 100 performs various functions, such as: determining the run-time application credential associated with the run-time application program (e.g., the credential-reporting element in the application execution environment); associating the run-time application credential with the run-time application communication activity (e.g., the credential-reporting element in the application execution environment); receiving the run-time application credential (e.g., application policy control 820); receiving information indicating the run-time application communication activity (e.g., the application policy control 820); determining if the run-time application credential matches the known-application credential (e.g., the application policy control 820); causing the known application access network policy to be applied to the run-time application communication activity (e.g., application policy control 820 instructing either the run-time controller element of the application execution environment 850 or the application policy enforcement element in the communications stack 860).
In some embodiments, the run-time application communication activity is an attempted access or successful access to access network 10 by the run-time application program, and the known application access network policy specifies allowing the access, blocking the access, limiting the access, or accounting for the access.
In some embodiments, the run-time application communication activity is an attempted access or successful access to an access network by the run-time application program, and the known application access network policy specifies a usage notification policy for notifying the user of the attempted or successful access. In some embodiments, the usage notification policy is configured to present to a user through user interface 1697 an access network service usage breakdown showing the service usage for the run-time application program. In some embodiments, the usage breakdown includes a breakdown by application. In some embodiments, the usage breakdown includes a breakdown by network type. In some embodiments, the usage breakdown includes a breakdown by both application and network type. In some embodiments, the usage breakdown includes a breakdown by network type. In some embodiments, the usage breakdown includes a roaming network breakdown. In some embodiments, the usage breakdown includes a breakdown by roaming network usage and by application.
In some embodiments, the usage notification policy is configured to present to a user through user interface 1697 a warning of the potential rate of service usage for the known application program. In some embodiments, the usage notification policy is configured to present to a user through user interface 1697 an offer to purchase service for the run-time application program. In some embodiments, the usage notification policy is configured to present to a user through user interface 1697 an indication of how much of a service allowance allocated to the known application program has been used or is remaining to be used.
In some embodiments, the run-time application communication activity is an attempt to execute or successful execution of the run-time application program, and the known application access network policy specifies allowing execution of the run-time application program, blocking execution of the run-time application program, or notifying the user of the attempted or successful execution.
In some embodiments, end-user device 100 is further configured with second access modem 890 to communicate with a second access network, and the run-time application communication activity comprises a run-time application program's use of or attempted use of the first access network or the second access network. In some embodiments, the known application access network policy settings or instructions differ based on whether end-user device 100 is connected to the first access network or to the second access network.
In some embodiments, user interface 1697 provides a user of end-user device 100 with input capability to modify access network service according to user preference and to receive access network service notifications. In some embodiments, user interface 1697 accepts user inputs for modifying access network policy, such as limiting access by one or more applications or access to one or more network destinations. In some embodiments, user interface 1697 accepts user inputs for choosing or modifying a service plan.
In some embodiments, at least an aspect of the known application access network policy is entered by a device user through user interface 1697. In some embodiments, at least an aspect of the known application access network policy is obtained from a network element.
In some embodiments, the memory is further configured to store an unknown application access network policy to be applied to the run-time application communication activity when the run-time application credential does not match the known-application credential. In some such embodiments, the application policy decision agent is further configured to determine if the run-time application credential does not match the known-application credential, and, if the run-time application credential does not match the known-application credential, cause the unknown application access network policy to be applied to the run-time application communication activity.
In some embodiments, end-user device 100 further comprises a policy enforcement agent (e.g., either a run-time controller element of application execution environment 850 or application policy enforcement element 862 in communications stack 860) configured to apply the known application access network policy to the run-time application communication activity and to cause the known application access network policy to be applied to the run-time application communication activity. In some embodiments, the known application access network policy is applied to the run-time application communication activity by providing an instruction to the policy enforcement agent. In some embodiments, the policy enforcement agent (e.g., the run-time controller element of application execution environment 850 or application policy enforcement element 862 in communications stack 860) applies the known application access network policy at the application layer of a device operating system. In some embodiments, the policy enforcement agent applies the known application access network policy at the library or framework layer of a device operating system. In some embodiments, the policy enforcement agent applies the known application access network policy by interacting with communications stack 860 or modifying communications stack traffic flows. In some embodiments, the policy enforcement agent applies the known application access network policy at the kernel or low level OS layer of an operating system of end-user device 100.
End-User Device Agent Verification
It may be advantageous in some embodiments to validate particular agents on the end-user device that assist in the provisioning and/or management of device-assisted services. In some embodiments, end-user device 100 includes one or more verification agents that may be used to validate one or more device-assisted services agents. There are many possible device-assisted agents that may be verified, such as, for example: a usage reporting agent (e.g., an agent that reports aggregate or finer (e.g., per-service or classification) measures of access network usage by the end-user device), a usage counting agent (e.g., an agent that reports counts of access network usage by the end-user device), a policy enforcement agent, a notification agent, a policy decision agent, a network state agent, a kernel communication agent, a user interface agent, a persistence agent (e.g., an agent that reads or writes from a data store, such as a local memory), a plan catalog agent, a service controller communication agent, a tethering detection agent, a time-of-day agent (e.g., an agent that manages a policy based on time of day), a kernel agent, or an analytics agent. Examples of agents are shown in
There are a number of ways in which the verification agent can validate a device-assisted services agent, including, for example: by performing a hash operation, by performing a checksum operation, by determining whether a digital signature is valid, by performing a fingerprint, by generating a random challenge and checking a response by the device-assisted services agent to the challenge, by extracting features from the agent for analysis by an artificial intelligence element (e.g., a support vector machine, a hidden Markov model, a decision tree, or a decision forest), etc. In some embodiments, the verification agent sends a verification message to the service controller with information about the results of the verification operation. In some embodiments, the verification message contains information about the integrity status of one or more of the device-assisted services agents. In some embodiments, the verification message comprises a hash, where the hash is the result of one or more of: a hash operation on a kernel component, a hash operation on a system component, a hash operation on an application. In some embodiments, the verification message comprises a hash that is a combination of two or more hashes. In some embodiments, the verification message comprises a salted hash. In some embodiments, the end-user device receives a verification result from the service controller. In some embodiments, the end-user device takes an action based on the verification result (e.g., blocks, allows, rate-limits, or delays an access to the access network by the end-user device; quarantines the end-user device; provides a notification to a user of the end-user device; heals a device-assisted services agent; etc.).
In some embodiments, one or more agents on end-user device 100 comprise software components that are associated with installed-agent credentials. In some such embodiments, an agent associated with an installed-agent credential cannot be modified, updated, or replaced unless the software purporting to be a modification, update, or replacement is associated with a credential that matches the installed-agent credential. An installed-agent credential may comprise an agent kernel software being present with a proper signature, certificate, or hash result; an agent framework software being present with a proper signature, certificate, or hash result; or an agent application software being present with a proper signature, certificate, or hash result.
Fraud Detection and Mitigation
In some embodiments, service controller 122 (using, e.g., fraud server 129) is configured to detect fraudulent, or potentially fraudulent, activities by end-user device 100. There are several ways service controller 122 can detect fraud, including, for example, by observing whether service processor 115 exhibits expected behavior; by determining whether device-generated usage reports indicate fraudulent use of the access network resources; by examining the contents of trusted reports (e.g., reports from a trusted or secure source) of end-user device 100's data usage; by comparing contents of non-secure device-based usage reports to contents of trusted usage reports; by comparing end-user device 100's usage to expected usage based on population statistics; by detecting SIM card irregularities that may indicate attempts to steal sponsored services. In some embodiments, service controller 122 obtains a trusted measure of end-user device 100's service usage and uses the trusted measure, alone or in combination with another measure, to determine whether end-user device is properly implementing a policy that should be in place.
In some embodiments, service controller 122 applies a policy error detection procedure to generate a fraud score, wherein the fraud score indicates a level of confidence or a likelihood that the analyzed activity or set of activities is fraudulent. In some embodiments, service controller 122 (using, e.g., fraud server 129) determines whether data usage by end-user device 100 is fraudulent by using what may be called a “layered” or “tiered” approach. In some such embodiments, service controller applies at least two tests to determine whether end-user device 100 is behaving fraudulently. In some such embodiments, a trusted service policy implementation is verified by service controller 122 by performing at least two of the following operations in conjunction with a multi-step service usage analysis procedure: (a) comparing a trusted access network usage records with the usage limitations expected to be in place if the service policy is being properly implemented, (b) comparing a trusted service usage measure to a non-secure (e.g., device-generated) service processor-based service usage measure, (c) comparing a first device service processor service usage measure against a second device service processor service usage measure, and (d) comparing a device service usage measure against a population statistic for the device-based service usage measure.
In some embodiments, service controller 122 applies at least two tests, and combiner 2810 generates a fraud score based on the results of the at least two tests. In some embodiments, service controller 122 applies one or more of the following tests to determine the fraud score: (a) determining if service processor 115 is failing to send non-trusted (e.g., device-based) service usage reports even though service controller 122 is receiving trusted reports of end-user device 100's service usage; (b) comparing a trusted service usage measure to a limit or range of usage expected if end-user device 100 is properly implementing a service policy that should be in place; (c) comparing a trusted service usage measure to a non-secure (e.g., device-based) usage measure to determine if the difference between the two usage measures is within a specified tolerance; (d) comparing a non-secure (e.g., device-based) service usage measure to a limit or range of usage expected if end-user device 100 is properly implementing a service policy that should be in place; (e) comparing a classification of end-user device 100 usage to a limit or range of usage expected if end-user device 100 is properly implementing a service policy that should be in place; (f) comparing an aggregation of two or more classifications of end-user device 100 usage to an aggregate limit on usage to determine if the difference between the two measures is within a specified tolerance; (g) comparing a trusted measure of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a limit or range of usage expected if end-user device 100 is properly implementing a service policy that should be in place; (h) comparing a trusted measure of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a non-secure (e.g., device-based) measure of usage of the same class to determine if the difference between the two measures is within a specified tolerance; (i) comparing a statistical characterization of usage by a population of end-user devices to a trusted measure of end-user device 100's service usage to determine if the difference between the two measures is within a specified tolerance; (j) comparing a statistical characterization of usage of a particular class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) by a population of end-user devices to a trusted measure of end-user device 100's usage of that same class to determine if the difference between the two measures is within a specified tolerance; (k) comparing a statistical characterization of usage by a population of end-user devices to a non-secure measure of end-user device 100's service usage to determine if the difference between the two measures is within a specified tolerance; (l) comparing a statistical characterization of usage of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) to a non-secure (e.g., device-based) measure of usage of the same class to determine if the difference between the two measures is within a specified tolerance; (m) comparing detailed class (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) usage information in a usage report (trusted or non-secure) to determine whether a policy that should be in place allows the classified activity; (n) determining whether service processor 115 successfully authenticated with service controller 122; (o) determining whether service processor 115 is reporting (e.g., sending heartbeat messages, device reports, etc.) to service controller 122 in an expected manner; (p) determining whether usage of one or more classes (e.g., an application, a group of applications, a network destination, a group of network destinations, etc.) is consistently slightly under particular limits that would indicate likely fraud on the part of end-user device 100; (q) comparing an amount or percentage of unknown or unclassified data usage allocated by service processor 115 to a particular class to an expected amount or percentage of unknown or unclassified data usage, where the expected amount or percentage is determined using information from a trusted source (e.g., a web crawler, domain object model, etc.).
The outputs of the N tests may be pass/fail indicators or values (e.g., integer, binary, real numbers, etc.). In some embodiments in which the outputs of the N tests are pass/fail indicators, combiner 2810 determines a fraud score of “pass” or “fail” (e.g., combiner 2810 generates one fraud score (e.g., a discrete value such as 0) if the result is “pass” and a different fraud score (e.g., a different discrete value such as 1) if the result is “fail”). In some embodiments, the fraud score is “pass” if each of the N individual test results indicates the associated test was passed. In some embodiments, the fraud score is “fail” if at least one of the N individual test results indicates that the associated test was failed. In some embodiments, the fraud score is “pass” if at least M individual test results indicate the associated tests were passed, where M is less than N. In some embodiments, the fraud score is “fail” if M or more individual test results indicate the associated tests were failed. As will be appreciated by a person having ordinary skill in the art in view of the disclosures herein, there are many other ways to combine the individual test results and determine the fraud score, and the examples above are not meant to be limiting.
In some embodiments, the output of each of the N tests is a value. In some embodiments, combiner 2810 performs a linear combination of the N individual test results. In some embodiments, combiner 2810 scales one or more of the N test results before performing a combination (linear or otherwise).
In some embodiments, each output value is between a minimum value and a maximum value (e.g., between 0 and 1, or between values A and B, inclusive, etc.), and the maximum value is associated with a high likelihood of fraudulent behavior by end-user device 100. In some embodiments, each output value is between 0 and 1, and each output value represents a probability of fraudulent behavior on the part of end-user device 100. In some such embodiments, combiner 2810 multiplies the individual test result values to generate the fraud score. In some embodiments, combiner 2810 applies a weighting factor to one or more of the N test results before multiplying them. As will be appreciated by a person having ordinary skill in the art in view of the disclosures herein, there are many other ways to combine the individual test results and determine the fraud score, and the examples above are not meant to be limiting.
In some embodiments, a high fraud score is associated with a high likelihood of fraudulent behavior on the part of end-user device 100. In some such embodiments, if the fraud score generated by combiner 2810 based on the results of N initial tests is greater than (or greater than or equal to) a threshold, service controller 122 generates a fraud alert. In some embodiments, if the fraud score generated by combiner 2810 based on the results of N initial tests, where N is less than the maximum number of tests available, is greater than (or greater than or equal to) a threshold, additional tests are run. In some embodiments, one or more additional tests are added to the set of tests selected initially (e.g., the value of N is increased, and additional tests are selected and included). In some embodiments, at least one of the one or more additional tests is more computationally-expensive than one or more of the tests in the initial set of N tests.
In some embodiments in which a high fraud score is associated with a high likelihood of fraudulent behavior on the part of end-user device 100, if the fraud score generated by combiner 2810 based on the results of N initial tests, where N is less than the maximum number of tests available, is greater than (or greater than or equal to) a threshold, a different set of N tests is selected and run. In some embodiments, the different set of N tests includes one or more of the tests run in the initial set of N tests. In some embodiments, at least one of the tests in the different set of N tests is more computationally-expensive than one or more of the tests in the initial set of N tests.
In some embodiments, a low fraud score is associated with a high likelihood of fraudulent behavior on the part of end-user device 100. In some such embodiments, if the fraud score generated by combiner 2810 based on the results of N initial tests is less than (or less than or equal to) a threshold, service controller 122 generates a fraud alert. In some embodiments, if the fraud score generated by combiner 2810 based on the results of N initial tests, where N is less than the maximum number of tests available, is less than (or less than or equal to) a threshold, additional tests are run. In some embodiments, one or more additional tests are added to the set of tests selected initially (e.g., the value of N is increased, and additional tests are selected and included). In some embodiments, at least one of the one or more additional tests is more computationally-expensive than one or more of the tests in the initial set of N tests.
In some embodiments in which a low fraud score is associated with a high likelihood of fraudulent behavior on the part of end-user device 100, if the fraud score generated by combiner 2810 based on the results of N initial tests, where N is less than the maximum number of tests available, is less than (or less than or equal to) a threshold, a different set of N tests is selected and run. In some embodiments, the different set of N tests includes one or more of the tests run in the initial set of N tests. In some embodiments, at least one of the tests in the different set of N tests is more computationally-expensive than one or more of the tests in the initial set of N tests.
In some embodiments, one of the N tests indicates whether service processor 115 successfully completed the authentication procedure with service controller 122. In some embodiments, a failure of service processor 115 to complete the authentication procedure with service controller 122 results in a fraud score that indicates end-user device 100 is likely behaving fraudulently (e.g., an automatic “fail” or a fraud score that indicates a high likelihood of fraud). In some embodiments, the result of one or more tests is a quantized value associated with a likelihood of error (e.g., fraud) or a likelihood of non-error (e.g., no fraud), and the overall pass/fail criterion is based on a combination of one or more of the quantized values.
In some embodiments, service controller 122 applies different sets of N tests at different times. For example, in some embodiments, service controller 122 applies a set of N tests including more computationally expensive tests on occasion or periodically. In some embodiments, service controller 122 varies the value of N at various times. In some embodiments, service controller 122 regularly applies a small or modest set of tests, and then occasionally or periodically applies a larger set of tests. In some such embodiments, the larger set of tests includes one or more tests that are more computationally expensive than tests in the smaller set (e.g., tests that require processing of flow data records, discussed below).
In some embodiments, if the fraud score indicates a policy implementation error (e.g., likely fraudulent behavior by end-user device 100), service controller 122 takes an action comprising one or more of: generating a fraud alert; flagging end-user device 100 or a user associated with end-user device 100 for further evaluation; charging for end-user device 100's usage at a pre-determined rate associated with end-user device 100 being in a fraudulent state; notifying a user of end-user device 100; notifying a network administrator; quarantining end-user device 100 or a user's access to the access network; suspending end-user device 100 or a user of end-user device 100 from the access network.
Fraud Detection Based on Service Processor Behavior
Fraudulent or potentially fraudulent activity by end-user device 100 can be detected by service controller 122 by observing the behavior of end-user device 100 after service processor 115 has been authenticated. In some embodiments, detecting fraud comprises ensuring that service control device link 1691 and service control server link 1638 are operating correctly, and there is no break in a continuous heartbeat authentication sequence.
In some embodiments, service processor 115 sends periodic or occasional device-based usage data reports (UDRs) to service controller 122. The UDRs contain information about end-user device 100's data usage. For example, the UDRs may indicate how many bytes of data associated with a particular application, such as a map application, or service, such as a music streaming service, end-user device used since the last report, or during a particular time period. In some embodiments, service processor 115 sends the UDRs in response to a request from service controller 122. In some embodiments, service controller 122 generates a fraud alert if, after having been authenticated, service processor 115 fails to send device-based usage reports when expected or requested by service controller 122, or when service processor 115 sends device-based usage reports at unexpected or improper times. In some embodiments, service controller 122 generates a fraud alert if it receives UDRs from service processor 115 after receiving a “data session stopped” trigger from a network element.
In some embodiments, service controller 122 generates a fraud alert if service processor 115 fails to respond as expected to commands issued by service controller 122. In some embodiments, service controller 122 sends a command to service processor 115 and observes a response from service processor 115. In some embodiments, when fraud is suspected, service controller 122 instructs service processor 115 to apply and enforce policy modifications. Service controller 122 then observes the response of service processor 115 and performs an analysis on information sent by service processor 115 to service controller 122 to determine whether the behavior of end-user device 100 is indicative of fraud.
In some embodiments, service controller 122 directs service processor 115 to change a setting of end-user device 100. If the setting change ordinarily would cause a deterministic behavior change in the operation of an end-user device that is operating according to an established policy, service controller 122 may determine that end-user device 100 is operating fraudulently if service controller 122 does not observe that end-user device 100's behavior has changed in the expected manner. As an example, service controller 122 might suspend end-user device 100's use of a sponsored service (i.e., a service for which a sponsor entity subsidizes an end-user device's access to that service). If end-user device 100 continues to use the sponsored service after service controller 122 suspended end-user device 100's use of the sponsored service, service controller 122 may conclude that the access is fraudulent.
In some embodiments, service controller 122 changes a parameter to cause end-user device 100 to modify its behavior and potentially also to change particular settings of end-user device 100. For example, service controller 122 might communicate to service processor 115 a lower maximum data rate at which end-user device 100 is allowed to send data over the access network. If end-user device 100 continues to send data at a rate above the newly-imposed maximum data rate, service controller 122 may conclude that end-user device 100 is operating fraudulently. In some embodiments, parameter changes are constructed, for example, from rules or by building a reaction model for a user population, where the reaction model learns to distinguish legitimate activity from fraudulent behavior.
Fraud Detection Using Trusted Usage Measures/Records
Fraudulent or potentially fraudulent activity by end-user device 100 can be detected by examining trusted measures or records of data usage by end-user device 100. In some embodiments, a network element (e.g., service usage reconciliation and fraud detect 642 or fraud server 129) examines the content of usage reports from a trusted source to determine whether end-user device 100 is operating within the policies that should be in place. The usage reports may indicate a variety of information, including, for example, one or more of: a “bulk” measure of aggregate data usage, destinations accessed, network state (e.g., time of day, network busy state, network congestion state, etc.), type of network (e.g., 2G, 3G, 4G, WiFi, home, roaming, etc.), etc. In some embodiments, the trusted records contain information about end-user device 100's data use associated with a class of service activities, where the class is a particular application, a group of applications, a particular network destination, a group of network destinations, a network type, etc. For example, the trusted records may contain one or more of: record start time, record end time, information identifying the class, the amount of data use associated with the class, etc.
There are several possible sources of trusted records, including network elements, end-user device 100, and third-party sources. Records from network elements are generally trusted because it is difficult for unauthorized parties to obtain access to the records themselves or the network elements that generate the records, particularly if some or all of the security measures disclosed herein are in place. Examples of network elements that can produce trusted records are: gateways (e.g., GGSN 2240, SGSN 2230, PDSN, routers, switches, etc.), a home agent, proxy servers, a charging gateway system, a mediation element (e.g., mediation 22210), a reconciliation element (e.g., reconciliation server 131), a billing element (e.g., central billing 1619, carrier billing 139), a AAA element (e.g., access network AAA server 1621), and other network elements.
End-user device 100 can also generate trusted records if it includes a secure device data record (DDR) processor and a secure protocol for the sending of reports from the secure DDR processor to service controller 122. The use of secure DDRs is described in detail in U.S. patent application Ser. No. 13/247,998, which is entitled “Secured Device Data Records” and is incorporated herein by reference.
Third-party sources can also provide trusted records if measures are in place to verify the reports. Examples of third-party sources that can provide trusted records are: partner service destination servers (e.g., search sites, advertisement sites, application service sites, shopping sites, content sites, gaming sites, e-mail sites, etc.), enterprise customer networks, etc. Third-party sources may provide such information as usage reports, site visits, transaction reports, ad view reports, economic benefit reports, usage credit increase instructions, etc.
In some embodiments, using data usage reports from a trusted source, a network element determines whether end-user device 100's usage, as given by a trusted usage measure is within a limit or range of usage behavior expected if an applicable policy is in place. For example, in some embodiments, the network element determines whether the bulk usage by end-user device 100 is no higher than a maximum amount specified by a policy that should be in place. In some embodiments, the network element determines whether end-user device 100's use of a particular class (e.g., an application, a group of applications, a network destination, a group of network destinations, network type, etc.) is within data usage limits specified in the control policy that should be in place. In some embodiments, the network element determines whether end-user device 100's use of a particular class is allowed under the control policy that should be in place. As will be now be appreciated by one of ordinary skill in the art in view of the disclosures herein, there are many ways that a network element can use information in reports from a trusted source to verify that end-user device 100 is operating in compliance with policies that should be in place, and the examples given above are not meant to be limiting.
Fraud Detection Using Non-Secure Device-Based Usage Measures/Records
In some embodiments, service processor 115 is not capable of generating and sending secure DDRs. Instead, service processor 115 is capable only of generating and sending non-secure records (e.g., UDRs) of end-user device 100's data usage. In such cases, an unscrupulous user might attempt to hack end-user device 100 so that the reports it sends contain information that is more favorable to the user than it should be, e.g., by reporting less data usage (either aggregate or of a class) than end-user device 100 actually used or by reporting data usage that should be accounted as usage under a subscriber-paid service plan as usage of a sponsored service. In some embodiments, service controller 122 uses device-based usage measures to detect when a user attempts to tamper with service processor 115 in order to have usage of one service reported incorrectly (e.g., as usage of a different class, as usage of a sponsored service when it is actually part of a subscriber-paid plan, etc.). In some embodiments, service controller 122 compares usage measures in device-based (e.g., non-secure) reports to corresponding usage measures in a report from a trusted source.
In some embodiments, service controller 122 generates a fraud alert if it receives UDRs from end-user device 100, but the UDRs indicate end-user device 100's usage is beyond a charging policy limit. In some embodiments, if service controller 122 receives UDRs from end-user device 100, but the charging codes in those UDRs do not correspond to charging codes for the currently-allowed active services (e.g., the charging codes indicate that end-user device 100 is using data or a class for which it is not authorized, etc.), service controller 122 generates a fraud alert.
In some embodiments, service controller 122 examines the content of device-based usage reports (e.g., reports generated by service processor 115 and sent to service controller 122) to verify that service processor 115 is properly classifying services. In some embodiments, service controller 122 determines whether applications being used or destinations being accessed by end-user device 100 are authorized under a service plan associated with end-user device 100. In some embodiments, service controller 122 examines the content of device-based usage reports to determine whether end-user device 100 imposed a service control that was supposed to be in place (e.g., a cap on usage; a speed of usage (such as a maximum rate); an amount of usage of background or foreground data; state modifiers such as time-of-day, network busy state, network type (e.g., home, roaming, WiFi, cellular, etc.); quality-of-service limits, etc.).
In some embodiments, service controller 122 examines the content of device-based usage reports to verify that the service usage measures being reported by end-user device 100 are compliant with the access network policy or policies that should be in place. In some embodiments, service controller 122 determines whether one or more of the following measures are within limits imposed by a policy that should be in place: bulk (e.g., aggregate) usage; usage of a class (e.g., an application, a group of applications, a network destination (e.g., IP address, domain address, etc.), a group of network destinations, etc.); application-specific usage that includes transaction-based single-application service or multi-application service; background usage; foreground usage; usage that is identified by a time-of-day, network-busy-state, quality-of-service, or network-type state modifier; roaming usage; usage associated with specific content (e.g., streaming video, streaming audio, etc.); usage based on a specific layer 3/4 protocol (e.g., TCP, UDP, and/or a Layer 7 protocol (e.g., IGMP, RTMP, RSTP, etc.)).
In some embodiments in which service processor 115 tracks end-user device 100's use of a class (e.g., an application, a group of applications, a network destination, a group of network destinations, network type, etc.), service controller 122 examines the content of device-based usage reports to determine whether end-user device 100 is properly identifying and allocating data usage associated with the class. As is described in detail in several previous applications listed in the “Cross Reference to Related Applications” section (including U.S. patent publication 2010/0198698, filed Jan. 27, 2010 and entitled “Adaptive Ambient Services”), classifying data usage in the dynamic (e.g., non-static) environment of the Internet can be challenging. For example, a class may include access to a particular web site. Service processor 115 should count, as usage of the class, end-user device 100's access to the collection of URLs associated with the web site, but not access to other network destinations and/or applications not associated with the web site. Although it is possible to create, at any point in time, a comprehensive list of all content associated with the web site, a problem arises whenever the web site changes (e.g., links or URLs are changed, content from other web sites is included or removed, etc.), because the list of associated addresses/domains and access list policies will be inaccurate if it is not updated immediately after the change.
Several of the patent applications listed in the “Cross Reference to Related Applications” section of this document, including U.S. patent application Ser. No. 13/253,013, entitled “System and Method for Providing User Notifications” and incorporated by reference herein, disclose ways to track changes in the Internet to facilitate providing, for example, service plans with different classes, sponsored services, etc. One way to track changes is to use search engine/web crawler techniques to create and update a catalog of content sources, destinations (e.g., advertisement servers, network domains, etc.) etc. that are associated with a class. As would be understood by a person of ordinary skill in the art, a web crawler is a computer program that browses the web in a methodical, automated way. Web crawlers are also known as ants, automatic indexers, bots, web spiders, web robots, or web scutters. Web crawlers may be used to copy, check, or validate links on web sites. A web crawler may start with a list of URLs to visit. As the crawler visits these URLs, it identifies all the hyperlinks in the page and adds them to the list of URLs to visit. The new list is sometimes called the crawl frontier. URLs from the crawl frontier are then recursively visited according to a set of policies that specify which pages to visit, how often to re-visit those pages, etc.
The immediate identification and propagation to all service processors of all changes in every web site associated with every sponsored service or every class within all service plans can be difficult. Therefore, in some embodiments, when end-user device 100 engages in service activities associated with a class (e.g., sends or receives data using a particular application that is itself a class, or using an application from a defined set of applications comprising a class; or accesses a particular network destination that is itself a class, or accesses a particular network destination that is in a class comprising a set of network destinations; or uses a particular network type, etc.), and in the course of using data within the class end-user device 100 is directed to a destination that service processor 115 does not know or is unclassified, service processor 115 grants a temporary access “lease.” Under the lease, access to, for example, certain unknown or unclassified destinations is allowed (e.g., for a particular amount of data, for a particular amount of time, etc.) but monitored until the unclassified or unknown application or destination can be reclassified as allowed or disallowed. A lease temporarily allows unknown or unclassified activities to take place within the class under the theory that such activities may be the legitimate result of a change in an Internet destination included in the class, and, therefore, it would be undesirable to block these activities or to allocate data access costs associated with them to a “bulk” usage category or to a different class when they should be allocated to the class.
Service controller 122 can use information from a web crawler/search engine (e.g., the crawl frontier) to assess whether service processor 115 is likely correctly allocating data usage to particular classes. In some embodiments, service controller 122 determines whether service processor 115 is allocating a reasonable amount of unknown or unclassified data usage to the class based on web crawler results. For example, if the web crawler results indicate that, at a particular point in time or on average, approximately 80 percent of content available at or through a particular web site is known (e.g., has a URL that alone indicates it is part of the class, has a URL that indicates it is from an ad server or another so-called known, benign domain, the content of which is unlikely to be accessed fraudulently by a user, etc.), and 20 percent of the content is unknown (e.g., not known to be part of the class, not a known, benign domain, etc.), service controller 122 may determine that end-user device 100 is likely operating fraudulently if only 50 percent of the data usage allocated by service processor 115 is known to be associated with the web site, and the other 50 percent of the data usage allocated by service processor 115 to the class is associated with unknown or unclassified content or destinations. Such a result may indicate that service processor 115 has been hacked and is improperly allocating data usage to the class.
In some embodiments, service controller 122 determines whether device-based usage reports indicate that service processor 115 is likely fraudulently allocating data usage to a sponsored service. For example, in some embodiments, service controller 122 determines how much of the data usage service processor 115 is allocating to a sponsored service is known to be associated with the sponsored service and how much is not known to be associated with the sponsored service. In some embodiments, service controller 122 determines (e.g., based on web crawler or similar data) whether service processor 115 is allocating too much unknown or unclassified data usage to a sponsored service. In some embodiments, service controller 122 assesses whether service processor 115 is properly granting leases (e.g., by determining whether the leases are of an appropriate duration, are terminated properly, etc.). In some embodiments, service controller generates a fraud alert if the UDRs indicate that end-user device is improperly classifying disallowed destinations (e.g., web sites, URLs, etc.) as part of a sponsored service.
In some embodiments, service controller 122 compares usage counts in carrier-based usage reports, or usage reports from another trusted source, to usage counts in UDRs from end-user device 100. In some embodiments, if the difference between the usage counts in the two reports is not within a tolerance (e.g., an amount of data, a percentage, etc.), service controller 122 generates a fraud alert. In some embodiments, if the counts in the reports agree, and the charging codes in the UDRs are correct, but the UDRs indicate that service processor 115 has incorrectly categorized (e.g., classified) the data usage, service controller 122 generates a fraud alert. In some embodiments, if the counts in the reports are in agreement, but the usage rate (e.g., units of data per unit of time) within a service component (e.g., a class) or within a service activity is greater than a rate limit set by the control policy, service controller 122 generates a fraud alert.
In some embodiments, service controller 122 generates a fraud alert if a comparison between the device-based UDRs and carrier-based (or other trusted) usage reports indicates that end-user device 100 consistently under-reports its usage of data in a particular class (e.g., an application, a group of applications, a destination, a group of destinations, etc.). Such underreporting may indicate that service processor 115 is substituting usage counts from a higher-priced service for the counts associated with a lower-priced or sponsored service (e.g., service processor 115 is reporting more usage of the lower-priced service and less usage of the higher-priced service). Such “skimming” can occur, for example, within a single service, across multiple services, across multiple time periods, or in other ways or combinations of these ways.
In some embodiments, service controller 122 generates a fraud alert if the UDRs from service processor 115 indicate that end-user device 100's usage of a service, component, or activity is abnormal when compared to a hard rate limit, such as an allowed usage per hour, day, or week, or an expected rate limit, such as a rate limit imposed on streaming services.
In some embodiments, service controller 122 compares a usage rate of end-user device 100 to the “average” end-user device usage rate, which it determines using a statistical model of usage data associated with a specific service plan or component of a service plan (e.g., a class) by a population or sub-population of devices. In some such embodiments, service controller 122 performs what is known in the art as a k-nearest neighbor classification, using the usage rate to identify whether end-user device 100 is potentially behaving fraudulently. As would be understood by a person having ordinary skill in the art, the k-nearest neighbor classification may be trained by learning vector quantization (LVQ) using tunable training parameters such as, for example, the time window of data usage, usage rate, etc.
In some embodiments, service controller 122 may or may not generate a fraud alert upon detecting a particular condition. For example, if the usage counts contained in trusted reports and UDRs from service processor 115 are in agreement, but end-user device 100's usage rate, in terms of units of data per unit of time, deviates significantly from the usage rate of the “average” user, it could mean that service processor 115 has been tampered with or otherwise compromised. Alternatively, however, it could mean simply that the usage patterns for that service activity or service component are changing, or that end-user device 100 is being used legitimately, but in an unusual manner as compared to how most end-user devices are used. A change in usage patterns could result, for example, if the service plan to which end-user device 100 is subscribed adds streaming content, such as video or audio, and a user is among the first to take advantage of the new content. In some embodiments, service controller 122 may simply flag the activity as potentially fraudulent, or it may wait until it has performed additional analysis to make a decision regarding whether service processor 115's behavior is likely fraudulent.
In some embodiments, service controller 122 determines a second measure of a network state to confirm that end-user device is reporting the correct network state in its charging reports. In some embodiments, service controller 122 (or another suitable network function) obtains the network state as determined using a group of devices. In some embodiments, service controller 122 (or another suitable network function) characterizes sub-network portions (e.g., base stations, base station sectors, geographic areas, RANs, etc.) based on a population of end-user devices connected to that sub-network portion.
In some embodiments, service controller 122 determines a second measure of device access behavior for a given network state to ensure end-user device 100 is implementing the correct controls. In some embodiments, the second measure is from a network element. In some embodiments, the second measure is from a secure DDR processor on end-user device 100. In some embodiments, the second measure is from a second monitor point within end-user device 100. In some embodiments, the second measure is “good customer feedback” from a third party source.
In some embodiments, service controller 122 compares a trusted (e.g., network-based, secure DDR, or third-party) measure of the device's service usage to a device-based (e.g., service-processor-based) measure of the device's service usage. In some embodiments, one or both of the trusted service usage measures and the device-based service usage measures include a classification of service usage based on application. In some embodiments, one or both of the service usage measures include a classification of service usage based on network destination or network service identifier. In some embodiments, one or both of the service usage measures include a classification of service usage based on network type (e.g., roaming, home, cellular, WiFi, etc.). In some embodiments, one or both of the service usage measures include a classification of service usage based on time of day. In some embodiments, one or both of the service usage measures include a classification of service usage based on QoS class. In some embodiments, one or both of the service usage measures include a classification of service usage based on geography. In some embodiments, one or both of the service usage measures include a classification of service usage based on a roaming network.
In some embodiments, a trusted service policy implementation is verified by comparing a first device-based service processor service usage measure against a second device-based service processor service usage measure. In some embodiments, one or both service processor usage measures include a classification of service usage based on application. In some embodiments, one or both service processor usage measures include a classification of service usage based on network destination or network service identifier. In some embodiments, one or both service processor usage measures include a classification of service usage based on network type. In some embodiments, one or both service processor usage measures include a classification of service usage based on time of day. In some embodiments, one or both service processor usage measures include a classification of service usage based on QoS class. In some embodiments, one or both service processor usage measures include a classification of service usage based on geography. In some embodiments, one or both service processor usage measures include a classification of service usage based on a roaming network.
A second source (not shown) generates or provides second service usage measures 2370. In some embodiments, the second source is a network element, such as a mediation element, a gateway, a real-time reporting element, a charging element, a billing element, or the like. In some embodiments, the second source is a database. In some embodiments, the second source is a roaming partner network element. In some embodiments, the second source is an element on end-user device 100 that generates secure device data records. In some embodiments, the second source is a partner network destination that provides information about customer usage of or transactions with that destination. In some embodiments, the second source is an application on end-user device 100.
Based on the second service usage measures, the second source sends second usage records to service controller 122, or service controller 122 obtains the second usage records from the second source. Service controller 122 processes the second usage records in record normalization, time reconciliation and pre-preprocessing 2360. In some embodiments, record normalization, time reconciliation and pre-preprocessing 2360 modifies the format of the second usage records to facilitate one or more of service usage processing, reporting, analysis, comparison, mediation and reconciliation operations performed within the service controller system. In some embodiments, record normalization, time reconciliation and pre-preprocessing 2360 observes the second usage records and time stamps and time synchronizes, time aligns, or time aggregates multiple second usage records so that a more consistent measure of usage with a common time reference can be achieved within the service controller system for one or more of service usage processing, reporting, analysis, comparison, mediation and reconciliation purposes. Service controller 122 stores the second usage records in second source usage records 2350.
Service controller 122 applies reconciliation and verification processing algorithms 2340 to reconcile records in device usage records 2320 with records in second source usage records 2350 and to validate records in device usage records 2320. Service controller 122 stores information based on the results of reconciliation and verification processing algorithms 2340 in data warehouse 2330.
In some embodiments, reconciliation and verification processing algorithms 2340 reconcile detailed classifications of service usage off of a bulk service usage accounting and onto a finer classification of service usage accounting. For ease of explanation, the finer classifications of service usage accounting are referred to herein as “micro charging data records” or “micro-CDRs.” In some embodiments, reconciliation and verification processing algorithms 2340 accomplish charging for detailed classifications of service usage by providing a detailed micro-CDR charging code identifier in the micro-CDR usage record communicated to the carrier network mediation or billing system (e.g., operator data mediation 2380). In some embodiments, reconciliation and verification processing algorithms 2340 accomplish charging for a detailed classification of service usage by mediating out (or subtracting) the amount of service usage reported in the micro-CDR from the amount of service usage accounted to bulk service usage. In some embodiments, reconciliation and verification processing algorithms 2340 sends charging data records (e.g., CDRs, micro-CDRs, etc.) to operator data mediation 2380.
In some embodiments, reconciliation and verification processing algorithms 2340 perform a fraud analysis using information from one or both of second source usage records 2350 and device usage records 2320. In some embodiments, reconciliation and verification processing algorithms 2340 compares usage records associated with a specific device or user credential from one or both of second source usage records 2350 and device usage records 2320 to determine if service usage is outside of pre-defined service usage policy behavior limits. In some embodiments, reconciliation and verification processing algorithms 2340 compares service usage information associated with a specific device or user credential from one or both of second source usage records 2350 and device usage records 2320 to determine if a pre-defined service usage limit has been reached or exceeded. In some embodiments, reconciliation and verification processing algorithms 2340 compares service usage information associated with a specific device or user credential from one or both of second usage records 2350 and device usage records 2320 to determine if the specific device or user is exhibiting a service usage behavior that is outside of pre-defined statistical limits as compared to the service usage behavior of a device or user population. In some embodiments, reconciliation and verification processing algorithms 2340 stores the results of its fraud analysis in data warehouse 2330. In some embodiments, reconciliation and verification processing algorithms 2340 sends fraud alerts to operator CRM system 2390 (e.g., a carrier fraud processing system, carrier personnel, a device user, a system administrator, etc.).
In some embodiments, the second usage records comprise information from multiple other measures or reports. In some embodiments, the second usage records are based on information, measures, or reports from end-user device 100. In some embodiments, the second usage records are based on information, measures, or reports from other end-user devices. In some embodiments, the second usage records are determined based on information, measures, or reports from one or more network elements (e.g., a base station, the RAN, the core, or using device-assisted means, etc.).
In some embodiments, the second usage records comprise a measure of bulk (e.g., aggregate or unclassified) data usage by end-user device 100. For example, in some embodiments, the second usage records comprise a bulk usage report, specific to end-user device 100, generated by the network, by an application service provider, or by a server. In some embodiments, the second usage records are based on information in one or more previous reports sent by end-user device 100.
In some embodiments, the second usage records comprise information associated with the access network state. In some embodiments, the second usage records are determined from network state tagged information. In some embodiments, the second usage records comprise information from a device data record (DDR), which may indicate the network busy state and the network type. In some embodiments, the second usage records are determined from DDR network state tagged information.
In some embodiments, the second usage records comprise information from flow data record. In some embodiments, the flow data record (FDR) reports a detailed level of service usage classification that indicates service usage broken down by network source or destination (e.g., domain, URL, IP address, etc.) and possibly one or more ports and protocols. In some embodiments, the FDR reports a detailed level of service usage classification that indicates usage broken down by device user application or OS application. In some embodiments, the FDR reports a detailed level of service usage classification that indicates service usage broken down by time of day, network congestion state or service QoS level. In some embodiments, the FDR reports a detailed level of service usage broken down by network type (e.g., 2G, 3G, 4G, WiFi, home, roaming, etc.). In some embodiments, the FDR reports a detailed level of service usage broken down by home or roaming network.
In some embodiments, the FDRs are sourced from a network element capable of classifying traffic (e.g., a deep packet inspection [DPI] gateway, a proxy server, a gateway or server dedicated to a given service classification, a good customer feedback source described elsewhere herein, etc.). In some embodiments, the second usage records are derived from a device service monitor. In some embodiments, the second usage records are derived from a trusted device service monitor. In some embodiments, the trusted device service monitor is located in a secure execution environment on the device that cannot be accessed by a user or user installed application software.
In some embodiments, the second usage records allow service controller 122 to determine whether the access behavior of end-user device 100, given the network state, indicates that end-user device 100 is implementing the correct policy controls. In some embodiments, service controller 122 confirms that service processor 115 is reporting the correct network state in its data usage reports. In some embodiments, a network element determines the correct network state based on a group of devices. The information is reported to service controller 122 or another suitable network function. Service controller 122 (or other suitable network function) characterizes portions of the sub-network (e.g., base stations, base station sectors, geographic areas, radio access network (RAN), etc.) based on the population of end-user devices connected to that sub-network portion. The network element can also gather network busy-state measures from network equipment, such as from base stations or by sampling the RAN, to determine the second measure.
In some embodiments, the second usage records provide information about a cap on the aggregate amount of data usage by end-user device 100. Service controller 122 verifies that the total data usage by end-user device 100, as reported in the first usage records, does not exceed the cap. If the first usage records provide data usage amounts for individual services used by end-user device 100, service controller 122 verifies that the sum of the usage amounts for the individual services does not exceed the cap.
In some embodiments, the network classifies FDRs to known service components, determines credits of classified usage for each service component, ensures that the service component usage does not exceed specified limits (or matches end-user device reports for the component), and checks whether the sum of the components matches the bulk measure.
There are several potentially fraudulent circumstances that may be detected by service controller 122 using one or more of the embodiments disclosed herein, such as the example embodiment illustrated in
Carrier-generated charging data records (CDRs) or real-time reporting records (RTRs) (or other real-time or near-real-time usage record formats such as, e.g., flow data records (FDRs), batch processed usage records, continuous usage record event feeds or SMS formatted usage record messages) flow from carrier 2650 (which can be, e.g., a real time reporting system, a network gateway, a network usage charging system element, a AAA, an HLR, a billing element, etc.) to load balancer 2652 to CDR/RTR filtering element 2654.
In some embodiments, load balancer 2652 selects one of many CDR/RTR processing threads that are available in the service controller information processing system. In some embodiments, the processing thread is an asynchronous software or firmware program running on a gateway or server CPU. In some embodiments, the processing thread is a virtual machine processing thread that exists in a resource pool of gateway or server CPUs or virtual machines, which may include geographically separated or redundant resource pools. As illustrated in
CDR/RTR filtering element 2654 selects the records that are associated with devices that include a device client that communicates with the service controller (e.g., the device client can be a service processor configured to provide service usage notification updates, on-device service plan purchase or activation with UI options display and user selection actions, device-assisted access control policy enforcement, device-assisted service usage charging policy enforcement, device-assisted service notification messages, etc.). In some embodiments, devices supporting DAS are identified by device credentials or user credentials that are communicated to the service controller as described herein, where the device credential or user credential are members of a device group or user group that is managed by the service controller.
In some embodiments, CDR/RTR filtering element 2654 may be used advantageously to quickly receive and acknowledge a CDR/RTR record to provide asynchronous functionality because of real-time processing requirements, server processing thread scalability and maintainability requirements, or server processing thread geographic redundancy requirements. In some embodiments, filtering eliminates unnecessary load on JMS queue 2656 and/or CDR/RTR database 2660. CDR/RTR filtering element 2654 places the records from end-user devices known to be configured with a device client (e.g., a service processor configured to provide service usage notification updates, on-device service plan purchase or activation with UI options display and user selection actions, device-assisted access control policy enforcement, device-assisted service usage charging policy enforcement, device-assisted service notification messages, etc.) that communicates with the service controller through Java messaging service (JMS) queue 2656. In some embodiments, CDR/RTR filtering element 2654 filters out device records for devices that may have a form of service processor 115, but service processor 115 has not properly authenticated with the service controller 122. In some embodiments, the device clients that are known to be configured with a device client that communicates with service controller 122 are determined by looking up a device credential or user credential associated with CDRs or RTRs in a device group or user group management database.
JMS queue 2656 buffers the CDR/RTR information remaining after CDR/RTR filtering 2654 and allocates one or more CDRs/RTRs to a service usage processing thread in CDR/RTR processor 2658. In some embodiments, JMS queue 2656 is a persistent queue. In some embodiments, JMS queue 2656 is a primary messaging system between service controller applications.
CDR/RTR processor 2658 retrieves the records from JMS queue 2656, transforms the records, and stores them in CDR/RTR database 2660. In some embodiments, CDR/RTR processor 2658 is an application or a process thread. In some embodiments, CDR/RTR processor 2658 pulls a CDR/RTR record from JMS queue 2656, transforms the record, and stores the transformed record in CDR/RTR database 2660 in one transaction in order to provide fault tolerance in the case of system failure. In some embodiments, CDR/RTR processor 2658 formats the CDR/RTR information to provide a common service usage information format to facilitate one or more of service usage processing, reporting, analysis, comparison, mediation and reconciliation operations performed within the service controller system. In some embodiments, CDR/RTR processor 2658 observes CDR/RTR time stamps and time synchronizes, time aligns, or time aggregates multiple CDR/RTR reports so that a more consistent measure of usage with a common time reference can be achieved within the service controller system for one or more of service usage processing, reporting, analysis, comparison, mediation and reconciliation purposes.
In some embodiments, end-user devices capable of DAS reporting (e.g., devices configured with a device client that communicates with the service controller, such as service processor 115 described herein) connect periodically or on occasion to usage reporting gateway 2672 to report their data usages. In some embodiments, DAS reporting information includes but is not limited to one or more of user service plan purchase or activation selection choices, device user service policy configuration preference selections (e.g., user-generated service policy assignments for applications, websites, network types, or home/roaming policies), DAS service usage reports, DAS device policy state reports, DAS software environment integrity reports, and other reports.
In some embodiments, DAS device usage reports and analytics flow from carrier device network 2668 (e.g., devices configured with service processors 115 that are in communication with the service controller) to load balancer 2670 to usage reporting gateway 2672. In some embodiments, load balancer 2670 selects one of many usage reporting processing threads that are available in the service controller information processing system. In some embodiments, the usage reporting processing thread is an asynchronous software or firmware program running on a gateway or server CPU. In some embodiments, the usage reporting processing thread is a virtual machine processing thread that exists in a resource pool of gateway or server CPUs or virtual machines, which may include geographically separated or redundant resource pools. As illustrated in
Usage reporting gateway 2672 accepts reports from devices configured with a device client (e.g., service processor 115 configured to provide service usage notification updates, on-device service plan purchase or activation with UI options display and user selection actions, device assisted access control policy enforcement, device assisted service usage charging policy enforcement, device assisted service notification messages, etc.) that communicates with service controller 122 and places the reports on JMS queue 2674. In some embodiments, usage reporting gateway 2672 only accepts device reports from device service processors 115 that have authenticated with the service controller system (e.g. service controller 122). In some embodiments, usage reporting gateway 2672 only accepts device reports from device service processors 115 configured with device credentials or user credentials that are members of a device group or user group that is managed by service controller 122. In some embodiments, usage reporting gateway 2672 rejects reports from end-user devices without authenticated service processors. In some embodiments, usage reporting gateway 2672 is an application or a process thread. In some embodiments, usage reporting gateway 2672 quickly receives and acknowledges end-user device reports. In some embodiments, usage reporting gateway 2672 provides asynchronous functionality that is advantageous to support real-time processing requirements.
In some embodiments, end-user device 100 is authenticated before reports are put onto JMS queue 2674. In some embodiments, JMS queue 2674 is a persistent queue. In some embodiments, JMS queue 2674 is a primary messaging system between service controller applications.
Report processor 2676 retrieves reports from JMS queue 2674, transforms the reports, and stores the transformed reports in usage report database 2678. In some embodiments, report processor 2676 is an EAI. In some embodiments, report processor 2676 retrieves reports from JMS queue 2674, transforms the reports, and stores the transformed reports in usage report database 2678 in a single transaction in order to provide fault tolerance in case of system failure. In some embodiments, report processor 2676 formats the device usage report information to provide a common service usage information format to facilitate one or more of service usage processing, reporting, analysis, comparison mediation and reconciliation purposes internal processing and comparison within the service controller system. In some embodiments, report processor 2676 observes device usage report time stamps and time synchronizes, time aligns or time aggregates multiple device usage reports so that a more consistent measure of usage with a common time reference can be achieved within the service controller system for one or more of service usage processing, reporting, analysis, comparison mediation and reconciliation purposes.
In some embodiments, CDR/RTR filtering 2654, CDR/RTR processor 2658, report processor 2676, and usage reporting gateway 2672 share a host.
In some embodiments, micro-CDR generator 2680 retrieves records from CDR/RTR database 2660 and retrieves reports from usage report database 2678. In some embodiments, micro-CDR generator 2680 determines a service usage amount for a micro-CDR service usage classification, assigns a usage accounting identifier to the micro-CDR report that identifies the usage as being accounted to a device user for the device associated with a device credential or user credential, and reports this amount of service usage to the carrier network 2666 (in the exemplary embodiment of
In some embodiments, fraud analyzer 2682 retrieves records from CDR/RTR database 2660. In some embodiments, fraud analyzer 2682 retrieves reports form usage report database 2678. In some embodiments, fraud analyzer 2682 retrieves micro-CDRs from micro-CDR generator 2680. In some embodiments, fraud analyzer 2682 performs a fraud analysis using information from one or more of CDR/RTR database 2660, usage report database 2678, and micro-CDR generator 2680. In some embodiments, fraud analyzer 2682 compares usage records associated with a specific device or user credential from one or more of CDR/RTR database 2660, usage report database 2678, and micro-CDR generator 2680 to determine if service usage by that device is outside of pre-defined service usage policy behavior limits. In some embodiments, fraud analyzer 2682 compares service usage information associated with a specific device or user credential from one or more of CDR/RTR database 2660, usage report database 2678, and micro-CDR generator 2680 to determine if a pre-defined service usage limit has been reached or exceeded by that device. In some embodiments, fraud analyzer 2682 compares service usage information associated with a specific device or user credential from one or more of CDR/RTR database 2660, usage report database 2678 and micro-CDR generator 2680 to determine if the specific device or user is exhibiting a service usage behavior that is outside of pre-defined statistical limits as compared to the service usage behavior of a device or user population. In some embodiments, fraud analyzer 2682 stores the results of its fraud analysis in data warehouse 2694. In some embodiments, fraud analyzer 2682 sends fraud alerts to carrier network 2666.
Fraud Detection for Time-Based Service Plans
In some embodiments, a service plan in effect for end-user device 100 is a time-based service plan (e.g., access network costs associated with a particular service or application are not charged to the user, or are charged to the user at a reduced rate during a particular time period). In some such embodiments, an agent on end-user device 100 detects fraudulent or potentially fraudulent activities by determining whether the time or time zone setting on end-user device 100 is correct or within a tolerance.
At step 1060, an agent (e.g., policy control agent 1692, service monitor agent 1696, policy implementation agent 1690, etc.) on end-user device 100 obtains the actual time. In some embodiments, the agent obtains the actual time from a trusted source. In some embodiments, the trusted source is an NTP server. In some embodiments, the trusted source is a cell tower. In some embodiments, the agent obtains the actual time based on information about a cell tower location. In some embodiments, the agent obtains the actual time based on information from a GPS receiver. In some embodiments, the agent obtains the actual time based on a geo-located IP address. At step 1062, the agent compares the time setting on the device (the device time) to the actual time. At step 1064, the agent determines if the difference between the actual time and the device time is within a tolerance. In some embodiments, the tolerance is set by portal user 102. If the difference is within the tolerance, the process ends at step 1068. If the difference is not within the tolerance, the agent takes an action at step 1066. In some embodiments, the action is to generate a fraud alert. In some embodiments, the action is to adjust the time setting on end-user device 100. In some embodiments, the action is to use the actual time to enforce a policy (e.g., a control policy, a charging policy, or a notification policy). In some embodiments, the action is to take a countermeasure, such as, for example, to block, delay, rate-limit, or quarantine access to the access network by end-user device 100. In some embodiments, the action is to provide a notification to a user of end-user device 100. In some embodiments, the action is to send a message to service controller 122.
Additional Fraud Detection Techniques
In the embodiment of
As illustrated in
As illustrated in
Fraud control center 2516 retrieves fraud data from main database 2514 and performs one or more of the following functions: an aggregate analysis of various fraud metrics (events and/or scores) to determine whether end-user device 100 is likely operating fraudulently; presentation of fraud-related information through a dashboard (e.g., a user interface); and taking an action to mitigate the fraud (e.g., notify a network administrator of a network resource so that further evaluation can take place, increase a billing rate for end-user device 100, notify a user of or subscriber associated with end-user device 100 of the service agreement violation and, if applicable, increased billing rate, via one or more communication media [e.g., service processor 115, device notification client user interface, text message, e-mail message, voicemail, phone call], throttle or suspend end-user device 100's access to the access network, throttle or suspend an application's access to the access network.
As illustrated in the embodiment of
Fraud server 129 generates fraud events (e.g., fraud alerts) and stores them in main database 2514. Fraud control center 2516 retrieves fraud data from main database 2514. Depending on the content of the fraud data, fraud control center 2516 may display information about the fraud data on dashboard 2518, which, in some embodiments, includes a user interface such as a display. In some embodiments, fraud responder 2520 takes an action based on the fraud data, such as notifying carrier 2506 of fraudulent or potentially fraudulent activity by end-user device 100.
Detection of Fraudulent Use of SIM Cards
End-user device 100 may contain a “sponsored SIM” card or another credential that allows the device to use a fixed amount of data, possibly associated with a particular service, at a reduced charge or at no charge to the user. Unscrupulous users may attempt to find ways to increase their quantity of free or subsidized data usage with sponsored SIM cards. In some embodiments, service controller 122 detects fraud associated with SIM cards and takes actions to address the fraud.
Without loss of generality, in the following related embodiments the terms “SIM card” and “SIM” are used to represent a device credential source. As would be appreciated by one of ordinary skill in the art, other device credential sources (e.g., a soft-SIM, a universal SIM, an IMSI source, a wireless modem, a phone number source, an IMEI source, an MEID source, a MAC address source, an IP address source, a secure device identifier source, a device secure communication encryption key source, etc.) can be interchanged with SIM card in many of the embodiments. For example, in embodiments in which a SIM card is moved from one device to another, another type of device credential could be moved instead (e.g., soft SIM, universal SIM, an IMSI source, a wireless modem, a phone number source, an IMEI source, an MEID source, a MAC address source, an IP address source, a secure device identifier source, a device secure communication encryption key source, etc.). As another example, when a user tampers with a service processor associated with a SIM, the user could be tampering with a service processor associated with another type of device credential (e.g., soft SIM, universal SIM, an IMSI source, a wireless modem, a phone number source, an IMEI source, an MEID source, a MAC address source, an IP address source, a secure device identifier source, a device secure communication encryption key source, etc.). There are many other examples where the term “SIM” can be exchanged for another source of device credentials, with the examples being too numerous to list and yet evident to one of ordinary skill in the art in the context of the teachings herein.
In some embodiments, the one or more device credential sources include a SIM card. In some embodiments, service controller 122 can be configured to recognize which end-user device 100 or service processor 115 the SIM is associated with, use the SIM and device association to look up a desired device portion of a wireless access network service policy, and communicate the policy to the appropriate device service processor. In some embodiments, the two different device portions of a wireless access network policy are determined according to a device group or user group service policy definition that includes one or more SIM credentials and/or one or more service processor credentials, and these policy definitions are entered in a virtual service provider work station that manages the service controller and/or service processor policies.
In some embodiments, service controller 122 is configured to recognize when the SIM card from a first device with a first service processor has been moved to a second device with a second service processor. In some such embodiments, service controller 122 is configured to recognize which device or service processor the SIM is associated with, use the SIM and device association to look up a desired network portion of a wireless access network service policy, and cause the network portion of a wireless access network service policy to be implemented or enforced in one or more network service policy enforcement elements. In some embodiments, the two different network portions of a wireless access network policy are determined according to a device group or user group service policy definition that includes one or more SIM credentials and/or one or more service processor credentials, and these policy definitions are entered in a virtual service provider work station that manages the service controller and/or network service policy enforcement element policies.
In some embodiments, the one or more device credential sources include a SIM card. In some embodiments, service controller 122 is configured to detect when a device user has moved the SIM card from a first device configured with a properly configured service processor to a second device that is not configured with a properly configured service processor. In some embodiments, service controller 122 is configured to determine that the first device is configured with a properly configured service processor and communicate a device portion of a wireless access network service policy to the appropriate device service processor. In some embodiments, the device portion of a wireless access network policy is determined according to a device group or user group service policy definition that includes a SIM credential and/or a service processor credential, and these policy definitions are entered in a virtual service provider work station that manages the service controller and/or device service processor policies. In some embodiments, service controller 122 is configured to determine that the first device is configured with a properly configured service processor and cause a first network portion of a wireless access network service policy to be implemented or enforced in one or more network service policy enforcement elements. In some embodiments, service controller 122 is configured to determine that the second device is not configured with a properly configured service processor and cause a second network portion of a wireless access network service policy to be implemented or enforced in one or more network service policy enforcement elements. In some embodiments, the device portion of a wireless access network policy is determined according to a device group or user group service policy definition that includes a SIM credential, and these policy definitions are entered in a virtual service provider work station that manages the service controller and/or network service policy enforcement element policies.
In some of these embodiments, the differences between the first network portion of a wireless access network service policy and the second network portion of a wireless access network service policy can include a difference in network access privileges, a difference in allowable network destinations, a difference in service usage accounting or billing for “bulk” access, a difference in service usage accounting or billing for a classification of access, a difference in service usage accounting rates or billing rates for “bulk” access, a difference in service usage accounting rates or billing rates for a classification of access, a difference in sponsored (ambient) service accounting or billing, a difference in service speed or quality, a difference in which networks the device or user has access to, a difference in the service usage notification that is provided to the end user, a difference in roaming service policies or permissions or accounting/billing rates, a quarantining of the device or user access capabilities, differences between (e.g., disabling or otherwise modifying) one or more features of device operation, or suspending the device from access to the network.
In some embodiments, a SIM and service processor 115 are associated with a classification of service usage and a corresponding device portion of access network service policy enforcement. Service controller 122 is then responsible for properly authenticating the proper configuration of service processor 115 in association with the SIM in order to determine the appropriate network portion of network access service policy that should be enforced.
In some embodiments, a SIM and service processor 115 are associated with one or more application-specific services wherein the device network access service has policy elements that are specific to a device software or firmware application. A software or firmware application-specific service can include but is not limited to a service with specific policy elements associated with a user application program; an operating system program, library or function; a background application service such as an application update, content caching, software update or other background application service.
In some embodiments, a SIM and service processor 115 are associated with one or more network-destination-specific services wherein the device network access service has policy elements that are specific to a network destination or resource. A network destination or resource can include but is not limited to a server, gateway, destination address, domain, website or URL.
In some embodiments, a SIM and service processor 115 are associated with any combination of a device application, network destination or resource; a type of network; a roaming condition (e.g., a home or roaming network); a time period; a level of network congestion; a level of network quality-of-service (QoS); and a background or foreground communication.
In some embodiments, a SIM and service processor 115 are associated with one or more sponsored services (also referred to herein as ambient services), wherein a portion or all of the service usage accounting for one or more classifications of service usage are accounted to, charged to, or billed to a service sponsor rather than the device user or party who pays for the user service plan. The portion of service that is sponsored can be all of the device access or a portion or classification of the device access. In some embodiments, the classification of the sponsored portion of service (e.g., the identification of the portion of the device's use of the access network that should be allocated to the service sponsor) is accomplished on the device with service processor 115. In some embodiments, the classification of the sponsored portion of service is accomplished in the network using DPI elements, gateway elements, server elements, proxy elements, website elements or web service elements. In some embodiments, the classification of the sponsored portion of service is accomplished with a classification policy implemented by a combination of a service processor on the device (e.g., steering a classification of service to a given network element via a re-direction, re-route, or tunnel [e.g. secure SSL, VPN, APN or other tunnel protocol]) and one or more network elements (e.g., DPI elements, gateway elements, server elements, proxy elements, website elements or web service elements). In some embodiments, the portion of service that is sponsored includes service for one device application or a group of device applications. In some embodiments, the portion of service that is sponsored includes service for a network destination or resource, a server or website, or a group of network destinations, servers or websites. In some embodiments, the portion of service that is sponsored includes service on a specific type of network. In some embodiments, the portion of service that is sponsored includes service on a home network or a roaming network. In some embodiments, the portion of service that is sponsored includes service during a time period. In some embodiments, the portion of service that is sponsored includes service for a certain range of network congestion. In some embodiments, the portion of service that is sponsored can include service for a certain range of network QoS. In some embodiments, the portion of service that is sponsored includes service for a network background or foreground data communication. In some embodiments, the portion of service that is sponsored includes any combination of device application, network destination or resource, a type of network, a roaming condition (e.g., home or roaming network), a time period, a level of network congestion, a level of network QoS, and a background or foreground communication.
In some embodiments, a SIM (or other source of user credential or device credential, as explained previously) is installed in or present in association with a device configured with a device service processor configuration that provides access network policy enforcement. In such embodiments, one or more network elements can implement or enforce a network-based portion of access network policy enforcement, and service processor 115 can be configured to implement or enforce a device-based portion of access network policy enforcement. In some embodiments, one or more SIM credentials can be used at least in part to identify the network-based portion of access network policy. In some embodiments, one or more SIM credentials can be used at least in part to identify the device-based portion of access network policy.
In some embodiments that include a SIM module policy association, the policy enforcement includes one or more of access control policy enforcement, service usage limit, access accounting policy enforcement, and access service user notification policy enforcement. In some embodiments, the access control policy enforcement includes one or more of allowing, limiting, blocking, deferring, delaying or traffic shaping device network access for “bulk” access (e.g., “not classified” access), or one or more specific classifications of access network service activities. In some embodiments, the access accounting policy enforcement includes one or more of counting an amount of “bulk” (e.g., “unclassified”) access network service usage, or counting an amount of access network service usage for one or more specific classifications of access network service activities. In some embodiments, the access service notification policy enforcement includes one or more of notifying an end user when a pre-defined service usage condition occurs for “bulk” (e.g. “unclassified”) access network service usage or notifying an end user when a pre-defined service usage condition occurs for one or more specific classifications of access network service activities. Examples of specific classifications of access network service activities include access by an application or OS function, access to one or more network destinations or network resources (such as a web site, domain, IP address or other address identifier, URL, socket tuple, network server, network route or APN, network gateway or proxy, network content source or sub-network). Additional examples of specific classifications of access network service activities include device access to network services with different QoS service levels. In some embodiments, a portion of the policies associated with specific classifications of access network service are implemented or enforced with a device-based service processor, and other portions of access network service policy are enforced in one or more network-based elements.
In some embodiments in which one or more network elements implement or enforce a network-based portion of access network policy enforcement and a device service processor is configured to implement or enforce a device-based portion of access network policy enforcement, one or more device SIM credentials are identified and used at least in part to determine the policies enforced by the network. In such embodiments, service processor 115 can be relied upon to implement or enforce certain aspects of access network service policy that are not implemented or enforced in the network.
In some embodiments, a first portion of access network service policy is determined at least in part by one or more SIM credentials and is implemented by one or more network elements, and a second portion of access network service policy is intended to be implemented by a device-based service processor, but the SIM is installed in a device that is not configured with a service processor capable of implementing the second portion of access network service policy. In some such embodiments, a network element identifies whether the SIM is installed in a device that is configured with a service processor capable of implementing the second portion of access network service policy intended to be implemented on the device. In some embodiments, the identification is accomplished by a network system that implements one or more of the following device configuration detection and network policy selection functions: (1) Identify when a SIM whose credentials are used at least in part to identify a network-based portion of access network policy is installed in a device configured to include a service processor capable of implementing or enforcing a device-based portion of access network service policy, and provision a first network-based service policy in one or more network-based policy enforcement elements that implement or enforce access network service policy; (2) Identify when a SIM whose credentials are used at least in part to identify the network-based portion of access network policy is installed in a device that is not configured to include a service processor capable of implementing or enforcing a device-based portion of access network service policy and implement a second network-based service policy in one or more network-based policy enforcement elements that implement or enforce access network service policy.
In some embodiments, when it is determined that a SIM whose credentials are used at least in part to identify the network-based portion of access network policy is installed in a device configured to include a service processor capable of implementing or enforcing a device-based portion of access network service policy, a network-based service policy provisioning system provisions a first network-based service policy into one or more network elements (e.g., programs or sends the policy to one or more network elements) and also provisions a device-based service policy into a device service processor. In some embodiments, when it is determined that a SIM whose credentials are used at least in part to identify the network-based portion of access network policy is installed in a device that is not configured to include a service processor capable of implementing or enforcing a device-based portion of access network service policy, a network-based service policy provisioning system provisions a second network-based service policy into one or more network elements, and there is no policy provisioning for a device-based service processor.
Such embodiments are advantageous, for example, when a device-based service processor is capable of implementing or enforcing a network access service policy that has fine grain classification aspects that are not otherwise implemented or enforced in the network. For example, in some embodiments a SIM is installed in a first device configuration that includes a device-based service processor (e.g., service processor 115) capable of classifying access network service usage associated with one or more device software applications and enforcing a policy for access control, service limit, access accounting or access service notification for that classification. In this case, a first set of network-based access network service policies may be provisioned into the network elements that implement or enforce access network service policy. If the same SIM is installed in a second device configuration that does not include the described service processor capability, a second set of network-based access network service policies may be provisioned into the network elements that implement or enforce access network service policy. In such embodiments, the first device configuration can include a trusted access control or service limit policies in service processor 115 that determine the network access allowances for one or more applications, and the first network service policies are configured to facilitate this device-based application access control or service limitation. In contrast, the second device configuration, having no service processor, has no trusted access control or service limitation policies, and therefore the second network service policies may be configured in a manner that allows access only if the service plan or service account associated with the SIM (or second device or SIM user) includes permissions for “bulk” access, “unclassified” access, or access that is classified by the network and not by the device.
In some embodiments, the second network service policies are configured to modify the classification of network access services in accordance with capabilities that exist only in the network without the assistance of a device-assisted classification component.
In some embodiments, the second network service policies include a second access service accounting or charging rate that is different than the access service accounting or charging rate of the first network service policies. For example, the method of service accounting or service charging to the end user in the case where the SIM is installed in a device configuration that includes a service processor capability (e.g., the device is capable of performing service classification, accounting, control or notification functions) can be different than the method of service accounting or service charging to the end user in the case where the SIM is installed in a device configuration that does not include the service processor capability. For example, if the SIM is installed in a device configuration that includes a service processor capability, a given application (e.g., social networking application, email application, search application, voice application, news application, etc.) might have a first service accounting or charging policy defining a first charging measure (e.g., time-based usage for an application, website, content type, service type QoS class; or e.g., megabyte-based usage for an application, website, content type, service type QoS class, etc.) and/or first charging rate (e.g., $X per minute; or e.g., $Y per megabyte, etc.) when the device configuration includes a service processor capability, whereas when the SIM is not installed in a device configuration that includes a service processor capability, all traffic may be rated in the same manner (e.g., time-based or megabyte-based), potentially with a higher price. In some embodiments, when the SIM is not installed in a device configuration that includes a service processor capability, the device network access permissions are altered, or the device's communications may be quarantined or blocked.
In some embodiments, when a SIM is installed in a device with a first device configuration, service processor 115 is configured to differentially treat one or more classifications of access network service activities based on network congestion level, time of day, QoS level or background/foreground access (e.g., background content caching or background upload of device/user analytics, background software or OS updates, background application/server communications, etc.), but the same SIM can alternatively be installed in a device without such service processor capabilities (e.g., a device with a second device configuration). In such an embodiment, one or more of the network-based portions of access control or service limitation policy, network-based portion of accounting or charging policy, or network-based portion of user notification policy can be varied depending on whether the SIM is installed in a device with the first device configuration or the second device configuration. For example, if the SIM is recognized by the network in association with the first device configuration, a lower accounting rating or service usage price can be applied to traffic that is (i) allocated to background status, (ii) is controlled based on network congestion level, (iii) is controlled based on time of day, (iv) is controlled based on a lower QoS classification allowance, etc., whereas if the SIM is recognized by the network in association with the second device configuration, a single, potentially higher accounting rating or service usage price can be applied. In some embodiments, if the SIM is recognized by the network in association with the second device configuration the device network access permissions can be altered, or the device's communications can be quarantined or blocked.
In some embodiments, when a SIM is determined by a network element to be installed in a device configuration that includes a service processor service usage charging capability, one or more network elements are configured to zero-rate the device access (i.e., the one or more network elements will not apply the service usage accounting recorded by one or more network elements to the user's bill), and user service accounting or charging is turned over to a service controller that receives service usage accounting or charging information from the service processor.
In some embodiments, when a SIM is determined by a network element to be installed in a device configuration that includes a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications to one or more proxy gateway/servers, one or more network elements are configured to zero-rate the device access (i.e., the one or more network elements will not apply the service usage accounting recorded by one or more network elements to the user's bill), and user service accounting or charging is turned over to one or more proxy gateway/servers configured to account or charge for device service usage.
In some embodiments, when a SIM is determined by a network element to be installed in a device configuration that includes a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications to one or more proxy gateway/servers, the one or more proxy gateway/servers perform additional traffic access control or service limitation policy implementation or enforcement for the one or more classifications of service usage.
In some embodiments, when a SIM is determined by a network element to be installed in a device configuration that includes a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications to one or more proxy gateway/servers, the one or more proxy gateway/servers perform additional service usage classification for the purpose of service usage accounting, access control, service limiting or user notification.
In some embodiments, when a SIM is determined by a network element to be installed in a device configuration that does not include a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications to one or more proxy gateway/servers, network elements other than the proxy gateway/servers account for service usage, potentially at a different rate than when a SIM is determined by a network element to be installed in a device configuration that includes a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications.
In some embodiments in which the device configuration includes a service processor capability to route, re-direct or otherwise steer traffic for one or more service activity classifications to one or more proxy gateway/servers, the device routing, re-directing, or steering is accomplished by routing, re-directing, or steering the device traffic for one or more service usage classifications to a specific network destination or resource associated with the proxy gateway/server. In some embodiments, the routing, re-directing, or steering is accomplished using a secure tunnel through the network. In some embodiments the routing, re-directing, or steering is accomplished with a VPN or APN tunnel.
In some embodiments, a network-based service charging policy system is used in conjunction with a user service agreement confirmation system, wherein the user agreement confirmation system provides confirmation that the user has agreed to access service usage terms that stipulate a first rate of access service usage accounting or charging when a SIM is detected in association with a device configuration that includes a service processor capability, and a second rate of access service usage accounting or charging when a SIM is detected in association with a device configuration that does not include a service processor capability. In some embodiments, if a user removes or tampers with a device configuration that includes a service processor capability, or if a user installs a SIM in a device that is not configured with a service processor capability, the user service usage billing conditions are changed. In some embodiments, depending on the device configuration (e.g., with or without a service processor capability), the user is billed at a different rate for “bulk” service usage, or is billed at a different rate for one or more classifications of service usage.
In some embodiments, a network-based service charging policy system is used in conjunction with a user service agreement confirmation system, wherein the user agreement confirmation system provides confirmation that the user has agreed to access service usage terms that stipulate a first set of access service privileges when a SIM is detected in association with a device configuration that includes a service processor capability, and a second set of access service privileges when a SIM is detected in association with a device configuration that does not include a service processor capability. In some embodiments, if a user removes or tampers with a device configuration that includes a service processor capability, or if a user installs a SIM in a device that is not configured with a service processor capability, the user service usage permissions are modified. In some embodiments, this modification can include altering the allowed network destinations, altering the allowed network services, altering the allowed network resources, quarantining access or blocking access.
In some embodiments the presence of a device service processor in combination with a SIM results in the service controller providing advantageous network access services to the user. Examples include but are not limited to the sponsored services discussed herein, user-paid application-based services (e.g., user-paid services where access for one or more device applications is included in a service allowance with potentially lower cost than overall internet access), user-paid destination services (e.g., user-paid services where access for one or more network destinations or resources is included in a service allowance with potentially lower cost than overall internet access), roaming services (e.g., services that aid the user when the device is connected to a roaming network, such as by informing the user that she is roaming and asking if she wishes to continue or block roaming service usage, up to date roaming service usage indication or cost indication, roaming service rate indications, allowing a user to decide which device service usage classifications he wishes to allow while roaming, etc.), or service usage notification services (e.g., providing the user with an update of how much service usage or cost has been incurred, informing the user of what service plans are available, informing the user when a service plan sign up may be advantageous to the user based on an activity or group of activities the user is attempting, or providing the user with a set of service plan sign up choices that can be selected and purchased in a device user interface (UI), etc.). In some embodiments, these user services are made possible by the capabilities of the service processor on the device in conjunction with a specific configuration of a service controller or other network elements on an access service provider network.
In some embodiments, if the SIM for a first network service provider is removed from the device and another SIM for a second network or service provider is installed, the user may not have access to the same services. In some embodiments, the service processor on the device detects that the SIM has been changed and informs the user through a device user interface (UI) notification that if the user changes SIMS or service provider networks, the user will lose certain services. In some embodiments, the services that will be lost are listed in a UI notification. In some embodiments the UI notification states that if the user wishes to regain access to certain services, the user can re-install the original SIM.
The above description is provided to enable any person skilled in the art to make and use the invention. Various modifications to the embodiments are possible, and the principles described herein may be applied to these and other embodiments and applications without departing from the spirit and scope of the invention. Thus, the invention is not intended to be limited to the embodiments and applications shown, but is to be accorded the widest scope consistent with the principles, features and teachings disclosed herein.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example only, and not of limitation. Likewise, the various diagrams may depict an example architectural or other configuration for the invention, which is done to aid in understanding the features and functionality that can be included in the invention. The invention is not restricted to the illustrated example architectures or configurations, but the desired features can be implemented using a variety of alternative architectures and configurations. Indeed, it will be apparent to one of skill in the art how alternative functional, logical or physical partitioning and configurations can be implemented to implement the desired features of the present invention. Also, a multitude of different constituent module names other than those depicted herein can be applied to the various partitions. Additionally, with regard to flow diagrams, operational descriptions and method claims, the order in which the steps are presented herein shall not mandate that various embodiments be implemented to perform the recited functionality in the same order unless the context dictates otherwise.
Although the invention is described above in terms of various exemplary embodiments and implementations, it should be understood that the various features, aspects and functionality described in one or more of the individual embodiments are not limited in their applicability to the particular embodiment with which they are described, but instead can be applied, alone or in various combinations, to one or more of the other embodiments of the invention, whether or not such embodiments are described and whether or not such features are presented as being a part of a described embodiment. Thus, the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments.
Terms and phrases used in this document, and variations thereof, unless otherwise expressly stated, should be construed as open ended as opposed to limiting. As examples of the foregoing: the term “including” should be read as meaning “including, without limitation” or the like; the term “example” is used to provide exemplary instances of the item in discussion, not an exhaustive or limiting list thereof; the terms “a” or “an” should be read as meaning “at least one,” “one or more” or the like; and adjectives such as “conventional,” “traditional,” “normal,” “standard,” “known” and terms of similar meaning should not be construed as limiting the item described to a given time period or to an item available as of a given time, but instead should be read to encompass conventional, traditional, normal, or standard technologies that may be available or known now or at any time in the future. Likewise, where this document refers to technologies that would be apparent or known to one of ordinary skill in the art, such technologies encompass those apparent or known to the skilled artisan now or at any time in the future.
The presence of broadening words and phrases such as “one or more,” “at least,” “but not limited to” or other like phrases in some instances shall not be read to mean that the narrower case is intended or required in instances where such broadening phrases may be absent. The use of the term “module” does not imply that the components or functionality described or claimed as part of the module are all configured in a common package. Indeed, any or all of the various components of a module, whether control logic or other components, can be combined in a single package or separately maintained and can further be distributed in multiple groupings or packages or across multiple locations.
Additionally, the various embodiments set forth herein are described in terms of exemplary block diagrams, flow charts and other illustrations. As will become apparent to one of ordinary skill in the art after reading this document, the illustrated embodiments and their various alternatives can be implemented without confinement to the illustrated examples. For example, block diagrams and their accompanying description should not be construed as mandating a particular architecture or configuration.
This document incorporates by reference for all purposes the following non-provisional U.S. patent applications: application Ser. No. 12/380,778, filed Mar. 2, 2009, entitled VERIFIABLE DEVICE ASSISTED SERVICE USAGE BILLING WITH INTEGRATED ACCOUNTING, MEDIATION ACCOUNTING, AND MULTI-ACCOUNT, now U.S. Pat. No. 8,321,526 (issued Nov. 27, 2012); application Ser. No. 12/380,780, filed Mar. 2, 2009, entitled AUTOMATED DEVICE PROVISIONING AND ACTIVATION, now U.S. Pat. No. 8,839,388 (issued Sep. 16, 2014); application Ser. No. 12/695,019, filed Jan. 27, 2010, entitled DEVICE ASSISTED CDR CREATION, AGGREGATION, MEDIATION AND BILLING, now U.S. Pat. No. 8,275,830 (issued Sep. 25, 2012); application Ser. No. 12/695,020, filed Jan. 27, 2010, entitled ADAPTIVE AMBIENT SERVICES, now U.S. Pat. No. 8,406,748 (issued Mar. 26, 2013); application Ser. No. 12/694,445, filed Jan. 27, 2010, entitled SECURITY TECHNIQUES FOR DEVICE ASSISTED SERVICES, now U.S. Pat. No. 8,391,834 (issued Mar. 5, 2013); application Ser. No. 12/694,451, filed Jan. 27, 2010, entitled DEVICE GROUP PARTITIONS AND SETTLEMENT PLATFORM, now U.S. Pat. No. 8,548,428 (issued Oct. 1, 2013); application Ser. No. 12/694,455, filed Jan. 27, 2010, entitled DEVICE ASSISTED SERVICES INSTALL, now U.S. Pat. No. 8,402,111 (issued Mar. 19, 2013); application Ser. No. 12/695,021, filed Jan. 27, 2010, entitled QUALITY OF SERVICE FOR DEVICE ASSISTED SERVICES, now U.S. Pat. No. 8,346,225 (issued Jan. 1, 2013); application Ser. No. 12/695,980, filed Jan. 28, 2010, entitled ENHANCED ROAMING SERVICES AND CONVERGED CARRIER NETWORKS WITH DEVICE ASSISTED SERVICES AND A PROXY, now U.S. Pat. No. 8,340,634 (issued Dec. 25, 2012); application Ser. No. 13/134,005, filed May 25, 2011, entitled SYSTEM AND METHOD FOR WIRELESS NETWORK OFFLOADING, now U.S. Pat. No. 8,635,335 (issued Jan. 21, 2014); application Ser. No. 13/134,028, filed May 25, 2011, entitled DEVICE-ASSISTED SERVICES FOR PROTECTING NETWORK CAPACITY, now U.S. Pat. No. 8,589,541 (issued Nov. 19, 2013); application Ser. No. 13/229,580, filed Sep. 9, 2011, entitled WIRELESS NETWORK SERVICE INTERFACES, now U.S. Pat. No. 8,626,115 (issued Jan. 7, 2014); application Ser. No. 13/237,827, filed Sep. 20, 2011, entitled ADAPTING NETWORK POLICIES BASED ON DEVICE SERVICE PROCESSOR CONFIGURATION, now U.S. Pat. No. 8,832,777 (issued Sep. 9, 2014); application Ser. No. 13/239,321, filed Sep. 21, 2011, entitled SERVICE OFFER SET PUBLISHING TO DEVICE AGENT WITH ON-DEVICE SERVICE SELECTION, now U.S. Pat. No. 8,898,293 (issued Nov. 25, 2014); application Ser. No. 13/248,028, filed Sep. 28, 2011, entitled ENTERPRISE ACCESS CONTROL AND ACCOUNTING ALLOCATION FOR ACCESS NETWORKS, now U.S. Pat. No. 8,924,469 (issued Dec. 30, 2014); application Ser. No. 13/247,998, filed Sep. 28, 2011, entitled COMMUNICATIONS DEVICE WITH SECURE DATA PATH PROCESSING AGENTS, now U.S. Pat. No. 8,725,123 (issued May 13, 2014); application Ser. No. 13/248,025, filed Sep. 28, 2011, entitled SERVICE DESIGN CENTER FOR DEVICE ASSISTED SERVICES, now U.S. Pat. No. 8,924,543 (issued Dec. 30, 2014); application Ser. No. 13/253,013, filed Oct. 4, 2011, entitled SYSTEM AND METHOD FOR PROVIDING USER NOTIFICATIONS, now U.S. Pat. No. 8,745,191 (issued Jun. 3, 2014); application Ser. No. 13/309,556, filed Dec. 1, 2011, entitled END USER DEVICE THAT SECURES AN ASSOCIATION OF APPLICATION TO SERVICE POLICY WITH AN APPLICATION CERTIFICATE CHECK, now U.S. Pat. No. 8,893,009 (issued Nov. 18, 2014); and application Ser. No. 13/309,463, FILED Dec. 1, 2011, entitled SECURITY, FRAUD DETECTION, AND FRAUD MITIGATION IN DEVICE-ASSISTED SERVICES SYSTEMS, now U.S. Pat. No. 8,793,758 (issued Jul. 29, 2014).
This document incorporates by reference for all purposes the following provisional patent applications: Provisional Application No. 61/206,354, filed Jan. 28, 2009, entitled SERVICES POLICY COMMUNICATION SYSTEM AND METHOD; Provisional Application No. 61/206,944, filed Feb. 4, 2009, entitled SERVICES POLICY COMMUNICATION SYSTEM AND METHOD; Provisional Application No. 61/207,393, filed Feb. 10, 2009, entitled SERVICES POLICY COMMUNICATION SYSTEM AND METHOD; and Provisional Application No. 61/207,739, entitled SERVICES POLICY COMMUNICATION SYSTEM AND METHOD, filed Feb. 13, 2009; Provisional Application No. 61/270,353, filed on Jul. 6, 2009, entitled DEVICE ASSISTED CDR CREATION, AGGREGATION, MEDIATION AND BILLING; Provisional Application No. 61/275,208, filed Aug. 25, 2009, entitled ADAPTIVE AMBIENT SERVICES; and Provisional Application No. 61/237,753, filed Aug. 28, 2009, entitled ADAPTIVE AMBIENT SERVICES; Provisional Application No. 61/252,151, filed Oct. 15, 2009, entitled SECURITY TECHNIQUES FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/252,153, filed Oct. 15, 2009, entitled DEVICE GROUP PARTITIONS AND SETTLEMENT PLATFORM; Provisional Application No. 61/264,120, filed Nov. 24, 2009, entitled DEVICE ASSISTED SERVICES INSTALL; Provisional Application No. 61/264,126, filed Nov. 24, 2009, entitled DEVICE ASSISTED SERVICES ACTIVITY MAP; Provisional Application No. 61/348,022, filed May 25, 2010, entitled DEVICE ASSISTED SERVICES FOR PROTECTING NETWORK CAPACITY; Provisional Application No. 61/381,159, filed Sep. 9, 2010, entitled DEVICE ASSISTED SERVICES FOR PROTECTING NETWORK CAPACITY; Provisional Application No. 61/381,162, filed Sep. 9, 2010, entitled SERVICE CONTROLLER INTERFACES AND WORKFLOWS; Provisional Application No. 61/384,456, filed Sep. 20, 2010, entitled SECURING SERVICE PROCESSOR WITH SPONSORED SIMS; Provisional Application No. 61/389,547, filed Oct. 4, 2010, entitled USER NOTIFICATIONS FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/385,020, filed Sep. 21, 2010, entitled SERVICE USAGE RECONCILIATION SYSTEM OVERVIEW; Provisional Application No. 61/387,243, filed Sep. 28, 2010, entitled ENTERPRISE AND CONSUMER BILLING ALLOCATION FOR WIRELESS COMMUNICATION DEVICE SERVICE USAGE ACTIVITIES; Provisional Application No. 61/387,247, filed September 28, entitled SECURED DEVICE DATA RECORDS, 2010; Provisional Application No. 61/407,358, filed Oct. 27, 2010, entitled SERVICE CONTROLLER AND SERVICE PROCESSOR ARCHITECTURE; Provisional Application No. 61/418,507, filed Dec. 1, 2010, entitled APPLICATION SERVICE PROVIDER INTERFACE SYSTEM; Provisional Application No. 61/418,509, filed Dec. 1, 2010, entitled SERVICE USAGE REPORTING RECONCILIATION AND FRAUD DETECTION FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/420,727, filed Dec. 7, 2010, entitled SECURE DEVICE DATA RECORDS; Provisional Application No. 61/422,565, filed Dec. 13, 2010, entitled SERVICE DESIGN CENTER FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/422,572, filed Dec. 13, 2010, entitled SYSTEM INTERFACES AND WORKFLOWS FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/422,574, filed Dec. 13, 2010, entitled SECURITY AND FRAUD DETECTION FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/435,564, filed Jan. 24, 2011, entitled FRAMEWORK FOR DEVICE ASSISTED SERVICES; Provisional Application No. 61/472,606, filed Apr. 6, 2011, entitled MANAGING SERVICE USER DISCOVERY AND SERVICE LAUNCH OBJECT PLACEMENT ON A DEVICE; Provisional Application No. 61/550,906, filed Oct. 24, 2011, entitled SECURITY FOR DEVICE-ASSISTED SERVICES.
Number | Name | Date | Kind |
---|---|---|---|
5131020 | Liebesny et al. | Jul 1992 | A |
5283904 | Carson et al. | Feb 1994 | A |
5325532 | Crosswy et al. | Jun 1994 | A |
5572528 | Shuen | Nov 1996 | A |
5577100 | McGregor et al. | Nov 1996 | A |
5594777 | Makkonen et al. | Jan 1997 | A |
5617539 | Ludwig et al. | Apr 1997 | A |
5630159 | Zancho | May 1997 | A |
5633484 | Zancho et al. | May 1997 | A |
5633868 | Baldwin et al. | May 1997 | A |
5754953 | Briancon et al. | May 1998 | A |
5774532 | Gottlieb et al. | Jun 1998 | A |
5794142 | Vanttila et al. | Aug 1998 | A |
5814798 | Zancho | Sep 1998 | A |
5889477 | Fastenrath | Mar 1999 | A |
5892900 | Ginter et al. | Apr 1999 | A |
5903845 | Buhrmann et al. | May 1999 | A |
5915008 | Dulman | Jun 1999 | A |
5915226 | Martineau | Jun 1999 | A |
5933778 | Buhrmann et al. | Aug 1999 | A |
5940472 | Newman et al. | Aug 1999 | A |
5974439 | Bollella | Oct 1999 | A |
5983270 | Abraham et al. | Nov 1999 | A |
6035281 | Crosskey et al. | Mar 2000 | A |
6038452 | Strawczynski et al. | Mar 2000 | A |
6038540 | Krist et al. | Mar 2000 | A |
6047268 | Bartoli et al. | Apr 2000 | A |
6058434 | Wilt et al. | May 2000 | A |
6061571 | Tamura | May 2000 | A |
6064878 | Denker et al. | May 2000 | A |
6078953 | Vaid et al. | Jun 2000 | A |
6081591 | Skoog | Jun 2000 | A |
6098878 | Dent et al. | Aug 2000 | A |
6104700 | Haddock et al. | Aug 2000 | A |
6115823 | Velasco et al. | Sep 2000 | A |
6119933 | Wong et al. | Sep 2000 | A |
6125391 | Meltzer et al. | Sep 2000 | A |
6141565 | Feuerstein et al. | Oct 2000 | A |
6141686 | Jackowski et al. | Oct 2000 | A |
6148336 | Thomas et al. | Nov 2000 | A |
6154738 | Call | Nov 2000 | A |
6157636 | Voit et al. | Dec 2000 | A |
6185576 | McIntosh | Feb 2001 | B1 |
6198915 | McGregor et al. | Mar 2001 | B1 |
6219786 | Cunningham et al. | Apr 2001 | B1 |
6226277 | Chuah | May 2001 | B1 |
6246870 | Dent et al. | Jun 2001 | B1 |
6263055 | Garland et al. | Jul 2001 | B1 |
6292828 | Williams | Sep 2001 | B1 |
6317584 | Abu-Amara et al. | Nov 2001 | B1 |
6381316 | Joyce et al. | Apr 2002 | B2 |
6393014 | Daly et al. | May 2002 | B1 |
6397259 | Lincke et al. | May 2002 | B1 |
6401113 | Lazaridis et al. | Jun 2002 | B2 |
6418147 | Wiedeman | Jul 2002 | B1 |
6438575 | Khan et al. | Aug 2002 | B1 |
6445777 | Clark | Sep 2002 | B1 |
6449479 | Sanchez | Sep 2002 | B1 |
6466984 | Naveh et al. | Oct 2002 | B1 |
6477670 | Ahmadvand | Nov 2002 | B1 |
6502131 | Vaid et al. | Dec 2002 | B1 |
6505114 | Luciani | Jan 2003 | B2 |
6510152 | Gerszberg et al. | Jan 2003 | B1 |
6522629 | Anderson, Sr. | Feb 2003 | B1 |
6532235 | Benson et al. | Mar 2003 | B1 |
6532579 | Sato et al. | Mar 2003 | B2 |
6535855 | Cahill et al. | Mar 2003 | B1 |
6535949 | Parker | Mar 2003 | B1 |
6539082 | Lowe et al. | Mar 2003 | B1 |
6542500 | Gerszberg et al. | Apr 2003 | B1 |
6542992 | Peirce et al. | Apr 2003 | B1 |
6546016 | Gerszberg et al. | Apr 2003 | B1 |
6563806 | Yano et al. | May 2003 | B1 |
6570974 | Gerszberg et al. | May 2003 | B1 |
6574321 | Cox et al. | Jun 2003 | B1 |
6574465 | Marsh et al. | Jun 2003 | B2 |
6578076 | Putzolu | Jun 2003 | B1 |
6581092 | Motoyama | Jun 2003 | B1 |
6591098 | Shieh et al. | Jul 2003 | B1 |
6598034 | Kloth | Jul 2003 | B1 |
6601040 | Kolls | Jul 2003 | B1 |
6603969 | Vuoristo et al. | Aug 2003 | B1 |
6603975 | Inouchi et al. | Aug 2003 | B1 |
6606744 | Mikurak | Aug 2003 | B1 |
6628934 | Rosenberg et al. | Sep 2003 | B2 |
6631122 | Arunachalam et al. | Oct 2003 | B1 |
6636721 | Threadgill et al. | Oct 2003 | B2 |
6639975 | O'Neal et al. | Oct 2003 | B1 |
6640097 | Corrigan et al. | Oct 2003 | B2 |
6640334 | Rasmussen | Oct 2003 | B1 |
6650887 | McGregor et al. | Nov 2003 | B2 |
6651101 | Gai et al. | Nov 2003 | B1 |
6654786 | Fox et al. | Nov 2003 | B1 |
6654814 | Britton et al. | Nov 2003 | B1 |
6658254 | Purdy et al. | Dec 2003 | B1 |
6662014 | Walsh | Dec 2003 | B1 |
6678516 | Nordman et al. | Jan 2004 | B2 |
6683853 | Kannas et al. | Jan 2004 | B1 |
6684244 | Goldman et al. | Jan 2004 | B1 |
6690918 | Evans et al. | Feb 2004 | B2 |
6697821 | Ziff et al. | Feb 2004 | B2 |
6725031 | Watler et al. | Apr 2004 | B2 |
6725256 | Albal et al. | Apr 2004 | B1 |
6735206 | Oki et al. | May 2004 | B1 |
6748195 | Phillips | Jun 2004 | B1 |
6748437 | Mankude et al. | Jun 2004 | B1 |
6751296 | Albal et al. | Jun 2004 | B1 |
6754470 | Hendrickson et al. | Jun 2004 | B2 |
6757717 | Goldstein | Jun 2004 | B1 |
6760417 | Wallenius | Jul 2004 | B1 |
6763000 | Walsh | Jul 2004 | B1 |
6763226 | McZeal, Jr. | Jul 2004 | B1 |
6765864 | Natarajan et al. | Jul 2004 | B1 |
6765925 | Sawyer et al. | Jul 2004 | B1 |
6782412 | Brophy et al. | Aug 2004 | B2 |
6785889 | Williams | Aug 2004 | B1 |
6792461 | Hericourt | Sep 2004 | B1 |
6829596 | Frazee | Dec 2004 | B1 |
6829696 | Balmer et al. | Dec 2004 | B1 |
6839340 | Voit et al. | Jan 2005 | B1 |
6873988 | Herrmann et al. | Mar 2005 | B2 |
6876653 | Ambe et al. | Apr 2005 | B2 |
6879825 | Daly | Apr 2005 | B1 |
6882718 | Smith | Apr 2005 | B1 |
6885997 | Roberts | Apr 2005 | B1 |
6901440 | Bimm et al. | May 2005 | B1 |
6920455 | Weschler | Jul 2005 | B1 |
6922562 | Ward et al. | Jul 2005 | B2 |
6928280 | Xanthos et al. | Aug 2005 | B1 |
6934249 | Bertin et al. | Aug 2005 | B1 |
6934751 | Jayapalan et al. | Aug 2005 | B2 |
6947723 | Gurnani et al. | Sep 2005 | B1 |
6947985 | Hegli et al. | Sep 2005 | B2 |
6952428 | Necka et al. | Oct 2005 | B1 |
6957067 | Iyer et al. | Oct 2005 | B1 |
6959202 | Heinonen et al. | Oct 2005 | B2 |
6959393 | Hollis et al. | Oct 2005 | B2 |
6965667 | Trabandt et al. | Nov 2005 | B2 |
6965872 | Grdina | Nov 2005 | B1 |
6967958 | Ono et al. | Nov 2005 | B2 |
6970692 | Tysor | Nov 2005 | B2 |
6982733 | McNally et al. | Jan 2006 | B1 |
6983370 | Eaton et al. | Jan 2006 | B2 |
6996062 | Freed et al. | Feb 2006 | B1 |
6996076 | Forbes et al. | Feb 2006 | B1 |
6996393 | Pyhalammi et al. | Feb 2006 | B2 |
6998985 | Reisman et al. | Feb 2006 | B2 |
7002920 | Ayyagari et al. | Feb 2006 | B1 |
7007295 | Rose et al. | Feb 2006 | B1 |
7013469 | Smith et al. | Mar 2006 | B2 |
7017189 | DeMello et al. | Mar 2006 | B1 |
7024200 | McKenna et al. | Apr 2006 | B2 |
7024460 | Koopmas et al. | Apr 2006 | B2 |
7027055 | Anderson et al. | Apr 2006 | B2 |
7027408 | Nabkel et al. | Apr 2006 | B2 |
7031733 | Alminana et al. | Apr 2006 | B2 |
7032072 | Quinn et al. | Apr 2006 | B1 |
7039027 | Bridgelall | May 2006 | B2 |
7039037 | Wang et al. | May 2006 | B2 |
7039403 | Wong | May 2006 | B2 |
7039713 | Van Gunter et al. | May 2006 | B1 |
7042988 | Juitt et al. | May 2006 | B2 |
7043225 | Patel et al. | May 2006 | B1 |
7043226 | Yamauchi | May 2006 | B2 |
7043268 | Yukie et al. | May 2006 | B2 |
7047276 | Liu et al. | May 2006 | B2 |
7058022 | Carolan et al. | Jun 2006 | B1 |
7058968 | Rowland et al. | Jun 2006 | B2 |
7068600 | Cain | Jun 2006 | B2 |
7069248 | Huber | Jun 2006 | B2 |
7082422 | Zirngibl et al. | Jul 2006 | B1 |
7084775 | Smith | Aug 2006 | B1 |
7092696 | Hosain et al. | Aug 2006 | B1 |
7095754 | Benveniste | Aug 2006 | B2 |
7102620 | Harries et al. | Sep 2006 | B2 |
7110753 | Campen | Sep 2006 | B2 |
7113780 | McKenna et al. | Sep 2006 | B2 |
7113997 | Jayapalan et al. | Sep 2006 | B2 |
7120133 | Joo et al. | Oct 2006 | B1 |
7133386 | Holur et al. | Nov 2006 | B2 |
7133695 | Beyda | Nov 2006 | B2 |
7136361 | Benveniste | Nov 2006 | B2 |
7139569 | Kato | Nov 2006 | B2 |
7142876 | Trossen et al. | Nov 2006 | B2 |
7149229 | Leung | Dec 2006 | B1 |
7149521 | Sundar et al. | Dec 2006 | B2 |
7151764 | Heinonen et al. | Dec 2006 | B1 |
7158792 | Cook et al. | Jan 2007 | B1 |
7162237 | Silver et al. | Jan 2007 | B1 |
7165040 | Ehrman et al. | Jan 2007 | B2 |
7167078 | Pourchot | Jan 2007 | B2 |
7174156 | Mangal | Feb 2007 | B1 |
7174174 | Boris et al. | Feb 2007 | B2 |
7177919 | Truong et al. | Feb 2007 | B1 |
7180855 | Lin | Feb 2007 | B1 |
7181017 | Nagel et al. | Feb 2007 | B1 |
7191248 | Chattopadhyay et al. | Mar 2007 | B2 |
7197321 | Erskine et al. | Mar 2007 | B2 |
7200112 | Sundar et al. | Apr 2007 | B2 |
7203169 | Okholm et al. | Apr 2007 | B1 |
7203721 | Ben-Efraim et al. | Apr 2007 | B1 |
7203752 | Rice et al. | Apr 2007 | B2 |
7212491 | Koga | May 2007 | B2 |
7219123 | Fiechter et al. | May 2007 | B1 |
7222190 | Klinker et al. | May 2007 | B2 |
7222304 | Beaton et al. | May 2007 | B2 |
7224968 | Dobson et al. | May 2007 | B2 |
7228354 | Chambliss et al. | Jun 2007 | B2 |
7236780 | Benco | Jun 2007 | B2 |
7242668 | Kan et al. | Jul 2007 | B2 |
7242920 | Morris | Jul 2007 | B2 |
7245901 | McGregor et al. | Jul 2007 | B2 |
7248570 | Bahl et al. | Jul 2007 | B2 |
7251218 | Jorgensen | Jul 2007 | B2 |
7260382 | Lamb et al. | Aug 2007 | B1 |
7266371 | Amin et al. | Sep 2007 | B1 |
7269157 | Klinker et al. | Sep 2007 | B2 |
7271765 | Stilp et al. | Sep 2007 | B2 |
7272660 | Powers et al. | Sep 2007 | B1 |
7280816 | Fratti et al. | Oct 2007 | B2 |
7280818 | Clayton | Oct 2007 | B2 |
7283561 | Picher-Dempsey | Oct 2007 | B1 |
7283963 | Fitzpatrick et al. | Oct 2007 | B1 |
7286834 | Walter | Oct 2007 | B2 |
7286848 | Vireday et al. | Oct 2007 | B2 |
7289489 | Kung et al. | Oct 2007 | B1 |
7290283 | Copeland, III | Oct 2007 | B2 |
7310424 | Gehring et al. | Dec 2007 | B2 |
7313237 | Bahl et al. | Dec 2007 | B2 |
7315892 | Freimuth et al. | Jan 2008 | B2 |
7317699 | Godfrey et al. | Jan 2008 | B2 |
7318111 | Zhao | Jan 2008 | B2 |
7320029 | Rinne et al. | Jan 2008 | B2 |
7322044 | Hrastar | Jan 2008 | B2 |
7324447 | Morford | Jan 2008 | B1 |
7325037 | Lawson | Jan 2008 | B2 |
7336960 | Zavalkovsky et al. | Feb 2008 | B2 |
7340772 | Panasyuk et al. | Mar 2008 | B2 |
7346410 | Uchiyama | Mar 2008 | B2 |
7349695 | Oommen et al. | Mar 2008 | B2 |
7353533 | Wright et al. | Apr 2008 | B2 |
7356011 | Waters et al. | Apr 2008 | B1 |
7356337 | Florence | Apr 2008 | B2 |
7366497 | Nagata | Apr 2008 | B2 |
7366654 | Moore | Apr 2008 | B2 |
7369848 | Jiang | May 2008 | B2 |
7369856 | Ovadia | May 2008 | B2 |
7373136 | Watler et al. | May 2008 | B2 |
7373179 | Stine et al. | May 2008 | B2 |
7379731 | Natsuno et al. | May 2008 | B2 |
7388950 | Elsey et al. | Jun 2008 | B2 |
7389412 | Sharma et al. | Jun 2008 | B2 |
7391724 | Alakoski et al. | Jun 2008 | B2 |
7395244 | Kingsford | Jul 2008 | B1 |
7401338 | Bowen et al. | Jul 2008 | B1 |
7403763 | Maes | Jul 2008 | B2 |
7409447 | Assadzadeh | Aug 2008 | B1 |
7409569 | Illowsky et al. | Aug 2008 | B2 |
7411930 | Montojo et al. | Aug 2008 | B2 |
7418253 | Kavanagh | Aug 2008 | B2 |
7418257 | Kim | Aug 2008 | B2 |
7421004 | Feher | Sep 2008 | B2 |
7423971 | Mohaban et al. | Sep 2008 | B1 |
7428750 | Dunn et al. | Sep 2008 | B1 |
7440433 | Rink et al. | Oct 2008 | B2 |
7444669 | Bahl et al. | Oct 2008 | B1 |
7450591 | Korling et al. | Nov 2008 | B2 |
7450927 | Creswell et al. | Nov 2008 | B1 |
7454191 | Dawson et al. | Nov 2008 | B2 |
7457265 | Julka et al. | Nov 2008 | B2 |
7457870 | Lownsbrough et al. | Nov 2008 | B1 |
7460837 | Diener | Dec 2008 | B2 |
7466652 | Lau et al. | Dec 2008 | B2 |
7472189 | Mallya et al. | Dec 2008 | B2 |
7478420 | Wright et al. | Jan 2009 | B2 |
7486185 | Culpepper et al. | Feb 2009 | B2 |
7486658 | Kumar | Feb 2009 | B2 |
7493659 | Wu et al. | Feb 2009 | B1 |
7496652 | Pezzutti | Feb 2009 | B2 |
7499438 | Hinman et al. | Mar 2009 | B2 |
7499537 | Elsey et al. | Mar 2009 | B2 |
7502672 | Kolls | Mar 2009 | B1 |
7505756 | Bahl | Mar 2009 | B2 |
7505795 | Lim et al. | Mar 2009 | B1 |
7508799 | Sumner et al. | Mar 2009 | B2 |
7512128 | DiMambro et al. | Mar 2009 | B2 |
7512131 | Svensson et al. | Mar 2009 | B2 |
7515608 | Yuan et al. | Apr 2009 | B2 |
7515926 | Bu et al. | Apr 2009 | B2 |
7516219 | Moghaddam et al. | Apr 2009 | B2 |
7522549 | Karaoguz | Apr 2009 | B2 |
7522576 | Du et al. | Apr 2009 | B2 |
7526541 | Roese et al. | Apr 2009 | B2 |
7529204 | Bourlas et al. | May 2009 | B2 |
7535880 | Hinman et al. | May 2009 | B1 |
7536695 | Alam et al. | May 2009 | B2 |
7539132 | Werner et al. | May 2009 | B2 |
7539862 | Edgett | May 2009 | B2 |
7540408 | Levine et al. | Jun 2009 | B2 |
7545782 | Rayment et al. | Jun 2009 | B2 |
7546460 | Maes | Jun 2009 | B2 |
7546629 | Albert et al. | Jun 2009 | B2 |
7548875 | Mikkelsen et al. | Jun 2009 | B2 |
7548976 | Bahl et al. | Jun 2009 | B2 |
7551922 | Roskowski et al. | Jun 2009 | B2 |
7554983 | Muppala | Jun 2009 | B1 |
7555757 | Smith et al. | Jun 2009 | B2 |
7561899 | Lee | Jul 2009 | B2 |
7562213 | Timms | Jul 2009 | B1 |
7564799 | Holland et al. | Jul 2009 | B2 |
7565141 | Macaluso | Jul 2009 | B2 |
7574509 | Nixon et al. | Aug 2009 | B2 |
7574731 | Fascenda | Aug 2009 | B2 |
7577431 | Jiang | Aug 2009 | B2 |
7580356 | Mishra et al. | Aug 2009 | B1 |
7580857 | VanFleet et al. | Aug 2009 | B2 |
7583964 | Wong | Sep 2009 | B2 |
7584298 | Klinker et al. | Sep 2009 | B2 |
7586871 | Hamilton et al. | Sep 2009 | B2 |
7593417 | Wang et al. | Sep 2009 | B2 |
7593730 | Khandelwal et al. | Sep 2009 | B2 |
7599288 | Cole et al. | Oct 2009 | B2 |
7599714 | Kuzminskiy | Oct 2009 | B2 |
7602746 | Calhoun et al. | Oct 2009 | B2 |
7607041 | Kraemer et al. | Oct 2009 | B2 |
7609650 | Roskowski et al. | Oct 2009 | B2 |
7609700 | Ying et al. | Oct 2009 | B1 |
7610047 | Hicks, III et al. | Oct 2009 | B2 |
7610057 | Bahl et al. | Oct 2009 | B2 |
7610328 | Haase et al. | Oct 2009 | B2 |
7610396 | Taglienti et al. | Oct 2009 | B2 |
7614051 | Glaum et al. | Nov 2009 | B2 |
7617516 | Huslak et al. | Nov 2009 | B2 |
7620041 | Dunn et al. | Nov 2009 | B2 |
7620065 | Falardeau | Nov 2009 | B2 |
7620162 | Aaron et al. | Nov 2009 | B2 |
7620383 | Taglienti et al. | Nov 2009 | B2 |
7627314 | Carlson et al. | Dec 2009 | B2 |
7627600 | Citron et al. | Dec 2009 | B2 |
7627767 | Sherman et al. | Dec 2009 | B2 |
7627872 | Hebeler et al. | Dec 2009 | B2 |
7633438 | Tysowski | Dec 2009 | B2 |
7634388 | Archer et al. | Dec 2009 | B2 |
7636574 | Poosala | Dec 2009 | B2 |
7636626 | Oesterling et al. | Dec 2009 | B2 |
7643411 | Andreasen et al. | Jan 2010 | B2 |
7644151 | Jerrim et al. | Jan 2010 | B2 |
7644267 | Ylikoski et al. | Jan 2010 | B2 |
7647047 | Moghaddam et al. | Jan 2010 | B2 |
7650137 | Jobs et al. | Jan 2010 | B2 |
7653394 | McMillin | Jan 2010 | B2 |
7656271 | Ehrman et al. | Feb 2010 | B2 |
7657920 | Arseneau et al. | Feb 2010 | B2 |
7660419 | Ho | Feb 2010 | B1 |
7661124 | Ramanathan et al. | Feb 2010 | B2 |
7664494 | Jiang | Feb 2010 | B2 |
7668176 | Chuah | Feb 2010 | B2 |
7668612 | Okkonen | Feb 2010 | B1 |
7668903 | Edwards et al. | Feb 2010 | B2 |
7668966 | Klinker et al. | Feb 2010 | B2 |
7676673 | Weller et al. | Mar 2010 | B2 |
7680086 | Eglin | Mar 2010 | B2 |
7681226 | Kraemer et al. | Mar 2010 | B2 |
7684370 | Kezys | Mar 2010 | B2 |
7685131 | Batra et al. | Mar 2010 | B2 |
7685254 | Pandya | Mar 2010 | B2 |
7685530 | Sherrard et al. | Mar 2010 | B2 |
7688792 | Babbar et al. | Mar 2010 | B2 |
7693107 | De Froment | Apr 2010 | B2 |
7693720 | Kennewick et al. | Apr 2010 | B2 |
7697540 | Haddad et al. | Apr 2010 | B2 |
7710932 | Muthuswamy et al. | May 2010 | B2 |
7711848 | Maes | May 2010 | B2 |
7719966 | Luft et al. | May 2010 | B2 |
7720206 | Devolites et al. | May 2010 | B2 |
7720464 | Batta | May 2010 | B2 |
7720505 | Gopi et al. | May 2010 | B2 |
7720960 | Pruss et al. | May 2010 | B2 |
7721296 | Ricagni | May 2010 | B2 |
7724716 | Fadell | May 2010 | B2 |
7725570 | Lewis | May 2010 | B1 |
7729326 | Sekhar | Jun 2010 | B2 |
7730123 | Erickson et al. | Jun 2010 | B1 |
7734784 | Araujo et al. | Jun 2010 | B1 |
7742406 | Muppala | Jun 2010 | B1 |
7746854 | Ambe et al. | Jun 2010 | B2 |
7747240 | Briscoe et al. | Jun 2010 | B1 |
7747699 | Prueitt et al. | Jun 2010 | B2 |
7747730 | Harlow | Jun 2010 | B1 |
7752330 | Olsen et al. | Jul 2010 | B2 |
7756056 | Kim et al. | Jul 2010 | B2 |
7756534 | Anupam et al. | Jul 2010 | B2 |
7756757 | Oakes, III | Jul 2010 | B1 |
7760137 | Martucci et al. | Jul 2010 | B2 |
7760711 | Kung et al. | Jul 2010 | B1 |
7760861 | Croak et al. | Jul 2010 | B1 |
7765294 | Edwards et al. | Jul 2010 | B2 |
7769397 | Funato et al. | Aug 2010 | B2 |
7770785 | Jha et al. | Aug 2010 | B2 |
7774323 | Helfman | Aug 2010 | B2 |
7774412 | Schnepel | Aug 2010 | B1 |
7774456 | Lownsbrough et al. | Aug 2010 | B1 |
7778176 | Morford | Aug 2010 | B2 |
7778643 | Laroia et al. | Aug 2010 | B2 |
7792257 | Vanier et al. | Sep 2010 | B1 |
7792538 | Kozisek | Sep 2010 | B2 |
7792708 | Alva | Sep 2010 | B2 |
7797019 | Friedmann | Sep 2010 | B2 |
7797060 | Grgic et al. | Sep 2010 | B2 |
7797204 | Balent | Sep 2010 | B2 |
7797401 | Stewart et al. | Sep 2010 | B2 |
7801523 | Kenderov | Sep 2010 | B1 |
7801783 | Kende et al. | Sep 2010 | B2 |
7801985 | Pitkow et al. | Sep 2010 | B1 |
7802724 | Nohr | Sep 2010 | B1 |
7805140 | Friday et al. | Sep 2010 | B2 |
7805522 | Schlüter et al. | Sep 2010 | B2 |
7805606 | Birger et al. | Sep 2010 | B2 |
7809351 | Panda et al. | Oct 2010 | B1 |
7809372 | Rajaniemi | Oct 2010 | B2 |
7813746 | Rajkotia | Oct 2010 | B2 |
7817615 | Breau et al. | Oct 2010 | B1 |
7817983 | Cassett et al. | Oct 2010 | B2 |
7822837 | Urban et al. | Oct 2010 | B1 |
7826427 | Sood et al. | Nov 2010 | B2 |
7826607 | de Carvalho Resende et al. | Nov 2010 | B1 |
7835275 | Swan et al. | Nov 2010 | B1 |
7843831 | Morrill et al. | Nov 2010 | B2 |
7843843 | Papp, III et al. | Nov 2010 | B1 |
7844034 | Oh et al. | Nov 2010 | B1 |
7844728 | Anderson et al. | Nov 2010 | B2 |
7848768 | Omori et al. | Dec 2010 | B2 |
7849161 | Koch et al. | Dec 2010 | B2 |
7849477 | Cristofalo et al. | Dec 2010 | B2 |
7853255 | Karaoguz et al. | Dec 2010 | B2 |
7853656 | Yach et al. | Dec 2010 | B2 |
7856226 | Wong et al. | Dec 2010 | B2 |
7860088 | Lioy | Dec 2010 | B2 |
7865182 | Macaluso | Jan 2011 | B2 |
7865187 | Ramer et al. | Jan 2011 | B2 |
7868778 | Kenwright | Jan 2011 | B2 |
7873001 | Silver | Jan 2011 | B2 |
7873344 | Bowser et al. | Jan 2011 | B2 |
7873346 | Petersson et al. | Jan 2011 | B2 |
7873540 | Arumugam | Jan 2011 | B2 |
7873705 | Kalish | Jan 2011 | B2 |
7877090 | Maes | Jan 2011 | B2 |
7881199 | Krstulich | Feb 2011 | B2 |
7881697 | Baker et al. | Feb 2011 | B2 |
7882029 | White | Feb 2011 | B2 |
7882247 | Sturniolo et al. | Feb 2011 | B2 |
7882560 | Kraemer et al. | Feb 2011 | B2 |
7886047 | Potluri | Feb 2011 | B1 |
7889384 | Armentrout et al. | Feb 2011 | B2 |
7890084 | Dudziak et al. | Feb 2011 | B1 |
7890111 | Bugenhagen | Feb 2011 | B2 |
7894431 | Goring et al. | Feb 2011 | B2 |
7899039 | Andreasen et al. | Mar 2011 | B2 |
7899438 | Baker et al. | Mar 2011 | B2 |
7903553 | Liu | Mar 2011 | B2 |
7907970 | Park et al. | Mar 2011 | B2 |
7911975 | Droz et al. | Mar 2011 | B2 |
7912025 | Pattenden et al. | Mar 2011 | B2 |
7912056 | Brassem | Mar 2011 | B1 |
7920529 | Mahler et al. | Apr 2011 | B1 |
7921463 | Sood et al. | Apr 2011 | B2 |
7925740 | Nath et al. | Apr 2011 | B2 |
7925778 | Wijnands et al. | Apr 2011 | B1 |
7929959 | DeAtley et al. | Apr 2011 | B2 |
7929960 | Martin et al. | Apr 2011 | B2 |
7929973 | Zavalkovsky et al. | Apr 2011 | B2 |
7930327 | Craft et al. | Apr 2011 | B2 |
7930446 | Kesselman et al. | Apr 2011 | B2 |
7930553 | Satarasinghe et al. | Apr 2011 | B2 |
7933274 | Verma et al. | Apr 2011 | B2 |
7936736 | Proctor, Jr. et al. | May 2011 | B2 |
7937069 | Rassam | May 2011 | B2 |
7937450 | Janik | May 2011 | B2 |
7940685 | Breslau et al. | May 2011 | B1 |
7940751 | Hansen | May 2011 | B2 |
7941184 | Prendergast et al. | May 2011 | B2 |
7944948 | Chow et al. | May 2011 | B2 |
7945238 | Baker et al. | May 2011 | B2 |
7945240 | Klock et al. | May 2011 | B1 |
7945945 | Graham et al. | May 2011 | B2 |
7948952 | Hurtta et al. | May 2011 | B2 |
7948953 | Melkote et al. | May 2011 | B2 |
7948968 | Voit et al. | May 2011 | B2 |
7949529 | Weider et al. | May 2011 | B2 |
7953808 | Sharp et al. | May 2011 | B2 |
7953877 | Vemula et al. | May 2011 | B2 |
7957020 | Mine et al. | Jun 2011 | B2 |
7957381 | Clermidy et al. | Jun 2011 | B2 |
7957511 | Drudis et al. | Jun 2011 | B2 |
7958029 | Bobich et al. | Jun 2011 | B1 |
7962622 | Friend et al. | Jun 2011 | B2 |
7965983 | Swan et al. | Jun 2011 | B1 |
7966405 | Sundaresan et al. | Jun 2011 | B2 |
7969950 | Iyer et al. | Jun 2011 | B2 |
7970350 | Sheynman | Jun 2011 | B2 |
7970426 | Poe et al. | Jun 2011 | B2 |
7974624 | Gallagher et al. | Jul 2011 | B2 |
7975184 | Goff et al. | Jul 2011 | B2 |
7978627 | Taylor et al. | Jul 2011 | B2 |
7978686 | Goyal et al. | Jul 2011 | B2 |
7979069 | Hupp et al. | Jul 2011 | B2 |
7979889 | Gladstone et al. | Jul 2011 | B2 |
7984130 | Bogineni et al. | Jul 2011 | B2 |
7984511 | Kocher et al. | Jul 2011 | B2 |
7986935 | D'Souza et al. | Jul 2011 | B1 |
7987496 | Bryce et al. | Jul 2011 | B2 |
7987510 | Kocher et al. | Jul 2011 | B2 |
7990049 | Shioya | Aug 2011 | B2 |
8000276 | Scherzer et al. | Aug 2011 | B2 |
8000318 | Wiley et al. | Aug 2011 | B2 |
8005009 | McKee et al. | Aug 2011 | B2 |
8005459 | Balsillie | Aug 2011 | B2 |
8005726 | Bao | Aug 2011 | B1 |
8005913 | Carlander | Aug 2011 | B1 |
8005988 | Maes | Aug 2011 | B2 |
8010080 | Thenthiruperai et al. | Aug 2011 | B1 |
8010081 | Roskowski | Aug 2011 | B1 |
8010082 | Sutaria et al. | Aug 2011 | B2 |
8010990 | Ferguson et al. | Aug 2011 | B2 |
8015133 | Wu et al. | Sep 2011 | B1 |
8015234 | Lum et al. | Sep 2011 | B2 |
8019687 | Wang et al. | Sep 2011 | B2 |
8019820 | Son et al. | Sep 2011 | B2 |
8019846 | Roelens et al. | Sep 2011 | B2 |
8019868 | Rao et al. | Sep 2011 | B2 |
8019886 | Harrang et al. | Sep 2011 | B2 |
8023425 | Raleigh | Sep 2011 | B2 |
8024397 | Erickson et al. | Sep 2011 | B1 |
8024424 | Freimuth et al. | Sep 2011 | B2 |
8027339 | Short et al. | Sep 2011 | B2 |
8031601 | Feroz et al. | Oct 2011 | B2 |
8032168 | Ikaheimo | Oct 2011 | B2 |
8032409 | Mikurak | Oct 2011 | B1 |
8032899 | Archer et al. | Oct 2011 | B2 |
8036387 | Kudelski et al. | Oct 2011 | B2 |
8036600 | Garrett et al. | Oct 2011 | B2 |
8044792 | Orr et al. | Oct 2011 | B2 |
8045973 | Chambers | Oct 2011 | B2 |
8046449 | Yoshiuchi | Oct 2011 | B2 |
8050275 | Iyer | Nov 2011 | B1 |
8050690 | Neeraj | Nov 2011 | B2 |
8050705 | Sicher et al. | Nov 2011 | B2 |
8059530 | Cole | Nov 2011 | B1 |
8060017 | Schlicht et al. | Nov 2011 | B2 |
8060463 | Spiegel | Nov 2011 | B1 |
8064418 | Maki | Nov 2011 | B2 |
8064896 | Bell et al. | Nov 2011 | B2 |
8065365 | Saxena et al. | Nov 2011 | B2 |
8068824 | Shan et al. | Nov 2011 | B2 |
8068829 | Lemond et al. | Nov 2011 | B2 |
8073427 | Koch et al. | Dec 2011 | B2 |
8073721 | Lewis | Dec 2011 | B1 |
8078140 | Baker et al. | Dec 2011 | B2 |
8078163 | Lemond et al. | Dec 2011 | B2 |
8085808 | Brusca et al. | Dec 2011 | B2 |
8086398 | Sanchez et al. | Dec 2011 | B2 |
8086497 | Oakes, III | Dec 2011 | B1 |
8086791 | Caulkins | Dec 2011 | B2 |
8090359 | Proctor, Jr. et al. | Jan 2012 | B2 |
8090361 | Hagan | Jan 2012 | B2 |
8090616 | Proctor, Jr. et al. | Jan 2012 | B2 |
8091087 | Ali | Jan 2012 | B2 |
8094551 | Huber et al. | Jan 2012 | B2 |
8095112 | Chow et al. | Jan 2012 | B2 |
8095124 | Balia | Jan 2012 | B2 |
8095640 | Guingo et al. | Jan 2012 | B2 |
8095666 | Schmidt et al. | Jan 2012 | B2 |
8098579 | Ray et al. | Jan 2012 | B2 |
8099077 | Chowdhury et al. | Jan 2012 | B2 |
8099517 | Jia et al. | Jan 2012 | B2 |
8102814 | Rahman et al. | Jan 2012 | B2 |
8103285 | Kalhan | Jan 2012 | B2 |
8104080 | Burns et al. | Jan 2012 | B2 |
8107953 | Zimmerman et al. | Jan 2012 | B2 |
8108520 | Ruutu et al. | Jan 2012 | B2 |
8112435 | Epstein et al. | Feb 2012 | B2 |
8116223 | Tian et al. | Feb 2012 | B2 |
8116749 | Proctor, Jr. et al. | Feb 2012 | B2 |
8116781 | Chen et al. | Feb 2012 | B2 |
8122128 | Burke, II et al. | Feb 2012 | B2 |
8122249 | Falk et al. | Feb 2012 | B2 |
8125897 | Ray et al. | Feb 2012 | B2 |
8126123 | Cai et al. | Feb 2012 | B2 |
8126396 | Bennett | Feb 2012 | B2 |
8126476 | Vardi et al. | Feb 2012 | B2 |
8126722 | Robb et al. | Feb 2012 | B2 |
8130793 | Edwards et al. | Mar 2012 | B2 |
8131256 | Martti et al. | Mar 2012 | B2 |
8131281 | Hildner et al. | Mar 2012 | B1 |
8131840 | Denker | Mar 2012 | B1 |
8131858 | Agulnik et al. | Mar 2012 | B2 |
8132256 | Bari | Mar 2012 | B2 |
8134954 | Godfrey et al. | Mar 2012 | B2 |
8135388 | Gailloux et al. | Mar 2012 | B1 |
8135392 | Marcellino et al. | Mar 2012 | B2 |
8135657 | Kapoor et al. | Mar 2012 | B2 |
8140690 | Ly et al. | Mar 2012 | B2 |
8144591 | Ghai et al. | Mar 2012 | B2 |
8145194 | Yoshikawa et al. | Mar 2012 | B2 |
8146142 | Lortz | Mar 2012 | B2 |
8149748 | Bata et al. | Apr 2012 | B2 |
8149823 | Turcan et al. | Apr 2012 | B2 |
8150394 | Bianconi et al. | Apr 2012 | B2 |
8150431 | Wolovitz et al. | Apr 2012 | B2 |
8151205 | Follmann et al. | Apr 2012 | B2 |
8155155 | Chow et al. | Apr 2012 | B1 |
8155620 | Wang et al. | Apr 2012 | B2 |
8155666 | Alizadeh-Shabdiz | Apr 2012 | B2 |
8155670 | Fullam et al. | Apr 2012 | B2 |
8156206 | Kiley et al. | Apr 2012 | B2 |
8159520 | Dhanoa et al. | Apr 2012 | B1 |
8160015 | Rashid et al. | Apr 2012 | B2 |
8160056 | Van der Merwe et al. | Apr 2012 | B2 |
8160598 | Savoor | Apr 2012 | B2 |
8165576 | Raju et al. | Apr 2012 | B2 |
8166040 | Brindisi et al. | Apr 2012 | B2 |
8166554 | John | Apr 2012 | B2 |
8170553 | Bennett | May 2012 | B2 |
8174378 | Richman et al. | May 2012 | B2 |
8174970 | Adamczyk et al. | May 2012 | B2 |
8175574 | Panda et al. | May 2012 | B1 |
8180333 | Wells et al. | May 2012 | B1 |
8180881 | Seo et al. | May 2012 | B2 |
8180886 | Overcash et al. | May 2012 | B2 |
8184530 | Swan et al. | May 2012 | B1 |
8184590 | Rosenblatt | May 2012 | B2 |
8185088 | Klein et al. | May 2012 | B2 |
8185093 | Jheng et al. | May 2012 | B2 |
8185127 | Cai et al. | May 2012 | B1 |
8185152 | Goldner | May 2012 | B1 |
8185158 | Tamura et al. | May 2012 | B2 |
8190087 | Fisher | May 2012 | B2 |
8190122 | Alexander et al. | May 2012 | B1 |
8190675 | Tribbett | May 2012 | B2 |
8191106 | Choyi et al. | May 2012 | B2 |
8191116 | Gazzard | May 2012 | B1 |
8191124 | Wynn et al. | May 2012 | B2 |
8194549 | Huber et al. | Jun 2012 | B2 |
8194553 | Liang et al. | Jun 2012 | B2 |
8194572 | Horvath et al. | Jun 2012 | B2 |
8194581 | Schroeder et al. | Jun 2012 | B1 |
8195093 | Garrett et al. | Jun 2012 | B2 |
8195153 | Frencel et al. | Jun 2012 | B1 |
8195163 | Gisby et al. | Jun 2012 | B2 |
8195661 | Kalavade | Jun 2012 | B2 |
8196199 | Hrastar et al. | Jun 2012 | B2 |
8200163 | Hoffman | Jun 2012 | B2 |
8200200 | Belser et al. | Jun 2012 | B1 |
8200509 | Kenedy | Jun 2012 | B2 |
8200775 | Moore | Jun 2012 | B2 |
8200818 | Freund et al. | Jun 2012 | B2 |
8204190 | Bang et al. | Jun 2012 | B2 |
8204505 | Jin et al. | Jun 2012 | B2 |
8204794 | Peng et al. | Jun 2012 | B1 |
8208788 | Ando et al. | Jun 2012 | B2 |
8208919 | Kotecha | Jun 2012 | B2 |
8213296 | Shannon et al. | Jul 2012 | B2 |
8213363 | Ying et al. | Jul 2012 | B2 |
8214536 | Zhao | Jul 2012 | B2 |
8214890 | Kirovski | Jul 2012 | B2 |
8219134 | Maharajh et al. | Jul 2012 | B2 |
8223655 | Heinz et al. | Jul 2012 | B2 |
8223741 | Bartlett et al. | Jul 2012 | B1 |
8224382 | Bultman | Jul 2012 | B2 |
8224773 | Spiegel | Jul 2012 | B2 |
8228818 | Chase et al. | Jul 2012 | B2 |
8229394 | Karlberg | Jul 2012 | B2 |
8229914 | Ramer et al. | Jul 2012 | B2 |
8230061 | Hassan et al. | Jul 2012 | B2 |
8233433 | Kalhan | Jul 2012 | B2 |
8233883 | De Froment | Jul 2012 | B2 |
8233895 | Tysowski | Jul 2012 | B2 |
8234583 | Sloo et al. | Jul 2012 | B2 |
8238287 | Gopi et al. | Aug 2012 | B1 |
8239520 | Grah | Aug 2012 | B2 |
8242959 | Mia et al. | Aug 2012 | B2 |
8244241 | Montemurro | Aug 2012 | B2 |
8249601 | Emberson et al. | Aug 2012 | B2 |
8254880 | Aaltonen et al. | Aug 2012 | B2 |
8254915 | Kozisek | Aug 2012 | B2 |
8255515 | Melman et al. | Aug 2012 | B1 |
8255534 | Assadzadeh | Aug 2012 | B2 |
8255689 | Kim et al. | Aug 2012 | B2 |
8259692 | Bajko | Sep 2012 | B2 |
8264965 | Dolganow | Sep 2012 | B2 |
8265004 | Toutonghi | Sep 2012 | B2 |
8266681 | Deshpande et al. | Sep 2012 | B2 |
8270955 | Ramer et al. | Sep 2012 | B2 |
8270972 | Otting et al. | Sep 2012 | B2 |
8271025 | Brisebois et al. | Sep 2012 | B2 |
8271045 | Parolkar et al. | Sep 2012 | B2 |
8271049 | Silver et al. | Sep 2012 | B2 |
8271992 | Chatley et al. | Sep 2012 | B2 |
8275415 | Huslak | Sep 2012 | B2 |
8275830 | Raleigh | Sep 2012 | B2 |
8279067 | Berger et al. | Oct 2012 | B2 |
8279864 | Wood | Oct 2012 | B2 |
8280351 | Ahmed et al. | Oct 2012 | B1 |
8280354 | Smith et al. | Oct 2012 | B2 |
8284740 | O'Connor | Oct 2012 | B2 |
8285249 | Baker et al. | Oct 2012 | B2 |
8285992 | Mathur | Oct 2012 | B2 |
8291238 | Ginter et al. | Oct 2012 | B2 |
8291439 | Jethi et al. | Oct 2012 | B2 |
8296404 | McDysan et al. | Oct 2012 | B2 |
8300575 | Willars | Oct 2012 | B2 |
8301513 | Peng et al. | Oct 2012 | B1 |
8306518 | Gailloux | Nov 2012 | B1 |
8306741 | Tu | Nov 2012 | B2 |
8307067 | Ryan | Nov 2012 | B2 |
8307095 | Clark et al. | Nov 2012 | B2 |
8315198 | Corneille et al. | Nov 2012 | B2 |
8315593 | Gallant et al. | Nov 2012 | B2 |
8315594 | Mauser et al. | Nov 2012 | B1 |
8315718 | Caffrey et al. | Nov 2012 | B2 |
8315999 | Chatley et al. | Nov 2012 | B2 |
8320244 | Muqattash et al. | Nov 2012 | B2 |
8320902 | Moring et al. | Nov 2012 | B2 |
8320949 | Matta | Nov 2012 | B2 |
8325638 | Jin et al. | Dec 2012 | B2 |
8325906 | Fullarton et al. | Dec 2012 | B2 |
8326319 | Davis | Dec 2012 | B2 |
8326359 | Kauffman | Dec 2012 | B2 |
8326828 | Zhou et al. | Dec 2012 | B2 |
8331223 | Hill et al. | Dec 2012 | B2 |
8331293 | Sood | Dec 2012 | B2 |
8332375 | Chatley et al. | Dec 2012 | B2 |
8332517 | Russell | Dec 2012 | B2 |
8335161 | Foottit et al. | Dec 2012 | B2 |
8339991 | Biswas et al. | Dec 2012 | B2 |
8340625 | Johnson et al. | Dec 2012 | B1 |
8340628 | Taylor et al. | Dec 2012 | B2 |
8340678 | Pandey | Dec 2012 | B1 |
8340718 | Colonna et al. | Dec 2012 | B2 |
8346210 | Balsan et al. | Jan 2013 | B2 |
8346923 | Rowles et al. | Jan 2013 | B2 |
8347104 | Pathiyal | Jan 2013 | B2 |
8347362 | Cai et al. | Jan 2013 | B2 |
8347378 | Merkin et al. | Jan 2013 | B2 |
8350700 | Fast et al. | Jan 2013 | B2 |
8351592 | Freeny, Jr. et al. | Jan 2013 | B2 |
8351898 | Raleigh | Jan 2013 | B2 |
8352360 | De Judicibus et al. | Jan 2013 | B2 |
8352630 | Hart | Jan 2013 | B2 |
8352980 | Howcroft | Jan 2013 | B2 |
8353001 | Herrod | Jan 2013 | B2 |
8355570 | Karsanbhai et al. | Jan 2013 | B2 |
8355696 | Olding et al. | Jan 2013 | B1 |
8356336 | Johnston et al. | Jan 2013 | B2 |
8358638 | Scherzer et al. | Jan 2013 | B2 |
8358975 | Bahl et al. | Jan 2013 | B2 |
8363658 | Delker et al. | Jan 2013 | B1 |
8363799 | Gruchala et al. | Jan 2013 | B2 |
8364089 | Phillips | Jan 2013 | B2 |
8364806 | Short et al. | Jan 2013 | B2 |
8369274 | Sawai | Feb 2013 | B2 |
8370477 | Short et al. | Feb 2013 | B2 |
8370483 | Choong et al. | Feb 2013 | B2 |
8374090 | Morrill et al. | Feb 2013 | B2 |
8374592 | Proctor, Jr. et al. | Feb 2013 | B2 |
8375128 | Tofighbakhsh et al. | Feb 2013 | B2 |
8375136 | Roman et al. | Feb 2013 | B2 |
8379847 | Bell et al. | Feb 2013 | B2 |
8380247 | Engstrom | Feb 2013 | B2 |
8385199 | Coward et al. | Feb 2013 | B1 |
8385896 | Proctor, Jr. et al. | Feb 2013 | B2 |
8385964 | Haney | Feb 2013 | B2 |
8385975 | Forutanpour | Feb 2013 | B2 |
8386386 | Zhu | Feb 2013 | B1 |
8391262 | Maki et al. | Mar 2013 | B2 |
8391834 | Raleigh | Mar 2013 | B2 |
8392982 | Harris et al. | Mar 2013 | B2 |
8396458 | Raleigh | Mar 2013 | B2 |
8396929 | Helfman et al. | Mar 2013 | B2 |
8401968 | Schattauer et al. | Mar 2013 | B1 |
8402165 | Deu-Ngoc et al. | Mar 2013 | B2 |
8402540 | Kapoor et al. | Mar 2013 | B2 |
8406427 | Chand et al. | Mar 2013 | B2 |
8406736 | Das et al. | Mar 2013 | B2 |
8407472 | Hao et al. | Mar 2013 | B2 |
8407763 | Weller et al. | Mar 2013 | B2 |
8411587 | Curtis et al. | Apr 2013 | B2 |
8411691 | Aggarwal | Apr 2013 | B2 |
8412798 | Wang | Apr 2013 | B1 |
8413245 | Kraemer et al. | Apr 2013 | B2 |
8418168 | Tyhurst et al. | Apr 2013 | B2 |
8422988 | Keshav | Apr 2013 | B1 |
8423016 | Buckley et al. | Apr 2013 | B2 |
8429403 | Moret et al. | Apr 2013 | B2 |
8429409 | Wall et al. | Apr 2013 | B1 |
8437734 | Ray et al. | May 2013 | B2 |
8441955 | Wilkinson et al. | May 2013 | B2 |
8442015 | Behzad et al. | May 2013 | B2 |
8446831 | Kwan et al. | May 2013 | B2 |
8447324 | Shuman et al. | May 2013 | B2 |
8447607 | Weider et al. | May 2013 | B2 |
8447980 | Godfrey et al. | May 2013 | B2 |
8448015 | Gerhart | May 2013 | B2 |
8452858 | Wu et al. | May 2013 | B2 |
8461958 | Saenz et al. | Jun 2013 | B2 |
8463232 | Tuli et al. | Jun 2013 | B2 |
8468337 | Gaur et al. | Jun 2013 | B2 |
8472371 | Bari et al. | Jun 2013 | B1 |
8477778 | Lehmann, Jr. et al. | Jul 2013 | B2 |
8483135 | Cai et al. | Jul 2013 | B2 |
8483694 | Lewis et al. | Jul 2013 | B2 |
8484327 | Werner et al. | Jul 2013 | B2 |
8484568 | Rados et al. | Jul 2013 | B2 |
8488597 | Nie et al. | Jul 2013 | B2 |
8489110 | Frank et al. | Jul 2013 | B2 |
8489720 | Morford et al. | Jul 2013 | B1 |
8494559 | Malmi | Jul 2013 | B1 |
8495181 | Venkatraman et al. | Jul 2013 | B2 |
8495227 | Kaminsky et al. | Jul 2013 | B2 |
8495360 | Falk et al. | Jul 2013 | B2 |
8495700 | Shahbazi | Jul 2013 | B2 |
8495743 | Kraemer et al. | Jul 2013 | B2 |
8499087 | Hu | Jul 2013 | B2 |
RE44412 | Naqvi et al. | Aug 2013 | E |
8503358 | Hanson et al. | Aug 2013 | B2 |
8503455 | Heikens | Aug 2013 | B2 |
8504032 | Lott et al. | Aug 2013 | B2 |
8504574 | Dvorak et al. | Aug 2013 | B2 |
8504687 | Maffione et al. | Aug 2013 | B2 |
8504690 | Shah et al. | Aug 2013 | B2 |
8504729 | Pezzutti | Aug 2013 | B2 |
8505073 | Taglienti et al. | Aug 2013 | B2 |
8509082 | Heinz et al. | Aug 2013 | B2 |
8514927 | Sundararajan et al. | Aug 2013 | B2 |
8516552 | Raleigh | Aug 2013 | B2 |
8520589 | Bhatt et al. | Aug 2013 | B2 |
8520595 | Yadav et al. | Aug 2013 | B2 |
8521110 | Rofougaran | Aug 2013 | B2 |
8521775 | Poh et al. | Aug 2013 | B1 |
8522039 | Hyndman et al. | Aug 2013 | B2 |
8522249 | Beaule | Aug 2013 | B2 |
8522337 | Adusumilli et al. | Aug 2013 | B2 |
8523547 | Pekrul | Sep 2013 | B2 |
8526329 | Mahany et al. | Sep 2013 | B2 |
8527410 | Markki et al. | Sep 2013 | B2 |
8527662 | Biswas et al. | Sep 2013 | B2 |
8528068 | Weglein et al. | Sep 2013 | B1 |
8531954 | McNaughton et al. | Sep 2013 | B2 |
8531995 | Khan et al. | Sep 2013 | B2 |
8532610 | Manning Cassell et al. | Sep 2013 | B2 |
8533775 | Alcorn et al. | Sep 2013 | B2 |
8538394 | Zimmerman et al. | Sep 2013 | B2 |
8538421 | Brisebois et al. | Sep 2013 | B2 |
8538458 | Haney | Sep 2013 | B2 |
8539544 | Garimella et al. | Sep 2013 | B2 |
8539561 | Gupta et al. | Sep 2013 | B2 |
8543265 | Ekhaguere et al. | Sep 2013 | B2 |
8543814 | Laitinen et al. | Sep 2013 | B2 |
8544105 | Mclean et al. | Sep 2013 | B2 |
8548427 | Chow et al. | Oct 2013 | B2 |
8548428 | Raleigh | Oct 2013 | B2 |
8549173 | Wu et al. | Oct 2013 | B1 |
8554876 | Winsor | Oct 2013 | B2 |
8559369 | Barkan | Oct 2013 | B2 |
8565746 | Hoffman | Oct 2013 | B2 |
8566236 | Busch | Oct 2013 | B2 |
8571474 | Chavez et al. | Oct 2013 | B2 |
8571501 | Miller et al. | Oct 2013 | B2 |
8571598 | Valavi | Oct 2013 | B2 |
8571993 | Kocher et al. | Oct 2013 | B2 |
8572117 | Rappaport | Oct 2013 | B2 |
8572256 | Babbar | Oct 2013 | B2 |
8583499 | De Judicibus et al. | Nov 2013 | B2 |
8588240 | Ramankutty et al. | Nov 2013 | B2 |
8589541 | Raleigh et al. | Nov 2013 | B2 |
8589955 | Roundtree et al. | Nov 2013 | B2 |
8594665 | Anschutz | Nov 2013 | B2 |
8600895 | Felsher | Dec 2013 | B2 |
8601125 | Huang et al. | Dec 2013 | B2 |
8605691 | Soomro et al. | Dec 2013 | B2 |
8619735 | Montemurro et al. | Dec 2013 | B2 |
8620257 | Qiu et al. | Dec 2013 | B2 |
8621056 | Coussemaeker et al. | Dec 2013 | B2 |
8626115 | Raleigh et al. | Jan 2014 | B2 |
8630314 | York | Jan 2014 | B2 |
8631428 | Scott et al. | Jan 2014 | B2 |
8634425 | Gorti et al. | Jan 2014 | B2 |
8635164 | Rosenhaft et al. | Jan 2014 | B2 |
8639215 | McGregor | Jan 2014 | B2 |
8644702 | Kalajan | Feb 2014 | B1 |
8644813 | Gailloux et al. | Feb 2014 | B1 |
8645518 | David | Feb 2014 | B2 |
8655357 | Gazzard et al. | Feb 2014 | B1 |
8660853 | Robb et al. | Feb 2014 | B2 |
8666395 | Silver | Mar 2014 | B2 |
8667542 | Bertz et al. | Mar 2014 | B1 |
8670334 | Keohane et al. | Mar 2014 | B2 |
8670752 | Fan et al. | Mar 2014 | B2 |
8675852 | Maes | Mar 2014 | B2 |
8676682 | Kalliola | Mar 2014 | B2 |
8676925 | Liu et al. | Mar 2014 | B1 |
8693323 | McDysan | Apr 2014 | B1 |
8694772 | Kao et al. | Apr 2014 | B2 |
8700729 | Dua | Apr 2014 | B2 |
8701015 | Bonnat | Apr 2014 | B2 |
8705361 | Venkataraman et al. | Apr 2014 | B2 |
8706863 | Fadell | Apr 2014 | B2 |
8713535 | Malhotra et al. | Apr 2014 | B2 |
8713641 | Pagan et al. | Apr 2014 | B1 |
8719397 | Levi et al. | May 2014 | B2 |
8719423 | Wyld | May 2014 | B2 |
8725899 | Short et al. | May 2014 | B2 |
8730842 | Collins et al. | May 2014 | B2 |
8731519 | Flynn et al. | May 2014 | B2 |
8732808 | Sewall et al. | May 2014 | B2 |
8739035 | Trethewey | May 2014 | B2 |
8744339 | Halfmann et al. | Jun 2014 | B2 |
8761711 | Grignani et al. | Jun 2014 | B2 |
8780857 | Balasubramanian et al. | Jul 2014 | B2 |
8787249 | Giaretta et al. | Jul 2014 | B2 |
8793304 | Lu et al. | Jul 2014 | B2 |
8799227 | Ferguson et al. | Aug 2014 | B2 |
8804517 | Oerton | Aug 2014 | B2 |
8811338 | Jin et al. | Aug 2014 | B2 |
8811991 | Jain et al. | Aug 2014 | B2 |
8812525 | Taylor, III | Aug 2014 | B1 |
8818394 | Bienas et al. | Aug 2014 | B2 |
8819253 | Simeloff et al. | Aug 2014 | B2 |
8825109 | Montemurro et al. | Sep 2014 | B2 |
8826411 | Moen et al. | Sep 2014 | B2 |
8831561 | Sutaria et al. | Sep 2014 | B2 |
8837322 | Venkataramanan et al. | Sep 2014 | B2 |
8838686 | Getchius | Sep 2014 | B2 |
8838752 | Lor et al. | Sep 2014 | B2 |
8843849 | Neil et al. | Sep 2014 | B2 |
8849297 | Balasubramanian | Sep 2014 | B2 |
8855620 | Sievers et al. | Oct 2014 | B2 |
8862751 | Faccin et al. | Oct 2014 | B2 |
8863111 | Selitser et al. | Oct 2014 | B2 |
8868725 | Samba | Oct 2014 | B2 |
8868727 | Yumerefendi et al. | Oct 2014 | B2 |
8875042 | Lejeune et al. | Oct 2014 | B2 |
8880047 | Konicek et al. | Nov 2014 | B2 |
8891483 | Connelly et al. | Nov 2014 | B2 |
8898748 | Burks et al. | Nov 2014 | B2 |
8908516 | Tzamaloukas et al. | Dec 2014 | B2 |
8929374 | Tönsing et al. | Jan 2015 | B2 |
8930238 | Coffman et al. | Jan 2015 | B2 |
8943551 | Ganapathy et al. | Jan 2015 | B2 |
8948726 | Smith et al. | Feb 2015 | B2 |
8949597 | Reeves et al. | Feb 2015 | B1 |
8966018 | Bugwadia et al. | Feb 2015 | B2 |
8971841 | Menezes et al. | Mar 2015 | B2 |
8971912 | Chou et al. | Mar 2015 | B2 |
8972537 | Bastian et al. | Mar 2015 | B2 |
8977284 | Reed | Mar 2015 | B2 |
8995952 | Baker et al. | Mar 2015 | B1 |
9002322 | Cotterill | Apr 2015 | B2 |
9002342 | Tenhunen et al. | Apr 2015 | B2 |
9014973 | Ruckart | Apr 2015 | B2 |
9015331 | Lai et al. | Apr 2015 | B2 |
9030934 | Shah et al. | May 2015 | B2 |
9032427 | Gallant et al. | May 2015 | B2 |
9049010 | Jueneman et al. | Jun 2015 | B2 |
9064275 | Lu et al. | Jun 2015 | B1 |
9105031 | Shen | Aug 2015 | B2 |
9111088 | Ghai et al. | Aug 2015 | B2 |
9135037 | Petrescu-Prahova et al. | Sep 2015 | B1 |
9137286 | Yuan | Sep 2015 | B1 |
9137389 | Neal et al. | Sep 2015 | B2 |
9172553 | Dawes et al. | Oct 2015 | B2 |
9173090 | Tuchman et al. | Oct 2015 | B2 |
9176913 | Millet et al. | Nov 2015 | B2 |
9177455 | Remer | Nov 2015 | B2 |
9282460 | Souissi | Mar 2016 | B2 |
9286469 | Kraemer et al. | Mar 2016 | B2 |
9286604 | Aabye et al. | Mar 2016 | B2 |
9325737 | Gutowski et al. | Apr 2016 | B2 |
9326173 | Luft | Apr 2016 | B2 |
9344557 | Gruchala et al. | May 2016 | B2 |
9361451 | Oberheide et al. | Jun 2016 | B2 |
9367680 | Mahaffey et al. | Jun 2016 | B2 |
9369959 | Ruutu et al. | Jun 2016 | B2 |
9402254 | Kneckt et al. | Jul 2016 | B2 |
9413546 | Meier et al. | Aug 2016 | B2 |
9459767 | Cockcroft et al. | Oct 2016 | B2 |
9589117 | Ali | Mar 2017 | B2 |
9609459 | Raleigh | Mar 2017 | B2 |
9634850 | Taft et al. | Apr 2017 | B2 |
20010048738 | Baniak et al. | Dec 2001 | A1 |
20010053694 | Igarashi et al. | Dec 2001 | A1 |
20020022472 | Watler et al. | Feb 2002 | A1 |
20020049074 | Eisinger et al. | Apr 2002 | A1 |
20020099848 | Lee | Jul 2002 | A1 |
20020116338 | Gonthier et al. | Aug 2002 | A1 |
20020120370 | Parupudi et al. | Aug 2002 | A1 |
20020120540 | Kende et al. | Aug 2002 | A1 |
20020131404 | Mehta et al. | Sep 2002 | A1 |
20020138599 | Dilman et al. | Sep 2002 | A1 |
20020138601 | Piponius et al. | Sep 2002 | A1 |
20020154751 | Thompson et al. | Oct 2002 | A1 |
20020161601 | Nauer et al. | Oct 2002 | A1 |
20020164983 | Raviv et al. | Nov 2002 | A1 |
20020176377 | Hamilton | Nov 2002 | A1 |
20020188732 | Buckman et al. | Dec 2002 | A1 |
20020191573 | Whitehill et al. | Dec 2002 | A1 |
20020199001 | Wenocur et al. | Dec 2002 | A1 |
20030004937 | Salmenkaita et al. | Jan 2003 | A1 |
20030005112 | Krautkremer | Jan 2003 | A1 |
20030013434 | Rosenberg et al. | Jan 2003 | A1 |
20030018524 | Fishman et al. | Jan 2003 | A1 |
20030028623 | Hennessey et al. | Feb 2003 | A1 |
20030046396 | Richter et al. | Mar 2003 | A1 |
20030050070 | Mashinsky et al. | Mar 2003 | A1 |
20030050837 | Kim | Mar 2003 | A1 |
20030084321 | Tarquini et al. | May 2003 | A1 |
20030088671 | Klinker et al. | May 2003 | A1 |
20030133408 | Cheng et al. | Jul 2003 | A1 |
20030134650 | Sundar et al. | Jul 2003 | A1 |
20030159030 | Evans | Aug 2003 | A1 |
20030161265 | Cao et al. | Aug 2003 | A1 |
20030171112 | Lupper et al. | Sep 2003 | A1 |
20030182420 | Jones et al. | Sep 2003 | A1 |
20030182435 | Redlich et al. | Sep 2003 | A1 |
20030184793 | Pineau | Oct 2003 | A1 |
20030188006 | Bard | Oct 2003 | A1 |
20030188117 | Yoshino et al. | Oct 2003 | A1 |
20030220984 | Jones et al. | Nov 2003 | A1 |
20030224781 | Milford et al. | Dec 2003 | A1 |
20030229900 | Reisman | Dec 2003 | A1 |
20030233332 | Keeler et al. | Dec 2003 | A1 |
20030236745 | Hartsell et al. | Dec 2003 | A1 |
20040019539 | Raman et al. | Jan 2004 | A1 |
20040019564 | Goldthwaite | Jan 2004 | A1 |
20040021697 | Beaton et al. | Feb 2004 | A1 |
20040024756 | Rickard | Feb 2004 | A1 |
20040030705 | Bowman-Amuah | Feb 2004 | A1 |
20040039792 | Nakanishi | Feb 2004 | A1 |
20040044623 | Wake et al. | Mar 2004 | A1 |
20040047358 | Chen et al. | Mar 2004 | A1 |
20040054779 | Takeshima et al. | Mar 2004 | A1 |
20040073672 | Fascenda | Apr 2004 | A1 |
20040082346 | Skytt et al. | Apr 2004 | A1 |
20040098715 | Aghera et al. | May 2004 | A1 |
20040102182 | Reith et al. | May 2004 | A1 |
20040103193 | Pandya et al. | May 2004 | A1 |
20040107360 | Herrmann et al. | Jun 2004 | A1 |
20040127200 | Shaw et al. | Jul 2004 | A1 |
20040127208 | Nair et al. | Jul 2004 | A1 |
20040127256 | Goldthwaite | Jul 2004 | A1 |
20040132427 | Lee et al. | Jul 2004 | A1 |
20040133668 | Nicholas, III | Jul 2004 | A1 |
20040137890 | Kalke | Jul 2004 | A1 |
20040168052 | Clisham et al. | Aug 2004 | A1 |
20040170191 | Guo et al. | Sep 2004 | A1 |
20040176104 | Arcens | Sep 2004 | A1 |
20040198331 | Coward et al. | Oct 2004 | A1 |
20040203755 | Brunet et al. | Oct 2004 | A1 |
20040203833 | Rathunde et al. | Oct 2004 | A1 |
20040225561 | Hertzberg et al. | Nov 2004 | A1 |
20040225898 | Frost et al. | Nov 2004 | A1 |
20040236547 | Rappaport et al. | Nov 2004 | A1 |
20040243680 | Mayer | Dec 2004 | A1 |
20040243992 | Gustafson et al. | Dec 2004 | A1 |
20040249918 | Sunshine | Dec 2004 | A1 |
20040255145 | Chow | Dec 2004 | A1 |
20040259534 | Chaudhari et al. | Dec 2004 | A1 |
20040260766 | Barros et al. | Dec 2004 | A1 |
20040267872 | Serdy et al. | Dec 2004 | A1 |
20050007993 | Chambers et al. | Jan 2005 | A1 |
20050009499 | Koster | Jan 2005 | A1 |
20050021995 | Lal et al. | Jan 2005 | A1 |
20050041617 | Huotari et al. | Feb 2005 | A1 |
20050048950 | Morper | Mar 2005 | A1 |
20050055291 | Bevente et al. | Mar 2005 | A1 |
20050055309 | Williams et al. | Mar 2005 | A1 |
20050055595 | Frazer et al. | Mar 2005 | A1 |
20050060266 | Demello et al. | Mar 2005 | A1 |
20050060525 | Schwartz et al. | Mar 2005 | A1 |
20050075115 | Corneille et al. | Apr 2005 | A1 |
20050079863 | Macaluso | Apr 2005 | A1 |
20050091505 | Riley et al. | Apr 2005 | A1 |
20050096024 | Bicker et al. | May 2005 | A1 |
20050097516 | Donnelly et al. | May 2005 | A1 |
20050107091 | Vannithamby et al. | May 2005 | A1 |
20050108075 | Douglis et al. | May 2005 | A1 |
20050111463 | Leung et al. | May 2005 | A1 |
20050128967 | Scobbie | Jun 2005 | A1 |
20050135264 | Popoff et al. | Jun 2005 | A1 |
20050163320 | Brown et al. | Jul 2005 | A1 |
20050166043 | Zhang et al. | Jul 2005 | A1 |
20050183143 | Anderholm et al. | Aug 2005 | A1 |
20050186948 | Gallagher et al. | Aug 2005 | A1 |
20050198377 | Ferguson et al. | Sep 2005 | A1 |
20050216421 | Barry et al. | Sep 2005 | A1 |
20050228985 | Ylikoski et al. | Oct 2005 | A1 |
20050238046 | Hassan et al. | Oct 2005 | A1 |
20050239447 | Holzman et al. | Oct 2005 | A1 |
20050245241 | Durand et al. | Nov 2005 | A1 |
20050246282 | Naslund et al. | Nov 2005 | A1 |
20050250508 | Guo | Nov 2005 | A1 |
20050250536 | Deng et al. | Nov 2005 | A1 |
20050254435 | Moakley et al. | Nov 2005 | A1 |
20050266825 | Clayton | Dec 2005 | A1 |
20050266880 | Gupta | Dec 2005 | A1 |
20060014519 | Marsh et al. | Jan 2006 | A1 |
20060019632 | Cunningham et al. | Jan 2006 | A1 |
20060020787 | Choyi et al. | Jan 2006 | A1 |
20060026679 | Zakas | Feb 2006 | A1 |
20060030306 | Kuhn | Feb 2006 | A1 |
20060034256 | Addagatla et al. | Feb 2006 | A1 |
20060035631 | White et al. | Feb 2006 | A1 |
20060040642 | Boris et al. | Feb 2006 | A1 |
20060045245 | Aaron et al. | Mar 2006 | A1 |
20060048223 | Lee et al. | Mar 2006 | A1 |
20060068796 | Millen et al. | Mar 2006 | A1 |
20060072451 | Ross | Apr 2006 | A1 |
20060072550 | Davis et al. | Apr 2006 | A1 |
20060072646 | Feher | Apr 2006 | A1 |
20060075506 | Sanda et al. | Apr 2006 | A1 |
20060085543 | Hrastar et al. | Apr 2006 | A1 |
20060095517 | O'Connor et al. | May 2006 | A1 |
20060098627 | Karaoguz et al. | May 2006 | A1 |
20060099970 | Morgan et al. | May 2006 | A1 |
20060101507 | Camenisch | May 2006 | A1 |
20060112016 | Ishibashi | May 2006 | A1 |
20060114821 | Willey et al. | Jun 2006 | A1 |
20060114832 | Hamilton et al. | Jun 2006 | A1 |
20060126562 | Liu | Jun 2006 | A1 |
20060135144 | Jothipragasam | Jun 2006 | A1 |
20060136882 | Noonan et al. | Jun 2006 | A1 |
20060143066 | Calabria | Jun 2006 | A1 |
20060143098 | Lazaridis | Jun 2006 | A1 |
20060156398 | Ross et al. | Jul 2006 | A1 |
20060160536 | Chou | Jul 2006 | A1 |
20060165060 | Dua | Jul 2006 | A1 |
20060168128 | Sistla et al. | Jul 2006 | A1 |
20060173959 | McKelvie et al. | Aug 2006 | A1 |
20060174035 | Tufail | Aug 2006 | A1 |
20060178917 | Merriam et al. | Aug 2006 | A1 |
20060178918 | Mikurak | Aug 2006 | A1 |
20060182137 | Zhou et al. | Aug 2006 | A1 |
20060183462 | Kolehmainen | Aug 2006 | A1 |
20060190314 | Hernandez | Aug 2006 | A1 |
20060190987 | Ohta et al. | Aug 2006 | A1 |
20060199608 | Dunn et al. | Sep 2006 | A1 |
20060200663 | Thornton | Sep 2006 | A1 |
20060206709 | Labrou et al. | Sep 2006 | A1 |
20060206904 | Watkins et al. | Sep 2006 | A1 |
20060218395 | Maes | Sep 2006 | A1 |
20060233108 | Krishnan | Oct 2006 | A1 |
20060233166 | Bou-Diab et al. | Oct 2006 | A1 |
20060236095 | Smith et al. | Oct 2006 | A1 |
20060242685 | Heard et al. | Oct 2006 | A1 |
20060258341 | Miller et al. | Nov 2006 | A1 |
20060277590 | Limont et al. | Dec 2006 | A1 |
20060291419 | McConnell et al. | Dec 2006 | A1 |
20060291477 | Croak et al. | Dec 2006 | A1 |
20070005795 | Gonzalez | Jan 2007 | A1 |
20070019670 | Falardeau | Jan 2007 | A1 |
20070022289 | Alt et al. | Jan 2007 | A1 |
20070025301 | Petersson et al. | Feb 2007 | A1 |
20070033194 | Srinivas et al. | Feb 2007 | A1 |
20070033197 | Scherzer et al. | Feb 2007 | A1 |
20070036312 | Cai et al. | Feb 2007 | A1 |
20070055694 | Ruge et al. | Mar 2007 | A1 |
20070060200 | Boris et al. | Mar 2007 | A1 |
20070061243 | Ramer et al. | Mar 2007 | A1 |
20070061800 | Cheng et al. | Mar 2007 | A1 |
20070061878 | Hagiu et al. | Mar 2007 | A1 |
20070073899 | Judge et al. | Mar 2007 | A1 |
20070076616 | Ngo et al. | Apr 2007 | A1 |
20070093243 | Kapadekar et al. | Apr 2007 | A1 |
20070100981 | Adamczyk et al. | May 2007 | A1 |
20070101426 | Lee et al. | May 2007 | A1 |
20070104126 | Calhoun et al. | May 2007 | A1 |
20070109983 | Shankar et al. | May 2007 | A1 |
20070130283 | Klein et al. | Jun 2007 | A1 |
20070130315 | Friend et al. | Jun 2007 | A1 |
20070140113 | Gemelos | Jun 2007 | A1 |
20070140145 | Kumar et al. | Jun 2007 | A1 |
20070140275 | Bowman et al. | Jun 2007 | A1 |
20070143824 | Shahbazi | Jun 2007 | A1 |
20070147317 | Smith et al. | Jun 2007 | A1 |
20070147324 | McGary | Jun 2007 | A1 |
20070155365 | Kim et al. | Jul 2007 | A1 |
20070165630 | Rasanen | Jul 2007 | A1 |
20070168499 | Chu | Jul 2007 | A1 |
20070171856 | Bruce et al. | Jul 2007 | A1 |
20070174490 | Choi et al. | Jul 2007 | A1 |
20070192460 | Choi et al. | Aug 2007 | A1 |
20070198656 | Mazzaferri et al. | Aug 2007 | A1 |
20070201502 | Abramson | Aug 2007 | A1 |
20070213054 | Han | Sep 2007 | A1 |
20070220251 | Rosenberg et al. | Sep 2007 | A1 |
20070226225 | Yiu et al. | Sep 2007 | A1 |
20070226775 | Andreasen et al. | Sep 2007 | A1 |
20070234402 | Khosravi et al. | Oct 2007 | A1 |
20070243862 | Coskun et al. | Oct 2007 | A1 |
20070248100 | Zuberi et al. | Oct 2007 | A1 |
20070254675 | Zorlu Ozer et al. | Nov 2007 | A1 |
20070255769 | Agrawal et al. | Nov 2007 | A1 |
20070255797 | Dunn et al. | Nov 2007 | A1 |
20070255848 | Sewall et al. | Nov 2007 | A1 |
20070257767 | Beeson | Nov 2007 | A1 |
20070259656 | Jeong | Nov 2007 | A1 |
20070259673 | Willars et al. | Nov 2007 | A1 |
20070263558 | Salomone | Nov 2007 | A1 |
20070266422 | Germano et al. | Nov 2007 | A1 |
20070274327 | Kaarela et al. | Nov 2007 | A1 |
20070280453 | Kelley | Dec 2007 | A1 |
20070282896 | Wydroug et al. | Dec 2007 | A1 |
20070293191 | Mir et al. | Dec 2007 | A1 |
20070294395 | Strub et al. | Dec 2007 | A1 |
20070294410 | Pandya et al. | Dec 2007 | A1 |
20070297378 | Poyhonen et al. | Dec 2007 | A1 |
20070298764 | Clayton | Dec 2007 | A1 |
20070299965 | Nieh et al. | Dec 2007 | A1 |
20070300252 | Acharya et al. | Dec 2007 | A1 |
20080005285 | Robinson et al. | Jan 2008 | A1 |
20080005561 | Brown et al. | Jan 2008 | A1 |
20080010379 | Zhao | Jan 2008 | A1 |
20080010452 | Holtzman et al. | Jan 2008 | A1 |
20080018494 | Waite et al. | Jan 2008 | A1 |
20080022354 | Grewal et al. | Jan 2008 | A1 |
20080025230 | Patel et al. | Jan 2008 | A1 |
20080032715 | Jia et al. | Feb 2008 | A1 |
20080034063 | Yee | Feb 2008 | A1 |
20080034419 | Mullick et al. | Feb 2008 | A1 |
20080039102 | Sewall et al. | Feb 2008 | A1 |
20080049630 | Kozisek et al. | Feb 2008 | A1 |
20080050715 | Golczewski et al. | Feb 2008 | A1 |
20080051076 | O'Shaughnessy et al. | Feb 2008 | A1 |
20080052387 | Heinz et al. | Feb 2008 | A1 |
20080056273 | Pelletier et al. | Mar 2008 | A1 |
20080059474 | Lim | Mar 2008 | A1 |
20080059743 | Bychkov et al. | Mar 2008 | A1 |
20080060066 | Wynn et al. | Mar 2008 | A1 |
20080062900 | Rao | Mar 2008 | A1 |
20080064367 | Nath et al. | Mar 2008 | A1 |
20080066149 | Lim | Mar 2008 | A1 |
20080066150 | Lim | Mar 2008 | A1 |
20080066181 | Haveson et al. | Mar 2008 | A1 |
20080070550 | Hose | Mar 2008 | A1 |
20080077705 | Li et al. | Mar 2008 | A1 |
20080080457 | Cole | Apr 2008 | A1 |
20080081606 | Cole | Apr 2008 | A1 |
20080082643 | Storrie et al. | Apr 2008 | A1 |
20080083013 | Soliman et al. | Apr 2008 | A1 |
20080085707 | Fadell | Apr 2008 | A1 |
20080089295 | Keeler et al. | Apr 2008 | A1 |
20080089303 | Wirtanen et al. | Apr 2008 | A1 |
20080095339 | Elliott et al. | Apr 2008 | A1 |
20080096559 | Phillips et al. | Apr 2008 | A1 |
20080098062 | Balia | Apr 2008 | A1 |
20080109679 | Wright | May 2008 | A1 |
20080120129 | Seubert et al. | May 2008 | A1 |
20080120668 | Yau | May 2008 | A1 |
20080120688 | Qiu et al. | May 2008 | A1 |
20080125079 | O'Neil et al. | May 2008 | A1 |
20080126287 | Cox et al. | May 2008 | A1 |
20080127304 | Ginter et al. | May 2008 | A1 |
20080130534 | Tomioka | Jun 2008 | A1 |
20080130656 | Kim et al. | Jun 2008 | A1 |
20080132201 | Karlberg | Jun 2008 | A1 |
20080132268 | Choi-Grogan et al. | Jun 2008 | A1 |
20080134330 | Kapoor et al. | Jun 2008 | A1 |
20080139210 | Gisby et al. | Jun 2008 | A1 |
20080147454 | Walker et al. | Jun 2008 | A1 |
20080160958 | Abichandani et al. | Jul 2008 | A1 |
20080162637 | Adamczyk et al. | Jul 2008 | A1 |
20080162704 | Poplett et al. | Jul 2008 | A1 |
20080164304 | Narasimhan et al. | Jul 2008 | A1 |
20080166993 | Gautier et al. | Jul 2008 | A1 |
20080167027 | Gautier et al. | Jul 2008 | A1 |
20080167033 | Beckers | Jul 2008 | A1 |
20080168275 | DeAtley et al. | Jul 2008 | A1 |
20080168523 | Ansari et al. | Jul 2008 | A1 |
20080177998 | Apsangi et al. | Jul 2008 | A1 |
20080178300 | Brown et al. | Jul 2008 | A1 |
20080183812 | Paul et al. | Jul 2008 | A1 |
20080184127 | Rafey et al. | Jul 2008 | A1 |
20080189760 | Rosenberg et al. | Aug 2008 | A1 |
20080201266 | Chua et al. | Aug 2008 | A1 |
20080207167 | Bugenhagen | Aug 2008 | A1 |
20080212470 | Castaneda et al. | Sep 2008 | A1 |
20080212751 | Chung | Sep 2008 | A1 |
20080219268 | Dennison | Sep 2008 | A1 |
20080221951 | Stanforth et al. | Sep 2008 | A1 |
20080222692 | Andersson et al. | Sep 2008 | A1 |
20080225748 | Khemani et al. | Sep 2008 | A1 |
20080229385 | Feder et al. | Sep 2008 | A1 |
20080229388 | Maes | Sep 2008 | A1 |
20080235511 | O'Brien et al. | Sep 2008 | A1 |
20080240373 | Wilhelm | Oct 2008 | A1 |
20080250053 | Aaltonen et al. | Oct 2008 | A1 |
20080256593 | Vinberg et al. | Oct 2008 | A1 |
20080259924 | Gooch et al. | Oct 2008 | A1 |
20080262798 | Kim et al. | Oct 2008 | A1 |
20080263348 | Zaltsman et al. | Oct 2008 | A1 |
20080268813 | Maes | Oct 2008 | A1 |
20080270212 | Blight et al. | Oct 2008 | A1 |
20080279216 | Sharif-Ahmadi et al. | Nov 2008 | A1 |
20080282319 | Fontijn et al. | Nov 2008 | A1 |
20080293395 | Mathews et al. | Nov 2008 | A1 |
20080298230 | Luft et al. | Dec 2008 | A1 |
20080305793 | Gallagher et al. | Dec 2008 | A1 |
20080311885 | Dawson et al. | Dec 2008 | A1 |
20080313315 | Karaoguz et al. | Dec 2008 | A1 |
20080313730 | Iftimie et al. | Dec 2008 | A1 |
20080316923 | Fedders et al. | Dec 2008 | A1 |
20080318547 | Ballou et al. | Dec 2008 | A1 |
20080318550 | DeAtley | Dec 2008 | A1 |
20080319879 | Carroll et al. | Dec 2008 | A1 |
20080320497 | Tarkoma et al. | Dec 2008 | A1 |
20090005000 | Baker et al. | Jan 2009 | A1 |
20090005005 | Forstall et al. | Jan 2009 | A1 |
20090006116 | Baker et al. | Jan 2009 | A1 |
20090006200 | Baker et al. | Jan 2009 | A1 |
20090006229 | Sweeney et al. | Jan 2009 | A1 |
20090013157 | Beaule | Jan 2009 | A1 |
20090016310 | Rasal | Jan 2009 | A1 |
20090036111 | Danford et al. | Feb 2009 | A1 |
20090042536 | Bernard et al. | Feb 2009 | A1 |
20090044185 | Krivopaltsev | Feb 2009 | A1 |
20090046707 | Smires et al. | Feb 2009 | A1 |
20090046723 | Rahman et al. | Feb 2009 | A1 |
20090047989 | Harmon et al. | Feb 2009 | A1 |
20090048913 | Shenfield et al. | Feb 2009 | A1 |
20090049156 | Aronsson et al. | Feb 2009 | A1 |
20090049518 | Roman et al. | Feb 2009 | A1 |
20090054030 | Golds | Feb 2009 | A1 |
20090065571 | Jain | Mar 2009 | A1 |
20090067372 | Shah et al. | Mar 2009 | A1 |
20090068984 | Burnett | Mar 2009 | A1 |
20090070379 | Rappaport | Mar 2009 | A1 |
20090077622 | Baum et al. | Mar 2009 | A1 |
20090079699 | Sun | Mar 2009 | A1 |
20090113514 | Hu | Apr 2009 | A1 |
20090125619 | Antani | May 2009 | A1 |
20090132860 | Liu et al. | May 2009 | A1 |
20090149154 | Bhasin et al. | Jun 2009 | A1 |
20090157792 | Fiatal | Jun 2009 | A1 |
20090163173 | Williams | Jun 2009 | A1 |
20090172077 | Roxburgh et al. | Jul 2009 | A1 |
20090180391 | Petersen et al. | Jul 2009 | A1 |
20090181662 | Fleischman et al. | Jul 2009 | A1 |
20090197585 | Aaron | Aug 2009 | A1 |
20090197612 | Kiiskinen | Aug 2009 | A1 |
20090203352 | Fordon et al. | Aug 2009 | A1 |
20090217364 | Salmela et al. | Aug 2009 | A1 |
20090219170 | Clark et al. | Sep 2009 | A1 |
20090248883 | Suryanarayana et al. | Oct 2009 | A1 |
20090254857 | Romine et al. | Oct 2009 | A1 |
20090257379 | Robinson et al. | Oct 2009 | A1 |
20090271514 | Thomas et al. | Oct 2009 | A1 |
20090282127 | LeBlanc et al. | Nov 2009 | A1 |
20090286507 | O'Neil et al. | Nov 2009 | A1 |
20090287921 | Zhu et al. | Nov 2009 | A1 |
20090288140 | Huber et al. | Nov 2009 | A1 |
20090291665 | Gaskarth et al. | Nov 2009 | A1 |
20090299857 | Brubaker | Dec 2009 | A1 |
20090307696 | Vals et al. | Dec 2009 | A1 |
20090307746 | Di et al. | Dec 2009 | A1 |
20090315735 | Bhavani et al. | Dec 2009 | A1 |
20090320110 | Nicolson et al. | Dec 2009 | A1 |
20100017506 | Fadell | Jan 2010 | A1 |
20100020822 | Zerillo et al. | Jan 2010 | A1 |
20100027469 | Gurajala et al. | Feb 2010 | A1 |
20100027559 | Lin et al. | Feb 2010 | A1 |
20100030890 | Dutta et al. | Feb 2010 | A1 |
20100041364 | Lott et al. | Feb 2010 | A1 |
20100041365 | Lott et al. | Feb 2010 | A1 |
20100042675 | Fujii | Feb 2010 | A1 |
20100043068 | Varadhan et al. | Feb 2010 | A1 |
20100071053 | Ansari et al. | Mar 2010 | A1 |
20100075666 | Garner | Mar 2010 | A1 |
20100080202 | Hanson | Apr 2010 | A1 |
20100082431 | Ramer et al. | Apr 2010 | A1 |
20100103820 | Fuller et al. | Apr 2010 | A1 |
20100121744 | Belz et al. | May 2010 | A1 |
20100131584 | Johnson | May 2010 | A1 |
20100144310 | Bedingfield | Jun 2010 | A1 |
20100151866 | Karpov et al. | Jun 2010 | A1 |
20100153781 | Hanna | Jun 2010 | A1 |
20100167696 | Smith et al. | Jul 2010 | A1 |
20100188975 | Raleigh | Jul 2010 | A1 |
20100188990 | Raleigh | Jul 2010 | A1 |
20100188992 | Raleigh | Jul 2010 | A1 |
20100188994 | Raleigh | Jul 2010 | A1 |
20100190469 | Vanderveen et al. | Jul 2010 | A1 |
20100191576 | Raleigh | Jul 2010 | A1 |
20100191612 | Raleigh | Jul 2010 | A1 |
20100191846 | Raleigh | Jul 2010 | A1 |
20100192170 | Raleigh | Jul 2010 | A1 |
20100192212 | Raleigh | Jul 2010 | A1 |
20100195503 | Raleigh | Aug 2010 | A1 |
20100197268 | Raleigh | Aug 2010 | A1 |
20100198698 | Raleigh et al. | Aug 2010 | A1 |
20100198939 | Raleigh | Aug 2010 | A1 |
20100235329 | Koren et al. | Sep 2010 | A1 |
20100241544 | Benson et al. | Sep 2010 | A1 |
20100248719 | Scholaert | Sep 2010 | A1 |
20100284327 | Miklos | Nov 2010 | A1 |
20100284388 | Fantini et al. | Nov 2010 | A1 |
20100287599 | He | Nov 2010 | A1 |
20100311402 | Srinivasan et al. | Dec 2010 | A1 |
20100318652 | Samba | Dec 2010 | A1 |
20100325420 | Kanekar | Dec 2010 | A1 |
20110004917 | Salsa et al. | Jan 2011 | A1 |
20110013569 | Scherzer et al. | Jan 2011 | A1 |
20110019574 | Malomsoky et al. | Jan 2011 | A1 |
20110081881 | Baker et al. | Apr 2011 | A1 |
20110082790 | Baker et al. | Apr 2011 | A1 |
20110110309 | Bennett | May 2011 | A1 |
20110126141 | King et al. | May 2011 | A1 |
20110145920 | Mahaffey et al. | Jun 2011 | A1 |
20110159818 | Scherzer et al. | Jun 2011 | A1 |
20110173678 | Kaippallimalil et al. | Jul 2011 | A1 |
20110177811 | Heckman et al. | Jul 2011 | A1 |
20110195700 | Kukuchka et al. | Aug 2011 | A1 |
20110238545 | Fanaian et al. | Sep 2011 | A1 |
20110241624 | Park et al. | Oct 2011 | A1 |
20110252430 | Chapman et al. | Oct 2011 | A1 |
20110264923 | Kocher et al. | Oct 2011 | A1 |
20110277019 | Pritchard, Jr. | Nov 2011 | A1 |
20120020296 | Scherzer et al. | Jan 2012 | A1 |
20120029718 | Davis | Feb 2012 | A1 |
20120101952 | Raleigh et al. | Apr 2012 | A1 |
20120108225 | Luna et al. | May 2012 | A1 |
20120144025 | Melander et al. | Jun 2012 | A1 |
20120155296 | Kashanian | Jun 2012 | A1 |
20120166364 | Ahmad et al. | Jun 2012 | A1 |
20120166604 | Fortier et al. | Jun 2012 | A1 |
20120196644 | Scherzer et al. | Aug 2012 | A1 |
20120238287 | Scherzer | Sep 2012 | A1 |
20120330792 | Kashanian | Dec 2012 | A1 |
20130024914 | Ahmed et al. | Jan 2013 | A1 |
20130029653 | Baker et al. | Jan 2013 | A1 |
20130030960 | Kashanian | Jan 2013 | A1 |
20130058274 | Scherzer et al. | Mar 2013 | A1 |
20130065555 | Baker et al. | Mar 2013 | A1 |
20130072177 | Ross et al. | Mar 2013 | A1 |
20130084835 | Scherzer et al. | Apr 2013 | A1 |
20130095787 | Kashanian | Apr 2013 | A1 |
20130103376 | Gaddam et al. | Apr 2013 | A1 |
20130111572 | Gaddam et al. | May 2013 | A1 |
20130117140 | Kashanian | May 2013 | A1 |
20130117382 | Gaddam et al. | May 2013 | A1 |
20130144789 | Aaltonen et al. | Jun 2013 | A1 |
20130149994 | Gaddam et al. | Jun 2013 | A1 |
20130183937 | Neal et al. | Jul 2013 | A1 |
20130326356 | Zheng et al. | Dec 2013 | A9 |
20140073291 | Hildner et al. | Mar 2014 | A1 |
20140241342 | Constantinof | Aug 2014 | A1 |
Number | Date | Country |
---|---|---|
2688553 | Dec 2008 | CA |
1310401 | Feb 2000 | CN |
1345154 | Apr 2002 | CN |
1508734 | Jun 2004 | CN |
1538730 | Oct 2004 | CN |
1567818 | Jan 2005 | CN |
101035308 | Mar 2006 | CN |
1801829 | Jul 2006 | CN |
1802839 | Jul 2006 | CN |
1889777 | Jul 2006 | CN |
101155343 | Sep 2006 | CN |
1867024 | Nov 2006 | CN |
1878160 | Dec 2006 | CN |
1878160 | Dec 2006 | CN |
1937511 | Mar 2007 | CN |
101123553 | Sep 2007 | CN |
101080055 | Nov 2007 | CN |
101115248 | Jan 2008 | CN |
101127988 | Feb 2008 | CN |
101183958 | May 2008 | CN |
101335666 | Dec 2008 | CN |
101341764 | Jan 2009 | CN |
101815275 | Aug 2010 | CN |
1098490 | May 2001 | EP |
1289326 | Mar 2003 | EP |
1463238 | Sep 2004 | EP |
1503548 AL | Feb 2005 | EP |
1545114 | Jun 2005 | EP |
1545114 | Jun 2005 | EP |
1739518 | Jan 2007 | EP |
1772988 | Apr 2007 | EP |
1850575 | Oct 2007 | EP |
1887732 | Feb 2008 | EP |
1887732 | Feb 2008 | EP |
1942698 | Jul 2008 | EP |
1978772 | Oct 2008 | EP |
2007065 | Dec 2008 | EP |
2007065 | Dec 2008 | EP |
2026514 | Feb 2009 | EP |
2466831 | Jun 2012 | EP |
3148713 | Mar 2001 | JP |
2005339247 | Dec 2005 | JP |
2006-041989 | Feb 2006 | JP |
2006155263 | Jun 2006 | JP |
2006-197137 | Jul 2006 | JP |
2006-344007 | Dec 2006 | JP |
2007-318354 | Dec 2007 | JP |
2008-301121 | Dec 2008 | JP |
2009-111919 | May 2009 | JP |
2009-212707 | Sep 2009 | JP |
2009-218773 | Sep 2009 | JP |
2009-232107 | Oct 2009 | JP |
1998058505 | Dec 1998 | WO |
1999027723 AL | Jun 1999 | WO |
1999065185 | Dec 1999 | WO |
0208863 | Jan 2002 | WO |
2002045315 | Jun 2002 | WO |
2002067616 | Aug 2002 | WO |
2002067616 | Aug 2002 | WO |
2002093877 | Nov 2002 | WO |
2003014891 | Feb 2003 | WO |
2003017063 | Feb 2003 | WO |
2003017063 | Feb 2003 | WO |
2003017065 | Feb 2003 | WO |
2003017065 | Feb 2003 | WO |
2003058880 | Jul 2003 | WO |
2004028070 | Apr 2004 | WO |
2004064306 | Jul 2004 | WO |
2004077797 | Sep 2004 | WO |
2004095753 | Nov 2004 | WO |
2005008995 | Jan 2005 | WO |
2005053335 | Jun 2005 | WO |
2005083934 | Sep 2005 | WO |
2006004467 | Jan 2006 | WO |
2006004784 | Jan 2006 | WO |
2006012610 | Feb 2006 | WO |
2006050758 | May 2006 | WO |
2006073837 | Jul 2006 | WO |
2006077481 | Jul 2006 | WO |
2006093961 | Sep 2006 | WO |
2006120558 | Nov 2006 | WO |
2006130960 | Dec 2006 | WO |
2007001833 | Jan 2007 | WO |
2007014630 | Feb 2007 | WO |
2007018363 | Feb 2007 | WO |
2007053848 | May 2007 | WO |
2007068288 | Jun 2007 | WO |
2007069245 | Jun 2007 | WO |
2007097786 | Aug 2007 | WO |
2007107701 | Sep 2007 | WO |
2007120310 | Oct 2007 | WO |
2007124279 | Nov 2007 | WO |
2007126352 | Nov 2007 | WO |
2007129180 | Nov 2007 | WO |
2007133844 | Nov 2007 | WO |
2008017837 | Feb 2008 | WO |
2008051379 | May 2008 | WO |
2008066419 | Jun 2008 | WO |
2008080139 | Jul 2008 | WO |
2008080430 | Jul 2008 | WO |
2008099802 | Aug 2008 | WO |
2009008817 | Jan 2009 | WO |
2009091295 | Jul 2009 | WO |
2010088413 | Aug 2010 | WO |
2010128391 | Nov 2010 | WO |
2011002450 | Jan 2011 | WO |
2011002450 | Jan 2011 | WO |
2011149532 | Dec 2011 | WO |
2012047275 | Apr 2012 | WO |
Entry |
---|
Ahmed et al., “A Context-Aware Vertical Handover Decision Algorithm for Multimode Mobile Terminals and Its Performance,” BenQ Mobile, Munich Germany; University of Klagenfurt, Klagenfurt, Austria; 2006. |
Kassar et al., “An overview of vertical handover decision strategies in heterogeneous wireless networks,” ScienceDirect, University Pierre & Marie Curie, Paris, France, Jun. 5, 2007. |
Schiller et al., “Location-Based Services,” The Morgan Kaufmann Series in Data Management Systems, 2004. |
Sadeh et al., “Understanding and Capturing People's Privacy Policies in a Mobile Social Networking Application,” ISR School of Computer Science, Carnegie Mellon University, 2007. |
Jing et al., “Client-Server Computing in Mobile Environments,” GTE Labs. Inc., Purdue University, ACM Computing Surveys, vol. 31, No. 2, Jun. 1999. |
Rivadeneyra et al., “A communication architecture to access data services through GSM,” San Sebastian, Spain, 1998. |
Loopt User Guide, metroPCS, Jul. 17, 2008. |
“Jentro Technologies launches Zenlet platform to accelerate location-based content delivery to mobile devices,” The Mobile Internet, Boston, MA, Feb. 2008. |
“Ads and movies on the run,” the Gold Coast Bulletin, Southport, Q1d, Jan. 29, 2008. |
Richtel, “Cellphone consumerism; If even a debit card is too slow, now you have a new way to act on impulse: [National Edition],” National Post, Canada, Oct. 2, 2007. |
Kim, “Free wireless a high-wire act; MetroFi needs to draw enough ads to make service add profits,” San Francisco Chronicle, Aug. 21, 2006. |
Koutsopoulou et al., “Charging, Accounting and Billing Management Schemes in Mobile Telecommunication Networks and the Internet,” IEEE Communications Surveys & Tutorials, First Quarter 2004, vol. 6, No. 1. |
Sun et al., “Towards Connectivity Management Adaptability: Context Awareness in Policy Representation and End-to-end Evaluation Algorithm,” Dept. of Electrical and Information Engineering, Univ. of Oulu, Finland, 2004. |
Sabat, “The evolving mobile wireless value chain and market structure,” Nov. 2002. |
Nuzman et al., “A compund model for TCP connection arrivals for LAN and WAN applications,” Oct. 22, 2002. |
Kuntze et al., “Trustworthy content push,” Fraunhofer-Institute for Secure Information Technology SIT; Germany; WCNC 2007 proceedings, IEEE. |
Blackberry Mobile Data System, version 4.1, Technical Overview, 2006. |
Client Guide for Symantec Endpoint Protection and Symantec Network Access Control, 2007. |
Ehnert, “Small application to monitor IP trafic on a Blackberry—1.01.03 ”, Mar. 27, 2008; http://www.ehnert.net/MiniMoni/. |
NetLimiter Lite 4.0.19.0; http://www.heise.de/download/netlimiter-lite-3617703.html from vol. 14/2007. |
Muntermann et al., “Potentiale und Sicherheitsanforderungen mobiler Finanzinformationsdienste und deren Systeminfrastrukturen,” Chair of Mobile Commerce & Multilateral Security, Goethe Univ. Frankfurt, 2004. |
Kasper et al., “Subscriber Authentication in mobile cellular Networks with virtual software SIM Credentials using Trusted Computing,” Fraunhofer-Institute for Secure Information Technology SIT, Darmstadt, Germany; ICACT 2008. |
Fujitsu, “Server Push Technology Survey and Bidirectional Communication in HTTP Browser,” Jan. 9, 2008 (JP). |
Roy et al., “Energy Management in Mobile Devices with the Cinder Operating System”, Stanford University, MIT CSAIL, Jun. 3, 2010. |
Windows7 Power Management, published Apr. 2009. |
Quintana, David, “Mobile Multitasking,” Apr. 14, 2010. |
Open Mobile Alliance (OMA), Push Architecture, Candidate Version 2.2; Oct. 2, 2007; OMA-AD-Push-V2_2-20071002-C. |
VerizonWireless.com news, “Verizon Wireless Adds to Portfolio of Cosumer-Friendly Tools With Introduction of Usage Controls, Usage Controls and Chaperone 2.0 Offer Parents Full Family Security Solution,” Aug. 18, 2008. |
“The Construction of Intelligent Residential District in Use of Cable Television Network,” Shandong Science, vol. 13, No. 2, Jun. 2000. |
“Communication Concepts for Mobile Agent Systems,” by Joachim Baumann et al.; Inst. of Parallel and Distributed High-Performance Systems, Univ. of Stuttgart, Germany, pp. 123-135, 1997. |
“Prevent iCloud Documents & Data from using your data plan,” Oct. 26, 2011; CNET webarchive, by Jason Cipriani. |
“3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Policy and charging control architecture (Release 11),” 3GPP Standard; 3GPP TS 23.203 v11.6.0; Sophia Antipolis, France; pp. 1-177; Jun. 2012. |
“End to End QoS Solution for Real-time Multimedia Application;” Computer Engineering and Applications, 2007, 43 (4):155-159, by Tan Zu-guo, Wang Wen-juan; Information and Science School, Zhanjian Normal College, Zhan jiang, Guangdong 524048, China. |
“ASA/PIX: Allow Split Tunneling for VPN Clients on the ASA Configuration Example,” Document ID 70917, Jan. 10, 2008. |
3rd Generation Partnership Project, “Technical Specification Group Services and System Aspects; General Packet Radio Service (CPRS) Enhancements for Evolved Universal Terrestrial Radio Access Network (E-UTRAN) Access,” Release 8, Document No. 3GPP TS 23.401, V8.4.0, Dec. 2008. |
3rd Generation Partnership Project, “Technical Specification Group Services and System Aspects; Policy and Charging Control Architecture,” Release 8, Document No. 3GPP TS 23.203, V8.4.0, Dec. 2008. |
Alonistioti et al., “Intelligent Architectures Enabling Flexible Service Provision and Adaptability,” 2002. |
Amazon Technologies, Inc., “Kindle™ User's Guide,” 3rd Edition, Copyright 2004-2009. |
Chandrasekhar et al., “Femtocell Networks: A Survey,” Jun. 28, 2008. |
Chaouchi et al., “Policy Based Networking in the Integration Effort of 4G Networks and Services,” 2004 IEEE. |
Cisco Systems, Inc., “Cisco Mobile Exchange (CMX) Solution Guide: Chapter 2—Overview of GSM, GPRS, and UMTS,” Nov. 4, 2008. |
Dikaiakos et al., “A Distributed Middleware Infrastructure for Personalized Services,” Nov. 24, 2003. |
European Commission, “Data Roaming Tariffs—Transparency Measures,” [online] retrieved from http://web.archive.org/web/20081220232754/http://ec.europa.eu/information_society/activities/roaming/data/measures/index_en.htm, Dec. 20, 2008 [retrieved May 16, 2012]. |
Farooq et al., “An IEEE 802.16 WiMax Module for the NS-3 Simulator,” Mar. 2-6, 2009. |
Han et al., “Information Collection Services for Qos-Aware Mobile Applications,” 2005. |
Hartmann et al., “Agent-Based Banking Transactions & Information Retrieval—What About Performance Issues?” 1999. |
Hewlett-Packard Development Company, LP, “IP Multimedia Services Charging,” white paper, Jan. 2006. |
Hossain et al., “Gain-Based Selection of Ambient Media Services in Pervasive Environments,” Mobile Networks and Applications. Oct. 3, 2008. |
Knight et al., “Layer 2 and 3 Virtual Private Networks: Taxonomy, Technology, and Standarization Efforts,” IEEE communications Magazine, Jun. 2004. |
Koutsopoulou et al., “Middleware Platform for the Support of Charging Reconfiguration Actions,” 2005. |
Kyriakakos et al., “Ubiquitous Service Provision in Next Generation Mobile Networks,” Proceedings of the 13th IST Mobile and Wireless Communications Summit, Lyon, France, Jun. 2004. |
Li, Yu, “Dedicated E-Reading Device: The State of the Art and the Challenges,” Scroll, vol. 1, No. 1, 2008. |
Nilsson et al., “A Novel MAC Scheme for Solving the QoS Parameter Adjustment Problem in IEEE802.11e EDCA,” Feb. 2006. |
Oppliger, Rolf, “Internet Security: Firewalls and Bey,” Communications of the ACM, May 1997, vol. 40. No. 5. |
Rao et al., “Evolution of Mobile Location-Based Services,” Communication of the ACM, Dec. 2003. |
Steglich, Stephan, “I-Centric User Interaction,” Nov. 21, 2003. |
Van Eijk, et al., “GigaMobile, Agent Technology for Designing Personalized Mobile Service Brokerage,” Jul. 1, 2002. |
Zhu et al., “A Survey of Quality of Service in IEEE 802.11 Networks,” IEEE Wireless Communications, Aug. 2004. |
Anton, B. et al., “Best Current Practices for Wireless Internet Service Provider (WISP) Roaming”; Release Date Feb. 2003, Version 1.0; Wi-Fi Alliance—Wireless ISP Roaming (WISPr). |
Ruckus Wireless—White Paper; “Smarter Wi-Fi for Mobile Operator Infrastructures” 2010. |
Accuris Networks, “The Business Value of Mobile Data Offload—a White Paper”, 2010. |
Wireless Broadband Alliance, “WISPr 2.0, Apr. 8, 2010”; Doc. Ref. No. WBA/RM/WISPr, Version 01.00. |
Thurston, Richard, “WISPr 2.0 Boosts Roaming Between 3G and Wi-Fi”; Jun. 23, 2010; Web page from zdnet.com; Zdnet.com/wispr-2-0-boosts-roaming-between-3g-and-wi-fi-3040089325/. |
Wi-Fi Alliance Technical Committee Hotspot 2.0 Technical Task Group, “Hotspot 2.0 (Release 1) Technical Specification—Version 1.0.0”; 2012. |
Wi-Fi Alliance Hotspot 2.0 Technical Task Group, “Wi-Fi Certified Passpoint™ (Release 1) Deployment Guidelines—Version 1.0—Oct. 2012”. |
Dixon et al., Triple Play Digital Services: Comcast and Verizon (Digital Phone, Television, and Internet), Aug. 2007. |
3rd Generation Partnership Project; “Technical Specification Group Services and System Aspects; IP Flow Mobility and seamless WLAN offload; Stage 2,” Release 10, Document No. 3GPP TS 23.261, V1.0.0, Mar. 2010. |
3rd Generation Partnership Project, “Technical Specification Group Core Network and Terminals; Access Network Discovery and Selection Function (ANDSF) Management Object (MO),” Release 9, Document No. 3GPP TS 24.312, V9.1.0, Mar. 2010. |
Ahmed et al., “Multi Access Data Network Connectivity and IP Flow Mobility in Evolved Packet System (EPS),” 2010 IEEE. |
Android Cupcake excerpts, The Android Open Source Project, Feb. 10, 2009. |
Number | Date | Country | |
---|---|---|---|
20170188232 A1 | Jun 2017 | US |
Number | Date | Country | |
---|---|---|---|
61418507 | Dec 2010 | US | |
61418509 | Dec 2010 | US | |
61420727 | Dec 2010 | US | |
61422565 | Dec 2010 | US | |
61422572 | Dec 2010 | US | |
61422574 | Dec 2010 | US | |
61435564 | Jan 2011 | US | |
61472606 | Apr 2011 | US | |
61550906 | Oct 2011 | US | |
61384456 | Sep 2010 | US | |
61270353 | Jul 2009 | US | |
61264126 | Nov 2009 | US | |
61348022 | May 2010 | US | |
61381159 | Sep 2010 | US | |
61381162 | Sep 2010 | US | |
61385020 | Sep 2010 | US | |
61387243 | Sep 2010 | US | |
61387247 | Sep 2010 | US | |
61407358 | Oct 2010 | US | |
61264120 | Nov 2009 | US | |
61252153 | Oct 2009 | US | |
61389547 | Oct 2010 | US | |
61275208 | Aug 2009 | US | |
61237753 | Aug 2009 | US | |
61252151 | Oct 2009 | US | |
61206354 | Jan 2009 | US | |
61206944 | Feb 2009 | US | |
61207393 | Feb 2009 | US | |
61207739 | Feb 2009 | US | |
61206354 | Jan 2009 | US | |
61206944 | Feb 2009 | US | |
61207393 | Feb 2009 | US | |
61207739 | Feb 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13309463 | Dec 2011 | US |
Child | 14340270 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14340270 | Jul 2014 | US |
Child | 15287597 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13237827 | Sep 2011 | US |
Child | 13309463 | US | |
Parent | 13134028 | May 2011 | US |
Child | 13237827 | US | |
Parent | 13253013 | Oct 2011 | US |
Child | 13134028 | US | |
Parent | 12695019 | Jan 2010 | US |
Child | 13253013 | US | |
Parent | 12694455 | Jan 2010 | US |
Child | 12695019 | US | |
Parent | 13134005 | May 2011 | US |
Child | 12694455 | US | |
Parent | 12695021 | Jan 2010 | US |
Child | 13134005 | US | |
Parent | 12380780 | Mar 2009 | US |
Child | 12695021 | US | |
Parent | 12380778 | Mar 2009 | US |
Child | 13134005 | US | |
Parent | 12380780 | US | |
Child | 12380778 | US | |
Parent | 12695020 | Jan 2010 | US |
Child | 12380780 | US | |
Parent | 12694445 | Jan 2010 | US |
Child | 12695020 | US |