The disclosure generally relates to mechanisms for updating applications on computing devices.
Users of mobile computing devices can install applications on mobile devices to enable the mobile devices to perform a variety of tasks. Developers of the applications will often update the applications with various improvements or bug fixes. When applications are updated, users can be notified and prompted to download the application updates. If the user has installed a large number of applications on the mobile device, the user can be frequently prompted to download new updates for the applications on the mobile device and can be required to provide input to initiate the downloading and installing of the new application updates. Having to deal with the frequent application update notifications and user input requirements for downloading application updates can be annoying and tedious for the user.
In some implementations, a mobile device can be configured to automatically download and install updates to applications installed on the mobile device. In some implementations, the automatic updates can be performed based on how the mobile device is connected to a network that provides access to the application updates. In some implementations, the automatic updates can be performed based on whether the mobile device has previously downloaded applications or application updates from a caching server. In some implementations, indicia can be presented on a graphical user interface of the mobile device to indicate which applications have been updated. In some implementations, an application update can be downloaded while the corresponding application is in use by the user. The application can be installed when the application is no longer being used by the user.
In some implementations, an application service can store application data that indicates whether an application should be automatically updated on a mobile device. In some implementations, the application service can collect application version information from mobile devices and use the application version information to determine which application versions should be available for download from the application service. The application service can determine based on the application version information whether the mobile device should perform a full or partial application update.
Particular implementations provide at least the following advantages: Users are not required to provide input to download application updates. Automatic application updates are performed based on connectivity to WiFi, cellular data, and/or a caching server, thereby reducing cellular data usage when updating applications and improving download speed. Users will not be prevented from using an application installed on the mobile device while application updates are being downloaded.
Details of one or more implementations are set forth in the accompanying drawings and the description below. Other features, aspects, and potential advantages will be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
In some implementations, mobile device 102 can download applications from media library 108 hosted by caching server 110. For example, media library 108 can include applications previously purchased and/or downloaded to caching server 110 by the user. Media library 108 can be a software application that maintains a repository of media (e.g., applications, electronic books, music, videos, etc.), for example. Caching server 110 can be a computing device of the user. For example, caching server 110 can be a computing device accessible through the user's home network (e.g., local area network 118). Caching server 110 can be a computing device accessible through a corporate network (e.g., local area network 118). The user can select applications from media library 108 to download to and install on the mobile device. Once mobile device 102 has downloaded the selected applications, mobile device 102 can install the applications on the mobile device.
In some implementations, mobile device 102 can periodically query application service 104 (or media library 108) to determine if there are updates available for the applications installed on mobile device 102. For example, mobile device 102 can send application information, including application identifiers, version numbers, etc., for each application installed on mobile device 102 to application service 104. Application service 104 can compare the version number of an application installed on mobile device 102 to the current version (e.g., latest version) of the application available to application service 104. If a newer version (e.g., update) of the application is available, application service 104 can transmit back to mobile device 102 a list of applications that have updates available to download. For example, application service 104 can transmit application names, identifiers, version numbers, etc., of updated applications to mobile device 102.
In some implementations, application service 104 will track installed application version information received from mobile devices and determine which versions of applications to retain at the application service based on the installed application versions. For example, application service 104 can maintain a repository of applications and application versions. Application service 104 can remove older versions of applications when the application version information received from the mobile devices indicates that the older application versions are no longer needed. For example, if an application in the repository has versions one through six (1-6) but the application version information received from the mobile devices indicates that the oldest version installed on any mobile device is version four (4), then application service 104 can delete or remove versions 1-3 of the application from the application version repository. Thus, application service 104 can more efficiently maintain the application service repository and make available storage capacity that can be used to store other applications or data.
In some implementations, mobile device 102 can be configured to automatically download application updates. For example, mobile device can automatically download and install the application updates identified by application service 104. In some implementations, mobile device 102 can be configured to prefer downloading application updates from caching server 110. For example, mobile device 102 can connect to caching server 110 through local area network (LAN) 118. Mobile device 102 can connect to LAN 118 through wireless access point 112, for example.
In some implementations, mobile device 102 can store information that identifies devices from which mobile device 102 has previously downloaded applications or other media (e.g., electronic books). For example, if mobile device 102 has previously downloaded an application or other media from caching server 110, mobile device can store information that identifies caching server 110 as a source for media downloads. If mobile device 102 has previously downloaded an application or other media from server 106, then mobile device 102 can store information that identifies server 106 as a source for media downloads. In some implementations, the information that identifies caching server 110 (e.g., the internet protocol address) can be used to determine if caching server 110 is hosted on a LAN that mobile device 102 regularly connects to. If the caching server 110 is accessible through a LAN (e.g., LAN 118), then when mobile device 102 receives information identifying updated applications, mobile device 102 will attempt to download the application updates from caching server 110 before attempting to download the application updates from server 106, as described in further detail below.
By configuring mobile device 102 to prefer downloading application updates from caching server 110 through LAN 118, the amount of time and bandwidth required to download application updates can be reduced. For example, the connection between two devices on the same LAN is often faster than a connection over a WAN because of the reduced distance and the reduced number of network devices (e.g., routers) that need to be traversed. Moreover, the caching server can download an application update once and serve the application update to multiple devices over the LAN thereby reducing the bandwidth required between the LAN and server 106 to serve application updates to the multiple devices.
In some implementations, mobile device 102 can be configured to prefer downloading application updates through wireless access point 112 or LAN 118. For example, mobile device 102 can determine whether mobile device 102 is connected to wide area network (WAN) 120 (e.g., the internet) through a WiFi connection (e.g., wireless access point 112 and LAN 118) or through a cellular data connection (e.g., radio access technology transceiver 114, CDMA, LTE, WiMAX, GSM, etc.). If mobile device 102 is connected to WAN 120 through cellular data, mobile device 102 can be configured to wait until mobile device 120 is connected to wireless access point 112 (e.g., WiFi) to download application updates. By configuring mobile device 102 to prefer a WiFi connection for downloading application updates, the user can experience faster application downloads and the user will not be charged by the cellular data provider for using cellular data when downloading application updates.
At step 204, the mobile device can receive updated application information. For example, the application service can compare the installed application information received by the application service in the application update request to information about the current versions of the installed applications available through the application service. For example, the application service can compare the versions of the applications installed on the mobile device to the current versions of the applications available for downloading from the application service to determine if an update is available for the applications installed on the mobile device. The application service can then send to the mobile device information identifying which installed applications have been updated. For example, the information identifying updated applications can include, for each updated application an application identifier, a version identifier and/or a description of changes or updates made to the application. The updated application information can include a link (e.g., URL) to the application update that the mobile device can use to download the application update. For example, the link can point to a partial application update (e.g., one or more files that contain only the changes or updates to the application). The link can point to a full application update (e.g., a complete updated application).
At step 206, the mobile device can determine whether to download application updates. For example, the mobile device can be configured to prefer updating from a caching server when the mobile device has previously downloaded an application from the caching server. Thus, the mobile device can be configured to wait for a connection to the caching server to be established before downloading application updates. The mobile device can be configured to prefer downloading over WiFi instead of downloading over cellular data. Thus, the mobile device can be configured to wait for a WiFi connection to be established before downloading application updates. The mobile device can be configured to download application updates over a cellular data connection when a specified wait period (e.g., amount of time) has elapsed. The determination whether to download application updates is described in further detail with reference to the decision flow diagram of
In some implementations, parental control settings can prevent application updates from being downloaded to the mobile device. For example, the updated application information can include parental control ratings (e.g., G, PG, PG-13, R, etc.) for each application update. If the parental control rating for an updated application exceeds the parental control rating limit configured for the mobile device (e.g., the parental control configuration restricts applications to a PG rating but the application update changes the rating of the application to an R rating), then the mobile device will not download and install the application update.
At step 208, once the mobile device has determined that an application update download should be performed, the mobile device can automatically download application updates to the mobile device. For example, the mobile device can automatically download application updates from media library 108 stored on caching server 110 or from an application service 104 executing on server 106. In some implementations, an update for an application can be downloaded to the mobile device even while the application is being used by a user. In some implementations, automatic application update downloads will be initiated upon connection to a WiFi access point. In some implementations, automatic application update downloads will be initiated upon connection to the caching server. In some implementations, automatic application updates will be performed over a cellular data connection when a connection to the caching server and/or WiFi access point has not been established within a specified period of time.
In some implementations, user initiated downloads will be prioritized over automatic application update downloads. For example, if the user selects an application or other media item to download to the mobile device, the automatic application update download can be paused (e.g., suspended) while the selected application or media item is downloaded to the device. Once the user selected item is downloaded, the automatic application update download can be resumed by the mobile device.
At step 210, the mobile device can determine whether an application to be updated on the mobile device is currently being used by a user of the mobile device. For example, the mobile device can be configured with a function that identifies what applications are currently executing on and/or are currently in the foreground of a display of the mobile device.
At step 212, the mobile device can install the application update if the application is not currently being used by a user of the mobile device. For example, if the application is not currently executing on and/or is not currently in the foreground of the display of the mobile device, the downloaded application update for the application can be installed.
At step 214, the mobile device can present a notification indicating which applications have been updated. For example, the mobile device can present indicia on a graphical user interface of the mobile device indicating which applications have been updated. In some implementations, the mobile device can present an interface identifying (e.g., listing) the updated applications.
In some implementations, an automatic application update failure will be silently handled. For example, when an automatic application update download or installation fails, no notification of the failure will be presented to the user. If a download or installation failure occurs, the download or installation can be attempted again in the future. If the application cannot be updated with a specified period of time, then the user can be notified that the application update is available but has not been downloaded. In some implementations, a failure will cause a notification to be displayed to the user. The notification can indicate the application and version number of the failed download and/or installation, for example.
At 304, the mobile device can wait for a WiFi connection. For example, the mobile device can be configured to wait for a connection to a WiFi network (e.g., WiFi access point) before downloading application updates. The mobile device can be configured to wait a specified amount of time for a WiFi connection. For example, the WiFi wait period can be five days.
At 306, the mobile device can determine whether the mobile device has established a WiFi connection within the specified amount of time. For example, the WiFi wait period can begin when the mobile device receives information identifying applications that have been updated at the application service. The WiFi wait period can be applied to each individual application update. Thus, the WiFi wait period can expire at different times for applications that were updated on different days.
At 308, if the mobile device establishes a WiFi connection within the specified amount of time, the mobile device can determine whether to wait for a connection to a caching server. For example, the mobile device can be configured to wait a specified amount of time (a caching server wait period) for a connection to a caching server and download application updates from the caching server. For example, if the mobile device has previously downloaded applications and/or application updates from a caching server, then the mobile device can wait a specified amount of time for the next connection to the caching server to download application updates from the caching server.
At 310, if the mobile device is configured to wait for a caching server, the mobile device can determine whether the mobile device has established a connection with the caching server within a specified amount of time (e.g., three days) since the application update information was received by the mobile device. If the mobile device establishes a connection with the caching server within the caching server wait period, then the mobile device can download application updates from the caching server at 312.
At 314, if a WiFi connection is established at 306 but the mobile device is not configured to wait for a connection to the caching server at 308 or has not established a connection to the caching server within the caching server wait period at 310, then the mobile device can download the application updates from the application service at 314.
At 316, if a WiFi connection is not established within the specified amount of time (e.g., WiFi wait period), then the mobile device can determine whether to automatically download application updates over a cellular data connection. For example, the user can enable or disable automatic application update downloads over cellular data. If cellular data downloads are enabled, the mobile device can download application updates from the application service at 314 over a cellular data connection. If cellular data downloads are disabled or if the size of the application update data is greater than a threshold size (e.g., 50 Mb), then the mobile device can notify the user of pending (e.g., not downloaded or installed) application updates 318 and wait for the user to initiate downloading application updates.
In some implementations, if downloads over cellular data is disabled, the amount of time (e.g., WiFi wait period) that the mobile device will wait for a WiFi connection can be extended. For example, the mobile device can be configured to wait for a WiFi connection for five days if cellular data downloads are enabled. If cellular data downloads are disabled, the mobile device can be configured to wait ten days for a WiFi connection before notifying the user that there are pending application updates.
In some implementations, the server can store installed application information received from many mobile devices so that the server can determine which application versions should be stored or retained at the server. For example, if the application version information received from the mobile devices indicates that version 4 is the oldest version of an application installed on the mobile devices, the server can delete from storage versions of the application that are older than version 4 (e.g., versions 1-3).
At step 404, the server can determine which installed applications have updated versions available at the server. For example, the server can compare the application identifiers and/or the version identifiers to corresponding applications and/or application updates on the server to determine whether an update exists for an application installed on the mobile device. For example, if the version of an application installed on the mobile device is different than the latest (e.g., most current) version of the application available at the server, then an application update exists for the installed application.
In some implementations, instead of waiting for a client request, the server can send notifications to mobile devices when applications have been updated. For example, when the server receives an application update from an application developer, the server can send an application update notification to all mobile devices that have corresponding application installed. The mobile device can then attempt to download and update the application according to the processes described herein.
At step 406, the server can determine if automatic updates are enabled for each application. For example, an application developer can upload an updated application (e.g., full application) to the server (e.g., to the application service). When the application or application update is uploaded to the server, the developer can specify that the application should not be automatically updated on mobile devices. For example, the server can maintain application metadata for each application that indicates whether the application can be automatically updated on mobile devices. If the metadata indicates that the application should not be automatically updated by mobile devices, then the server will exclude the application from the application update information that will be sent to the mobile device and the mobile device will not download the application. Alternatively, if the metadata indicates that the application should not be automatically updated, the server can send application update information for the application to the mobile device. The application update information can include information indicating that the mobile device should not automatically apply the application update, for example. The mobile device can then indicate to the user (e.g., an icon or graphic on the display of the mobile device) that an application update is available for the application. The user can then choose whether to download and install the application update.
At step 408, the server can determine for each updated application whether a full or partial application update. For example, a full update will cause the mobile device to download the entire application. A partial update will cause the mobile device to download only changes to the application. For example, if a partial update is performed, then only portions (e.g., files, libraries, etc.) of the application that have changed since the mobile device last downloaded the application will be downloaded to the mobile device. In some implementations, if the server determines that there is only one version difference between the application installed on the mobile device and the current or latest version of the application available on the server (e.g., the installed version is the immediate predecessor of the application version on the server), then the server will determine that a partial application update should be performed. In some implementations, if there is more than one version difference between the installed version of the application and the current or latest version of the application on the server, then a full application update will be performed (e.g., the entire application will be downloaded).
At step 410, the server can transmit application update information to the mobile device. For example, the server can send to the mobile device a list of installed applications that have updates that are available for download from the server. The application update information can include application identifiers, version identifiers and/or an identifier (e.g., file name) for or link (e.g., URL) to the full application or partial update files.
At step 412, the server can receive an application update download request from the mobile device. For example, the request can include application identifiers, application version identifiers and/or file identifiers. The server can use the information in the application request to identify which application updates (e.g., which application files, the entire application, a portion of the application, change data) to transmit to the mobile device. At step 414, the server can transmit the application updates to the mobile device.
This disclosure describes various Graphical User Interfaces (GUIs) for implementing various features, processes or workflows. These GUIs can be presented on a variety of electronic devices including but not limited to laptop computers, desktop computers, computer terminals, television systems, tablet computers, e-book readers and smart phones. One or more of these electronic devices can include a touch-sensitive surface. The touch-sensitive surface can process multiple simultaneous points of input, including processing data related to the pressure, degree or position of each point of input. Such processing can facilitate gestures with multiple fingers, including pinching and swiping.
When the disclosure refers to “select” or “selecting” user interface elements in a GUI, these terms are understood to include clicking or “hovering” with a mouse or other input device over a user interface element, or touching, tapping or gesturing with one or more fingers or stylus on a user interface element. User interface elements can be virtual buttons, menus, selectors, switches, sliders, scrubbers, knobs, thumbnails, links, icons, radial buttons, checkboxes and any other mechanism for receiving input from, or providing feedback to a user.
Sensors, devices, and subsystems can be coupled to the peripherals interface 906 to facilitate multiple functionalities. For example, a motion sensor 910, a light sensor 912, and a proximity sensor 914 can be coupled to the peripherals interface 906 to facilitate orientation, lighting, and proximity functions. Other sensors 916 can also be connected to the peripherals interface 906, such as a global navigation satellite system (GNSS) (e.g., GPS receiver), a temperature sensor, a biometric sensor, magnetometer or other sensing device, to facilitate related functionalities.
A camera subsystem 920 and an optical sensor 922, e.g., a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor, can be utilized to facilitate camera functions, such as recording photographs and video clips. The camera subsystem 920 and the optical sensor 922 can be used to collect images of a user to be used during authentication of a user, e.g., by performing facial recognition analysis.
Communication functions can be facilitated through one or more wireless communication subsystems 924, which can include radio frequency receivers and transmitters and/or optical (e.g., infrared) receivers and transmitters. The specific design and implementation of the communication subsystem 924 can depend on the communication network(s) over which the computing device 900 is intended to operate. For example, the computing device 900 can include communication subsystems 924 designed to operate over a GSM network, a GPRS network, an EDGE network, a Wi-Fi or WiMax network, and a Bluetooth™ network. In particular, the wireless communication subsystems 924 can include hosting protocols such that the device 100 can be configured as a base station for other wireless devices.
An audio subsystem 926 can be coupled to a speaker 928 and a microphone 930 to facilitate voice-enabled functions, such as speaker recognition, voice replication, digital recording, and telephony functions. The audio subsystem 926 can be configured to facilitate processing voice commands, voiceprinting and voice authentication, for example.
The I/O subsystem 940 can include a touch-surface controller 942 and/or other input controller(s) 944. The touch-surface controller 942 can be coupled to a touch surface 946. The touch surface 946 and touch-surface controller 942 can, for example, detect contact and movement or break thereof using any of a plurality of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, and surface acoustic wave technologies, as well as other proximity sensor arrays or other elements for determining one or more points of contact with the touch surface 946.
The other input controller(s) 944 can be coupled to other input/control devices 948, such as one or more buttons, rocker switches, thumb-wheel, infrared port, USB port, and/or a pointer device such as a stylus. The one or more buttons (not shown) can include an up/down button for volume control of the speaker 928 and/or the microphone 930.
In one implementation, a pressing of the button for a first duration can disengage a lock of the touch surface 946; and a pressing of the button for a second duration that is longer than the first duration can turn power to the computing device 900 on or off. Pressing the button for a third duration can activate a voice control, or voice command, module that enables the user to speak commands into the microphone 930 to cause the device to execute the spoken command. The user can customize a functionality of one or more of the buttons. The touch surface 946 can, for example, also be used to implement virtual or soft buttons and/or a keyboard.
In some implementations, the computing device 900 can present recorded audio and/or video files, such as MP3, AAC, and MPEG files. In some implementations, the computing device 900 can include the functionality of an MP3 player, such as an iPod™. The computing device 900 can, therefore, include a 36-pin connector that is compatible with the iPod. Other input/output and control devices can also be used.
The memory interface 902 can be coupled to memory 950. The memory 950 can include high-speed random access memory and/or non-volatile memory, such as one or more magnetic disk storage devices, one or more optical storage devices, and/or flash memory (e.g., NAND, NOR). The memory 950 can store an operating system 952, such as Darwin, RTXC, LINUX, UNIX, OS X, WINDOWS, or an embedded operating system such as VxWorks.
The operating system 952 can include instructions for handling basic system services and for performing hardware dependent tasks. In some implementations, the operating system 952 can be a kernel (e.g., UNIX kernel). In some implementations, the operating system 952 can include instructions for performing automatic updating of applications. For example, operating system 952 can implement the automatic application updating features as described with reference to
The memory 950 can also store communication instructions 954 to facilitate communicating with one or more additional devices, one or more computers and/or one or more servers. The memory 950 can include graphical user interface instructions 956 to facilitate graphic user interface processing; sensor processing instructions 958 to facilitate sensor-related processing and functions; phone instructions 960 to facilitate phone-related processes and functions; electronic messaging instructions 962 to facilitate electronic-messaging related processes and functions; web browsing instructions 964 to facilitate web browsing-related processes and functions; media processing instructions 966 to facilitate media processing-related processes and functions; GNSS/Navigation instructions 968 to facilitate GNSS and navigation-related processes and instructions; and/or camera instructions 970 to facilitate camera-related processes and functions.
The memory 950 can store other software instructions 972 to facilitate other processes and functions, such as the automatic application updating processes and functions as described with reference to
The memory 950 can also store other software instructions 974, such as web video instructions to facilitate web video-related processes and functions; and/or web shopping instructions to facilitate web shopping-related processes and functions. In some implementations, the media processing instructions 966 are divided into audio processing instructions and video processing instructions to facilitate audio processing-related processes and functions and video processing-related processes and functions, respectively.
Each of the above identified instructions and applications can correspond to a set of instructions for performing one or more functions described above. These instructions need not be implemented as separate software programs, procedures, or modules. The memory 950 can include additional instructions or fewer instructions. Furthermore, various functions of the computing device 900 can be implemented in hardware and/or in software, including in one or more signal processing and/or application specific integrated circuits.
This application is a continuation (and claims the benefit of priority under 35 USC 120) of U.S. application Ser. No. 13/759,832, filed Feb. 5, 2013, now allowed, which is incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4747040 | Blanset et al. | May 1988 | A |
4787026 | Barnes et al. | Nov 1988 | A |
4984149 | Iwashita et al. | Jan 1991 | A |
5040110 | Miki et al. | Aug 1991 | A |
5131069 | Hall et al. | Jul 1992 | A |
5131089 | Cole | Jul 1992 | A |
5146568 | Flaherty et al. | Sep 1992 | A |
5257378 | Sideserf et al. | Oct 1993 | A |
5280627 | Flaherty et al. | Jan 1994 | A |
5291564 | Shah et al. | Mar 1994 | A |
5291584 | Challa et al. | Mar 1994 | A |
5325529 | Brown et al. | Jun 1994 | A |
5339430 | Lundin et al. | Aug 1994 | A |
5452454 | Basu | Sep 1995 | A |
5454098 | Pisello et al. | Sep 1995 | A |
5459650 | Noro | Oct 1995 | A |
5459850 | Clay et al. | Oct 1995 | A |
5465364 | Lathrop et al. | Nov 1995 | A |
5483647 | Yu et al. | Jan 1996 | A |
5491513 | Wickstrom et al. | Feb 1996 | A |
5491813 | Bondy et al. | Feb 1996 | A |
5499378 | McNeill et al. | Mar 1996 | A |
5546585 | Soga | Aug 1996 | A |
5548783 | Jones et al. | Aug 1996 | A |
5603011 | Piazza | Feb 1997 | A |
5666293 | Metz et al. | Sep 1997 | A |
5694583 | Williams et al. | Dec 1997 | A |
5717903 | Bonola | Feb 1998 | A |
5724530 | Stein et al. | Mar 1998 | A |
5742829 | Davis et al. | Apr 1998 | A |
5754774 | Bittinger et al. | May 1998 | A |
5758165 | Shuff | May 1998 | A |
5764992 | Kullick | Jun 1998 | A |
5784581 | Hannah | Jul 1998 | A |
5802297 | Engquist | Sep 1998 | A |
5842011 | Basu | Nov 1998 | A |
5859978 | Sonderegger et al. | Jan 1999 | A |
5890014 | Long | Mar 1999 | A |
5892909 | Grasso et al. | Apr 1999 | A |
5916047 | Schickert et al. | Jun 1999 | A |
5918048 | Mealey et al. | Jun 1999 | A |
5926631 | McGarvey | Jul 1999 | A |
5946469 | Chidester | Aug 1999 | A |
5948101 | David et al. | Sep 1999 | A |
5953516 | Bonola | Sep 1999 | A |
5958020 | Evoy et al. | Sep 1999 | A |
5968170 | Gross et al. | Oct 1999 | A |
5974547 | Klimenko | Oct 1999 | A |
6006029 | Bianchi et al. | Dec 1999 | A |
6006034 | Heath et al. | Dec 1999 | A |
6009274 | Fletcher et al. | Dec 1999 | A |
6009480 | Pleso | Dec 1999 | A |
6012103 | Sartore et al. | Jan 2000 | A |
6016400 | Day et al. | Jan 2000 | A |
6016402 | Thomas et al. | Jan 2000 | A |
6020914 | Douhet | Feb 2000 | A |
6023585 | Perlman et al. | Feb 2000 | A |
6038601 | Lambert et al. | Mar 2000 | A |
6064566 | Agata et al. | May 2000 | A |
6066182 | Wilde et al. | May 2000 | A |
6067618 | Weber | May 2000 | A |
6073205 | Thomson | Jun 2000 | A |
6128734 | Gross et al. | Oct 2000 | A |
6130668 | Stein | Oct 2000 | A |
6134614 | Chari et al. | Oct 2000 | A |
6161176 | Hunter et al. | Dec 2000 | A |
6163853 | Findlay et al. | Dec 2000 | A |
6170008 | Bahlmann et al. | Jan 2001 | B1 |
6175917 | Arrow et al. | Jan 2001 | B1 |
6175918 | Shimizu | Jan 2001 | B1 |
6178503 | Madden et al. | Jan 2001 | B1 |
6185678 | Arbaugh et al. | Feb 2001 | B1 |
6198558 | Graves et al. | Mar 2001 | B1 |
6199204 | Donohue | Mar 2001 | B1 |
6202091 | Godse | Mar 2001 | B1 |
6204847 | Wright | Mar 2001 | B1 |
6205473 | Thomasson et al. | Mar 2001 | B1 |
6209031 | Casey et al. | Mar 2001 | B1 |
6209089 | Selitrennikoff et al. | Mar 2001 | B1 |
6252889 | Patki et al. | Jun 2001 | B1 |
6253209 | Chase-Salerno et al. | Jun 2001 | B1 |
6260068 | Zalewski et al. | Jul 2001 | B1 |
6266809 | Craig et al. | Jul 2001 | B1 |
6269396 | Shah et al. | Jul 2001 | B1 |
6269481 | Perlman et al. | Jul 2001 | B1 |
6275851 | Cromer et al. | Aug 2001 | B1 |
6279030 | Britton et al. | Aug 2001 | B1 |
6279109 | Brundridge | Aug 2001 | B1 |
6292941 | Jollands | Sep 2001 | B1 |
6314438 | Stein et al. | Nov 2001 | B1 |
6317826 | McCall et al. | Nov 2001 | B1 |
6324691 | Gazdik | Nov 2001 | B1 |
6330653 | Murray et al. | Dec 2001 | B1 |
6330715 | Razzaghe-Ashrafi | Dec 2001 | B1 |
6334149 | Davis, Jr. et al. | Dec 2001 | B1 |
6345294 | O'Toole et al. | Feb 2002 | B1 |
6345309 | Ohsawa et al. | Feb 2002 | B2 |
6357040 | Porter | Mar 2002 | B1 |
6374363 | Wu et al. | Apr 2002 | B1 |
6393560 | Merrill et al. | May 2002 | B1 |
6401093 | Anand et al. | Jun 2002 | B1 |
6421777 | Pierre-Louis et al. | Jul 2002 | B1 |
6434695 | Esfahani et al. | Aug 2002 | B1 |
6438683 | Endsley | Aug 2002 | B1 |
6466203 | Van Ee | Oct 2002 | B2 |
6466972 | Paul et al. | Oct 2002 | B1 |
6477642 | Lupo | Nov 2002 | B1 |
6487601 | Hubacher et al. | Nov 2002 | B1 |
6490677 | Aguilar et al. | Dec 2002 | B1 |
6505243 | Lortz | Jan 2003 | B1 |
6513061 | Ebata et al. | Jan 2003 | B1 |
6519633 | Kubik et al. | Feb 2003 | B1 |
6529948 | Bowman-Amuah | Mar 2003 | B1 |
6535976 | Hoggarth et al. | Mar 2003 | B1 |
6543004 | Cagle et al. | Apr 2003 | B1 |
6564232 | Cole et al. | May 2003 | B1 |
6578069 | Hopmann et al. | Jun 2003 | B1 |
6606744 | Mikurak | Aug 2003 | B1 |
6611915 | Kubik et al. | Aug 2003 | B1 |
6625754 | Aguilar et al. | Sep 2003 | B1 |
6631442 | Blumenau | Oct 2003 | B1 |
6633916 | Kauffman | Oct 2003 | B2 |
6671748 | Cole et al. | Dec 2003 | B1 |
6718549 | Narin et al. | Apr 2004 | B1 |
6728787 | Leigh | Apr 2004 | B1 |
6735741 | Pannu | May 2004 | B1 |
6751658 | Haun et al. | Jun 2004 | B1 |
6751794 | McCaleb et al. | Jun 2004 | B1 |
6757706 | Dong et al. | Jun 2004 | B1 |
6785885 | Norris et al. | Aug 2004 | B2 |
6807558 | Hassett et al. | Oct 2004 | B1 |
6807641 | Ishiguro et al. | Oct 2004 | B1 |
6854112 | Crespo et al. | Feb 2005 | B2 |
6944185 | Patki et al. | Sep 2005 | B2 |
6944857 | Glaser et al. | Sep 2005 | B1 |
6976057 | Yoshiasa | Dec 2005 | B2 |
6976252 | White et al. | Dec 2005 | B2 |
6996076 | Forbes et al. | Feb 2006 | B1 |
7076774 | Chrysanthakopoulos et al. | Jul 2006 | B2 |
7089551 | Fordemwalt et al. | Aug 2006 | B2 |
7089553 | Glaser et al. | Aug 2006 | B1 |
7162539 | Garcie-Luna-Aceves | Jan 2007 | B2 |
7180858 | Roy et al. | Feb 2007 | B1 |
7249354 | Tigani et al. | Jul 2007 | B2 |
7281047 | Hayko et al. | Oct 2007 | B2 |
7343422 | Garcia-Luna-Aceves et al. | Mar 2008 | B2 |
7496914 | Ling | Feb 2009 | B1 |
7552233 | Raju et al. | Jun 2009 | B2 |
7565450 | Garcia-Luna-Aceves et al. | Jul 2009 | B2 |
7577754 | Garcia-Luna-Aceves et al. | Aug 2009 | B2 |
7664876 | Garcia-Luna-Aceves | Feb 2010 | B2 |
7725596 | Garcia-Luna-Aceves et al. | May 2010 | B2 |
7730155 | Meyer et al. | Jun 2010 | B1 |
7730159 | Meyer et al. | Jun 2010 | B1 |
7765277 | Meyer et al. | Jul 2010 | B1 |
7797353 | Singh | Sep 2010 | B1 |
7908337 | Garcia-Luna-Aceves et al. | Mar 2011 | B2 |
8594850 | Gourlay | Nov 2013 | B1 |
8838731 | Meyer et al. | Sep 2014 | B2 |
20030088716 | Sanders | May 2003 | A1 |
20040015953 | Vincent | Jan 2004 | A1 |
20040024848 | Smith et al. | Feb 2004 | A1 |
20050055687 | Mayer | Mar 2005 | A1 |
20060082467 | Funk | Apr 2006 | A1 |
20060130037 | Mackay | Jun 2006 | A1 |
20060206450 | Fletcher et al. | Sep 2006 | A1 |
20070006216 | Nakane | Jan 2007 | A1 |
20070198698 | Boyd | Aug 2007 | A1 |
20070211674 | Ragnar | Sep 2007 | A1 |
20080005734 | Poristoin | Jan 2008 | A1 |
20080102815 | Sengupta | May 2008 | A1 |
20080209410 | Demsky et al. | Aug 2008 | A1 |
20090064122 | Bielski | Mar 2009 | A1 |
20090138477 | Piira | May 2009 | A1 |
20090217244 | Bozak | Aug 2009 | A1 |
20090307682 | Gharabally | Dec 2009 | A1 |
20100311399 | Cusick | Dec 2010 | A1 |
20110196826 | Retief | Aug 2011 | A1 |
20110286437 | Austin | Nov 2011 | A1 |
20120106458 | Jang | May 2012 | A1 |
20130185563 | Djabarov | Jul 2013 | A1 |
20130254274 | Sun | Sep 2013 | A1 |
20130326606 | Kelly | Dec 2013 | A1 |
20130339942 | Brunsman | Dec 2013 | A1 |
20140040412 | Yanagihara | Feb 2014 | A1 |
20140068587 | Krishna | Mar 2014 | A1 |
20140082513 | Mills | Mar 2014 | A1 |
20140130064 | Haemel | May 2014 | A1 |
20140179272 | Zhang | Jun 2014 | A1 |
20140365561 | Meyer et al. | Dec 2014 | A1 |
20150242198 | Tobolski | Aug 2015 | A1 |
Number | Date | Country |
---|---|---|
200849861 | Dec 2008 | TW |
201017202 | May 2010 | TW |
WO 2012072016 | Jun 2012 | WO |
Entry |
---|
International Search Report and Written Opinion in International Application No. PCT/US2014/014662, dated May 23, 2014, 13 pages. |
Kellex, “Android Market Now Allows for Content Filtering”, May 14, 2011, DroidLife, http://www.droidlife.com/2011/05/14/android-market-now-allows-for-content-filtering/, accessed on Aug. 22, 2015. |
MacRumors Forum, “Wifi Sync: Does it Sync App Updates?”, http://forums.macrumors.com/showthread.php?t=1265936, accessed on Apr. 3, 2015. |
Mahajan et al., “Augmenting Mobile 3G Using WiFi”, Proceedings of the 8th International conference on Mobile systems, applications, and services, 2010, pp. 209-222. |
Roy, How to Make Android Apps Update Via Wi-Fi only, http://techlogon.com/2011/12/20/how-to-make-androidapps-update-via-wi-fi-only/, access on Apr. 3, 2015. |
Ruddock, “Android Market 3.3.11 Adds New Settings,” Apr. 25, 2012, Retrieved from the Internet: URL: http ://www.androidpol ice. coni/2011/11/01/download-android-market-3-3-II-adds-new-settings-default-auto-update-update-over-wi-fi-only-shortcuts-and-more/ [retrieved on May 7, 2014], 5 pages. |
Vartiainen et al., “Auto-update,” Proc 4th Intl Conference Mobile Technol, Apps, Systems, and 1st Intl Symposium on Computer Human Interaction in Mobile Technol, Mobility '07, Jan. 2007, 683-689. |
Lindgren, “Efficient Content Distribution in an Information-centric Hybrid Mobile Network”, 2011 IEEE Consumer Communications and Networking Conference (CCNC), Jan. 9-12, 2011, pp. 1134-1138. |
“Device Configuration Assistant Design Overview” Sun Microsystems, 1999, 8 pages. |
“Etherboot,” downloaded from www.slug.org.au/etherboot/ on Oct. 11, 1999, 4 pages. |
“Netboot Introduction”, Downloaded from www.han.de/.about.gero/netboot/english/introduction.html on Oct. 11, 1999, 13 pages. |
Alexander, S. “HDCP Options and BOOTP Vendor Extensions” Network Working Group, RFC 2132, Mar. 1997 (35 pages). |
Apple Computer, Inc., “Getting Started with Mac OS X Server: Includes Installation and Setup lnforamtion for Mac OS X Server version 10.2,” pp. 1-24, 2002. |
Arbaugh, William A., et al. “A Secure and Reliable Bootstrap Architecture” IEEE Symposium on Security and Privacy, May 4-5, 1997, pp. 65-71. |
Burke, Michael G. et al., “The Jalapeno Dynamic Optimizing Compiler for Java.TM.,” IBM Thomas J. Watson Research Center, 1999 (13 pages). |
Campbell, Andrew T. et al., “A Survey of Programmable Networks,” 1999, 18 pages. |
Chuang, Shaw-Cheng et al., “A Case Study of Secure ATM Switch Booting,” IEEE 1996 (10 pages). |
Croft, Bill and Gilmore, John. “Bootstrap Protocol (BOOTP)” Network Working Group RFC 951, Sep. 1985 (12 pages). |
Davidson, Rusel and MacKinnon James G., “Bootstrap Tests: How Many Bootstraps?” Jun. 1998 (15 pages). |
Estrin, Deborah et al. “A Dynamic Bootstrap Mechanism for Rendezvous-Based Multicast Routing” IEEE INFOCOM '99. Eighteenth Annual Joint Conference of the IEEE Computer and Communications Societies. vol. 3, Mar. 21-25, 1999, pp. 1090-1098. |
Ford, Bryan et al. “The Flux OS Toolkit: Reusable Components for OS Implementation” IEEE May 5-6, 1997, pp. 14-19. |
Ford et al., “The Flux OSKit: A Substrate for Kernel and Language Research,” The University of Utah: School of Computing, © 1997, retrieved on Jul. 21, 2016, https://www.cs.utah.edu/flux/papers/oskit-sosp97.html, 33 pages. |
Hesterberg, Tim C., “Bootstrap Tilting Inteference and Large Data Sets—Proposal to NSF SBIR Program,” Jun. 11, 1998, pp. 2-22. |
Hobbs, M.J. et al., “Booting of the RHODOS Distributed Operating System,” Sep. 8, 1984, 18 pages. |
Kaszeta, Rich“A New Use for Old and Outdated PC's,” Downloaded from www.menet.umn.edu/'kaszeta/unix/xterminal/index.html on Oct. 11, 1999, 8 pages. |
Red Hat, Inc., “Red Hat Linux 9: Red Hat Linux Customization Guide,” chapter 7-8, 43 pages, 2003. |
Reynolds, J. “BOOTP Vendor Information Extensions” Network Working Group RFC 1395, Jan. 1993 (8 pages). |
Uhlig, Richard et al., “Trap-Driven Simulation with Tapeworm II,” 6th Int. Conf. Architectural Support for Programmin Languages and Operating Systems (ASPLOS-VI), Oct. 1994, 14 pages. |
Wimer, W. “Clarifications and Extensions for the Bootstrap Protocol” Network Working Group, RFC 1532, Oct. 1993 (22 pages). |
Wong, P.K. “Remote Boot Windows 95a Step by Step Instructions,” Downloaded from wpkgate.kc.com.my/remoteboot/win95.txt on Oct. 11, 1999, 5 pages. |
Number | Date | Country | |
---|---|---|---|
20170010883 A1 | Jan 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13759832 | Feb 2013 | US |
Child | 15273782 | US |