Data loader using location identity to provide secure communication of data to recipient devices

Information

  • Patent Application
  • 20040078594
  • Publication Number
    20040078594
  • Date Filed
    October 22, 2002
    22 years ago
  • Date Published
    April 22, 2004
    20 years ago
Abstract
A data loader device is used to convey digital data in a secure manner to another device. The data loader may be fixed (referred to as a Class_A loader) or portable (referred to as a Class_B loader). The data loader encrypts the digital data using a location-identity that permits the digital data to be transferred only if the data loader is disposed at an appropriate location. The fixed data loader remains in a stationary location, and a device to be loaded is brought to the data loader for loading. The portable data loader can be loaded by the fixed data loader, and then transported to another location to load a recipient device. The digital data that is conveyed is unrestricted in nature, and can include keys, navigational information, watermarking parameters, or any other digital content requiring secure delivery. In an embodiment, the data loader device includes a “no-move” system that precludes compromise of data contained therein if the data loader device is moved. Upon detection of movement above a predefined threshold level, the “no-move” system produces an alarm condition that inhibits operation of the device.
Description


BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention


[0002] The present invention is directed to controlling access to digital data, and more particularly, to a system for providing secure communication of information to recipient devices in a manner such that the information can only be communicated or accessed at specified locations.


[0003] 2. Description of Related Art


[0004] Rapid advances in computer, telecommunications and networking technology have enabled new opportunities and applications that were impossible just a few years ago. These advances are exemplified by the rapid growth of network systems seeking to deliver “high-value” content securely to authorized recipients. Examples of such networks include those that handle confidential, sensitive, or classified information in the health care, financial, and national security fields. They also include networks that handle intellectual property or copyrighted data such as computer software, literary works, and entertainment products. A fundamental aspect of these networks is the sharing of information between users, nodes and components of the network. But, whenever information is shared there is also the risk that the information will be obtained by unauthorized persons. Controlling the security of the information in such systems, including confidentiality, authenticity, integrity, authorized use, transaction secrecy, site protection, etc., has therefore proven to be a critical aspect of such networks.


[0005] One technology that is commonly used to protect information on these networks is cryptography. Cryptography is the use of codes and ciphers to protect data from unintended disclosure or modification. It is primarily used to control access to communications transmitted over open networks, but may also be used to control access to stored data. In a transmission utilizing cryptography to protect digital data, the sender converts the original data, or “plaintext,” into a coded equivalent called “ciphertext” using an encryption algorithm. The ciphertext is then decoded (or decrypted) by the receiver and thereby turned back into plaintext. The encryption algorithm uses a key, which in digital systems is a string of bits. In general, the larger the number of bits in the key, the longer it takes to break the code using so-called “brute force” methods.


[0006] A drawback of conventional cryptographic systems is the inherent risk in distributing keys to recipients of encrypted information. If an unauthorized user intercepts the keys, then that unauthorized user could gain access to the encrypted information. Within military systems, a portable hardware device known as a loader or fill device is often used to transfer confidential information, such as encryption/decryption keys and other mission critical information. The loader/fill device typically includes an electronic memory in which the confidential information may be stored. The loader can be electrically or optically connected directly to a recipient device, such as a satellite receiver, in order to load the confidential information directly into the recipient device. The use of a direct electrical or optical connection between the loader and the recipient device, such as via a cable or shielded connector, precludes radio frequency (RF) broadcasts that can be intercepted. The security of the communication network therefore depends on the physical control over the loader. If the loader were to be misplaced or misappropriated, then the security of the entire communication network could be compromised.


[0007] Co-pending patent application Ser. No. 09/992,378, filed Nov. 16, 2001, for SYSTEM AND METHOD FOR DELIVERING ENCRYPTED INFORMATION IN A COMMUNICATION NETWORK USING LOCATION IDENTITY AND KEY TABLES, discloses a system for controlling access to data based not only on a secret key, but also on location. For example, in the context of digital cinema, such a system would enable a producer of digital movies to be assured that its products could only be decrypted in certain theaters whose locations are known in advance. Or, a provider of entertainment products such as movies and subscription television would be assured that its products could only be decrypted within the premises of its customers or within a particular geographic region. This capability would guard against many threats, including the unauthorized distribution of copyright-protected works over the Internet or through other means. Even if the keys were compromised, recipients would not be at the proper location to enable decryption.


[0008] Accordingly, it would be desirable to provide a system for providing secure communication of information to recipient devices in a manner such that the information can only be communicated or accessed at specified locations. It would also be desirable to provide a system to protect a device containing critical information, such as encryption/decryption keys, and that would render the critical information unusable to unauthorized persons if the device were misappropriated.



SUMMARY OF THE INVENTION

[0009] The present invention overcomes these and other drawbacks of the prior art by providing a data loader device used to convey digital data in a secure manner to another device. The data loader may be fixed (referred to as a Class_A loader) or portable (referred to as a Class_B loader). The Class_A loader remains in a stationary location, and a device to be loaded is brought to it for loading. The Class_B loader can be loaded by the Class_A loader, and then transported to another location to load a recipient device. The data loader encrypts the digital data using a location-identity that permits the digital data to be transferred only if the data loader is disposed at an appropriate location. The digital data that is conveyed is unrestricted in nature, and can include keys, navigational information, watermarking parameters, or any other digital content requiring secure delivery.


[0010] In an embodiment of the invention, a Class_A data loader comprises a service profile containing customer location information and original data to be distributed to at least one customer, and a fill data generator adapted to generate fill data based on the original data and transfer the fill data to a recipient device. Exemplary recipient devices may include set-top-boxes used for decoding cable television content, military vehicles needing keys and mission profile data to perform their missions, secure computing facilities using location-based cipher functions to access and communicate secure content, and the like. The service profile determines what information is to be conveyed to a customer. For example, if the recipient device is a cable set-top-box, the service profile may contain information identifying which television programming options the customer has ordered. The Class_A loader would then generate fill data containing keys necessary for the customer to access the ordered television channels.


[0011] The customer location information is used to generate the fill data such that the original data can only be recovered from the fill data if the recipient device is located at the location of the customer. The data loader apparatus may further have the ability to identify a current location of the apparatus, such as using a GPS receiver or assisted-GPS system, with the fill data generator being unable to unlock the fill data if the identified current location is not consistent with a predetermined location for the apparatus.


[0012] The Class_A data loader may also include a “no-move” system including a motion detector adapted to detect movement of the apparatus. Detected movement above a predefined threshold level produces an alarm condition that may cause the original data to be destroyed in order to prevent misappropriation of the original data. A timer included with the data loader apparatus would permit a period of time for transport of the apparatus without producing the alarm condition. During this time period, the Class_A loader would be inhibited from generating fill data.


[0013] In another embodiment of the invention, a Class_B data loader comprises a data memory adapted to store locked fill data received from a Class_A loader, a location identifier adapted to identify a current location for the Class_B loader, and a fill data converter adapted to recover fill data from the locked fill data and transfer the fill data to a customer recipient device. As with the first embodiment, the fill data can be recovered (i.e., unlocked) only if the current location is consistent with a predetermined customer location. The location identifier further comprises a GPS satellite navigation signal receiver. Additionally, the location identifier may further include a location memory adapted to store a last known current location and time for a predetermined period of time upon detecting a GPS satellite navigation signal outage condition. The Class_B loader would generally be loaded with fill data by a Class_A loader, and then transported to a customer location to load the fill data into a recipient device.


[0014] In yet another embodiment of the invention, a communication network includes a data originator device having digital data to be distributed, a first data loading device (e.g., a Class_A loader) disposed at a first predetermined location, and a recipient device. The data originator device adds a first level of encryption to the digital data that can only be removed at the first predetermined location. The first data-loading device is adapted to receive the digital data having the first level of encryption. The first data-loading device removes the first level of encryption from the digital data and adds a second level of encryption to the digital data. The recipient device is adapted to receive the digital data having the second level of encryption, and can remove the second level of encryption only when it is disposed at the second predetermined location.


[0015] The first data-loading device may additionally add a third level of encryption to the digital data. A second data-loading device (e.g., a Class_B loader) is adapted to receive from the first data-loading device the digital data having the second and third levels of encryption. The second data-loading device removes the third level of encryption from the digital data only when it is disposed at the third predetermined location. The second data-loading device thereafter provides to the recipient device the digital data with only the second level of encryption remaining. The second data-loading device is intended to be a portable device.


[0016] In still another embodiment of the invention, a data-handling apparatus includes a “no-move” system that precludes compromise of data contained therein if the data-handling apparatus is moved. The data-handling apparatus may include a cipher device used to perform cipher functions on digital data in accordance with a location identity such that the cipher functions are only performed if a current physical location of the apparatus corresponds to predetermined location parameters. The “no-move” system can identify the current physical location of the apparatus, such as using a GPS receiver or assisted-GPS system. Alternatively, the data-handling device may be loaded with location information, such as by a Class_A loader. A motion detector is adapted to detect movement of the apparatus after the “no-move” system is activated, such as during conditions in which the current physical location cannot be identified, e.g., during an outage of GPS satellite navigation signals. A last known physical location of the apparatus may be utilized during such conditions. Upon detection of movement above a predefined threshold level, the motion detector produces an alarm condition that inhibits operation of the cipher device. The alarm condition may further cause the cipher device to destroy the digital data. The “no-move” system may further include a timer coupled to the motion detector to define a period of time for transport of the apparatus without producing the alarm condition.


[0017] A more complete understanding of the assisted GPS signal detection and processing system for indoor location determination will be afforded to those skilled in the art, as well as a realization of additional advantages and objects thereof, by a consideration of the following detailed description of the preferred embodiment. Reference will be made to the appended sheets of drawings, which will first be described briefly.







BRIEF DESCRIPTION OF THE DRAWINGS

[0018]
FIG. 1 is a block diagram of an exemplary network using loader devices to control the delivery of information to recipient devices;


[0019]
FIG. 2 is a block diagram of a Class_A loader in accordance with an embodiment of the invention;


[0020]
FIG. 3 is a block diagram of a Class_B loader in accordance with an embodiment of the invention;


[0021]
FIG. 4 is a block diagram of a “no-move” system for use with the Class_A loader of FIG. 2;


[0022]
FIG. 5 is a flowchart illustrating an exemplary method for geo-encrypting digital data using a location identity attribute;


[0023]
FIG. 6 is a flowchart illustrating an exemplary method for accessing geo-encrypted digital data using the location identity attribute; and


[0024]
FIG. 7 is a block diagram illustrating communication of information to a recipient device through Class_A and Class_B loaders.







DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

[0025] The invention satisfies the need for a system for providing secure communication of information to recipient devices in a manner such that the information can only be communicated or accessed at specified locations. The invention also provides a system to protect a device containing critical information, such as encryption/decryption keys, by rendering the critical information unusable to unauthorized persons if the device were misappropriated. In the description that follows, like element numerals are used to describe like elements illustrated in one or more of the figures.


[0026] Referring first to FIG. 1, a general block diagram illustrates an exemplary communication network using loader devices to manage the delivery of information to recipient devices. The network includes central location 12 and a plurality of customer locations 32, 36, 42. The central location 12 contains a data source 14, and it is desired to distribute data from the data source 14 to recipient devices 34, 38, 26 disposed at the respective customer locations 32, 36, 42. The actual data to be distributed can be of any type or for any purpose, such as cryptography keys, address information, operational parameters, and the like, except that it is desired to permit access to the data only at the customer locations 32, 36, 42. The central location 12 further includes a Class_A loader 16 that is connected to the data source 14. The Class_A loader 16 is intended to remain in a fixed location, such as a service depot or retail outlet, as will be better understood from the description that follows.


[0027] The Class_A loader 16 is used to transfer data from the data source 14 to the recipient devices 34, 36, 26, either directly or through a Class_B loader 22, 24. The Class_A loader 16 would only be able to transfer the data if the Class_A loader 16 is located in the appropriate place. To ascertain whether the Class_A loader 16 is in the appropriate place, the Class_A loader 16 may include a receiver for accessing satellite navigation signals, such as Global Positioning System or GPS. If the Class_A loader 16 is located in a place in which satellite navigation signals are attenuated, such as within a building, the Class_A loader 16 may include an assisted GPS (A-GPS) system that enables end users to obtain indoor location information using data that aids in receiving the attenuated satellite navigation signals. An exemplary A-GPS system is disclosed in co-pending patent application Ser. No. 10/193,586, filed Jul. 10, 2002, for ASSISTED GPS SIGNAL DETECTION AND PROCESSING SYSTEM FOR INDOOR LOCATION DETERMINATION, which is incorporated by reference herein. The Class_A loader 16 may itself be loaded with location information by another device, such as a Class_B loader (described below). The Class_A loader 16 may further include a system that detects movement of the Class_A loader 16 from its fixed position. Any movement of the Class_A loader 16 that is detected may then cause the Class_A loader to disable operation and/or destroy any data that it is holding so as to prevent compromise of the data by misappropriation of the Class_A loader.


[0028] With the Class_A loader 16 located in the proper position, the Class_A loader can transfer the stored data to a Class_B loader 22, 24. The Class_B loader 22, 24 is intended to be a transportable device that can be physically taken to a customer location. For example, a customer service agent may transport the Class_B loader 22 to customer locations in order to transfer data to each customer's respective recipient device. As shown in FIG. 1, the Class_B loader 22 is transported to the first customer location 32, whereupon the Class_B loader 22 loads the data into the associated recipient device 34. Likewise, the Class_B loader 24 is transported to the second customer location 36, whereupon the Class_B loader 24 loads the data into the associated recipient device 38. Significantly, the Class_B loader 22, 24 would only be able to transfer the data to the respective recipient device 34, 38 when the Class_B loader is located in the appropriate place, i.e., the respective customer location 32, 36. Since the Class_A loader 16 knows in advance the customer locations 32, 36, the original data load to the respective Class_B loader 22, 24 is transformed such that it can only be recovered by the recipient device located in the appropriate customer location. This way, the Class_B loader 22, 24 could not be used to transfer data to a recipient device at an unauthorized location. It should also be appreciated that each Class_B loader 22, 24 could be adapted to store and load data for plural customer locations.


[0029] The Class_A loader 16 could also transfer the stored data directly into a recipient device 26 that is physically transported to the central location 12, thereby avoiding the need for an intermediary Class_B loader. The recipient device 26 could then be transported to the appropriate customer location 42 for use. For example, a customer may go directly to the central location 12 to pick up a recipient device 26 that is loaded specifically for the customer's location. As with the Class_B loader 22, 24, the recipient device 26 would only be able to access the data when it is located in the appropriate place, i.e., the customer location 42. So, the recipient device 26 would not work if it were taken to a location other than the customer location 42.


[0030] In a preferred-embodiment of the invention, access to the data is controlled by encrypting the data in such a manner that it can be decrypted only at a specified location and with a secret key. Data encrypted in such a manner is said to be geo-encrypted. This geo-encryption process comprises a method in which plaintext data is first encrypted using a random data-encrypting key that is generated at the time of encryption. The data-encrypting key is then encrypted (or locked) using a location value and a key-encrypting key. The encrypted data-encrypting key is then transmitted to the receiver along with the ciphertext data. The receiver both must be at the correct location and must have a copy of a corresponding key decrypting key in order to derive the location key and decrypt the data-encrypting key. After the data-encrypting key is decrypted (or unlocked), it is used to decrypt the ciphertext. If an attempt is made to decrypt the data-encrypting key at an incorrect location or using an incorrect key decryption key, the decryption will fail. In addition, the encrypted data encrypting key or ciphertext optionally may be rendered unusable so that it becomes impossible to ever decrypt that particular ciphertext. An exemplary geo-encryption method and apparatus is disclosed in co-pending patent application Ser. No. 09/992,378, filed Nov. 16, 2001, for SYSTEM AND METHOD FOR DELIVERING ENCRYPTED INFORMATION IN A COMMUNICATION NETWORK USING LOCATION IDENTITY AND KEY TABLES, which is incorporated by reference herein.


[0031]
FIG. 5 illustrates a general method for associating digital data with a location identity attribute 511 that precisely defines the region in which access of the digital data is permitted. The method starts at step 500 with a command to geo-encrypt digital data using a location identity attribute. A first part of the method provides for the generation of the location identity attribute. The location identity attribute comprises two items of information: (a) a location value, and (b) a proximity value. The location value corresponds to the unique geographic position of a particular place, such as corresponding to the location of the customer. The proximity value corresponds to the extent of a zone or area that encompasses the location. The location identity attribute may comprise a point location or an exact location if the proximity value is set to zero, null, empty, etc., or some other value indicating that the area referred to by the location identity attribute is a unique point location. At step 502, a customer location 501 for the digital data is retrieved from memory and held for later use. Proximity 503 of the location identity attribute 511 is determined at step 504, and the customer location 501 and proximity 503 are used to generate the location identity attribute 511 at step 506.


[0032] Any geographic region or area that contains the customer location can serve as the proximity for the location identity attribute. The proximity may comprise a rectangular region defined by two adjacent longitude lines (providing horizontal edges) and two adjacent latitude lines (providing vertical edges). Alternatively, the proximity may comprise a circular region represented by a single number defining the radius around the location. The circular region can be further defined as an elliptical area either centered at the location, or a circular or elliptical area that contains the location but not necessarily as the centroid. In another alternative, the proximity may comprise an irregular closed polygon, or a corridor.


[0033] A second part of the method provides for the generation of encryption keys and the encryption of the plaintext digital information. At step 508, a key ID 505 is used to select and retrieve a key encrypting key 530 from a key table that allows for the storage of a plurality of keys. The location identity 511 is then used at step 510 to derive a location value 507 and a shape parameter 509. The shape parameter 509 defines a shape of an area of interest without identifying the specific location corresponding to the area of interest. The shape parameter 509 is a locationless translation of the proximity portion of the location identity attribute 511. Locationless refers to the characteristic of the shape parameter 509 as defining the shape of a proximate area without reference to any actual location.


[0034] Then, at step 514, the process generates a random data encrypting key 524. This data encrypting key 524 is used to encrypt the plaintext digital information 518 at step 516 to produce geo-encrypted digital information 520. The data encrypting key 524 is then encrypted at step 522 using the location value 507 and the key-encrypting key 530. The geo-encrypted digital information 520, the encrypted data encrypting key 526 (also referred to below as a cipher key), the shape parameter 509, and the key ID 505 are then communicated to a receiving device (e.g., the Class_A loader, Class_B loader or recipient device). Attempts to decrypt the geo-encrypted information 520 by the receiving device will be denied unless the location of the receiver device 400 matches the location specified by the location identity attribute 511 and the receiving device has the correct key decrypting key identified by the key ID 505.


[0035]
FIG. 6 shows a general method for enforcing access to geo-encrypted digital information by location. The method starts at step 600 with a command to decrypt the geo-encrypted digital information 520. A first part of the method provides for the generation of the location value 507. At step 602, the method determines the location of the receiver device, such as using satellite navigation signals. The device location information 604 is then used in conjunction with the shape parameter 509 received from the provider of the geo-encrypted digital information to generate the location value 507 at step 606. As will be appreciated, the location value 507 generated by the receiving device must match the location value 507 used by the providing device to geo-encrypt the digital information, otherwise the receiving device will be unable to geo-decrypt the encrypted digital information 520.


[0036] In a second part of the method, the location value 507 is used with a key decrypting key 610 to geo-decrypt the encrypted digital information. The key-decrypting key 610 is retrieved from the key table of the receiving device at step 608 in accordance with the key ID 505 received from the providing device. It should be appreciated that the key-decrypting key 610 retrieved at step 608 must correspond to the key encrypting key 530 used in geo-encrypting the digital information; otherwise, the geo-decryption will fail. At step 612, the selected key decrypting key 610 and the generated location value 507 are used to decrypt the data encrypting key 526. If the location of the receiving device is consistent with the location value 507 used by the providing device, the decryption will recover the original data encrypting key 524. Lastly, the data encrypting key 524 is used to decrypt the geo-encrypted digital information 520 to recover the plaintext digital information 518 at step 614.


[0037] Returning now to FIG. 2, a functional-block diagram of a Class_A loader 120 is shown in accordance with an embodiment of the invention. A central element of the Class_A loader 120 is a fill data generator 126 that produces fill data to be transferred to a device to be loaded 130, e.g., a Class_B loader or recipient device. In a preferred embodiment of the invention, the fill data generator 126 geo-encrypts digital data in accordance with the method described above with respect to FIG. 5. The fill data generator 126 receives a plurality of inputs in order to produce the fill data. A service profile 122 comprises a database containing information regarding the customers (e.g., name, address, service type, etc.) as well as the auxiliary data and key IDs to be transferred. For example, the Class_A loader 12 may be used to load television set top boxes with keys used to decrypt television signals transmitted over a cable system or other media, with each key corresponding to a particular channel or network (e.g., HBO®, TNT®, TBS®, CARTOON NETWORK®, CNN®, CINEMAX®, etc.). A customer may order a suite of services including certain channels, and the Class_A loader 120 may be used to load the customer's set top box with the appropriate keys to receive these channels. The fill data generator 126 would receive the auxiliary data and key IDs from the service profile 122.


[0038] The service profile 122 would also provide the customer address information to a geodetic information system 128 that would convert the address information into a geographic location in accordance with appropriate coordinates, e.g., latitude, longitude, and altitude. The geodetic information system 128 may comprise a layered map or database used to perform the address translation. The geographic location information is provided to the fill data generator 126, where it becomes part of the location identity used to encrypt the auxiliary data and other information that is to be transferred to the device 130. The device 130 may further have a unique device serial number that is provided back to the service profile 122. This way, the service profile 122 can maintain a record of which device received the encrypted data for a particular customer. The device serial number may further be included with the auxiliary data to be encrypted, thereby providing a further verification that the appropriate device received the data.


[0039] In an embodiment of the invention, the geodetic information system 128 may also provide cable plant delay information (bCABLE) corresponding to the signal delay between the headend and customer location of a cable plant used to deliver cable television signals or other electronic media. The recipient device could then use the cable plant delay information to aid in calculating precise location information using an assisted-GPS system (as described in co-pending patent application Ser. No. 10/193,586, identified above). Note that bCABLE will be different for different user equipment because the path from the headend is not identical. When the cable plant is used to deliver satellite navigation signals received at the headend to the customer, a position solution based on those signals will have an internal time bias that is wrong by bCABLE seconds. If bCABLE is known, it can provide the customer with the basis for a precise time hack. For fixed connection end users, it should be appreciated that bCABLE should be relatively fixed in value, so that once known bCABLE can be stored in memory for future use.


[0040] Additionally, since bCABLE is different for every customer, the cable plant delay can serve as a unique location signature for the customer. The cable delay bCABLE can be initially measured using a two-way cable modem. Several known cable modem standards (e.g., DOCSIS 1.0) incorporate provisions for measuring cable plant delay in order to facilitate efficient upstream TDMA messaging on a shared frequency channel. The initial measured value for the cable plant delay bCABLE could be included in the location identity that is used to encrypt data communicated to the customer. The customer would then measure bCABLE as part of each communication operation. If the measured bCABLE value is outside of a specified range, the customer would be unable to decrypt the data.


[0041] The fill data generator 126 also receives a geographic location in appropriate coordinates for the Class_A loader 120 from device location block 124. The fill data generator 126 uses this geographic location information to ensure that the Class_A loader 120 is in the proper location, i.e., it has not moved. As described above, the Class_A loader 120 will only be able to transfer fill data to the device 130 if the Class_A loader is located in the appropriate place. The device location block 124 may include a GPS receiver that receives satellite navigation signals and derives location information therefrom. But, since it is anticipated that the Class_A loader 120 be located indoors where GPS signals may be attenuated, the device location block 124 of the Class_A loader may include other systems for verifying location, such as an assisted-GPS system and/or a “no move” system, which will each be described further below.


[0042] In an embodiment of the present invention, the device location block 124 includes an assisted-GPS system as described in co-pending patent application Ser. No. 10/193,586, identified above. The Class_A loader 120 may be connected via a cable plant or other transmission media to a GPS receiver (not shown) in another location having unobstructed sky access to the GPS satellites. The GPS receiver receives the satellite signals and provides an A-GPS signal to the device location block 124 of the Class_A loader 120. The device location block 124 uses the A-GPS signal to recover the attenuated satellite navigation signals.


[0043] As known in the art, the GPS satellites transmit two specially coded carrier signals, including the L1 signal for civilian use and the L2 signal for military and governmental use. GPS receivers process the signals to compute the user's position within a radius of ten meters or better as well as an accurate time measure. The course/acquisition (C/A) signal is one of the signals modulated on the L1 carrier. The C/A code is used to determine pseudorange (i.e., the apparent distance to the satellite plus time bias), which is then used by the GPS receiver to determine position. The C/A code is a pseudo-random noise (PN) code, meaning that it has the characteristics of random noise, but is not really random. To the contrary, the C/A code is very precisely defined. There are thirty-seven PN sequences used for the C/A code, and each GPS satellite broadcasts a different code. The PN sequence contains no data; it is simply an identifier; however, its timing is very precisely determined, and that timing is used to determine the pseudorange. The PN sequences are each a sequence of zeros and ones (binary), with each zero or one referred to as a “chip” rather than a bit to emphasize that the zeros and ones do not carry data. The C/A signal has a 1.023 MCh/sec chipping rate and a code length of 1,023, so it repeats itself after every 1 msec interval.


[0044] Another signal modulated onto the L1 carrier is the broadcast data message, which includes information describing the positions of the satellites. Each satellite sends a full description of its own orbit and clock calibration data (within the ephemeris information) and an approximate guide to the orbits of the other satellites (contained within the almanac information). The broadcast data message is modulated at a much slower rate of 50 bps.


[0045] In order to receive a GPS signal and measure the pseudorange to the satellite, a GPS receiver performs a correlation process in which a search is conducted for the satellite's unique PN code. The received signal is checked against all of the possible PN codes. The GPS receiver generates each of these codes and checks for a match. Even if the GPS receiver generates the right PN code, it will only match the received signal if it is lined up exactly. Because of the time delay between broadcast and reception, the received signal also has to be given a time delay. When a match is found, the GPS receiver identifies the PN code (and therefore the satellite). Using the ephemeris and clock calibration data contained in the 50 bps broadcast data message, the GPS receiver can calculate the time delay (and therefore the pseudorange).


[0046] The correlation process is conducted in a carrier frequency dimension and a code phase dimension. In the carrier frequency dimension, the GPS receiver replicates carrier signals to match the frequencies of the GPS signals as they arrive at the receiver. But, due to the Doppler effect, the frequency f at which the GPS signal is transmitted by the satellite changes by an amount Δf before the signal arrives at the receiver. Thus, the GPS signal should have a frequency f+Δf when it arrives at the receiver. During search and acquisition, to account for the Doppler effect, the GPS receiver replicates the carrier signals across a frequency spectrum until the frequency of the replicated carrier signal matches the frequency of the received signal. Similarly, in the code phase dimension, the GPS receiver replicates the unique PN codes associated with each satellite. The phases of the replicated PN codes are shifted across a code phase spectrum until the replicated carrier signals modulated with the replicated PN codes correlate, if at all, with GPS signals received by the receiver. The code phase spectrum includes every possible phase shift for the associated PN code.


[0047] The correlation process is implemented by a correlator that performs a multiplication of a phase-shifted replicated PN code modulated onto a replicated carrier signal with the received GPS signals. The GPS receiver essentially performs a search of two parameters: Range and Doppler. The receiver divides the field of uncertainty into Range/Doppler bins and looks in each bin to see if that corresponds to a correct pair of values. Setting the carrier frequency and code phase has the effect of tuning the correlator to a particular Range/Doppler combination. The envelope response peaks when the correlator is tuned to the appropriate Range/Doppler combination. Otherwise, unless the tuning is close to the correct values, the envelope response is minimal. Once properly tuned, the receiver can recover the navigation data from the detected GPS signals and use the navigation data to determine a location for the receiver.


[0048] The A-GPS signal assists the Class_A loader 120 in two respects. First, the A-GPS signal includes the 50 bps broadcast data message recovered from the GPS satellite signals that contains satellite orbital information and clock correction parameters for all satellites in view at the location of the GPS receiver. This information helps the device location block 124 figure out where the GPS satellites are as well as the pseudorange to the satellites. Second, the satellite orbital information and clock correction parameters can be used to narrow down the search of Range/Doppler bins by eliminating unlikely combinations. By knowing how the GPS satellites move as a function of time and an approximate location for the Class_A loader 120, the device location block 124 can predict better which Range/Doppler combinations are likely to result in a correlation, thereby reducing the numbers of correlators that are employed for this purpose.


[0049]
FIG. 4 illustrates an embodiment of the Class_A loader including a “no-move” system. The purpose of the “no-move” system is to ensure that the Class_A loader is not moved after it has been installed. While a GPS receiver would be able to monitor position, and thereby detect movement of the Class_A loader, attenuation of the GPS satellite navigation signals makes this solution impractical for certain indoor applications. The Class_A loader includes a key storage 174 that is loaded via a secure and authenticated interface 172 with one or more keys used for encrypting and decrypting data. The keys may be geo-locked in the manner discussed above. This initial loading operation may be performed at a location different than the ultimate operational location for the Class_A loader. In that case, the keys would be geo-locked for the intended operational location for the Class_A loader. Once located in the intended operational location, the keys can be retrieved from the key storage 174 for use in cipher functions 176 as discussed above.


[0050] More particularly, the “no-move” system includes a set-up timer 182, a threshold comparison 184, and a motion detector 186. The set-up timer 182 enables the “no-move” system to define a time period in which the “no-move” system is inoperative, thereby allowing the Class_A loader to be transported to the intended operational location. The “no move” system becomes operational when the time period defined by the set-up timer 182 has elapsed. The motion detector 186 detects any physical movement of the Class_A loader. A conventional two-axis acceleration sensor (e.g., Analog Devices ADXL202/ADXL210) or other like device may provide the motion detector 186. Any movement that is detected by the motion detector 186 is reported to the threshold comparison 184, which compares the detected movement to a predetermined threshold level. The predetermined threshold level may be selected such that nominal movement of the Class_A loader, e.g., within a few feet, would not trigger the “no-move” system. But, any movement that exceeds the predetermined threshold level would trigger an alarm system 188. The alarm system 188 may produce an audible/visible alarm and/or send a signal to maintenance personnel to check on the status of the Class_A loader. The threshold comparison 184 may also provide a command to the key storage 174 instructing that all keys contained therein be destroyed. This would prevent access to the keys if the Class_A loader were moved to another location beyond the range of the predetermined threshold level. The “no-move” system may further include a battery backup 190 power source that maintains operation of the threshold comparison 184 and motion detector 186 in the event of loss of electrical power to the Class_A loader.


[0051] In an alternative embodiment of the invention, the “no-move” system of FIG. 4 could be utilized in other systems besides data loaders. For example, the “no-move” system could be utilized in any device that also includes an A-GPS system. In such a device, the A-GPS system would provide primary location determination as long as sufficient (albeit attenuated) GPS signals are available. The A-GPS system then passes the location estimate to the “no-move” system. When the A-GPS system is unable to estimate location, the “no-move” system becomes operational, using the last known position from the A-GPS system from which to measure movement against.


[0052] The “no-move” system could also be utilized in a device that does not have an independent way to determine location, but rather may include a memory that is loaded with location information, such as by a Class_A or Class_B loader (discussed below). Once loaded with location information, the device may have a certain amount of time before the “no-move” system becomes operational. After this time expires, any movement of the device beyond the predetermined threshold would trigger an alarm condition as described above. While this alternative embodiment would have particular applicability to systems that utilize cipher functions to encrypt/decrypt data, the “no-move” system could also have broader applicability to provide anti-theft and information protection for computers and other data handling systems.


[0053] Turning now to FIG. 3, a block diagram of an exemplary Class_B loader 140 is illustrated. As described above, the Class_B loader 140 is intended to be a portable device. The Class_B loader 140 includes a fill memory 142 that stores the fill data received from a Class_A loader. It should be appreciated that the fill data stored in the fill memory 142 is locked, i.e., it is geo-encrypted in accordance with the method described above with respect to FIG. 5. The Class_B loader 140 further includes a device 144 that unlocks the geo-encrypted fill data in order to transfer the fill data to a device to be loaded 160, e.g., a recipient device. In a preferred embodiment of the invention, the fill data unlocking device 144 geo-decrypts the digital data in accordance with the method described above with respect to FIG. 6. The fill data unlocking device 144 receives a geographic location in appropriate coordinates for the Class_B loader 140 from location block 146. The fill data unlocking device 144 uses this geographic location information to ensure that the Class_B loader 140 is in the proper location, e.g., the customer location. As described above, the Class_B loader 140 will only be able to transfer fill data to the device 160 if the Class_B loader is located in the appropriate place. The device 160 may further have a unique device serial number that is provided back to the fill data unlocking device 144. The device serial number can be checked against information contained in the fill memory 142 in order to provide a further verification that the appropriate device 160 will receive the data.


[0054] The Class_B loader 140 further includes a GPS receiver 148 that provides the geographic location information to the location block 146. Since it is anticipated that the Class_B loader 140 be a portable device that is often carried indoors where GPS signals may be attenuated, the location block 140 further includes a memory that will hold the last geographic location information received from the GPS receiver 148. When the GPS receiver 148 is unable to receive satellite navigation signals due to signal attenuation, i.e., a GPS outage, a timer 152 initiates a count for a predetermined period of time. The location block 146 will continue to hold the last received geographic location information until the predetermined period of time is reached, whereupon the fill data unlocking device 144 will cease unlocking the geo-encrypted fill data. This predetermined period of time should be sufficient to permit an operator to load a recipient device 160 with fill data, while limiting time for inappropriate uses of the Class_B loader 140.


[0055] In an embodiment of the invention, the location block 146 may also provide cable plant delay information (bCABLE) corresponding to the signal delay between the headend and customer location of a cable plant used to deliver cable television signals or other electronic media. The recipient device could then use the cable plant delay information to calculate precise location information using an assisted-GPS system (as described above and in co-pending patent application Ser. No. 10/193,586, identified above). Moreover, the location block 146 may also provide an accurate time hack to the recipient device 160. The correlator count of a GPS receiver in the recipient device 160 can be reduced by providing a time hack of sufficient accuracy to permit searching fewer than all PN code phases. The Class_B loader 140 may further include a precision oscillator (e.g., TCXO, OCXO (temperature-compensated crystal oscillator or “ovenized” crystal oscillator) or Rubidium). Time discipline may be provided by GPS, LORAN, or some other source while the Class_B loader 140 is exposed to appropriate signals, and the precision oscillator used to maintain an accurate time count in the absence of discipline.


[0056] Referring now to FIG. 7, a block diagram illustrates an example of secure communication of information to a recipient device through Class_A and Class_B loaders. An intellectual property (IP) owner or proxy 710 has a random key that is used to encrypt digital information, such as a television broadcast. The random key is encrypted using a locking process (L0) 712 to provide a random key L0(RK) that is geo-locked for the location of a Class_A loader. The locking process (L0) 712 receives as inputs the key ID and the location of the Class_A loader. Optionally, the locking process (L0) 712 may further receive valid times in which the geo-locked random key can be decrypted by the Class_A loader.


[0057] The geo-locked random key L0(RK) is transferred to the Class_A loader 720. The geo-locked random key is decrypted using an unlocking process (U0) 722 to recover the random key. The unlocking process (U0) 722 receives as inputs the key ID, the secure location of the Class_A loader 720, and (optionally) the secure time. The random key can only be recovered if these inputs match the inputs used by the locking process (L0) 712 to geo-lock the random key. Next, the recovered random key is again encrypted along with other auxiliary data using a locking process (L1) 724 to produce fill data. The locking process (L1) 724 receives as inputs the key ID, the customer location, and (optionally) the valid times in which the fill data may be transferred to a recipient device. The fill data is then encrypted to a second level using a locking process (L2) 726 to produce geo-locked fill data. The locking process (L2) 726 receives as inputs the key ID, the customer location, and (optionally) the valid times in which the locked fill data may be transferred to a recipient device (i.e., a Class_B loader).


[0058] The geo-locked fill data is transferred from the Class_A loader 720 to a Class_B loader 730. The Class_B loader 730 may provide the Class_A loader 720 with a device ID or serial number to provide further validation of the transfer. The Class_B loader 730, containing the geo-locked fill data stored in memory, may be physically transported to a customer location to load a recipient device 740. The Class_B loader 730 removes the second level of encryption using an unlocking process (U2) 732 to recover the fill data, which is loaded into the recipient device 740. The unlocking process (U2) 732 receives as inputs the key ID, the secure location of the Class_B loader 730, and (optionally) the secure time. The fill data can only be recovered if these inputs match the inputs used by the locking process (L2) 726 used to geo-lock the fill data. The recipient device 740 may provide the Class_B loader 730 with a device ID or serial number to provide further validation of the transfer.


[0059] Lastly, the recipient device 740 decrypts the fill data using an unlocking process (U1) 742 to recover the random key and auxiliary data. The unlocking process (U1) 742 receives as inputs the key ID, the secure location of the recipient device 740, and (optionally) the secure time. The random key and auxiliary data can only be recovered if these inputs match the inputs used by the locking process (L1) 724 to geo-lock the random key and auxiliary data. The recipient device 740 can then utilize the random key to decrypt digital information, such as the originally encrypted television broadcast distributed by the IP owner or proxy 710.


[0060] Having thus described preferred embodiments of a data loader using location identity to provide secure communication of data to recipient devices location determination, it should be apparent to those skilled in the art that certain advantages of the above-described system have been achieved. It should also be appreciated that various modifications, adaptations, and alternative embodiments thereof may be made within the scope and spirit of the present invention. The invention is further defined by the following claims.


Claims
  • 1. An apparatus for distributing data, comprising: a service profile containing customer location information and original data to be distributed to at least one customer; and a fill data generator adapted to generate fill data based on said original data and transfer said fill data to a recipient device, said fill data being generated in accordance with said customer location information such that said original data can only be recovered from said fill data if said recipient device is located at said location of said at least one customer.
  • 2. The apparatus of claim 1, further comprising means for identifying a current location of said apparatus, said fill data generator being inhibited from generating said fill data if said identified current location is not consistent with a predetermined location for said apparatus.
  • 3. The apparatus of claim 2, wherein said location identifying means further comprises a GPS satellite navigation signal receiver.
  • 4. The apparatus of claim 2, wherein said location identifying means further comprises an assisted-GPS signal receiver.
  • 5. The apparatus of claim 2, wherein said location identifying means further comprises a motion detector adapted to detect movement of said apparatus, wherein detected movement above a predefined threshold level produces an alarm condition.
  • 6. The apparatus of claim 5, wherein said original data is destroyed upon said alarm condition.
  • 7. The apparatus of claim 5, wherein said location identifying means further comprises a timer adapted to permit a period of time for transport of said apparatus without producing said alarm condition.
  • 8. The apparatus of claim 1, wherein said original data further comprises at least one random key.
  • 9. The apparatus of claim 1, further comprising a geodetic information converter adapted to convert said customer location information into geodetic information.
  • 10. The apparatus of claim 1, wherein said fill data further comprises an estimate of time delay of signals communicated to said customer location via a cable plant.
  • 11. An apparatus for distributing data, comprising: a data memory storing locked fill data received from a loader device; a location identifying device to identify a current location for said apparatus; and a fill data converter recovering fill data from said locked fill data and transferring said fill data to a customer recipient device, said fill data being recovered only if said current location is consistent with a predetermined customer location.
  • 12. The apparatus of claim 11, wherein said location identifying device further comprises a GPS satellite navigation signal receiver.
  • 13. The apparatus of claim 12, wherein said location identifying device further comprises a location memory adapted to store a last known current location for a predetermined period of time upon detecting a GPS satellite navigation signal outage condition.
  • 14. The apparatus of claim 11, wherein said fill data further comprises an estimate of time delay of signals communicated to said customer location via a cable plant.
  • 15. The apparatus of claim 11, wherein said fill data further comprises an accurate time hack.
  • 16. A communication network, comprising: a data originator device having digital data to be distributed, said data originator device adding a first level of encryption to said digital data such that said first level of encryption can only be removed at a first predetermined location; a first data loading device disposed at said first predetermined location and adapted to receive said digital data having said first level of encryption, said first data loading device removing said first level of encryption from said digital data and adding a second level of encryption to said digital data such that said second level of encryption can only be removed at a second predetermined location; and a recipient device adapted to receive said digital data having said second level of encryption, said recipient device removing said second level of encryption from said digital data only when disposed at said second predetermined location.
  • 17. The communication network of claim 16, wherein said first data loading device adding a third level of encryption to said digital data such that said third level of encryption can only be removed at a third predetermined location.
  • 18. The communication network of claim 17, further comprising a second data loading device adapted to receive from said first data loading device said digital data having said second and third levels of encryption, said second data loading device removing said third level of encryption from said digital data only when disposed at said third predetermined location, said second data loading device thereafter providing to said recipient device said digital data with said second level of encryption remaining.
  • 19. The communication network of claim 18, wherein said second data loading device is portable.
  • 20. The communication network of claim 16, wherein said digital data further comprises a random key used by said data owner device to encrypt data content prior to distribution to said recipient device, wherein said recipient device uses said random key to decrypt said data content.
  • 21. The communication network of claim 16, wherein said first data loading device adding auxiliary data to said digital data prior to adding said second level of encryption, said recipient device recovering both said auxiliary data and said digital data upon removal of said second level of encryption.
  • 22. The communication network of claim 18, wherein said second data loading device providing a corresponding device identification (ID) to said first data loading device, said first data loading device using said device ID to verify that said second data loading device is authorized to receive said digital data having said second and third levels of encryption.
  • 23. The communication network of claim 22, wherein said recipient device providing a corresponding device identification (ID) to said second data loading device, said second data loading device using said device ID to verify that said recipient device is authorized to receive said digital data having said second level of encryption.
  • 24. A method for communicating data, comprising the steps of: originating digital data to be distributed; adding a first level of encryption to said digital data such that said first level of encryption can only be removed at a first predetermined location; loading said digital data having said first level of encryption into a first loading device; removing said first level of encryption from said digital data only if said first loading device is disposed at said first predetermined location, and adding a second level of encryption to said digital data such that said second level of encryption can only be removed at a second predetermined location; loading said digital data having said second level of encryption into a recipient device; and removing said second level of encryption from said digital data only if said recipient device is disposed at said second predetermined location.
  • 25. The method of claim 24, further comprising the step of adding a third level of encryption to said digital data such that said third level of encryption can only be removed at a third predetermined location.
  • 26. The method of claim 25, further comprising the steps of loading said digital data having said second and third levels of encryption from said first loading device into a second loading device, and removing said third level of encryption from said digital data only if said second loading device is disposed at said third predetermined location.
  • 27. The method of claim 26, further comprising the step of transporting said second loading device from said first predetermined location to said second predetermined location.
  • 28. The method of claim 24, wherein said digital data further comprises a random key used to encrypt data content prior to distribution to said recipient device, further comprising the step of decrypting said data content using said random key.
  • 29. The method of claim 24, further comprising the step of adding auxiliary data to said digital data prior to adding said second level of encryption.
  • 30. The method of claim 26, further comprising the steps of providing a device identification (ID) from said recipient device to said second data loading device, and using said device ID to verify that said recipient device is authorized to receive said digital data having said second level of encryption.
  • 31. A data-handling apparatus, comprising: a cipher device to perform cipher functions on digital data in accordance with a location identity such that said cipher functions are only performed if a current physical location of said apparatus corresponds to predetermined location parameters; means for identifying said current physical location of said apparatus; and a motion detector adapted to detect movement of said apparatus from said current physical location, wherein upon detection of movement above a predefined threshold level said motion detector produces an alarm condition that inhibits operation of said cipher device.
  • 32. The data-handling apparatus of claim 31, wherein said cipher device destroys said digital data upon said alarm condition.
  • 33. The data-handling apparatus of claim 32, wherein said digital data further comprises at least one key used by said cipher device.
  • 34. The data-handling apparatus of claim 31, further comprising a timer coupled to said motion detector to define a period of time for transport of said apparatus without producing said alarm condition.
  • 35. The data-handling apparatus of claim 31, wherein said location identifying means further comprises a GPS satellite navigation signal receiver.
  • 36. The data-handling apparatus of claim 31, wherein said location identifying means further comprises an assisted-GPS system.
  • 37. The data-handling apparatus of claim 31, wherein a last known physical location of said apparatus is utilized during conditions in which said identifying means is unable to identify said current physical location.
  • 38. The data-handling apparatus of claim 31, wherein said location identifying means further comprises a memory adapted to store location information loaded by an external device.
  • 39. A method for handling data, comprising the steps of: performing cipher functions on digital data in accordance with a location identity such that said cipher functions are only performed if a current physical location corresponds to predetermined location parameters; identifying said current physical location; and detecting movement from said current physical location beyond a predefined threshold level and producing an alarm condition that inhibits performance of said cipher functions.
  • 40. The method of claim 39, further comprising destroying said digital data upon said alarm condition.
  • 41. The method of claim 40, wherein said digital data further comprises at least one key used in performance of said cipher functions.
  • 42. The method of claim 39, further comprising precluding said alarm condition for a predetermined period of time.
  • 43. The method of claim 39, wherein said identifying step further comprises identifying location using GPS satellite navigation signals.
  • 44. The method of claim 39, wherein said identifying step further comprises identifying location using assisted-GPS signals.
  • 45. The method of claim 39, further comprising utilizing a last known physical location during conditions in which said current physical location cannot be identified.
  • 46. The method of claim 39, wherein said identifying step further comprises loading location information from an external device.