1. Technical Field
The present inventions relate to revocation of software applications and, more particularly, relate to the revocation of software applications using a revocation list in a portable electronic device.
2. Description of the Related Art
The security of devices (such as a cellular phone) is important and is beginning to be addressed. Some manufacturers of devices have implemented integrity and authenticity checks of software that runs on the device. This may include the OS, device drivers, base code, libraries, and user applications. The term Secure Boot is used to denote the concept of verifying software in an unbroken chain from the Boot ROM to applications. Such a device may be viewed as a trusted device, and the device is said to contain a trusted platform. Some of the characteristics of a trusted platform may include:
As on a personal computer, platforms that allow software to be loaded and executed from a variety of sources/vendors can also make it possible for hackers to exploit it. However, the potential consequences in a wireless system may be worse than on a personal computer. For example, a hacker could create a Trojan horse program that turns on phone transmitters continuously, or sends constant phone messages in a denial-of-service attack on the wireless infrastructure.
A secure software lifecycle may be viewed as having three components: prevention, detection, and response. Prevention is done by screening and evaluating the software, which may include screening the software vendor. A trusted signing server, or trusted authority, is expected to address these issues before giving its stamp of approval. Its stamp, namely a cryptographic signature of the software, is an assurance given by the trusted authority, to all devices that receive the software package, that the software has been signed by it. Detection is the ability to determine whether the approved software has been tampered with. If the device verifies the software package, that is an assurance that the software has been received in the same condition as it was when it was signed by the trusted authority. Nominally, a trusted device will not launch software that is not signed, nor will it launch software that failed the signature verification process.
The “response” component refers to the ability to take action on software that is noncompliant. An example of a response mechanism is, if a software package fails the verification step, the device can prevent the software from being run. This is an example of a response due to an event that occurred after the trusted authority signed the software. But, responding to an event that traces itself prior to that, in the prevention phase, is more problematic. What response can be done if there was an incident of some sort in the prevention phase? Normally, if the software has been signed by a trusted authority, then it will pass verification by the device. How can an action be taken against software when it is found to be noncompliant, or rogue, after it has been signed by a trusted authority and delivered to the device?
There is the chance that an application should be revoked after it has been released to the public. Some possible reasons include:
Current and future devices will increasingly contain software developed by vendors outside of the control of the manufacturer of such devices. Devices that contain legitimately signed software need to have a procedure to remove applications that are deemed “bad”. The term application revocation is used generically to describe this capability.
Trusted applications can be revoked within a portable electronic device. At least one of the applications within the portable electronic device has an application identifier (ID). The portable electronic device can be a cellular 10 telephone or radiotelephone or other device such as a PIM (Personal Information Manager), PDA (Personal Digital Assistant), gaming console, pager, portable computer, a set-top box, or an mp3 music player and digital camera or portable video recorder.
The portable electronic device is typically a trusted portable electronic device. Trusted here means that we trust the chain of software events up to and until the application is obtained within the portable electronic device. The applications within the portable electronic device are typically applications signed by a trusted authority. Each application within the portable electronic device typically has an application certificate containing the application identifier and an application signature. The portable electronic device comprises a revocation application for performing the revocation process and determining which if any applications to revoke. The revocation application is also a trusted application.
A portable electronic device may contain an application revocation list (ARL) comprising at least one application identifier for each application on the list. The application revocation list is preferably signed so that when the portable electronic device receives it, it can be trusted because its source can be verified. The application identifier uniquely identifies the application. The application identifier can identify more than a single application. The application identifier can identify an application software package. This package can be a collection of installed code, post-installed code, multiple pieces of code, and non-contiguous code. The portable electronic device maintains the relationship between an application identifier and the application software package. Hereafter, reference to an application that is associated with an application identifier should be understood to also include an application software package
The application revocation list is a new security credential that contains information that revokes an application. At a minimum, it must include an application identifier linked to the application. The application revocation list may optionally contain a timestamp value associated with each application identifier. The revocation application may use the timestamp information for managing its revocation processing activities by date. Using the example of the Product Certificate as described in U.S. Pat. No. 6,223,291, by the same inventors as the present inventions, and hereby incorporated by reference, the Product Certificate may include the following items:
The Application Identifier in the application revocation list would be linked to the Subject field of such a Product Certificate. Whenever an application is launched, a trusted verification application on the portable electronic device checks the application revocation list to see whether the application's identifier is on it. The application revocation list itself is signed by a trusted authority, so before the application revocation list is processed; it must first be verified by the device. This prevents anyone such as a hacker from creating fake application revocation lists to subvert the system. If an application is found to be on the application revocation list, then it is considered to be revoked. The portable electronic device will process revoked applications according to a security policy. For example, the security policy might prevent the revoked application from running, or it may remove the application from the device, or it may force the device to look for an update from a server.
When a portable electronic device receives an application revocation list, one of the steps required before processing the application revocation list is to first verify the authenticity of the application revocation list by verifying its signature. Then, the portable electronic device determines whether application identifiers on the application revocation list match application identifiers within the portable electronic device. Such can be performed by comparing the application revocation list against the application list (i.e., which contains an association between application identifiers and the applications themselves) maintained by the portable electronic device. If an application identifier on the application revocation list matches an application identifier within the portable electronic device, the application so identified is revoked. Revocation of the application can be processed within the portable electronic device in a number of ways. One way of processing the revocation of the application within the portable electronic device is to remove the application. Another way of processing the revocation of the application within the portable electronic device is to delete the application from memory. Another way of processing the revocation of the application within the portable electronic device is to move the application into a restricted area of memory of the portable electronic device. Another way of processing the revocation of the application within the portable electronic device is to disable the application. Another way of processing the revocation of the application within the portable electronic device is to mark the application as revoked. These are non-limiting examples of revocation of an application.
The portable electronic device 110 has an antenna 126 connected to the radio transceiver 123. The portable electronic device 110 communicates with a remote server 140 via a base antenna 146 over a communications network. The radio transceiver 123 can be a cellular telephone transceiver which allows the portable electronic device 110 to transmit and receive voice traffic with a public switched telephone network PSTN. The radio transceiver 123 also allows the portable electronic device to wirelessly receive new application revocation lists for storage in the application revocation list memory 135.
The processor 120 performs operating functions of the portable electronic device 110. One operating function performed by the processor 120 is determining whether an application identifier on the application revocation list matches an application identifier of an application that runs on the portable electronic device, and if so processing a revocation of the application corresponding to the application identifier.
(For compactness, “an application identifier of an application that runs on the portable electronic device” may be alternatively expressed as “an application identifier of an application on the portable electronic device” or “an application identifier on the portable electronic device”)
The memory 130 may contain a restricted area wherein an application is moved upon processing of a revocation. Alternatively the processor 120 may disable the application processed for revocation, or it may delete from the memory 130 the application processed for revocation, or it may disable the application in memory.
The radio transceiver 123 of the portable electronic device 110 may query the remote server 140 to search for and receive an application revocation list and store it in the application revocation list memory 135. The remote server 140 may be operated by the manufacturer of the portable electronic device or by the service provider of the communications network or by a trusted authority. The portable electronic device 110 may have more than one application revocation list stored in the application revocation list memory 135. The portable electronic device would process each application revocation list.
The portable electronic device can derive a list of application identifiers from the applications stored in the application memory 233. The list could be stored in working memory or added to the application memory. The applications are illustrated in
Additionally, application identifiers themselves might not be contained within the code of each application or within a certificate associated with each application. Thus application identifiers may be derived too by the portable electronic device. One way to derive an application identifier from an application is to hash the application code using a hash algorithm. The result of the hashing would then be used as the application identifier for that application.
The application identifiers can be many bytes long, but could be as short as one byte. The result of a hash using SHA-1, for example, is 20 bytes.
The application revocation list 235 may contain a list of application identifiers for applications that have been revoked. The application revocation list 235 may also contain a signature of its data. It is possible that none of the applications in the application space 233 are listed in the application revocation list 235. It is also possible that the application revocation list 235 contains application identifiers for applications which are not present on a given portable electronic device.
In the alternative embodiment of
The application memory 233 can be contained in more than one place in the portable electronic device. The application memory 233 can also be located external to the portable electronic device, for example, as part of an accessory such as a camera attachment. What is important is that the processor 120 in the portable electronic device 110 can access this memory.
Finally in
It is important for a trusted system to verify applications, if they are signed. If signature verification of applications is implemented, then the applications can be considered trusted if they are successfully verified. Although verifying the applications enhances the security, it is not a necessary step in the revocation process itself. The verification of applications can happen at any time, which is after step 360 or before step 310, or between steps 310 and 360.
Variations of the application revocation described with reference to
In step 410 a trusted authority creates an application revocation list. The application revocation list contains application identifiers corresponding to applications to be revoked by recipient portable electronic devices. The trusted authority at step 420 then signs the application revocation list to provide assurance to devices that the application revocation list is trusted. One advantage of the embodiments of the present inventions is that the trusted authority can be different entities. The trusted authority may be the portable electronic device manufacturer, a system operator for the portable electronic device, or some other trusted authority. Another advantage of the embodiments of the present inventions is that the entity that determines which applications are placed on an application revocation list can be a different entity than the authorities that signed the applications.
In order to deliver the application revocation list, at step 510, a remote server on the communications network observes whether the portable electronic device is found or sensed on the network. The portable electronic device may be found or sensed on the network at the time that it registers upon power up. Alternatively the portable electronic device may be live on the network when the server is ready to check for its presence. If not, then step 510 is repeated until the portable electronic device is sensed on the network. When the portable electronic device is sensed on the network, step 520 will send the application revocation list to the portable electronic device. This allows the remote server to push the application revocation list to the portable electronic device. As an alternative to pushing, the portable electronic device can request application revocation list updates from a remote server upon power up or at other instances such as installation of new applications, or by user request, or even according to a predetermined schedule.
Although the inventions have been described and illustrated in the above description and drawings, it is understood that this description is by example only, and that numerous changes and modifications can be made by those skilled in the art without departing from the true spirit and scope of the inventions. Although the examples in the drawings depict only example constructions and embodiments, alternate embodiments are available given the teachings of the present patent disclosure. For example, although application revocation in cellular phone examples are disclosed, the inventions are applicable to a personal digital assistant, a gaming console, pager, portable computer, a set-top box or an mp3 music player and a digital camera or portable video recorder.