US8983536B2 - Resource management in a multi-operating environment - Google Patents

Resource management in a multi-operating environment Download PDF

Info

Publication number
US8983536B2
US8983536B2 US13/052,514 US201113052514A US8983536B2 US 8983536 B2 US8983536 B2 US 8983536B2 US 201113052514 A US201113052514 A US 201113052514A US 8983536 B2 US8983536 B2 US 8983536B2
Authority
US
United States
Prior art keywords
memory
threshold
computing
reached
communication device
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US13/052,514
Other versions
US20120102495A1 (en
Inventor
Vamshika R Gangam
Joshua D Galicia
Su-Yin Gan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google Technology Holdings LLC
Original Assignee
Google Technology Holdings LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Google Technology Holdings LLC filed Critical Google Technology Holdings LLC
Priority to US13/052,514 priority Critical patent/US8983536B2/en
Assigned to MOTOROLA MOBILITY, INC. reassignment MOTOROLA MOBILITY, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: GALICIA, JOSHUA D., GAN, SU-YIN, GANGAM, VAMSHIKA R.
Priority to PCT/US2011/051904 priority patent/WO2012054156A2/en
Publication of US20120102495A1 publication Critical patent/US20120102495A1/en
Assigned to MOTOROLA MOBILITY LLC reassignment MOTOROLA MOBILITY LLC CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: MOTOROLA MOBILITY, INC.
Assigned to Google Technology Holdings LLC reassignment Google Technology Holdings LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MOTOROLA MOBILITY LLC
Priority to US14/617,024 priority patent/US9489240B2/en
Application granted granted Critical
Publication of US8983536B2 publication Critical patent/US8983536B2/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • G06F9/5022Mechanisms to release resources
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/485Task life-cycle, e.g. stopping, restarting, resuming execution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3037Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a memory, e.g. virtual memory, cache
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/32Monitoring with visual or acoustical indication of the functioning of the machine

Definitions

  • FIG. 2 is a block diagram representing an exemplary multi-operating environment
  • FIG. 4D shows an exemplary webscreen for a memory manager in same state as in FIG. 4C along with an exemplary notification.
  • a bubble diagram 300 is shown that identifies memory threshold decisions and functionality in an exemplary multi-operating environment.
  • Memory threshold is determined by realizing the amount of memory necessary to retain stability and functionality for a mobile communication device to operate reliably as though it was operating in a conventional stand-alone real time communication operating environment.
  • variable “x” is designated as low memory threshold and variable “y’ is designated as critical memory threshold.
  • Variable “mem” is designated as the computing environment memory that is currently being used.
  • the memory usage of the computing environment such as Linux-based middleware operating environment 240 in FIG. 2 is below a low threshold and thus is considered to be within normal operating range at bubble 310 (i.e., mem ⁇ x).
  • the disabling of computing functionality in the computing environment can include restricting full web browser access or alternatively restricting partial web browser access by enabling selection of certain web pages to close. Moreover, the disabling of computing functionality will nevertheless allow the user to close windows or applications until at least the memory usage is once again below the low memory threshold (x). This exception to the disabled computing functionality can be accomplished by using a pop-up window, for example, that allows the user to exit applications and web browser tabs in order to free memory (i.e., gain additional unused memory), and also keep critical telephony functions.
  • memory manager 410 illustrates an exemplary critical memory threshold condition (i.e., where memory usage is nearly or substantially depleted).
  • Webscreen 400 is “grayed out”, thus only allowing a user to close memory draining entries 432 within the computing operating environment via buttons or icons 425 .
  • memory manager 410 restricts usage of the mouse or pointer and the keyboard for entering text.
  • memory manager 410 prevents the user from doing anything other than closing open windows or applications in the computing environment.
  • the only exception to this user restriction is when there is an urgent notification like an incoming call, alarm, or message, for example or when webscreen 400 is locked.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Telephone Function (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Telephonic Communication Services (AREA)

Abstract

A method for providing user access to telephony operations in a multi operating environment having memory resources nearly depleted that include determining whether a predetermined first memory threshold of a computing environment has been reached and displaying a user interface corresponding to memory usage; and determining whether a predetermined second memory threshold, greater than the first, of the computing environment has been reached. Restricting computing functionality and allowing user access for telephony operations, corresponding to a mobile device, when the second memory threshold is reached is included as well. Also included is maintaining the computing restriction until the memory usage returns below the second memory threshold.

Description

This is a nonprovisional application claiming the benefit of provisional application, 61/405,894, filed Oct. 22, 2010 under 35 U.S.C. 119(e), whose contents are incorporated by reference herein in their entirety.
FIELD OF THE INVENTION
The present invention relates generally to sharing resources in multi-operating environments. More specifically, the present invention relates to monitoring and managing shared memory resources within a multi-operating environment that includes a mobile communication device.
BACKGROUND
New operational challenges arise when creating multi-operational environment devices (e.g. hardware devices that can include mobile and computing environments on a single device) including: (i) using the memory resources as efficiently as possible in all modes of operation; (ii) maintaining mobile communication or telephony stability and critical functionality while also using the computing environment.
Communication device operating instability can be seen in a multi-operating environment where resources such as memory are shared across the operating environments. Hardware devices can be docked or tethered or exist as peripheral devices during communication or operation within their respective operating environment.
Emulation systems that allow one operating system to control the devices have been thought of as managing resources efficiently. However, other resources such as processor usage are not efficiently handled.
More importantly is controlling the multi-operating environment under critical conditions such as extremely depleted memory resources.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is an exemplary perspective view of a mobile communication device;
FIG. 2 is a block diagram representing an exemplary multi-operating environment;
FIG. 3 is a bubble diagram identifying memory threshold decisions and functionality in an exemplary multi-operating environment;
FIG. 4A shows an exemplary webscreen for a memory manager in one state;
FIG. 4B shows an exemplary webscreen for a memory manager in another state;
FIG. 4C shows an exemplary webscreen for a memory manager in yet another state; and
FIG. 4D shows an exemplary webscreen for a memory manager in same state as in FIG. 4C along with an exemplary notification.
DETAILED DESCRIPTION
Many consumers have experienced instable computing environments and have grown accustomed to dealing with “bugs” in their operating systems. In stark contrast, mobile communication environments are expected to be more robust than typical computing environments, because of the important function of communication on a as needed basis, for example in emergency situations or to give a person's whereabouts to concerned persons. Therefore, there is a challenging opportunity when a mobile communication operating environment is combined with a computing environment on a single platform or kernel. The following discussion describes a way to ensure that devices with these combined capabilities (e.g., mobile tablets/mobile telephones and desktop/laptop computing) remain at least as reliable as the typical mobile telephone.
While the specification concludes with claims defining features of the invention that are regarded as novel and unobvious, it is believed that the invention is 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 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.
Referring to FIG. 1, an exemplary mobile communication device 100, such as a mobile telephone is provided. A front view of mobile communication device 100 is shown in FIG. 1. Mobile device 100 includes an integrated touch panel 102, wherein the integrated touch panel 102 comprises a capacitive touch sensor and an electrophoretic display (EPD). Additionally, physical operational buttons 104 may be included on the mobile communication device.
Referring to FIG. 2, a block diagram is shown of an exemplary multi-operating environment 200 in communication with a solitary Linux kernel 205. The multi-operating environment can include a Linux distribution system, a Linux-based operating system or a non-Linux-based operating system. Device hardware 210, such as mobile telephones, mobile tablets, mobile communication devices, is also in communication with the Linux kernel 205. The multi-operating environment 200 includes a first middleware operating environment 220 and a second middleware operating environment 240 in communication with a single Linux kernel 205. By example, the second middleware operating system environment 240 is a standard Linux distribution (i.e., a computing operating environment) and the first middleware operating system environment 220 is an embedded operating environment intended for use in mobile devices, such as an Android™ operating system. (Open handsetlliance, www.openhandsetalliance.com)
In one embodiment, a Linux distribution operating system 200 is in communication with the Linux kernel 205, which is in communication with the device hardware 210. The device hardware 210 can be a memory storage device (not shown) coupled to a processor (not shown) which stores computer executable instructions which are configured to perform various functions and operations, as described herein.
An exemplary operating system 200 includes Ubuntu® (Canonical Ltd., www.ubuntu.com) for the Linux-based middleware operating environment 240. It is specifically intended that multiple middleware operating system environments co-exist independent of the other(s). Exemplary environments that can be included in multi-operating environment 200 include Android™, Ubuntu® (Canonical Ltd., www.ubuntu.com), standard Linux-based environments, Symbian (Symbian Foundation Ltd., www.symbian.com), and Windows-based environments. In an alternative embodiment, it is envisioned that greater than two operating environments are configured to independently co-exist on the same core kernel 205. However, kernel 205 may be partioned as well.
Referring to FIG. 3, a bubble diagram 300 is shown that identifies memory threshold decisions and functionality in an exemplary multi-operating environment. Memory threshold is determined by realizing the amount of memory necessary to retain stability and functionality for a mobile communication device to operate reliably as though it was operating in a conventional stand-alone real time communication operating environment. Specifically, variable “x” is designated as low memory threshold and variable “y’ is designated as critical memory threshold. Variable “mem” is designated as the computing environment memory that is currently being used. At initialization or start, the memory usage of the computing environment, such as Linux-based middleware operating environment 240 in FIG. 2 is below a low threshold and thus is considered to be within normal operating range at bubble 310 (i.e., mem<x). However, the usage of several applications at once can lead to increased memory usage that will approach bubble 320 (i.e., x>mem<y). When the memory usage crosses the low memory threshold associated with bubble 320 a warning on a graphical user interface for the computing environment (not shown) is displayed for the user. However, full computing functionality within the computing environment is still possible and accessible by the user.
As the user continues to draw upon memory resources by using additional applications and web browsers or web pages, for example, the memory usage will track towards critical at bubble 330 (i.e., mem>y). At this juncture, a warning on the graphical user interface for the computing environment is displayed and computing functionality is disabled while at the same time there remains limited telephony operational functionality within the mobile communicating operating environment (e.g., Android™ as a first middleware operating system environment 220 in FIG. 2). The limited telephony operational functionality can include text, inbound calls, outbound calls, notifications, and images.
The disabling of computing functionality in the computing environment can include restricting full web browser access or alternatively restricting partial web browser access by enabling selection of certain web pages to close. Moreover, the disabling of computing functionality will nevertheless allow the user to close windows or applications until at least the memory usage is once again below the low memory threshold (x). This exception to the disabled computing functionality can be accomplished by using a pop-up window, for example, that allows the user to exit applications and web browser tabs in order to free memory (i.e., gain additional unused memory), and also keep critical telephony functions.
With regard to what the user sees in the computing environment as computing functionality is disabled, one or more selectable icons are disabled or in the alternative an entire webpage can be “grayed-out”. That is the webpage will have no functionality for the user when it is grayed out.
Referring to FIG. 4A, an exemplary webscreen 400 is shown in normal state that includes a memory manager 410 under operation by a controller (not shown). Memory usage for the mobile communicating operating environment is displayed as entry 420. A selectable button or icon 425 is associated with the task manager for the mobile communicating operating environment. Other webscreens or windows that are currently open in webscreen 400 are entries 430. The entries 430 can include social networking webpages, web browsers, photo gallery websites, video replay websites, sporting websites, and email entities, for example. Selectable buttons or icons 425 enable a user to close these open webscreens or windows 435 that are displayed as entries 430. Selectable widgets 437 can also include social networking webpages, web browsers, photo gallery websites, video replay websites, sporting websites, and email entities, for example; along with telephony functions as well.
Referring to FIG. 4B, memory manager 410 illustrates an exemplary low memory threshold condition as low memory notification 412. Low memory notification 412 remains on webscreen 400 until the low memory warning condition ceases. A “More Info” button or icon 413 can open a memory manager application that is in the warning mode.
Referring to FIG. 4C, memory manager 410 illustrates an exemplary critical memory threshold condition (i.e., where memory usage is nearly or substantially depleted). Webscreen 400 is “grayed out”, thus only allowing a user to close memory draining entries 432 within the computing operating environment via buttons or icons 425. In addition, memory manager 410 restricts usage of the mouse or pointer and the keyboard for entering text. Thus, memory manager 410 prevents the user from doing anything other than closing open windows or applications in the computing environment. The only exception to this user restriction is when there is an urgent notification like an incoming call, alarm, or message, for example or when webscreen 400 is locked.
Referring to FIG. 4D, memory manager 410 illustrates an exemplary critical memory threshold condition 412 (i.e., where memory usage is nearly or substantially depleted) and an urgent mobile communication notification window 440 (e.g., an incoming call, text, or image) within the mobile communication operating environment. During this juncture the computing functionality is severely or substantially limited; for example, automatic or manual selection for access or usage of memory draining web browser or specific tabs, select web pages, or windows within the memory draining web browser. However, the user may use either a mouse or keyboard to answer the phone call that is displayed in mobile communication notification window 440. Thereafter, once the call ends, memory manager 410 will further restrict computing functionality until the memory usage returns to below the critical memory threshold (y) as shown in FIG. 3.
Notably, the memory resources of the mobile communication device, i.e., mobile telephone or mobile tablet can also be tracked via a graphical user interface as shown in FIGS. 4A-4D. The user can select a button or icon to display the ongoing memory usage associated primarily with the mobile communication device.
This invention makes a mobile phone that is functioning in a multi-operating environment more stable and more reliable by preventing the user from opening additional windows or starting new applications when memory resources are critically low. This in turn, will help in making sure that the multi-operating environment doesn't crash or fail due to the lack of memory and the invention will also help in preventing missed calls that could inevitably arise in the event of system crash.
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, such as a controller, can be adapted for carrying out the methods described herein. A combination of hardware and software within a processing system can include an application that when 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 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, on 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 as 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).
It is specifically intended that the present invention not be limited to the embodiments and illustrations contained herein, but include modified forms of those embodiments including portions of the embodiments and combinations of elements of different embodiments as come within the scope of the following claims.

Claims (6)

We claim:
1. A method for a communication device including first and second independent operating systems on a common kernel, the first operating system providing telephony operations and the second operating system providing a computing environment, the communication device further including a memory manager, the method comprising:
determining, by the memory manager, that a predetermined first memory threshold of the computing environment has been reached;
in response to determining that the first threshold is reached, displaying, on a user interface of the communication device, memory information when the first threshold has been reached;
determining, by the memory manager, that a predetermined second memory threshold of the computing environment has been reached, the second threshold greater than the first threshold;
in response to determining that the second threshold is reached, the memory manager restricting computing functionality of the second operating system and keeping memory available for telephony operations provided by the first operating system; and
maintaining the computing functionality restriction of the second operating system until the memory usage of the communication device falls below the second memory threshold.
2. The method according to claim 1, wherein the second memory threshold is a critical memory threshold, the communication device generating a memory usage warning while impacting functionality in the computing environment in order to retain telephony operations.
3. The method according to claim 2, wherein the computing functionality impacted includes restricted web browser access.
4. The method according to claim 2, wherein the computing functionality impacted includes restricting web browser access to select web pages.
5. The method according to claim 4, wherein the select web pages are tabbed web pages.
6. The method according to claim 1, wherein the memory is made available for telephony operations including inbound and outbound calling.
US13/052,514 2010-10-22 2011-03-21 Resource management in a multi-operating environment Active 2032-08-02 US8983536B2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
US13/052,514 US8983536B2 (en) 2010-10-22 2011-03-21 Resource management in a multi-operating environment
PCT/US2011/051904 WO2012054156A2 (en) 2010-10-22 2011-09-16 Resource management in a multi-operating environment
US14/617,024 US9489240B2 (en) 2010-10-22 2015-02-09 Resource management in a multi-operating environment

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US40589410P 2010-10-22 2010-10-22
US13/052,514 US8983536B2 (en) 2010-10-22 2011-03-21 Resource management in a multi-operating environment

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US14/617,024 Division US9489240B2 (en) 2010-10-22 2015-02-09 Resource management in a multi-operating environment

Publications (2)

Publication Number Publication Date
US20120102495A1 US20120102495A1 (en) 2012-04-26
US8983536B2 true US8983536B2 (en) 2015-03-17

Family

ID=44774121

Family Applications (2)

Application Number Title Priority Date Filing Date
US13/052,514 Active 2032-08-02 US8983536B2 (en) 2010-10-22 2011-03-21 Resource management in a multi-operating environment
US14/617,024 Expired - Fee Related US9489240B2 (en) 2010-10-22 2015-02-09 Resource management in a multi-operating environment

Family Applications After (1)

Application Number Title Priority Date Filing Date
US14/617,024 Expired - Fee Related US9489240B2 (en) 2010-10-22 2015-02-09 Resource management in a multi-operating environment

Country Status (2)

Country Link
US (2) US8983536B2 (en)
WO (1) WO2012054156A2 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9342325B2 (en) 2012-05-17 2016-05-17 Google Technology Holdings LLC Synchronizing launch-configuration information between first and second application environments that are operable on a multi-modal device
US9348633B2 (en) 2009-07-20 2016-05-24 Google Technology Holdings LLC Multi-environment operating system
US9354900B2 (en) 2011-04-28 2016-05-31 Google Technology Holdings LLC Method and apparatus for presenting a window in a system having two operating system environments
US9367331B2 (en) 2009-07-20 2016-06-14 Google Technology Holdings LLC Multi-environment operating system
US9372711B2 (en) 2009-07-20 2016-06-21 Google Technology Holdings LLC System and method for initiating a multi-environment operating system
US9389877B2 (en) 2009-07-20 2016-07-12 Google Technology Holdings LLC Multi-environment operating system
US9417753B2 (en) 2012-05-02 2016-08-16 Google Technology Holdings LLC Method and apparatus for providing contextual information between operating system environments
US10261565B2 (en) 2014-01-09 2019-04-16 International Business Machines Corporation Enhanced security and resource utilization in a multi-operating system environment

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8868899B2 (en) * 2009-07-20 2014-10-21 Motorola Mobility Llc System and method for switching between environments in a multi-environment operating system
US8983536B2 (en) 2010-10-22 2015-03-17 Google Technology Holdings LLC Resource management in a multi-operating environment
US9396041B2 (en) 2012-02-01 2016-07-19 Google Technology Holdings LLC Optimization of resource usage in a multi-environment computing system
US9032168B2 (en) * 2012-05-31 2015-05-12 Htc Corporation Memory management methods and systems for mobile devices
CN103488640B (en) * 2012-06-11 2017-01-25 北汽福田汽车股份有限公司 Automatic analysis method and device for mapping file
US9799380B2 (en) * 2013-11-05 2017-10-24 Google Inc. Managing open tabs of an application
JP2015106167A (en) * 2013-11-28 2015-06-08 ソニー株式会社 Information processing device, information processing method, and storage medium
US20170017518A1 (en) * 2015-07-18 2017-01-19 Capso Vision, Inc. Method of Automatic Allocation of Processing Power and System Resource for Image Viewing and Processing Application
CN106874108B (en) * 2016-12-28 2021-02-09 广东工业大学 Technology for minimizing number of micro clouds in mobile cloud computing

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1467282A2 (en) 2003-04-09 2004-10-13 Jaluna SA Operating systems
WO2009112896A2 (en) 2008-03-12 2009-09-17 Sony Ericsson Mobile Communications Ab Adaptive video encode scaling
WO2009120598A1 (en) 2008-03-25 2009-10-01 Qualcomm Incorporated Apparatus and methods for widget-related memory management
US20100211769A1 (en) 2009-02-19 2010-08-19 Subramonian Shankar Concurrent Execution of a Smartphone Operating System and a Desktop Operating System
US20110016301A1 (en) 2009-07-20 2011-01-20 Galicia Joshua D System and method for initiating a multi-environment operating system
US20110016299A1 (en) 2009-07-20 2011-01-20 Galicia Joshua D Multi-environment operating system
US20120083264A1 (en) * 2010-09-30 2012-04-05 Apple Inc. Method and apparatus for transport format selection in a mobile wireless device
US8352733B2 (en) * 2006-08-04 2013-01-08 Apple Inc. Resource restriction systems and methods
US20130212283A1 (en) * 2009-08-28 2013-08-15 Microsoft Corporation Resource Sharing in Multi-Principal Browser

Family Cites Families (82)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE19648422C2 (en) 1996-11-22 2000-03-30 Hans Beckhoff Method and device for implementing a real-time capable control program in a non-real-time capable operating program
US6938254B1 (en) * 1997-05-06 2005-08-30 Microsoft Corporation Controlling memory usage in systems having limited physical memory
US6336120B1 (en) 1997-08-26 2002-01-01 International Business Machines Corporation Method and system for supporting hierarchical storage management (HSM) file system across multiple platforms
US6178503B1 (en) 1998-09-11 2001-01-23 Powerquest Corporation Managing multiple operating systems on a single computer
US6691146B1 (en) 1999-05-19 2004-02-10 International Business Machines Corporation Logical partition manager and method
US6460136B1 (en) 1999-07-12 2002-10-01 Hewlett-Packard Co., Method and apparatus for loading an operating system kernel from a shared disk memory
GB2369959A (en) 2000-12-08 2002-06-12 Ubinetics Ltd Holder for connecting a mobile communications device to a screen
US7461144B1 (en) 2001-02-16 2008-12-02 Swsoft Holdings, Ltd. Virtual private server with enhanced security
US7231531B2 (en) 2001-03-16 2007-06-12 Dualcor Technologies, Inc. Personal electronics device with a dual core processor
US20020151334A1 (en) 2001-04-11 2002-10-17 Motorola, Inc Communications device with call frequency analyzer
US9098437B2 (en) 2010-10-01 2015-08-04 Z124 Cross-environment communication framework
US8819705B2 (en) * 2010-10-01 2014-08-26 Z124 User interaction support across cross-environment applications
US20030065738A1 (en) 2001-10-01 2003-04-03 Thumb Logic, Inc. Wireless information systems and methods
JP2003196096A (en) 2001-12-07 2003-07-11 Internatl Business Mach Corp <Ibm> Computer system, its starting control method and program
EP1635255A3 (en) 2002-03-20 2006-05-24 Seiko Epson Corporation Apparatus for processing instructions of different instruction set architectures
US7783665B1 (en) 2002-03-27 2010-08-24 Parallels Holdings, Ltd. Effective file-sharing among virtual environments
US7424623B2 (en) 2002-03-28 2008-09-09 O2 Micro International Limited Personal computer integrated with personal digital assistant
US20030204708A1 (en) 2002-04-24 2003-10-30 Colin Hulme Portable computer having hierarchical operating systems
US7952569B2 (en) 2002-08-08 2011-05-31 Hewlett-Packard Development Company, L.P. System and method of switching between multiple viewing modes in a multi-head computer system
US20040095388A1 (en) 2002-11-15 2004-05-20 Rocchetti Robert J. Method and apparatus for creating user interfaces for computing devices
US20040207508A1 (en) 2003-04-16 2004-10-21 Jyh-Han Lin Method and apparatus for a dynamically customizable smart phonebook
US7634770B2 (en) 2003-05-19 2009-12-15 Hewlett-Packard Development Company, L.P. Kernel module interface dependencies
US7158154B2 (en) 2003-06-18 2007-01-02 Lg Electronics Inc. Method for controlling display mode in portable computer
US7376949B2 (en) 2003-10-01 2008-05-20 Hewlett-Packard Development Company, L.P. Resource allocation and protection in a multi-virtual environment
US7620667B2 (en) 2003-11-17 2009-11-17 Microsoft Corporation Transfer of user profiles using portable storage devices
JP2005277815A (en) 2004-03-25 2005-10-06 Fujitsu Ltd Utilized network selection method and communication system, and mobile terminal
GB0407977D0 (en) 2004-04-08 2004-05-12 Ibm Communication between browser windows
US7478204B2 (en) 2004-04-29 2009-01-13 International Business Machines Corporation Efficient sharing of memory between applications running under different operating systems on a shared hardware system
US20060010446A1 (en) 2004-07-06 2006-01-12 Desai Rajiv S Method and system for concurrent execution of multiple kernels
US7424601B2 (en) 2004-07-07 2008-09-09 Yongyong Xu Methods and systems for running multiple operating systems in a single mobile device
US20060046706A1 (en) 2004-08-26 2006-03-02 Jiansong Lin Monitoring and remote control of wireless communication device accessories and functionality
US7398528B2 (en) 2004-11-13 2008-07-08 Motorola, Inc. Method and system for efficient multiprocessor processing in a mobile wireless communication device
US7529921B2 (en) 2004-12-17 2009-05-05 Cardiac Pacemakers, Inc. Fast initialization of medical device system having multiple operating systems
US20080307425A1 (en) 2005-03-31 2008-12-11 Shailendra Tripathi Data Processing System and Method
US8195624B2 (en) 2005-06-30 2012-06-05 Phoenix Technologies Ltd. Shared file system management between independent operating systems
US20070050765A1 (en) 2005-08-30 2007-03-01 Geisinger Nile J Programming language abstractions for creating and controlling virtual computers, operating systems and networks
WO2007035611A2 (en) 2005-09-16 2007-03-29 Hoshiko, Llc Low power mode for portable computer system
US7636586B2 (en) 2005-10-12 2009-12-22 Nokia Corporation Mobile communication terminal
US20070136402A1 (en) * 2005-11-30 2007-06-14 International Business Machines Corporation Automatic prediction of future out of memory exceptions in a garbage collected virtual machine
US20070135043A1 (en) 2005-12-12 2007-06-14 Motorola, Inc. Method and system for accessible contact information on a locked electronic device
US20070174429A1 (en) 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
US7536537B2 (en) 2006-04-20 2009-05-19 Harris Corporation Simultaneous dual booting of platforms
US20070266231A1 (en) 2006-05-15 2007-11-15 Huey-Tyug Chua Portable Electronic Device and Method for Loading Resource Data of the Portable Electronic Device
US20070283147A1 (en) 2006-05-30 2007-12-06 Fried Eric P System and method to manage device access in a software partition
US9201703B2 (en) 2006-06-07 2015-12-01 International Business Machines Corporation Sharing kernel services among kernels
US8146089B2 (en) 2006-06-14 2012-03-27 Intel Corporation Sharing resources of a partitioned system
US7689820B2 (en) 2006-09-27 2010-03-30 L3 Communications Corporation Rapid-boot computing device with dual operating systems
US20080100568A1 (en) 2006-10-30 2008-05-01 Koch Paul B Electronic device providing tactile feedback
US7827358B2 (en) * 2007-01-07 2010-11-02 Apple Inc. Memory management methods and systems
WO2008137432A2 (en) 2007-05-01 2008-11-13 Dyyno Sharing of information and formatting information for transmission over a communication network
KR101415762B1 (en) 2007-07-25 2014-07-08 엘지전자 주식회사 Auxiliary output apparatus, Portable computer having auxiliary output apparatus and Changing method of Operating Systerm thereof
TWI352909B (en) 2007-09-05 2011-11-21 Htc Corp Method and system for supporting network sharing a
TWI362612B (en) 2007-09-05 2012-04-21 Htc Corp System and electronic device using multiple operating systems and operating method thereof
US7840186B2 (en) 2007-09-25 2010-11-23 Motorola Mobility, Inc. Wireless SATA/SAS data transfer system
US9003173B2 (en) 2007-09-28 2015-04-07 Microsoft Technology Licensing, Llc Multi-OS (operating system) boot via mobile device
WO2009049088A1 (en) 2007-10-10 2009-04-16 Sun Microsystems, Inc. Method and system for changing execution environments during application execution
CN101149685A (en) 2007-11-07 2008-03-26 苏州壹世通科技有限公司 Combined device and method for starting up multiple operation system from mobile memory apparatus
JP2009157802A (en) 2007-12-27 2009-07-16 Kyocera Corp Portable terminal and information processor
US20090287571A1 (en) 2008-03-26 2009-11-19 Robb Fujioka Hypervisor and virtual machine ware
US8484721B2 (en) 2008-08-04 2013-07-09 Moka5, Inc. Locked-down computing environment
US8260603B2 (en) 2008-09-30 2012-09-04 Hewlett-Packard Development Company, L.P. Scaling a prediction model of resource usage of an application in a virtual environment
US8180604B2 (en) 2008-09-30 2012-05-15 Hewlett-Packard Development Company, L.P. Optimizing a prediction of resource usage of multiple applications in a virtual environment
JP5137781B2 (en) 2008-10-30 2013-02-06 株式会社エヌ・ティ・ティ・ドコモ Mobile device and application switching method
US8954977B2 (en) 2008-12-09 2015-02-10 Intel Corporation Software-based thread remapping for power savings
US9389877B2 (en) 2009-07-20 2016-07-12 Google Technology Holdings LLC Multi-environment operating system
US9367331B2 (en) 2009-07-20 2016-06-14 Google Technology Holdings LLC Multi-environment operating system
US8868899B2 (en) 2009-07-20 2014-10-21 Motorola Mobility Llc System and method for switching between environments in a multi-environment operating system
JP5378946B2 (en) 2009-10-26 2013-12-25 株式会社日立製作所 Server management apparatus and server management method
AU2010320034B2 (en) 2009-11-13 2015-02-12 Google Llc Live wallpaper
US8631403B2 (en) 2010-01-04 2014-01-14 Vmware, Inc. Method and system for managing tasks by dynamically scaling centralized virtual center in virtual infrastructure
US8589952B2 (en) 2010-06-30 2013-11-19 Palm, Inc. Dual operating system operation and configuration
US20120036450A1 (en) 2010-08-03 2012-02-09 Research In Motion Limited Method for providing indication of communicatively coupled device
TWI520069B (en) 2010-08-11 2016-02-01 緯創資通股份有限公司 Application method for integrating heterogeneous operating systems based on the same system kernel
EP2625624B1 (en) 2010-10-08 2017-11-29 Lumi Technologies Limited Distribution of content and behavior to disparate platforms
US8983536B2 (en) 2010-10-22 2015-03-17 Google Technology Holdings LLC Resource management in a multi-operating environment
US8874665B2 (en) 2010-12-13 2014-10-28 At&T Mobility Ii Llc Systems, apparatus and methods for facilitating display and management of information for communication devices
US20120173986A1 (en) 2011-01-04 2012-07-05 Motorola-Mobility, Inc. Background synchronization within a multi-environment operating system
US8782258B2 (en) 2011-01-04 2014-07-15 Motorola Mobility Llc Transferring web data between operating system environments
US9015709B2 (en) 2011-03-08 2015-04-21 Rackspace Us, Inc. Hypervisor-agnostic method of configuring a virtual machine
US8615589B1 (en) 2011-06-27 2013-12-24 Amazon Technologies, Inc. Resource optimization recommendations
US11205019B2 (en) 2011-10-28 2021-12-21 Hewlett-Packard Development Company, L.P. Multiple computing environments on a computer system
US9396041B2 (en) 2012-02-01 2016-07-19 Google Technology Holdings LLC Optimization of resource usage in a multi-environment computing system

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1467282A2 (en) 2003-04-09 2004-10-13 Jaluna SA Operating systems
US8352733B2 (en) * 2006-08-04 2013-01-08 Apple Inc. Resource restriction systems and methods
WO2009112896A2 (en) 2008-03-12 2009-09-17 Sony Ericsson Mobile Communications Ab Adaptive video encode scaling
WO2009120598A1 (en) 2008-03-25 2009-10-01 Qualcomm Incorporated Apparatus and methods for widget-related memory management
US20100211769A1 (en) 2009-02-19 2010-08-19 Subramonian Shankar Concurrent Execution of a Smartphone Operating System and a Desktop Operating System
US20110016301A1 (en) 2009-07-20 2011-01-20 Galicia Joshua D System and method for initiating a multi-environment operating system
US20110016299A1 (en) 2009-07-20 2011-01-20 Galicia Joshua D Multi-environment operating system
US20130212283A1 (en) * 2009-08-28 2013-08-15 Microsoft Corporation Resource Sharing in Multi-Principal Browser
US20120083264A1 (en) * 2010-09-30 2012-04-05 Apple Inc. Method and apparatus for transport format selection in a mobile wireless device

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
Darcey, Lauren et al.: "Introducing Android", Aug. 10, 2009, Retrieved from Internet: Retrieved from the Internet: URL:http://media.techtarget.com/searchMobileComputing/downloads/Introducing Android.pdf, on Mar. 26, 2012, pp. 1-29.
Patent Cooperation Treaty, International Search Report and Written Opinion of the International Searching Authority for International Application No. PCT/US2011/051904, Apr. 4, 2012, 20 pages.
U.S. Appl. No. 12/838,984, filed Jul. 19, 2010, to Joshua D. Galicia, Jeffrey C. Carlyle and Andrew N. Tzakis, titled Multi-Environment Operating System, all pages.
U.S. Appl. No. 12/839,069, filed Jul. 19, 2010, to Joshua D. Galicia, Jeffrey C. Carlyle and Andrew N. Tzakis, titled System and Method for Switching Between Environments in a Multi-Environment Operating System, all pages.
U.S. Appl. No. 12/839,193, filed Jul. 19, 2010, to Joshua D. Galicia, Jeffrey C. Carlyle, Andrew N. Tzakis and Nicholas C. Hopman, titled Multi-Environment Operating System, all pages.
Zupeng: "MemoryUp Pro User Manual-Mobile RAM Booster for Android", Apr. 29, 2009, Retrieved from the Internet: URL:http://www.emobistudio.com/download/memoryup android/MemoryUp%20Pro%20(Android%20Edition)%20User%20Guide.pdf, retrieved on Mar. 26, 2012.

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9348633B2 (en) 2009-07-20 2016-05-24 Google Technology Holdings LLC Multi-environment operating system
US9367331B2 (en) 2009-07-20 2016-06-14 Google Technology Holdings LLC Multi-environment operating system
US9372711B2 (en) 2009-07-20 2016-06-21 Google Technology Holdings LLC System and method for initiating a multi-environment operating system
US9389877B2 (en) 2009-07-20 2016-07-12 Google Technology Holdings LLC Multi-environment operating system
US9354900B2 (en) 2011-04-28 2016-05-31 Google Technology Holdings LLC Method and apparatus for presenting a window in a system having two operating system environments
US9417753B2 (en) 2012-05-02 2016-08-16 Google Technology Holdings LLC Method and apparatus for providing contextual information between operating system environments
US9342325B2 (en) 2012-05-17 2016-05-17 Google Technology Holdings LLC Synchronizing launch-configuration information between first and second application environments that are operable on a multi-modal device
US10261565B2 (en) 2014-01-09 2019-04-16 International Business Machines Corporation Enhanced security and resource utilization in a multi-operating system environment
US10310581B2 (en) 2014-01-09 2019-06-04 International Business Machines Corporation Enhanced security and resource utilization in a multi-operating system environment

Also Published As

Publication number Publication date
US9489240B2 (en) 2016-11-08
WO2012054156A2 (en) 2012-04-26
US20150154053A1 (en) 2015-06-04
US20120102495A1 (en) 2012-04-26
WO2012054156A3 (en) 2012-06-14

Similar Documents

Publication Publication Date Title
US8983536B2 (en) Resource management in a multi-operating environment
EP3842905B1 (en) Icon display method and apparatus, terminal and storage medium
US10462279B2 (en) Notifying a user of events in a computing device
EP3572936B1 (en) Method, terminal and computer-readable storage medium for displaying interface of application program
US9218154B2 (en) Displaying categories of notifications on a dual screen device
US8881047B2 (en) Systems and methods for dynamic background user interface(s)
US8527011B1 (en) Providing interactive alert information
US8972892B2 (en) Notification in immersive applications
RU2689435C2 (en) Adaptive user interface panels manager
JP4977236B2 (en) Information terminal, launcher program and method
US20140310647A1 (en) Method for controlling interface and terminal therefor
US20170220307A1 (en) Multi-screen mobile device and operation
US20110061056A1 (en) Portable device and method for providing shortcuts in the portable device
US11119651B2 (en) Method for displaying multi-task management interface, device, terminal and storage medium
KR102062309B1 (en) Method for controlling window and an electronic device thereof
JP2012168966A (en) Information terminal, and program and method thereof
KR20130116345A (en) Method and apparatus for locking and unlocking multiple operating system environments with a single gesture input
CN106528735B (en) Method and device for controlling browser to play media resources
US20190079635A1 (en) Method for responding to touch operation and electronic device
TW201617839A (en) Light dismiss manager
CN107122686B (en) Method and device for sharing screen content and mobile terminal
EP3271806B1 (en) Method for controlling notification and electronic device thereof
US20170293417A1 (en) Method and system for detection and resolution of frustration with a device user interface
CN110908559B (en) Display method and device of shortcut application panel, electronic equipment and storage medium
CN115016696B (en) Spring frame display method and device

Legal Events

Date Code Title Description
AS Assignment

Owner name: MOTOROLA MOBILITY, INC., ILLINOIS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GANGAM, VAMSHIKA R.;GALICIA, JOSHUA D.;GAN, SU-YIN;SIGNING DATES FROM 20110318 TO 20110321;REEL/FRAME:025989/0477

AS Assignment

Owner name: MOTOROLA MOBILITY LLC, ILLINOIS

Free format text: CHANGE OF NAME;ASSIGNOR:MOTOROLA MOBILITY, INC.;REEL/FRAME:028441/0265

Effective date: 20120622

AS Assignment

Owner name: GOOGLE TECHNOLOGY HOLDINGS LLC, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MOTOROLA MOBILITY LLC;REEL/FRAME:034227/0095

Effective date: 20141028

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8