1. Field
One feature relates to providing content protection for subscriber-based mobile broadcast services. More specifically, trust is established between an accessory device and host device without placing trust in the device/host owner.
2. Background
Wireless networking systems have become a prevalent means to communicate with others worldwide. Wireless communication devices, such as cellular telephones, personal digital assistants, and the like have become smaller and more powerful in order to meet consumer needs and to improve portability and convenience. Consumers have become dependent upon these devices, demanding reliable service, expanded areas of coverage, additional services (e.g., web browsing capabilities), and continued reduction in size and cost of such devices.
A typical wireless communication network (e.g., employing frequency, time, and/or code division techniques or a combination thereof) includes one or more base stations that provide coverage areas to subscribers as well as mobile (e.g., wireless) devices that can transmit and/or receive data within the coverage areas. A typical base station can simultaneously transmit multiple data streams to multiple devices for broadcast, multicast, and/or unicast services, wherein a data stream is a stream of data that can be of independent reception interest to a user device. A user device within the coverage area of that base station can be interested in receiving one, more than one or all the data streams carried by the composite stream. Likewise, a user device can transmit data to the base station and/or another user device.
Forward link only technology has been developed by an industry group of wireless communication service providers to utilize the latest advances in system design to achieve the highest-quality performance. Forward link only technology is intended for a mobile multimedia environment and is suited for use with mobile user devices. Forward link only technology is designed to achieve high quality reception, both for real-time (streaming) content and other data services. Forward link only technology can provide robust mobile performance and high capacity without compromising power consumption. In addition, the technology reduces the network cost of delivering multimedia content by decreasing the number of base station transmitters that are necessarily deployed. Furthermore, forward link only technology based multimedia multicasting is complimentary to wireless operators' cellular network data and voice services, as cellular network data can be delivered to a same device that receives multimedia content by way of forward link only technology.
Once such forward link only technology is MediaFLO, by Qualcomm. Inc., which broadcasts data to portable access terminals such as cell phones and personal digital assistants (PDA). MediaFLO is a subscriber-based service and requires the device receiving the service to have an embedded forward link only receiver. However, service may now be extended to devices that do not have an embedded forward link only receiver. To utilize the service, a user may purchase a forward link only receiver, hereafter referred to as an “Accessory Device” that can stream content to a non-forward link only device, hereafter referred to as a “Host Device”.
Content providers as well as MediaFLO service operators mandate that such service deployment is robust against the following attacks: (1) Extract unencrypted digital content from the accessory device, the host device, or the communication link between the two; (2) Stream MediaFLO content to host devices that are not in the specified list of ‘approved host types’; (3) Stream MediaFLO content to more than one host device at a time; and (4) Stream MediaFLO content to a host device without the consent of the device owner.
However, in MediaFLO systems, content is encrypted only up to the forward link only protocol stack or accessory device. As a result, the transmission of the content from the forward link only protocol stack to the host device is not secure. Therefore, a method is needed for establishing trust between the accessory device and host device without placing trust in the device/host owner.
The following presents a simplified summary of one or more embodiments in order to provide a basic understanding of some embodiments. This summary is not an extensive overview of all contemplated embodiments, and is intended to neither identify key or critical elements of all embodiments nor delineate the scope of any or all embodiments. Its sole purpose is to present some concepts of one or more embodiments in a simplified form as a prelude to the more detailed description that is presented later.
According to one feature, a method operational in a security server is provided for establishing trust between an accessory device and a host device. The accessory device may be a forward link only receiver while the host device may be a non-forward link only device. The security server may include a key server, a host trust agent provider, which may have an established trust with the host device separate from the accessory device, and an accessory trust agent provider, which may have an established trust with the accessory device separate from the host device. Each of the trusted agents, i.e. the host trust agent provider and the accessory trust agent provider, may be an application executed by the accessory device or the host device. The application may be a flash player that could be an application with information embedded inside the application. The application may use the embedded information to establish the secure connection.
When establishing trust between the accessory device and the host device, the security server may first receive an accessory device identifier and a host device identifier via a first network. Using the accessory device identifier and the host device identifier, the key server may generate a master key. The master key, along with the accessory device identifier may then be sent to the accessory trust agent provider which may then generate an accessory token based on the accessory device identifier and a master key. Once generated, the accessory token may be sent from the accessory trust agent provider to the key server.
After receiving the accessory token, the key server may then send the host device identifier and the master key to the host trust agent provider which may then generate a host token based on the host device identifier and the master key. Once generated, the accessory token may be sent from the host trust agent provider to the key server. When the key server has both the host token and the accessory token, it may send them, via a second network over a forward link only interface, to the accessory device. The host token and the accessory token may then be used by the host device and the accessory device, respectively, to establish a session key which may be used to securely sending content between the accessory device and the host device.
Additionally, the key server may deliver empty tokens, a command to perform a task or tokens with new master keys to revoke or renew the session key between the accessory device and the host device.
According to one feature, an accessory device may establish trust with a host device for securely sending content. The accessory device may include a first communication interface that communicates with a subscriber-based server and a second communication interface that communicates with the host device. A processing circuit may be coupled to the first and second communication interfaces for receiving an accessory token and a host token from a security server via a second network over a forward link only interface. Once the accessory token and the host token are received, the accessory device may decrypt the master key from the accessory token. Upon generation of the master key, any trust previously established with the host device based on an old master key may be revoked. Next, the accessory device may receive a host device identifier from the host device via a first network and then send the host token, previously received from the security server, via the first network, when the accessory device is connecting to the host device for the first time. Using the master key, the accessory device may derive a session key which may be used for securely sending content to the host device as the content is encrypted with the session key.
According to one feature, a host device may establish trust with an accessory device for securely receiving content from the accessory device. The accessory device may be a forward link only receiver. The host device may include a first communication interface that communicates with a subscriber-based server and a second communication interface that communicates with the accessory device. A processing circuit may be coupled to the first and second communication interfaces for delivering a host device identifier to the accessory device. As a result of delivering the host device identifier, the host device may receive a host token from the accessory device if this is the first time that the host device and accessory device have established a connection. The host device may then decrypt a master key from the host token and use the master key to derive a session key which may be used to securely receive content from the accessory device as the content is encrypted with the session key.
According to another feature, a method operational on a host device is provided for establishing trust with an accessory device. When establishing trust with the accessory device, the host device may first send an accessory device identifier and a host device identifier to a security server via a first network to the accessory device. Next, an accessory token and a host token may be sent to the host device from the security server, via a second network, and the host device may then decrypt a master key from the accessory token. Upon decryption of the master key, any trust previously established with the accessory device based on an old master key may be revoked. The host identifier may then be sent to the accessory device and the accessory token that corresponds to the host device identifier may then be sent to the accessory device when connecting to the accessory device for the first time. A session key may be derived by the host device using the master key and the host device identifier. The session key between the accessory device and the host device may be temporary. The session key may be used to decrypt content which the host device receives from the accessory device encrypted with the session key. The content received from the accessory device may be real-time content.
Similarly, a host device is provided for establishing trust with an accessory device. The host device may include a first communication interface for communicating with a subscriber-based service and a second communication interface for communication with the accessory device. A processing circuit coupled to the first and second communication interfaces may cause the host device to send an accessory device identifier and a host device identifier to a security server via a first network; receive an accessory token and a host token from the security server, via a second network, over a forward link only interface, the accessory token and the host token utilized to establish a session key between the accessory device and the host device; decrypt a master key from the accessory token; send the host device identifier to the accessory device; send the accessory token to the accessory device when connecting the accessory device to the host device for the first time; derive a session key from the master key; and receive content from the accessory device encrypted with the session key via the first network.
Similarly, a computer-readable medium comprising instructions executable by a processor for establishing trust between an accessory device and a host device is provided. The instructions include sending an accessory device identifier and a host device identifier to a security server via a first network; receiving an accessory token and a host token from the security server, via a second network, over a forward link only interface, the accessory token and the host token utilized to establish a session key between the accessory device and the host device; decrypting a master key from the accessory token; sending the host device identifier to the accessory device; sending the accessory token to the accessory device when connecting the accessory device to the host device for the first time; deriving a session key from the master key; and receiving content from the accessory device encrypted with the session key via the first network.
According to another feature, a method operational on an accessory device is provided for establishing trust with a host device. The accessory device may be a forward link only receiver. When establishing trust with the host device, the accessory device may first receive a host device identifier from the host device. Next, an accessory token, corresponding to the host device identifier, may be received from the host device when connecting to the host device for the first time. After receiving the accessory token, the accessory device may decrypt the master key from the accessory token and derive a session key from the master key. The session key between the accessory device and the host device may be temporary. Content encrypted with the session key may then be transmitted to the host device. The transmitted content may be real-time content.
Similarly, an accessory device is provided for establishing trust with a host device. The accessory device includes a first communication interface for communicating with a subscriber-based service and a second communication interface for communicating with the host device. A processing circuit coupled to the first and second communication interfaces may cause the accessory device to receive a host device identifier from the host device; receive an accessory token, corresponding to the host device identifier, from the host device when connecting the accessory device to the host device for the first time; decrypt a master key from the accessory token; derive a session key from the master key; and transmit content to the host device encrypted with the session key.
Similarly, a computer-readable medium comprising instructions executable by a processor for establishing trust between an accessory device and a host device is provided. The instructions include receiving a host device identifier from the host device; receiving an accessory token, corresponding to the host device identifier, from the host device when connecting the accessory device to the host device for the first time; decrypting a master key from the accessory token; deriving a session key from the master key; and transmitting content to the host device encrypted with the session key.
According to yet another feature, an accessory device is provided for establishing trust with a host device. The accessory device may include a first communication interface that communicates with a subscriber-based server and a second communication interface that communicates with the host device. A processing circuit may be coupled to the first and second communication interfaces for installing a public key of a certificate authority in a trust agent of the accessory device and receiving a certificate revocation list via a forward link only interface. The certificate revocation list may be received through software updates installed on the accessory device through direct connection of the accessory device to a personal computer or through a network line with the host device. Next, a trust establishment phase on the accessory device may be initiated by an end user and a signed host device certificate may be received from the host device. The accessory device may then validate the host device certificate and generate the master key from the signed certificate. Next, the accessory device may send the master key, encrypted with the public key of the host device, to the host device. The accessory device may then derive a session key from the master key and then send content, encrypted with the session key, to the host device.
According to yet another feature, a host device is provided for establishing trust with an accessory device. The host device may include a first communication interface that communicates with a subscriber-based server and a second communication interface that communicates with the accessory device. A processing circuit may be coupled to the first and second communication interfaces for installing a private key and a signed certificate on a trust agent of the host device. The signed certificate may be, for example, a certificate based on a host device public key and a host device type which may be signed by a Certificate Authority. Once provisioned with the private key and signed certificate, the trust establishment phase on the host device may be initiated by the end user and the signed certificate may be sent to the accessory device. The host device may then receive the master key encrypted with the public key of the host device from the accessory device and then decrypt the master key. Next, any trust established using a previous master key may be revoked. The host device may then derive a session key from the master key so that it may receive content encrypted with the session key from the accessory device.
The features, nature, and advantages of the present features may become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout.
In the following description, specific details are given to provide a thorough understanding of the embodiments. However, it will be understood by one of ordinary skill in the art that the embodiments may be practiced without these specific details. For example, circuits may be shown in block diagrams, or not be shown at all, in order not to obscure the embodiments in unnecessary detail. In other instances, well-known circuits, structures and techniques may not be shown in detail in order not to obscure the embodiments.
In the following description, certain terminology is used to describe certain features. The term “accessory device”, includes, but is not limited to, a forward link only receiver. The term “host device”, includes, but it not limited, to a non-forward link only device.
Identified below are a list of acronyms and definitions used through this application.
A security system may be applied to content transmissions over a broadcast/multicast network infrastructure. The broadcast network infrastructure may be Evolution-Data Only Broadcast Multicast Services (BCMCS) that facilitates distribution of a subscription-based content delivery service. Upon subscribing to the content delivery service, the subscriber host device may be given the service key. A broadcast access key may be generated by the broadcast network infrastructure and used to encrypt content to be broadcasted. Consequently, only host devices that have received the service key (e.g., subscribe to the associated subscription package) can decrypt the broadcasted content.
One example of a subscriber-based forward link only service is MediaFLO, by Qualcomm Inc., which broadcasts data to portable access terminals (or host devices) such as cell phones and PDAs. Broadcast data may include multiple real-time audio and/or video streams, individual, non-realtime video and/or audio “clips”, as well as internet protocol (IP) datacast application data such as stock market quotes, sports scores, and weather reports. The “F-L-O” in MediaFLO stands for forward link only, meaning that the data transmission path is one-way, from the tower/server to the host device. MediaFLO addresses the inherent spectral inefficiency of unicasting high-rate full-motion video/audio to multiple subscribers (access terminals) but instead broadcasting such content. To limit access to the broadcasted content to subscribers, the content may be secured or encrypted by a key known only to subscriber host devices. MediaFLO content delivery may be implemented, for example, over an Evolution-Data Optimized or Evolution-Data only (EVDO) network that authenticates subscriber host devices and distributes the keys used to decode the programming.
In the present system three methods are provided for establishing trust between an accessory device and a host device. In each of these methods, one or more assumptions can be made. These assumptions include: (1) every host device and accessory device may be pre-provisioned with a trusted module, hereafter referred to as “trust agent”. The trusted agent may not be easily copied, modified or reverse engineered and may protect secret data against unauthorized disclosure. (2) Each trust agent may have pre-established trust (e.g. a shared cryptographic key) with a network side component, hereafter referred to as “Trust Agent Provider”. In other words, there may be a mechanism in place for the Trust Agent Provider to securely encapsulate (e.g. encrypt, sign) information for delivery to a trust agent. The accessory device and host device may have different Trust Agent Providers. Moreover, Trust Agent Providers may not be the same among all accessory devices or all host devices. (3) There may be a mechanism in place for the trust agent on the host device to authenticate to the accessory device and attest to the host device type.
Table 1 below depicts which assumptions may apply to each of the methods described in detail below.
In one aspect, a key may be placed inside the application at the factory, i.e. the key may be inside the application, inside the trusted agent, the host device for example. In another aspect, the key may be embedded inside the application and the owner may download the application from a website. As the infrastructure, i.e. the host trust agent provider, knows the key, the key may be known to both the accessory device and the host device.
A master key may be generated and each trust agent provider may create a token (secure envelope containing the master key) for delivery to the corresponding trust agent. Both tokens may be delivered to the accessory device over a forward link only interface. Upon first connection, the accessory device may deliver the token generated by the host trust agent provider to the host device. Both devices may use the master key to derive a session key that may then be used for encrypting the streamed content.
First, the owner (or end user) of the accessory device may log onto his/her MediaFLO web account and register an accessory device and host device by sending the identifier (ID) of the host device (ID.Host) and the ID of the accessory device (ID.ACC) to the key server located in the security server 214. The identifiers may be serial numbers of the accessory device and the host device or may be any other identifying number that uniquely identifies the accessory device and the host device.
In other words, to register the accessory device and the host device, the owner (or end user) may navigate to a registration website after identifying the unique identifying numbers of the accessory device and the host device. The unique identifying numbers may be entered on the website (or security server). Upon receiving the identifiers, the key server may generate a master key 216. The key server may then send, or deliver, the accessory device ID (ID.ACC) received from the end user, along with the master key (MasterKey), to the accessory trust agent provider in the security server 218. Using the master key and the accessory device ID, the accessory trust agent provider may generate an accessory token ([MasterKey]ID.ACC) 219 and send the accessory token ([MasterKey]ID.ACC) to the key server 220.
Once the key server receives the accessory token ([MasterKey]ID.ACC), it may then deliver the host device ID (ID.Host), along with the master key (MasterKey), to the host trust agent provider in the security server 222. Using the host device ID and the master key, the host trust agent provider may generate a host token ([MasterKey]ID.Host) 223 and then send the host token ([MasterKey]ID.Host) to the key server 224. After the key server has received the accessory token (MasterKeyID.ACC) and the host token ([MasterKey]ID.Host), both tokens may be delivered to the accessory device over the forward link only interface 226. In other words, once the infrastructure (or security server) has the tokens, it may then forward them through the forward link only link to the accessory device as a pair of keys. The pair of keys may include one key encrypted in two different ways. One of the keys may be for the accessory device and the other key may be for the host device.
The accessory device may then decrypt one of the two keys as it is encrypted with the accessory device identifier. The other key may be encrypted with the host device identifier and cannot be decrypted by the accessory device so the accessory device may forward the other key to the host device which can then decrypt it. In other words, the accessory device may extract the master key from the accessory token 228. Once the master key has been decrypted, the trust established with a previous master key may be revoked 229. The end user may then initiate the connection of the host device to the accessory device (i.e. a secure session) as the host device and accessory device both have the master key 230.
Once a secure connection between the accessory device and the host device is initiated, the host device may deliver its identifier (ID.Host) to the accessory device 232. If this is the first time the host device connects to the accessory device 234, the accessory device may return the host token ([MasterKey]ID.Host), corresponding to the received host device ID, to the host device 236. The host device may then decrypt the master key from the host token ([MasterKey]ID.Host) 238. The accessory and host devices may then derive a session key based on the master key 240 so that content may then be delivered to the host device, from the accessory device, encrypted with the session key 242. In one aspect, the content is real-time content.
In other words, there may be a secure link between the accessory device and the host device so when the accessory device receives the encrypted content via the forward link only network, the accessory device may decrypt the content at the forward link only stack and then re-encrypt it or re-secure it using the master key or some other derived key based on the master key (or the session key) and may then send it to the host device which can decrypt it play it back.
In one aspect, the trust established between the accessory device and host device may be made temporary by including an expiration time. As discussed above, the key server can revoke or renew previously established trust between the accessory device and the host device. Revocation may occur by delivering empty tokens, a token which includes a command to perform a task, or tokens with new master keys. The task may include a revocation of the master key.
For example, the master key may be revoked as the host device may be compromised as the same host device is being received in multiple requests for registration. To revoke the master key so that the accessory device is aware of the revocation, a message may be sent to the accessory device indicating that the master key is to be revoked. For example, the accessory device may have a direct link to the forward link only network. Alternatively, a mechanism may be included in the accessory device so that the host device renews the master key at specific intervals, such as every month or every week. The host device may request the infrastructure to provide a new key, however, if the host device is compromised, the infrastructure may refuse to give the host device a new key.
In yet another aspect, the host token may be delivered to the host device along with the MediaFLO application (user interface, player, etc.) that may allow the host device to connect to the accessory device and render the service to the user.
First, the owner (or end user) of the accessory device may initiate registration of the accessory device by sending an accessory device identifier to the host device 914. The host device may then send its host device identifier, as well as the accessory device identifier it received from the end user, to the security server for registering the accessory device 916. Upon receipt of the host device and accessory device identifiers, the key server may generate a master key using the identifiers 918. The key server may then deliver the accessory device ID, along with the master key, to the accessory trust agent provider 920. The accessory trust agent provider may then generate an accessory token using the accessory device ID and the master key 921 and send the accessory token to the key server 922. The key server may then send, or deliver, the host device ID along with the master key to the host trust agent provider 924. The host trust agent provider may then generate a host token using the host device ID and the master key 925 and send the host token to the key server 926.
Both accessory and host tokens may be delivered to the host device by the key server over a forward link only interface 928. The host device may then decrypt, or extract, the master key from the accessory token 930. Once the master key has been decrypted, the trust established with a previous master key may be revoked 931. The end user may then initiate the connection of the host device to the accessory device (i.e. a secure session) 932. The host device may then deliver its identifier (ID. HOST) to the accessory device 934. If this is the first time the host device is connecting to the accessory device 936, the host device may send the accessory token that corresponds to the host device ID to the accessory device 938. The accessory device may then decrypt, or extract, the master key from the accessory token 940. The host device and accessory device may then derive a session key from the master key 942 so that content may then be delivered from the accessory device to the host device encrypted with the session key 944.
Note that, (1) The trust established between the accessory device and host device can be made temporary by including an expiration time; (2) The key server can revoke or renew previously established trust between the accessory device and host device by delivering empty tokens, a token which includes a command to perform a task, or tokens with new master keys (the task may include a revocation of the master key); and (3) The host token may be delivered to the host device along with the MediaFLO application (user interface, player, etc.) that allows the host device to connect to the accessory device and render the service to the end user.
The accessory token that corresponds to the host device identifier may then be sent to the accessory device when connecting to the accessory device for the first time 1112. Using the master key and the host device identifier, a session key may be derived 1114. The session key may be used to decrypt content which the host device receives from the accessory device that has been encrypted with the session key 116. In one aspect, the content may be real-time content.
Furthermore, in this example, the accessory device owner may initiate the trust establishment between the host device and accessory device via some method, e.g. by pressing a button on each device, or by connecting the two devices via a universal serial bus (USB) cable. By the accessory device owner (or end user) initiating the trust establishment, an adversary connecting his/her host device to an accessory device without the consent of the accessory device owner may be prevented.
As showing in
In this method, the end user may initiate the trust establishment phase on the accessory device 1308 and host device 1310. For example, the end user may initiate the trust establishment phase by selecting a button on the host device, such as an iPhone, indicating the desire to start a secure communication. Next, the host device may send its signed certificate (cert{publickey.host, type.Host}) to the accessory device 1312. The certificate may include the public key of the host device and the type of the host device. In one aspect, the signed public key may be embedded inside an application which is downloaded inside the host device.
The accessory device may then validate the certificate using the public key of the certificate authority, confirm that the type of the host device is on an approved list of host devices (i.e. verify that the host device is a legitimate host device by checking the certificate authority) and generate the master key 1314. Next, the accessory device may deliver the master key to the host device encrypted with the public key of the host device 1316. The host device may then decrypt the master key 1318. Once the master key has been decrypted, trust established with a previous master key may be revoked 1319.
As both the host device and the accessory device may have the master key, the end user may initiate a secure connection of the host device to the accessory device 1320 and the host device and accessory device may each then derive a session key based on the master key 1322. Once the session key has been derived, content may then be delivered to the host device encrypted with the session key 1324. In one aspect, the content may be real-time content.
A connection between the host device and the accessory device may then be initiated with the host device by the end user 1414 and the host device may then derive a session key from the master key 1416. Content may be received from the accessory device and decrypted with the session key 1418. In one aspect, the content may be Real-time content.
One or more of the components, steps, and/or functions illustrated in
Those of skill in the art would further appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the embodiments disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system.
The description of the embodiments is intended to be illustrative, and not to limit the scope of the claims. As such, the present teachings can be readily applied to other types of apparatuses and many alternatives, modifications, and variations will be apparent to those skilled in the art.
The present application for patent claims priority to U.S. Provisional Application No. 61/121,536 entitled “Trust Establishment From Forward Link Only (FLO) To Non-FLO Devices”, filed Dec. 10, 2008, assigned to the assignee hereof and hereby expressly incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
61121536 | Dec 2008 | US |