The invention relates to devices and methods for controlling the function of central processing units within a set top box.
Current cable set top boxes (“STB”s) perform many tasks, including digital video recording (“DVR”), playing MP3s, playing digital photograph slideshows, playing DVDs, recording onto DVDs, rendering or streaming video, providing internet or other network access, playing back from a DVR, etc. Further, the STB can perform many of these functions at the same time. However, the STB's CPU has a limited number of processing cycles available for such multi-tasking. For example, if the STB is recording onto a DVD, this process could potentially shut down other operations or alternately the same could extend the time necessary to perform the process over a very long time because of other operations.
The systems disclosed allow an STB to manage a CPU as a resource. Further, users can be notified of the CPU status and presented with options to modify CPU resource preferences.
Referring to
In this description, the term “task” is employed to mean a complete function performed by an STB or a residential gateway. A CPU Resource Manager refers to a separate circuit, such as an ASIC or FPGA, or a circuit implemented in software, programmed to control what task the CPU performs and when each portion of a task is performed with respect to portions of other tasks also being performed.
User commands from the user interface layer 12 choose which tasks in task layer 14 commence, continue, and end execution. Execution of any of these tasks requires operation of at least some of a plurality of subsystems 18: a central processing unit (“CPU”), an operating system (“OS”), a hard disk and its associated controller, and other hardware, software, and firmware.
In addition to choosing which tasks to execute, the user interface layer 12 provides the user with a display, menu, or other such interface through which the user can provide input as to how CPU access is allocated. This allocation may be among currently-running tasks or may alternatively correspond to how CPU access by a newly-commenced task will affect processing of other currently-running tasks. In one system, the allocation may simply be that a particular task is preferred or should be given priority. In this system, the preferred or prioritized task may be allocated, e.g., 50% of CPU access time while the remaining tasks share the remaining 50%. This percentage may of course vary. For example, if the preferred task is DVR playback, this may be allocated an even greater percentage due to the deleterious results of slow playback. That is, slow DVR playback is highly noticeable to the user. On the other hand, slow DVD recording may not be very noticeable to a user, so a lesser percentage of CPU access may be allotted for such a task, even where such a task is the preferred or chosen task.
In another system, the user may directly allocate a specific percentage of CPU access time to each task. While this user interface may be more difficult for the user to operate, the same provides a greater level of control.
However the user interface layer 12 receives its instructions, the same implements the CPU allocation through a CPU resource manager 16. The CPU resource manager 16 controls which and how tasks are given access to the CPU. In particular, the CPU resource manager 16 monitors CPU usage and regulates the level of access each task has to the CPU. The CPU resource manager 16 then controls the plurality of subsystems 18 including the CPU, hard disk, operating system, and other system resources to accomplish the results of the user input. For example, if the user desires to give preference to playback of a television program, the DVR is chosen as a preferred application and the same is given preferred access to the CPU, operating system, and hard disk.
Various examples of the operation of CPU resource manager 16 are provided below. The level of CPU access and control can vary from a system in which the CPU resource manager 16 automatically allocates CPU access based on a predetermined set of rules to a system in which the CPU resource manager 16 is completely dependent on user allocation choices to determine CPU access.
In one system with minimal CPU resource management, the CPU resource manager 16 may simply allot CPU preference on a “first-come-first-served” basis. In other words, the first task to be chosen by the user could be given preference to the CPU until the task concludes. This preference may either terminate or toll other tasks or provide the other tasks with greatly reduced CPU access. In some cases, this may undesirably preclude use of the CPU for any other tasks for an extended period of time.
In a more sophisticated and general system, the CPU resource manager 16, based on user input, apportions a designated amount of CPU, measured, e.g., by time or resources, that is reserved for a particular task or tasks. As noted above, this may be by a preference or priority level setting for each task. In this case, a portion of CPU access could be set where the more preferred or priority tasks receive a higher portion of CPU access based on an algorithm or other scheme. In another system, the CPU may perform a portion of a task as measured by the percentage computation time, i.e., number of clock pulses, which is given to the task. Rather than percentage of computing time, a certain number of programming lines or instructions may be performed, with a higher percentage yielding a higher number of instructions performed. In yet another system, the time required to complete a latest operation of each task, e.g., a DVD “burn”, may be displayed and may be alterable by the user by shifting CPU access preferences using the user interface.
In cases where an algorithm or other scheme is employed, the same may also take into account the ease with which the task or operation may be performed. For example, a request of an on-demand television program requires little processing, while recording onto a DVD is very processor-intensive. In some systems, the request may take precedence due to its ease of performance.
The CPU resource manager 16 may also take into account certain rules and may provide the user interface with user options corresponding to these rules. As one example, a CPU resource manager default policy may be set such that video playback from the DVR is preferred and that any other CPU activity is subsumed to that process. As another example, if the user requests preference be given to the DVD-recording task, the user interface may interpose a warning that video playback may be unsatisfactory due to this preference request.
In more detail, given the monitoring of the CPU by the CPU resource manager 16, the CPU resource manager 16 may provide alerts to the user interface layer 12 that the CPU is not available for a certain task, or that execution of that task will be slow. The user, through user interface layer 12, can also choose between certain options, such as allowing a certain task to be slow or canceling or tolling, i.e., temporarily stopping, execution of other tasks so that the chosen task may execute in a timely or otherwise preferred manner.
As noted above, where a preference or priority level is set, the more preferred or priority tasks receive a higher portion of CPU access based on an algorithm or other scheme. Where a preference or priority level is set high, that operation or task may be considered to be running in the foreground. Alternatively, if the user is currently viewing the results of a particular task, e.g., DVR playback, then that task may also be considered to be running in the foreground. Where a preference or priority level is set low, that operation or task may be considered to be running in the background. Similarly, if the user is not currently viewing the results of a particular task, e.g., DVD recording, and that task is not considered important or vital to be performed in a timely manner, then that task may also be considered to be running in the background.
Referring to
Specific examples of the system and method are now provided. Referring to
A GUI 60 according to this method is shown in
First, certain of the tasks are time-sensitive while others may be considered time-insensitive. For example, the record and playback tasks 62, 66, and 68 are time-sensitive in that a user would find gaps in such tasks extremely noticeable and likely unacceptable. However, the burn task 64 may experience gaps but this is not noticeable to the user as they user is not typically paying attention to such burn tasks. In this way, this task is time-insensitive.
Time-sensitive tasks often require some minimum percentage of CPU resource allocation. In other words, if such tasks are not afforded this minimum percentage, gaps or other deleterious features appear in the performance of the task. As can be seen from
In the example of
Referring to
In more detail, referring to
If the task completes during the cycle, then a check is made as to whether the queue is empty (step 118). In other words, a check is made as to whether another task may be executed, as if one task ends, there should be no need to wait until the end of the completed task's allocated time prior to continuing CPU execution of the following task. If there are no tasks waiting to be performed, the method may end (step 122). If another task may be executed, then the status of the next task is retrieved (step 116) and processing continued by the fetch of appropriate instructions and data (step 102).
However, if the percentage-based time, or other measure of allocation, expires during execution, then the status of that task is saved (step 114), the status of the next task is retrieved (step 116), and processing continues by the fetch of appropriate instructions and data (step 102).
Advantages of the invention may include one or more of the following. With a CPU resource manager, the user may be informed when a chosen task will have an extended duration, e.g., the user interface may display “Burning this DVD will take 3 hours and 43 minutes”. The user may also be given a choice as to which process will be given preference, e.g., “Please select one of the following: Burn DVD in background, which will take 3 hours and 43 minutes; or Burn DVD in foreground, which will take 33 minutes, but will make DVR playback impossible”. Further, the invention is not limited to set-top boxes: any product that has significant multi-tasking and limited CPU bandwidth could benefit from the systems disclosed.
While the above description has been provided using the examples of recording a TV signal using a DVR, playing back a pre-recorded DVR signal, and recording a DVD, it should be clear to one of ordinary skill in the art that other applicable tasks include recording and playing back MP3 files, transferring a recorded file, e.g., a song or TV show, to another STB, playing digital photograph slideshows, playing a DVD, etc. Further, while the term “currently-running” has been employed to mean processes, tasks, and applications that are running on a single CPU, the term could also apply to processes, tasks, and applications running concurrently on multiple processors.
It should be noted that the process shown in the figures may be implemented in a general, multi-purpose or single purpose processor. Such a processor will execute instructions, either at the assembly, compiled or machine-level, to perform that process. Those instructions can be written by one of ordinary skill in the art following the description of the figures and stored or transmitted on a computer readable medium. The instructions may also be created using source code or any other known computer-aided design tool. A computer readable medium may be any medium capable of carrying those instructions and include a CD-ROM, DVD, magnetic or other optical disc, tape, silicon memory (e.g., removable, non-removable, volatile or non-volatile), packetized or non-packetized wireline or wireless transmission signals.
It should be noted that the description above refers to specific examples of the invention, but that the scope of the invention is to be limited only by the scope of the claims appended hereto.