Preferred embodiments of the present invention will be described below in more detail, with reference to the accompanying drawings, in which:
While the specification concludes with claims defining features of the invention that are regarded as novel, it is believed that the invention will be better understood from a consideration of the description in conjunction with the drawings. As required, detailed embodiments of the present invention are disclosed herein; however, it is to be understood that the disclosed embodiments are merely exemplary of the invention, which can be embodied in various forms. Therefore, specific structural and functional details disclosed herein are not to be interpreted as limiting, but merely as a basis for the claims and as a representative basis for teaching one skilled in the art to variously employ the present invention in virtually any appropriately detailed structure. Further, the terms and phrases used herein are not intended to be limiting but rather to provide an understandable description of the invention.
The present invention relates to a method and a system for prioritizing communication services across multiple service initiators in a multi-modal communication device. For example, inter-process communications can be established between two or more processors within the communication device. When a request for a service provided by a particular processor is received, the priority levels of services that are currently active on other processors can be considered when determining the appropriate response to the request. For example, if a service having higher priority than the requested service is currently active, and initiation of the requested service would interrupt the higher priority service, an error message can be provided in response to the request. Accordingly, the higher priority service can be maintained without interruption until the higher priority service is no longer required.
The communications system 100 can include a communication device 110. The communication device 110 can be a mobile station, such as a mobile computer, a personal digital assistant (PDA) or a mobile telephone, a game console, or any other electronic apparatus that may be used to wirelessly communicate with the communications network 105. The communication device 110 can include a network adapter 115 to support communications between the communication device 100 and the communications network 105. The network adapter 115 can be, for example, a transceiver that supports wireless communications and/or an adapter that supports wired communications.
The communication device 110 also can include an external device interface 120 to support communications with an external device 150. For example, the external device interface 120 can be a communications port, such as a network adapter, a universal serial bus (USB) interface, an enhanced mini USB (EMU) interface, an IEEE-1394 (FireWire) interface, or any other interface suitable for supporting communications with an external device 150. The external device 150 can be, for instance, a computer, a personal digital assistant, a gaming device, or any other device which can be communicatively linked to a communications device.
The communication device 110 further can include one or more processors, such as an application processor 125 and/or a baseband processor 130. The application processor 125 can execute applications, including services that run at the application layer. The baseband processor 130 also can execute applications, as well as execute baseband communications services. The applications/services can be stored in one or more datastores 135. A datastore 135 can comprise an electronic storage medium, a magnetic storage medium, an optical storage medium, a magneto-optical storage medium, or any other storage medium suitable for storing software or firmware.
An inter-process communications link 140 can be established between the application processor 125 and the baseband processor 130. The inter-process communication link can be implemented as a process which passes data from the application processor 125 to the baseband processor 130, and from the baseband processor 130 to the application processor 125. Such passing of data can be accomplished using methods known in the art. One example of such a method can use dual port random access memory that is accessible by both processors 125, 130, but other techniques can be used and the invention is not limited in this regard.
In operation, a call, for instance a circuit data call, can be initiated to establish a data communication link between the external device 150 and another device communicatively 155 linked to the communications network 105 via the communication device 110. The call can be initiated by a service instantiated on the application processor 125 or a service instantiated on the baseband processor 130. For example, the call may be requested via a user interface 145 on the communication device 110, in which case a service executed by the application processor 125 may request allocation of resources on the baseband processor 130 to establish the call. For example the service executed by the application processor 125 can interface with a service executed by the baseband processor 130. On the other hand, if the call is requested via the external device 150, a service executed by the baseband processor 130 may itself establish the call, or interface with another service executed by the baseband processor 130 to establish the call.
Regardless of which processor 125, 130 executes the service requesting the call, or which service/processor ends the call, each of the processors 125, 130 can be informed of the call status.
Although requests to initiate or terminate a call service can be generated by the application processor 125 or the external device 150, some requests may conflict with other services being executed on the communications device.
At step 605 a request for a service initiation can be received, for example via the external device or via the application processor on the communication device (e.g. responsive to user inputs entered via the user interface). Referring to decision box 610, if the service being requested is a service typically instantiated on the baseband processor, the process can proceed to decision box 615 where a determination can be made whether the requested service conflicts with another service instantiated on the baseband processor. If there is such a conflict, the process can proceed to decision box 625 and a determination can be made whether to override the conflicting service.
The decision whether to override the conflicting service can be based on any of a myriad of factors, some examples of which are discussed herein. For example, a priority level can be established for each of the services. If it is determined that the requested service has a higher priority level than the service instantiated on the baseband processor, at step 635 the requested service can be initiated. In addition, the service initiated messages previously discussed in the message flow diagrams can be provided by the baseband processor. Otherwise, at step 630, a conflict message can be provided. The conflict message can be provided via the user interface on the communication device or via the external device.
Referring again to decision box 615, if the requested service does not conflict with another service instantiated on the baseband processor, the process can proceed to decision box 620 and a decision can be made whether the requested service conflicts with another service that would be simultaneously instantiated on the application processor. If there is such a conflict, the process can again proceed to decision box 625, and a decision can be made whether to override the conflicting service on the application processor, for instance based on priorities assigned to the respective services. Based on the decision, a conflict message can be provided at step 630 or the service can be instantiated at 635. If there is no such conflict, the process can bypass decision box 625 and proceed to step 635 where the service can be instantiated.
In the example shown, the process can perform step 615 to determine whether there is a conflicting service on the baseband processor prior to determining whether there is a conflicting service on the application processor at step 620. It should be noted, however, that the respective positions of decision boxes 615 and 620 can be reversed in the flowchart, and the determination of whether there is a conflicting service on the application processor at step 620 can be performed prior to the determination of whether there is a conflicting service on the baseband processor.
Referring back to decision box 610, if the service being requested is a service typically instantiated on the application processor, the process can proceed to decision box 640 where a determination can be made whether the requested service conflicts with another service instantiated on the application processor. If there is such a conflict, the process can proceed to decision box 625 and an override decision can be made as previously described. If, however, there is no conflicting service instantiated on the application processor, the process can proceed to step 645 and a decision can be made whether the requested service conflicts with another service that would be simultaneously instantiated on the baseband processor. If there is such a conflict, the process can again proceed to decision box 625. If there is no such conflict, the process can proceed to step 635 and the requested service can be initiated.
In the example shown, the process can perform step 640 to determine whether there is a conflicting service on the application processor prior to determining whether there is a conflicting service on the baseband processor at step 645. Of course, the respective positions of decision boxes 640 and 645 can be reversed in the flowchart, and the determination of whether there is a conflicting service on the baseband processor at step 645 can be performed prior to the determination of whether there is a conflicting service on the application processor.
The present invention can be realized in hardware, software, or a combination of hardware and software. The present invention can be realized in a centralized fashion in one processing system or in a distributed fashion where different elements are spread across several interconnected processing systems. Any kind of processing system or other apparatus adapted for carrying out the methods described herein is suited. A typical combination of hardware and software can be a processing system with an application that, when being loaded and executed, controls the processing system such that it carries out the methods described herein. The present invention also can be embedded in an application product which comprises all the features enabling the implementation of the methods described herein and, which when loaded in a processing system, is able to carry out these methods.
The terms “computer program,” “software,” “application,” variants and/or combinations thereof, in the present context, mean any expression, in any language, code or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following: a) conversion to another language, code or notation; b) reproduction in a different material form. For example, an application can include, but is not limited to, a subroutine, a function, a procedure, an object method, an object implementation, an executable application, an applet, a servlet, a source code, an object code, a shared library/dynamic load library and/or other sequence of instructions designed for execution on a processing system.
The terms “a” and “an,” as used herein, are defined as one or more than one. The term “plurality,” as used herein, is defined as two or more than two. The term “another,” as used herein, is defined as at least a second or more. The terms “including” and/or “having,” as used herein, are defined as comprising (i.e., open language).
This invention can be embodied in other forms without departing from the spirit or essential attributes thereof. Accordingly, reference should be made to the following claims, rather than to the foregoing specification, as indicating the scope of the invention.