(19)
(11)EP 3 281 385 B1

(12)EUROPEAN PATENT SPECIFICATION

(45)Mention of the grant of the patent:
05.01.2022 Bulletin 2022/01

(21)Application number: 15888109.4

(22)Date of filing:  07.04.2015
(51)International Patent Classification (IPC): 
H04L 29/08(2006.01)
G06F 9/54(2006.01)
H04L 29/06(2006.01)
G06F 9/455(2018.01)
(52)Cooperative Patent Classification (CPC):
G06F 2209/541; H04L 67/125; H04W 4/50; H04L 67/1097; H04L 65/4084; H04L 65/602; H04W 4/06; H04L 65/4092; H04L 67/42; G06F 9/54
(86)International application number:
PCT/CN2015/075985
(87)International publication number:
WO 2016/161552 (13.10.2016 Gazette  2016/41)

(54)

CLOUD COMPUTING FOR MOBILE CLIENT DEVICES

CLOUD-COMPUTING FÜR MOBILE CLIENT-VORRICHTUNGEN

INFORMATIQUE EN NUAGE POUR DISPOSITIFS CLIENTS MOBILES


(84)Designated Contracting States:
AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

(43)Date of publication of application:
14.02.2018 Bulletin 2018/07

(73)Proprietor: Intel Corporation
Santa Clara, CA 95054 (US)

(72)Inventors:
  • ZHU, Bin
    Beijing 100013 (CN)
  • YANG, Yi
    Beijing 100013 (CN)
  • LIN, He
    Beijing 100013 (CN)
  • LI, Yuming
    Beijing 100013 (CN)
  • WANG, Zuo
    Beijing 100013 (CN)
  • XIE, Zhouyi
    Beijing 100013 (CN)

(74)Representative: Schäflein, Christian Georg et al
Maiwald Patentanwalts- und Rechtsanwaltsgesellschaft mbH Elisenhof Elisenstraße 3
80335 München
80335 München (DE)


(56)References cited: : 
WO-A1-2013/095485
CN-A- 102 571 940
CN-A- 102 981 440
US-A1- 2013 054 734
US-A1- 2014 280 704
WO-A1-2014/029944
CN-A- 102 647 620
CN-A- 103 259 874
US-A1- 2014 267 339
US-A1- 2015 011 311
  
      
    Note: Within nine months from the publication of the mention of the grant of the European patent, any person may give notice to the European Patent Office of opposition to the European patent granted. Notice of opposition shall be filed in a written reasoned statement. It shall not be deemed to have been filed until the opposition fee has been paid. (Art. 99(1) European Patent Convention).


    Description

    Technical Field



    [0001] The present disclosure relates to the field of computing. More particularly, the present disclosure relates to cloud computing for mobile client devices.

    Background



    [0002] The background description provided herein is for the purpose of generally presenting the context of the disclosure. Unless otherwise indicated herein, the materials described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.

    [0003] With advances in integrate circuit, computing, networking and related technologies, mobile computing devices have become widely available. At the same time, a plethora of applications are available for the mobile computing devices. Typically, an application developer develops an application, submits the application to the operator of an Application Store, and gets the application accepted and become available for download from the Application Store. Users of mobile computing devices would then go to the Application Store, download and install the application on the mobile computing devices, before the application can be run on the mobile computing devices. Periodically, the users have to access the Application Store again to download and install the updates to keep the applications current. The process is relatively cumbersome for the less sophisticated users. Additionally, executing applications on the mobile computing devices has the disadvantage of consuming battery power of the mobile computing devices, and reduces the duration of operation in between charges. Further, it requires the mobile computing devices to have increasing capabilities, and in turn, cost.

    [0004] WO 2014/029 944 A1 discloses systems and methods for providing remote access to content, such as games, from a thin client, such as an Internet browser, of a communication terminal. In this manner, an application may be used by a user of the terminal without having to run the application on the terminal itself.

    [0005] WO 2013/095 485 A1 discloses further systems and methods for remotely executing applications on a cloud server under the control of a client device.

    [0006] US 2014/267 939 A1 discloses methods and systems for securely transferring assets, via a cloud-based clipboard, from a first computing device to a second computing device, so that these assets may be rendered on the second computing device.

    [0007] US 2015/011 311 A1 discloses a method for executing, in response to a user of a mobile client device interacting with a first application, a second application on a remote server. Video frames of the screen display outputs are delivered from the remote server to the mobile client device. Interaction data for interacting with the second application is obtained on the mobile client device and sent to the remote server for consumption by the second application.

    Summary of the invention



    [0008] The invention is only defined by the appended claims. Embodiments not covered by the claims are meant to illustrate, and facilitate the understanding of, the claimed invention.

    Brief Description of the Drawings



    [0009] Embodiments of cloud computing for mobile computing devices of the present disclosure will be readily understood by the following detailed description in conjunction with the accompanying drawings. To facilitate this description, like reference numerals designate like structural elements. Embodiments are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings.

    Figure 1 illustrates a block diagram of a cloud computing environment incorporated with the cloud computing for mobile client device technique of the present disclosure, according to various embodiments.

    Figure 2 illustrates the cloud application server and cloud application client of Figure 1 in further detail, according to various embodiments.

    Figure 3 illustrates the computing environment of the mobile client device, including the cloud application client, in further detail, according to various embodiments.

    Figure 4 illustrates the computing environment of a cloud server, including the cloud application server, in further detail, according to various embodiments.

    Figure 5 illustrates the example cloud server and on demand composer of Figure 4 in further detail, according to various embodiment.

    Figure 6 illustrates an example cluster of computing servers, suitable for practicing the present disclosure, according to various embodiments.

    Figure 7 illustrates an example computer system suitable for use to practice various aspects of the present disclosure, according to various embodiments.

    Figure 8 illustrates a storage medium having instructions for practicing methods described with references to Figures 1-6, according to various embodiments.


    Detailed Description



    [0010] Apparatuses, methods and storage medium associated with cloud computing for mobile client devices are disclosed herein. In embodiments, a cloud server may include one or more processors, and a mobile computing operating system to host execution of an application. The cloud server may also include a cloud application server to interact with a cloud application client of a mobile client device to provide audio and video streams to the mobile client device, and to receive touch, key and/or sensor events from the mobile client device, to enable the application to be executed by the cloud server for the mobile client device.

    [0011] In embodiments, a mobile client device may include one or more processors, and a mobile computing operating system. The mobile client device may further include a cloud application client to interact with a cloud application server of a cloud server to receive audio and video streams from the cloud server, and to send touch, key and/or sensor events to the cloud server, to enable an application to be executed on the cloud server for the mobile client device.

    [0012] In the following detailed description, reference is made to the accompanying drawings which form a part hereof wherein like numerals designate like parts throughout, and in which is shown by way of illustration embodiments that may be practiced. It is to be understood that other embodiments may be utilized and structural or logical changes may be made without departing from the scope of the present disclosure. Therefore, the following detailed description is not to be taken in a limiting sense, and the scope of embodiments is defined by the appended claims and their equivalents.

    [0013] Aspects of the disclosure are disclosed in the accompanying description. Alternate embodiments of the present disclosure and their equivalents may be devised without parting from the spirit or scope of the present disclosure. It should be noted that like elements disclosed below are indicated by like reference numbers in the drawings.

    [0014] Various operations may be described as multiple discrete actions or operations in turn, in a manner that is most helpful in understanding the claimed subject matter. However, the order of description should not be construed as to imply that these operations are necessarily order dependent. In particular, these operations may not be performed in the order of presentation. Operations described may be performed in a different order than the described embodiment. Various additional operations may be performed and/or described operations may be omitted in additional embodiments.

    [0015] For the purposes of the present disclosure, the phrase "A and/or B" means (A), (B), or (A and B). For the purposes of the present disclosure, the phrase "A, B, and/or C" means (A), (B), (C), (A and B), (A and C), (B and C), or (A, B and C).

    [0016] The description may use the phrases "in an embodiment," or "in embodiments," which may each refer to one or more of the same or different embodiments. Furthermore, the terms "comprising," "including," "having," and the like, as used with respect to embodiments of the present disclosure, are synonymous.

    [0017] As used herein, the term "module" may refer to, be part of, or include an Application Specific Integrated Circuit (ASIC), an electronic circuit, a processor (shared, dedicated, or group) and/or memory (shared, dedicated, or group) that execute one or more software or firmware programs, a combinational logic circuit, and/or other suitable components that provide the described functionality.

    [0018] Referring now to Figure 1, wherein a block diagram of a cloud computing environment incorporated with the cloud computing for mobile client device technique of the present disclosure, according to various embodiments, is shown. As illustrated, cloud computing environment 100 may include a number of mobile client computing devices 102 communicatively coupled to a number of cloud servers 104, via one or more networks 106. Mobile client computing devices 102 and cloud servers 104 may respectively include cloud application clients 118 and cloud application servers 128 of the present disclosure, to cooperate with each other to enable applications 126 to be executed on cloud servers 104 on behalf of mobile client computing devices 102. Resultantly, users of mobile client computing devices 102 may execute applications without having to download and install these applications on mobile client computing devices 102, before they can run the applications (nor having to periodically download and install the updates). Additionally, the battery power of mobile client computing devices 102 may provide for longer operation durations between charges. Further, it is not necessary to pack mobile client computing devices 102 with high capacity/performance components to execute the increasingly more complex/sophisticated applications, which in turn may reduce the cost and affordability of mobile client computing devices 102. These and other aspects will be described more fully below.

    [0019] Each mobile client computing device 102, in addition to cloud application client 118, may include one or more processors 112, memory 114, mobile computing operating system 116, and peripherals 119, coupled with one another. Peripherals 119 may include, but are not limited to, touch sensitive screen, networking interface (NIC), and various sensors, such as, accelerometers, gyroscopes, global positioning, and so forth. Each of these elements, i.e. processors, 112, memory 114, mobile computing operating system 116 and peripherals 119 may be any one of a wide range of these elements known in the art. In other words, except for cloud application client 118, mobile client computing devices 102 may be any one of a number of mobile client computing devices known in the art, including, but are not limited to, wearable devices (such as, watches), smartphones, computing tablets, ultrabooks, e-books, laptop computers, and so forth.

    [0020] Similarly, each cloud server 104, in addition to cloud application server 128, may include one or more processors 120, memory 122, mobile computing operating system 124, one or more applications 126, and peripherals 129, coupled with one another. Peripherals 129 may include, but are not limited to, touch sensitive screen, networking interface (NIC), and various sensors, such as, accelerometers, global positioning, and so forth. Each of these elements, i.e. processors, 120, memory 122, mobile computing operating system 124, applications 126, and peripherals 129 may be any one of a wide range of these elements known in the art. In other words, except for cloud application server 126, cloud servers 104 may be any one of a number of cloud servers known in the art.

    [0021] In embodiments, cloud servers 104, themselves may be mobile computing devices, such as, but not limited to, wearable devices, smartphones, computing tablets, ultrabooks, e-books, laptop computers, and so forth. In alternate embodiments, cloud servers 104 may be thin servers designed to serve one mobile client computing device executing one application (for the mobile client computing device) at any one point in time (to be described more fully later with references to Figure 6). In other words, in embodiments, cloud computing environment 100 may be formed without employing conventional high power servers designed to host multiple applications for numerous clients. Such conventional high power servers typically require sophisticated server software, such as virtual machine managers (VMM) or hypervisors, and may be difficult to administer and/or costly.

    [0022] Referring now to Figure 2, wherein the cloud application server and cloud application client of Figure 1, according to various embodiments, are illustrated in further detail. As shown, cloud application client 218, which may be suitable for use as client application client 118 of Figure 1, and cloud application server 228, which may be suitable for use as cloud application server 128 of Figure 1, may be respectively incorporated with communication functionalities 240 and 250, in support of e.g., User Datagram Protocol (UDP), to communicatively couple with each other via, e.g., a UDP connection. In other embodiments, communication functionalities 240 and 250 may support other communication protocols.

    [0023] Additionally, cloud application server 228 and cloud application client 218 may be respectively configured to enable cloud application server 228 to provide commands, such as configuration commands, to cloud application client 218 to configure mobile client computing device 202, to enable cloud server 204 to execute an application on behalf of mobile client computing device 202. An example command may include, but is not limited to, screen resolution setting for mobile client computing device 202. Additional examples may include cloud application server 228 sending QoS control commands to cloud application client 218, e.g., to warn mobile client computing device 102 that current network is unstable and cloud server 104 has a need to decrease video resolution. Further examples may include cloud application client 218 sending video decoding failure to cloud application server 228, and cloud application server 228 would resend next instantaneous decoder refresh (IDR) frame and send command to ask cloud application client 218 to correct video decoding.

    [0024] In embodiments, cloud application server 228 may further include screen encoder 242, audio encoder 244, instrumentation module 246 and one or more remote sensors 248, whereas, cloud application client 218 may further include video decoder 232, audio decoder 234, on touch listener 236 and one or more sensor event listeners 238, to correspondingly cooperate with each other to facilitate execution of the application by cloud server 204 for mobile client computing device 202.

    [0025] More specifically, screen encoder 242, audio encoder 244, video decoder 232 and audio decoder 234 may be configured to enable screen encoder 242 and audio encoder 244 to respectively interact with video decoder 232 and audio decoder 234, to allow video and audio streams that capture the output of the application to be provided to mobile client computing device 202. On touch listener 236, sensor event listeners 238, instrumentation module 246 and remote sensors 248 may be configured to enable on touch listener 236 and sensor event listeners 238 to respectively interact with instrumentation module 246 and remote sensors 248 to provide touch, key and/or sensor events from mobile client device 202 to cloud server 204 as inputs to the application executing on cloud server 204.

    [0026] Referring now Figures 3 and 4, wherein the computing environments of the mobile client computing device (including the cloud application client) and cloud server (including cloud application server), according to various embodiments, are illustrated in further detail. As shown, for the example embodiments, mobile client computing device 102 and cloud server 104 may both operate e.g., an Android system 340 and 450. Android systems 340 and 450 may respectively include display surfaces 342 and 452, audio outputs 344 and 454, sensors (such as accelerometers and gyroscopes) 346 and 456. Android system 340 may also include touch sensor 348.

    [0027] For cloud server 104, cloud application server 228, in addition to screen encoder 242, audio encoder 244, instrumentation module 246 and remote sensor 248, may further include on demand composer 442 and audio recorder 444, coupled with each other as shown. For mobile client computing device 102, cloud application client 218, in addition to video decoder 232, audio decoder 234, on touch listener 236 and sensor event listener 238, may include a number of media codecs 332, coupled with each other as shown.

    [0028] In embodiments, on demand composer 442 may be configured to accelerate composition of the display surface of cloud server 104 while executing application 126. In particular, on demand composer 442 may be configured to compose the display surface of cloud server 104 with a reduced number of layer images. Referring now also to Figure 5 where Android system 450 of cloud server 104, according to various embodiments, is illustrated in further detail. As shown, Android system 450, in addition to application 126 being executed for mobile client computing device 102, may include a number of buffer queues 556 and 558, SurfaceFlinger 554, and hardware composer (e.g., a graphics co-processor) 552, coupled with each other. During conventional operation, SurfaceFlinger 554 would cooperate with hardware composer 552 to combine the various layer images and display overlays to compose display surface 452. To reduce the latency perceived by mobile client computing device 102, in embodiments, on demand composer 442 may be configured to copy the substantive layer images 562 and 564 from SurfaceFlinger 554, compose a substitute display surface which will be displayed on client with the copied layer images 562 and 564, and cancel the composition normally performed by hardware composer 552.

    [0029] Continuing to refer to Figures 3 and 4, screen encoder 242 may be configured to continuously encode the display surface composed by on demand composer 442 into video frames to form a video stream, and transmit the video stream to its counterpart (video decoder 232). The display surface may be encoded into a video stream employing any one of a number of video encoding schemes. Audio recorder 444 may be configured to record audio output of cloud server 104, while executing application 126 for mobile client computing device 102. Audio encoder 244 may be configured to encode the audio recording into an audio stream, and transmit the audio stream to its counterpart (audio decoder 234). The audio outputs may be encoded into an audio stream employing any one of a number of audio encoding schemes.

    [0030] Video decoder 232 and audio decoder 234 may be respectively configured to decode the video and audio streams to recover the displays and audio outputs of application 126, and provide them to media codecs 332. Media codecs 332 may be configured to render the recovered displays and audio outputs as display surface 342 and audio output 344.

    [0031] On the input side, on touch listener 236 may be configured to listen for touch or key events sensed by touch sensor 348. On detection of touch or key events, on touch listener 236 may forward the touch or key events to its counterpart (instrumentation module 246). On receipt, instrumentation module 246 may forward the touch or key events to application 126 as inputs.

    [0032] Similarly, sensor event listeners 238 may be configured to listen for sensor events sensed by various sensors 346 (e.g., accelerometer or gyroscope). On detection of sensor events, sensor event listeners 238 may forward the sensor events to its counterpart (remote sensor 248). On receipt, sensor listeners 248 may forward the respective sensors 456, to cause them to output corresponding events for application 126 as inputs.

    [0033] Referring now to Figure 6, wherein an example cluster of cloud servers, suitable for practicing the present disclosure, according to various embodiments, is illustrated. As shown, computing cluster 600 may include one or more log in servers 602, a number of "thin" cloud servers 604a-604d, and one or more data servers 606. Log in server(s) 602 may be configured to facilitate a mobile client computing device 102 in logging into the cluster 600, and run an application. Data server(s) 606 may be configured to host a number of applications, e.g., Android applications (denoted as 1_A and 1_B) or Window applications (denoted as 2_A and 2 B), persistent data of mobile client computing devices (across multiple execution sessions). Log in server(s) 602 and data server(s) 606 may be any one of a number of servers known in the art.

    [0034] Each "thin" cloud server 604a - 604d may be configured to host execution of one application for one mobile client computing device at any one point in time. In embodiments, each "thin" cloud server 604a - 604d may be an Atom device configured with an Atom processor from Intel Corporation of Santa Clara, CA, which is an ultra-low-voltage IA-32 and x86-64 CPUs (or microprocessors), an Android system 540, and cloud application server 228.

    [0035] Accordingly, computing cluster 600 may provide cloud computing of applications for mobile client computing devices 102, without the complexity and cost of employing conventional high power servers that typically require sophisticated server software, such as virtual machine managers (VMM) or hypervisors.

    [0036] Figure 7 illustrates an example computer system that may be suitable for use to practice selected aspects of the present disclosure. As shown, computer 700 may include one or more processors or processor cores 702, and system memory 704. When employed as a "thin" cloud server 604a-604d of computing cluster 600, processor 702 may be a processor from the Atom processor family of Intel® Corporation. For the purpose of this application, including the claims, the term "processor" refers to a physical processor, and the terms "processor" and "processor cores" may be considered synonymous, unless the context clearly requires otherwise. Additionally, computer 700 may include mass storage devices 706 (such as diskette, hard drive, compact disc read only memory (CD-ROM) and so forth), input/output devices 708 (such as display, keyboard, cursor control and so forth) and communication interfaces 710 (such as network interface cards, modems and so forth). The elements may be coupled to each other via system bus 712, which may represent one or more buses. In the case of multiple buses, they may be bridged by one or more bus bridges (not shown).

    [0037] Each of these elements may perform its conventional functions known in the art. In particular, system memory 704 and mass storage devices 706 may be employed to store a working copy and a permanent copy of the programming instructions implementing the operations associated with cloud application server 228 or cloud application client 218, earlier described, collectively referred to as computational logic 722. The various elements may be implemented by assembler instructions supported by processor(s) 702 or high-level languages, such as, for example, C, that can be compiled into such instructions.

    [0038] The number, capability and/or capacity of these elements 710 - 712 may vary, depending on whether computer 700 is used as a mobile client computing device, a log in server, a data server or a "thin" cloud server. When use as mobile client computing device, the capability and/or capacity of these elements 710 - 712 may vary, depending on whether the mobile client computing device is a wearable device, a smartphone, a computing tablet, an ultrabook or a laptop computer. Otherwise, the constitutions of elements 710-712 are known, and accordingly will not be further described.

    [0039] As will be appreciated by one skilled in the art, the present disclosure may be embodied as methods or computer program products. Accordingly, the present disclosure, in addition to being embodied in hardware as earlier described, may take the form of an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to as a "circuit," "module" or "system." Furthermore, the present disclosure may take the form of a computer program product embodied in any tangible or non-transitory medium of expression having computer-usable program code embodied in the medium. Figure 6 illustrates an example computer-readable non-transitory storage medium that may be suitable for use to store instructions that cause an apparatus, in response to execution of the instructions by the apparatus, to practice selected aspects of the present disclosure. As shown, non-transitory computer-readable storage medium 802 may include a number of programming instructions 804. Programming instructions 804 may be configured to enable a device, e.g., computer 700, in response to execution of the programming instructions, to perform operations associated with cloud application server 228 and/or cloud application client 218. In alternate embodiments, programming instructions 804 may be disposed on multiple computer-readable non-transitory storage media 802 instead. In alternate embodiments, programming instructions 804 may be disposed on computer-readable transitory storage media 802, such as, signals.

    [0040] Any combination of one or more computer usable or computer readable medium(s) may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non- exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device. Note that the computer- usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer- usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave. The computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.

    [0041] Computer program code for carrying out operations of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the "C" programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).

    [0042] The present disclosure is described with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.

    [0043] These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.

    [0044] The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.

    [0045] The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.

    [0046] The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. As used herein, the singular forms "a," "an" and "the" are intended to include plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms "comprises" and/or "comprising," when used in this specification, specific the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operation, elements, components, and/or groups thereof.

    [0047] Embodiments may be implemented as a computer process, a computing system or as an article of manufacture such as a computer program product of computer readable media. The computer program product may be a computer storage medium readable by a computer system and encoding a computer program instructions for executing a computer process.

    [0048] The corresponding structures, material, acts, and equivalents of all means or steps plus function elements in the claims below are intended to include any structure, material or act for performing the function in combination with other claimed elements are specifically claimed. The description of the present disclosure has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the disclosure in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill without departing from the scope and spirit of the disclosure. The embodiment was chosen and described in order to best explain the principles of the disclosure and the practical application, and to enable others of ordinary skill in the art to understand the disclosure for embodiments with various modifications as are suited to the particular use contemplated.

    [0049] Referring back to Figure 7, for one embodiment, at least one of processors 702 may be packaged together with memory having computational logic 722 (in lieu of storing on memory 704 and storage 706). For one embodiment, at least one of processors 702 may be packaged together with memory having computational logic 722 to form a System in Package (SiP). For one embodiment, at least one of processors 702 may be integrated on the same die with memory having computational logic 722. For one embodiment, at least one of processors 702 may be packaged together with memory having computational logic 722 to form a System on Chip (SoC). For at least one embodiment, the SoC may be utilized in, e.g., but not limited to, a smartphone or computing tablet.

    [0050] While the disclosure has been shown and described with reference to various embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the scope of the disclosure as defined by the appended claims.


    Claims

    1. A cloud server (104) for mobile cloud computing, comprising:

    one or more processors (120);

    a mobile computing operating system (450) to be operated by the one or more processors (120) to host execution of an application (126); and

    a cloud application server (128) to be operated by the one or more processors (120) to interact with a cloud application client (118) of a mobile client device (102) to:

    provide audio and video streams to the mobile client device (102), said streams comprising audio outputs and displays of the application (126) that is executed on the cloud server (104),

    receive touch or key events from a touch listener (236) of the cloud application client (218), and forward the touch or key events as inputs to the application (126) that is executed on the cloud server (104), and

    receive sensor events from a sensor event listener (238) of the cloud application client (118) that is configured to listen for sensor events sensed by sensors (346) of the mobile client device (102) and output corresponding events as inputs to the application (126) that is executed on the cloud server (104), wherein the sensors (346) comprise one or more of: an accelerometer, a gyroscope, and a global positioning sensor,

    so as to enable the application (126) to be executed on the cloud server (104) for the mobile client device (102),

    wherein the cloud application server (128) comprises an on demand composer (442) to accelerate composition of the display surface of the cloud server (104) executing the application (126), wherein the on demand composer composes the display surface using a reduced number of layer images used by a composer of the operating system (450) to compose the display surface by composing the display surface as a substitute display surface that comprises substantive layer images (562, 564), while cancelling the composition of these substantive layer images (562, 564) with display overlays that is normally performed by a hardware composer (552).


     
    2. The cloud server (104) of claim 1, wherein the cloud application server (128, 228) includes an on demand composer (442) to continuously compose a display surface of the cloud server (104) executing the application (126), wherein the on demand composer (442) composes the display surface using a reduced number of layer images used by a composer (552) of the operating system to compose the display surface.
     
    3. The cloud server (104) of claim 2, wherein the cloud application server (128, 228) further includes a screen encoder (242) to continuously encode the display surface into a video stream, and transmit the video stream to a video decoder of the cloud application client of the mobile client device.
     
    4. The cloud server (104) of claim 1, wherein the cloud application server (128, 228) includes an instrumentation module (246) to receive, on behalf of the application (126), touch or key events, from a touch or key event listener (236) of the cloud application client (118) of the mobile client device (102).
     
    5. The cloud server (104) of any one of claims 1-4, 9 and 10, wherein the cloud server (104) is to execute one application (126) for one mobile client device (102) at a time.
     
    6. A method for mobile cloud computing, comprising:

    executing an application (126), by a cloud server (104) having a mobile computing operating system (450), on behalf of a mobile client device (102), the operating system (450) being arranged to compose a display surface of the application (126) using a number of layer images;

    interacting, using a cloud application client (118) to be operated by one or more processors (112) of the mobile client device (102), with a cloud application server (128) of the cloud server (104), wherein this interacting comprises:

    composing, by an on demand composer (442) of the cloud application server (128), the display surface of the cloud server (104) executing the application (126) using a reduced number of layer images used by a composer of the operating system (450) to compose the display surface, so as to accelerate composition of the display surface by composing the display surface as a substitute display surface that comprises substantive layer images (562, 564), while cancelling the composition of these substantive layer images (562, 564) with display overlays that is normally performed by a hardware composer (552);

    receiving, by the cloud application client (118), audio and video streams from the cloud server (104), said streams comprising audio inputs and displays of the application (126) that is executed on the cloud server (104),

    listening, by the cloud application client (118), by means of a touch listener (236), for touch or key events, and sending the touch or key events to the cloud application server (128), and

    listening, by the cloud application client (118), by means of a sensor event listener (238), for sensor events sensed by sensors (346) of the mobile client device (102), and sending the sensor events to the cloud application server (128), wherein the sensors (346) comprise one or more of: an accelerometer, a gyroscope, and a global positioning sensor.


     
    7. The method of claim 6, further comprising: continuously receiving, by a video decoder (232) of the cloud application client, a video stream of an encoded recording of a display surface of the cloud server (104) while the cloud server (104) is executing the application (126), and decoding the video stream to recover the display surface for display on the mobile client device (102).
     
    8. The method of claim 6, 7 or 11, further comprising: listening, by the listener (236) of the cloud application client (118), for touch or key events of the mobile client device (102), and sending the touch or key events to an instrumentation module (246) of the cloud application server (104) for input to the application (126).
     
    9. The cloud server (104) of claim 2, wherein the cloud application server (128, 228) further includes an audio recorder (444) to continuously generate a recording of audio outputs of the cloud server (104) executing the application (126), and an audio encoder (244) coupled to the audio recorder (444) to encode the recording into an audio stream, and transmit the audio stream to an audio decoder (234) of the cloud application client (118) of the mobile client device (102).
     
    10. The cloud server (104) of claim 1, wherein the cloud application server further includes a remote sensor (248) to receive, on behalf of the application (126), sensor events, from a sensor event listener (238) of the cloud application client (118) of the mobile client device (102).
     
    11. The method of claim 6, further comprising: continuously receiving, by an audio decoder (234) of the cloud application client (118), an audio stream of an encoded recording of audio outputs of the server (104) while the server (104) is executing the application (126), and decoding the audio stream to recover the audio outputs for output on the mobile client device (102).
     
    12. The method of claim 6, 7 or 11, further comprising: listening, by the sensor event listener (238) of the cloud application client (118), for sensor events of the mobile client device (102), and sending the sensor events to a remote sensor (248) of the cloud application server for input to the application (126).
     


    Ansprüche

    1. Cloud-Server (104) für mobiles Cloud-Computing, der aufweist:

    einen oder mehrere Prozessoren (120);

    ein Mobile-Computing-Betriebssystem (450), das von dem einen oder den mehreren Prozessoren (120) zum Hosten der Ausführung einer Anwendung (126) zu betreiben ist; und

    einen Cloud-Anwendungs-Server (128), der von dem einen oder den mehreren Prozessoren (120) zum Zusammenwirken mit einem Cloud-Anwendungs-Client (118) einer mobilen Client-Vorrichtung (102) zu betreiben ist, um:

    der mobilen Client-Vorrichtung (102) Audiound Video-Streams bereitzustellen, wobei die Streams Audioausgaben und Anzeigen der Anwendung (126) umfassen, die auf dem Cloud-Server (104) ausgeführt wird,

    Berührungs- oder Tastenereignisse von einem Berührungs-Listener (236) des Cloud-Anwendungs-Clients (218) zu empfangen und die Berührungs- oder Tastenereignisse als Eingaben an die Anwendung (126), die auf dem Cloud-Server (104) ausgeführt wird, weiterzuleiten und

    Sensorereignisse von einem Sensorereignis-Listener (238) des Cloud-Anwendungs-Clients (118) zu empfangen, der dazu ausgebildet ist, für Sensorereignisse wachsam zu sein, die von Sensoren (346) der mobilen Client-Vorrichtung (102) erfasst werden, und entsprechende Ereignisse als Eingaben an die Anwendung (126) auszugeben, die auf dem Cloud-Server (104) ausgeführt wird, wobei die Sensoren (346) einen oder mehrere umfassen von: einem Beschleunigungsmesser, einem Gyroskop und einem Sensor für globale Positionsbestimmung,

    um zu ermöglichen, dass die Anwendung (126) auf dem Cloud-Server (104) für die mobile Client-Vorrichtung (102) ausgeführt wird,

    wobei der Cloud-Anwendungs-Server (128) einen On-Demand-Zusammensteller (442) zum Beschleunigen der Zusammenstellung der Anzeigeoberfläche des Cloud-Servers (104), der die Anwendung (126) ausführt, aufweist, wobei der On-Demand-Zusammensteller die Anzeigeoberfläche unter Verwendung einer reduzierten Anzahl von Ebenenbildern zusammenstellt, die von einem Zusammensteller des Betriebssystems (450) verwendet werden, um die Anzeigeoberfläche durch Zusammenstellen der Anzeigeoberfläche als eine Ersatzanzeigeoberfläche zusammenzustellen, die wesentliche Ebenenbilder (562, 564) aufweist, während die Zusammenstellung dieser wesentlichen Ebenenbilder (562, 564) mit Anzeigeüberlagerungen, die normalerweise von einem Hardware-Zusammensteller (552) durchgeführt wird, aufgehoben wird.


     
    2. Cloud-Server (104) nach Anspruch 1, wobei der Cloud-Anwendungs-Server (128, 228) einen On-Demand-Zusammensteller (442) zum laufenden Zusammenstellen einer Anzeigeoberfläche des Cloud-Servers (104), der die Anwendung (126) ausführt, umfasst, wobei der On-Demand-Zusammensteller (442) die Anzeigeoberfläche unter Verwendung einer reduzierten Anzahl von Ebenenbildern zusammenstellt, die von einem Zusammensteller (552) des Betriebssystems verwendet werden, um die Anzeigeoberfläche zusammenzustellen.
     
    3. Cloud-Server (104) nach Anspruch 2, wobei der Cloud-Anwendungs-Server (128, 228) ferner einen Bildschirmcodierer (242) zum laufenden Codieren der Anzeigeoberfläche in einen Video-Stream und Übertragen des Video-Streams an einen Videodecodierer des Cloud-Anwendungs-Clients der mobilen Client-Vorrichtung umfasst.
     
    4. Cloud-Server (104) nach Anspruch 1, wobei der Cloud-Anwendungs-Server (128, 228) ein Instrumentierungsmodul (246) zum Empfangen von Berührungs- oder Tastenereignissen von einem Berührungs- oder Tastenereignis-Listener (236) des Cloud-Anwendungs-Clients (118) der mobilen Client-Vorrichtung (102) im Auftrag der Anwendung (126) umfasst.
     
    5. Cloud-Server (104) nach einem der Ansprüche 1-4, 9 und 10, wobei der Cloud-Server (104) dafür vorgesehen ist, eine Anwendung (126) für eine mobile Client-Vorrichtung (102) zu einer Zeit auszuführen.
     
    6. Verfahren für mobiles Cloud-Computing, das umfasst:

    Ausführen einer Anwendung (126) durch einen Cloud-Server (104) mit einem Mobile-Computing-Betriebssystem (450) im Auftrag einer mobilen Client-Vorrichtung (102), wobei das Betriebssystem (450) dazu eingerichtet ist, eine Anzeigeoberfläche der Anwendung (126) unter Verwendung einer Anzahl von Ebenenbildern zusammenzustellen;

    Zusammenwirken mit einem Cloud-Anwendungs-Server (128) des Cloud-Servers (104) unter Verwendung eines Cloud-Anwendungs-Clients (118), der von einem oder mehreren Prozessoren (112) der mobilen Client-Vorrichtung (102) zu betreiben ist, wobei dieses Zusammenwirken umfasst:

    Zusammenstellen der Anzeigeoberfläche des Cloud-Servers (104), der die Anwendung (126) ausführt, durch einen On-Demand-Zusammensteller (442) des Cloud-Anwendungs-Servers (128) unter Verwendung einer reduzierten Anzahl von Ebenenbildern, die von einem Zusammensteller des Betriebssystems (450) verwendet werden, um die Anzeigeoberfläche zusammenzustellen, um die Zusammenstellung der Anzeigeoberfläche durch Zusammenstellen der Anzeigeoberfläche als eine Ersatzanzeigeoberfläche, die wesentliche Ebenenbilder (562, 564) aufweist, zu beschleunigen, während die Zusammenstellung dieser wesentlichen Ebenenbilder (562, 564) mit Anzeigeüberlagerungen, die normalerweise von einem Hardware-Zusammensteller (552) durchgeführt wird, aufgehoben wird;

    Empfangen von Audio- und Video-Streams von dem Cloud-Server (104) durch den Cloud-Anwendungs-Client (118), wobei die Streams Audioeingaben und Anzeigen der Anwendung (126) umfassen, die auf dem Cloud-Server (104) ausgeführt wird,

    Wachsamkeit für Berührungs- oder Tastenereignisse durch den Cloud-Anwendungs-Client (118) mittels eines Berührungs-Listeners (236) und Senden der Berührungs- oder Tastenereignisse an den Cloud-Anwendungs-Server (128) und

    Wachsamkeit für Sensorereignisse, die von Sensoren (346) der mobilen Client-Vorrichtung (102) erfasst werden, durch den Cloud-Anwendungs-Client (118) mittels eines Sensorereignis-Listeners (238) und Senden der Sensorereignisse an den Cloud-Anwendungs-Server (128), wobei die Sensoren (346) einen oder mehrere umfassen von: einem Beschleunigungsmesser, einem Gyroskop und einem Sensor für globale Positionsbestimmung.


     
    7. Verfahren nach Anspruch 6, das ferner aufweist: laufendes Empfangen eines Video-Streams einer codierten Aufzeichnung einer Anzeigeoberfläche des Cloud-Servers (104) durch einen Videodecodierer (232) des Cloud-Anwendungs-Clients, während der Cloud-Server (104) die Anwendung (126) ausführt, und Decodieren des Video-Streams zum Rückgewinnen der Anzeigeoberfläche zum Anzeigen auf der mobilen Client-Vorrichtung (102).
     
    8. Verfahren nach Anspruch 6, 7 oder 11, das ferner umfasst: Wachsamkeit für Berührungs- oder Tastenereignisse der mobilen Client-Vorrichtung (102) durch den Listener (236) des Cloud-Anwendungs-Clients (118) und Senden der Berührungs- oder Tastenereignisse an ein Instrumentierungsmodul (246) des Cloud-Anwendungs-Servers (104) zur Eingabe an die Anwendung (126) .
     
    9. Cloud-Server (104) nach Anspruch 2, wobei der Cloud-Anwendungs-Server (128, 228) ferner eine Audio-Aufzeichnungseinrichtung (444) zum laufenden Erzeugen einer Aufzeichnung von Audioausgaben des Cloud-Servers (104), der die Anwendung (126) ausführt, umfasst und einen Audiocodierer (244), der mit der Audio-Aufzeichnungseinrichtung (444) gekoppelt ist, um die Aufzeichnung in einen Audio-Stream zu codieren und den Audio-Stream an einen Audiodecodierer (234) des Cloud-Anwendungs-Clients (118) der mobilen Client-Vorrichtung (102) zu übertragen.
     
    10. Cloud-Server (104) nach Anspruch 1, wobei der Cloud-Anwendungs-Server ferner einen Fernsensor (248) zum Empfangen von Sensorereignissen von einem Sensorereignis-Listener (238) des Cloud-Anwendungs-Clients (118) der mobilen Client-Vorrichtung (102) im Auftrag der Anwendung (126) umfasst.
     
    11. Verfahren nach Anspruch 6, das ferner umfasst: laufendes Empfangen eines Audio-Streams einer codierten Aufzeichnung von Audioausgaben des Servers (104) durch einen Audiodecodierer (234) des Cloud-Anwendungs-Clients (118), während der Server (104) die Anwendung (126) ausführt, und Decodieren des Audio-Streams zum Rückgewinnen der Audioausgaben zur Ausgabe auf der mobilen Client-Vorrichtung (102).
     
    12. Verfahren nach Anspruch 6, 7 oder 11, das ferner umfasst: Wachsamkeit für Sensorereignisse der mobilen Client-Vorrichtung (102) durch den Sensorereignis-Listener (238) des Cloud-Anwendungs-Clients (118) und Senden der Sensorereignisse an einen Fernsensor (248) des Cloud-Anwendungs-Servers zur Eingabe an die Anwendung (126) .
     


    Revendications

    1. Serveur d'informatique en nuage (104) pour informatique mobile en nuage, comprenant :

    un ou plusieurs processeurs (120),

    un système d'exploitation informatique mobile (450) devant être mis en œuvre par le ou les processeurs (120) pour héberger l'exécution d'une application (126), et

    un serveur d'applications en nuage (128) devant être mis en œuvre par le ou les processeurs (120) pour interagir avec un client d'application en nuage (118) d'un dispositif client mobile (102) pour :

    fournir des flux audio et vidéo au dispositif client mobile (102), lesdits flux comprenant des sorties audio et des affichages de l'application (126) qui est exécutée sur le serveur d'informatique en nuage (104),

    recevoir des événements tactiles ou par clavier d'un auditeur tactile (236) du client d'application en nuage (218), et transférer les événements tactiles ou par clavier sous forme d'entrées vers l'application (126) qui est exécutée sur le serveur d'informatique en nuage (104), et

    recevoir des événements de détection d'un auditeur d'événements de détection (238) du client d'application en nuage (118) qui est configuré pour écouter des événements de détection captés par des capteurs (346) du dispositif client mobile (102), et délivrer des événements correspondants sous forme d'entrées vers l'application (126) qui est exécutée sur le serveur d'informatique en nuage (104), les capteurs (346) comprenant un ou plusieurs parmi : un accéléromètre, un gyroscope et un capteur de positionnement universel,

    de sorte à permettre l'exécution de l'application (126) sur le serveur d'informatique en nuage (104) pour le dispositif client mobile (102),

    dans lequel le serveur d'applications en nuage (128) comprend un dispositif de composition à la demande (442) permettant d'accélérer la composition de la surface d'affichage du serveur d'informatique en nuage (104) qui exécute l'application (126), le dispositif de composition à la demande composant la surface d'affichage en utilisant un nombre réduit d'images en couches utilisées par le dispositif de composition du système d'exploitation (450) pour composer la surface d'affichage en composant la surface d'affichage comme un surface d'affichage par substitution qui comprend des images de couche de fond (562, 564), tout en annulant la composition de ces images de couche de fond (562, 564) avec des superpositions d'affichage qui sont normalement effectuées par un dispositif matériel de composition (552) .


     
    2. Serveur d'informatique en nuage (104) selon la revendication 1, dans lequel le serveur d'applications en nuage (128, 228) inclut un dispositif de composition à la demande (442) destiné à composer de façon continue une surface d'affichage du serveur d'informatique en nuage (104) qui exécute l'application (126), le dispositif de composition à la demande (442) composant la surface d'affichage en utilisant un nombre réduit d'images en couches utilisées par un dispositif de composition (552) du système d'exploitation pour composer la surface d'affichage.
     
    3. Serveur d'informatique en nuage (104) selon la revendication 2, dans lequel le serveur d'applications en nuage (128, 228) inclut en outre un codeur d'écran (242) destiné à coder de façon continue la surface d'affichage en un flux vidéo, et à transmettre le flux vidéo à un décodeur vidéo du client d'application en nuage du dispositif client mobile.
     
    4. Serveur d'informatique en nuage (104) selon la revendication 1, dans lequel le serveur d'applications en nuage (128, 228) inclut en outre un module d'instrumentation (246) destiné à recevoir, pour le compte de l'application (126), des événements tactiles ou par clavier, d'un auditeur d'événements tactiles ou par clavier (236) du client d'application en nuage (118) du dispositif client mobile (102).
     
    5. Serveur d'informatique en nuage (104) selon l'une quelconque des revendications 1 à 4, 9 et 10, le serveur d'informatique en nuage (104) étant destiné à exécuter une seule application (126) pour un seul dispositif client mobile (102) à la fois.
     
    6. Procédé destiné à l'informatique mobile en nuage, comprenant :

    l'exécution d'une application (126), par un serveur d'informatique en nuage (104) comportant un système d'exploitation d'informatique mobile (450), pour le compte d'un dispositif client mobile (102), le système d'exploitation (450) étant agencé pour composer une surface d'affichage de l'application (126) en utilisant un certain nombre d'images en couches,

    l'interaction, en utilisant un client d'application en nuage (118) devant être mis en œuvre par un ou plusieurs processeurs (112) du dispositif client mobile (102), avec un serveur d'applications en nuage (128) du serveur d'informatique en nuage (104), cette interaction comprenant :

    la composition, par un dispositif de composition à la demande (442) du serveur d'applications en nuage (128), de la surface d'affichage du serveur d'informatique en nuage (104) qui exécute l'application (126) en utilisant un nombre réduit d'images en couches utilisées par un dispositif de composition du système d'exploitation (450) afin de composer la surface d'affichage, de sorte à accélérer la composition de la surface d'affichage en composant la surface d'affichage sous forme d'une surface d'affichage de substitution qui comprend des images de couche de fond (562, 564), tout en annulant la composition de ces images de couche de fond (562, 564) avec des superpositions d'affichage qui sont normalement effectuées par un dispositif matériel de composition (552),

    la réception, par le client d'application en nuage (118), de flux audio et vidéo provenant du serveur d'informatique en nuage (104), lesdits flux comprenant des entrées audio et des affichages de l'application (126) qui est exécutée sur le serveur d'informatique en nuage (104),

    l'écoute, par le client d'application en nuage (118), au moyen d'un auditeur tactile (236), d'événements tactiles ou par clavier, et l'envoi des événements tactiles ou par clavier au serveur d'applications en nuage (128), et

    l'écoute, par le client d'application en nuage (118), au moyen d'un auditeur d'événements de détection (238), d'événements de détection captés par des capteurs (346) du dispositif client mobile (102), et l'envoi des événements de détection au serveur d'applications en nuage (128), les capteurs (346) comprenant un ou plusieurs parmi : un accéléromètre, un gyroscope est un capteur de positionnement universel.


     
    7. Procédé selon la revendication 6, comprenant en outre : la réception de façon continue, par un décodeur vidéo (232) du client d'application en nuage, d'un flux vidéo d'un enregistrement codé d'une surface d'affichage du serveur d'informatique en nuage (104) alors que le serveur d'informatique en nuage (104) exécute l'application (126), et le décodage du flux vidéo pour récupérer la surface d'affichage en vue d'un affichage sur le dispositif client mobile (102).
     
    8. Procédé selon la revendication 6, la revendication 7 ou la revendication 11, comprenant en outre : l'écoute, par l'auditeur (236) du client d'application en nuage (118), d'événements tactiles ou par clavier du dispositif client mobile (102), et l'envoi des événements tactiles ou par clavier à un module d'instrumentation (246) du serveur d'informatique en nuage (104) en vue d'une entrée sur l'application (126).
     
    9. Serveur d'informatique en nuage (104) selon la revendication 2, dans lequel le serveur d'applications en nuage (128, 228) inclut en outre un enregistreur audio (444) destiné à générer de façon continue un enregistrement de sorties audio du serveur d'informatique en nuage (104) qui exécute l'application (126), ainsi qu'un codeur audio (244) couplé à l'enregistreur audio (444) afin de coder l'enregistrement en un flux audio et transmettre le flux audio à un décodeur audio (234) du client d'application en nuage (118) du dispositif client mobile (102).
     
    10. Serveur d'informatique en nuage (104) selon la revendication 1, dans lequel le serveur d'applications en nuage inclut en outre un capteur distant (248) destiné à recevoir, pour le compte de l'application (126), des événements de détection d'un auditeur d'événements de détection (238) du client d'application en nuage (118) du dispositif client mobile (102).
     
    11. Procédé selon la revendication 6, comprenant en outre : la réception de façon continue, par un décodeur audio (234) du client d'application en nuage (118), d'un flux audio d'un enregistrement codé de sorties audio du serveur (104) alors que le serveur (104) exécute l'application (126), et le décodage du flux audio pour récupérer les sorties audio en vue d'une délivrance sur le dispositif client mobile (102).
     
    12. Procédé selon la revendication 6, la revendication 7 ou la revendication 11, comprenant en outre : l'écoute, par l'auditeur d'événements de détection (238) du client d'application en nuage (118), d'événements de détection du dispositif client mobile (102), et l'envoi des événements de détection à un capteur distant (248) du serveur d'applications en nuage en vue d'une réception en entrée sur l'application (126).
     




    Drawing





























    Cited references

    REFERENCES CITED IN THE DESCRIPTION



    This list of references cited by the applicant is for the reader's convenience only. It does not form part of the European patent document. Even though great care has been taken in compiling the references, errors or omissions cannot be excluded and the EPO disclaims all liability in this regard.

    Patent documents cited in the description