The embodiments of the invention relate generally to the field of computer processors. More particularly, the embodiments relate to an apparatus and method for workload, power, and performance-aware dynamic core frequency ramp rate.
Existing core frequency scaling algorithms are a function of core activity, the energy performance preference (EPP) values for each application thread, and the SoC power budget available for each core. The algorithm runs periodically and estimates the optimal core frequency based on the above inputs and ramps the core to the target frequency.
Some client SoCs do not limit the ramp rate of core frequency. For example, if an application is started on a core that is idle, core frequency can be ramped to one of its highest frequencies from its minimum frequency in one transition. Sharp frequency ramps help improve responsiveness but prove to be damaging in terms of power consumption and energy efficiency. For example, for application load times where latency can be tolerated, higher core frequencies result in higher average power consumption and lower energy efficiency with no added visible benefit to the user experience. Slower ramp rates are also desired when the system is in a reduced power mode, where the goal is to have a lower power floor to prolong battery usage. SoCs today are not capable of limiting the core frequency ramp rates, let alone varying the ramp rates based on system modes or application needs dynamically at runtime.
A better understanding of the present invention can be obtained from the following detailed description in conjunction with the following drawings, in which:
In various embodiments, techniques are provided for managing power and thermal consumption in a heterogeneous (hetero) processor. As used herein the term “hetero processor” refers to a processor including multiple different types of processing engines. For example, a hetero processor may include two or more types of cores that have different microarchitectures, instruction set architectures (ISAs), voltage/frequency (VF) curves, and/or more broadly power/performance characteristics.
Optimal design/operating point of a heterogeneous processor (in terms of VF characteristics, instructions per cycle (IPC), functionality/ISA, etc.) is dependent on both inherent/static system constraints (e.g., common voltage rail) and a dynamic execution state (e.g., type of workload demand, power/thermal state, etc.). To extract power efficiency and performance from such architectures, embodiments provide techniques to determine/estimate present hardware state/capabilities and to map application software requirements to hardware blocks. With varying power/thermal state of a system, the relative power/performance characteristics of different cores change. Embodiments take these differences into account to make both local and globally optimal decisions. As a result, embodiments provide dynamic feedback of per core power/performance characteristics.
More specifically, embodiments provide closed loop control of resource allocation (e.g., power budget) and operating point selection based on the present state of heterogeneous hardware blocks. In embodiments, a hardware guided scheduling (HGS) interface is provided to communicate dynamic processor capabilities to an operating system (OS) based on power/thermal constraints. Embodiments may dynamically compute hardware (HW) feedback information, including dynamically estimating processor performance and energy efficiency capabilities. As one particular example, a lookup table (LUT) may be accessed based on underlying power and performance (PnP) characteristics of different core types and/or post-silicon tuning based on power/performance bias.
In addition, embodiments may determine an optimal operating point for the heterogeneous processor. Such optimal operating point may be determined based at least in part on a present execution scenario, including varying workload demands (performance, efficiency, responsiveness, throughput, IO response) of different applications, and shifting performance and energy efficiency capabilities of heterogeneous cores.
In embodiments, the dynamically computed processor performance and energy efficiency capabilities may be provided to an OS scheduler. The feedback information takes into account power and thermal constraints to ensure that current hardware state is provided. In this way, an OS scheduler can make scheduling decisions that improve overall system performance and efficiency. Note that this feedback is not dependent on workload energy performance preference (EPP) or other software input. Rather, it is based on physical constraints that reflect current hardware state.
In contrast, conventional power management mechanisms assume all cores to be of the same type, and thus estimate the maximum achievable frequency on each core to be same for a given power budget. This is not accurate, as different cores may have different power/performance capabilities individually and they may have different maximum frequency based on other platform constraints. And further, conventional power management algorithms assume the same utilization target for all cores when calculating performance state (P-state) and hence do not take into account the heterogeneity of an underlying architecture. Nor do existing techniques optimize the operating points with an objective of mapping a particular type of thread to a core type based on optimizing power or performance.
In general, a HGS interface provides dynamic processor capabilities to the OS based on power/thermal constraints. The OS takes this feedback as an input to a scheduling algorithm and maps workload demand to hetero compute units. The scheduler's mapping decisions may be guided by different metrics such as performance, efficiency or responsiveness, etc. The scheduling decisions in turn impact processor states, hence forming a closed loop dependence. Since workload demand, in terms of power/performance requirements, can vary by large margins, any change in scheduling decisions can cause a large shift in HGS feedback, leading to unacceptable stability issues. Embodiments provide techniques that are independent/resilient of the scheduling decisions or other software inputs from the operating system, and thus avoid these stability issues.
Although the following embodiments are described with reference to specific integrated circuits, such as in computing platforms or processors, other embodiments are applicable to other types of integrated circuits and logic devices. Similar techniques and teachings of embodiments described herein may be applied to other types of circuits or semiconductor devices that may also benefit from better energy efficiency and energy conservation. For example, the disclosed embodiments are not limited to any particular type of computer systems. That is, disclosed embodiments can be used in many different system types, ranging from server computers (e.g., tower, rack, blade, micro-server and so forth), communications systems, storage systems, desktop computers of any configuration, laptop, notebook, and tablet computers (including 2:1 tablets, phablets and so forth), and may be also used in other devices, such as handheld devices, systems on chip (SoCs), and embedded applications. Some examples of handheld devices include cellular phones such as smartphones, Internet protocol devices, digital cameras, personal digital assistants (PDAs), and handheld PCs. Embedded applications may typically include a microcontroller, a digital signal processor (DSP), network computers (NetPC), set-top boxes, network hubs, wide area network (WAN) switches, wearable devices, or any other system that can perform the functions and operations taught below. More so, embodiments may be implemented in mobile terminals having standard voice functionality such as mobile phones, smartphones and phablets, and/or in non-mobile terminals without a standard wireless voice function communication capability, such as many wearables, tablets, notebooks, desktops, micro-servers, servers and so forth. Moreover, the apparatuses, methods, and systems described herein are not limited to physical computing devices, but may also relate to software optimizations.
Referring now to
As seen, processor 110 may be a single die processor including multiple cores 120a-120n. In addition, each core may be associated with an integrated voltage regulator (IVR) 125a-125n which receives the primary regulated voltage and generates an operating voltage to be provided to one or more agents of the processor associated with the IVR. Accordingly, an IVR implementation may be provided to allow for fine-grained control of voltage and thus power and performance of each individual core. As such, each core can operate at an independent voltage and frequency, enabling great flexibility and affording wide opportunities for balancing power consumption with performance. In some embodiments, the use of multiple IVRs enables the grouping of components into separate power planes, such that power is regulated and supplied by the IVR to only those components in the group. During power management, a given power plane of one IVR may be powered down or off when the processor is placed into a certain low power state, while another power plane of another IVR remains active, or fully powered.
Still referring to
Also shown is a power control unit (PCU) 138, which may include hardware, software and/or firmware to perform power management operations with regard to processor 110. As seen, PCU 138 provides control information to external voltage regulator 160 via a digital interface to cause the voltage regulator to generate the appropriate regulated voltage. PCU 138 also provides control information to IVRs 125 via another digital interface to control the operating voltage generated (or to cause a corresponding IVR to be disabled in a low power mode). In various embodiments, PCU 138 may include a variety of power management logic units to perform hardware-based power management. Such power management may be wholly processor controlled (e.g., by various processor hardware, and which may be triggered by workload and/or power, thermal or other processor constraints) and/or the power management may be performed responsive to external sources (such as a platform or management power management source or system software).
In embodiments herein, PCU 138 may be configured to dynamically determine hardware feedback information regarding performance and energy efficiency capabilities of hardware circuits such as cores 120 and provide an interface to enable communication of this information to an OS scheduler, for use in making better scheduling decisions. To this end, PCU 138 may be configured to determine and store such information, either internally to PCU 138 or in another storage of system 100.
Furthermore, while
While not shown for ease of illustration, understand that additional components may be present within processor 110 such as uncore logic, and other components such as internal memories, e.g., one or more levels of a cache memory hierarchy and so forth. Furthermore, while shown in the implementation of
Processors described herein may leverage power management techniques that may be independent of and complementary to an operating system (OS)-based power management (OSPM) mechanism. According to one example OSPM technique, a processor can operate at various performance states or levels, so-called P-states, namely from P0 to PN. In general, the P1 performance state may correspond to the highest guaranteed performance state that can be requested by an OS. In addition to this P1 state, the OS can further request a higher performance state, namely a P0 state. This P0 state may thus be an opportunistic or turbo mode state in which, when power and/or thermal budget is available, processor hardware can configure the processor or at least portions thereof to operate at a higher than guaranteed frequency. In many implementations a processor can include multiple so-called bin frequencies above the P1 guaranteed maximum frequency, exceeding to a maximum peak frequency of the particular processor, as fused or otherwise written into the processor during manufacture. In addition, according to one OSPM mechanism, a processor can operate at various power states or levels. With regard to power states, an OSPM mechanism may specify different power consumption states, generally referred to as C-states, C0, C1 to Cn states. When a core is active, it runs at a C0 state, and when the core is idle it may be placed in a core low power state, also called a core non-zero C-state (e.g., C1-C6 states), with each C-state being at a lower power consumption level (such that C6 is a deeper low power state than C1, and so forth).
Understand that many different types of power management techniques may be used individually or in combination in different embodiments. As representative examples, a power controller may control the processor to be power managed by some form of dynamic voltage frequency scaling (DVFS) in which an operating voltage and/or operating frequency of one or more cores or other processor logic may be dynamically controlled to reduce power consumption in certain situations. In an example, DVFS may be performed using Enhanced Intel SpeedStep™ technology available from Intel Corporation, Santa Clara, Calif., to provide optimal performance at a lowest power consumption level. In another example, DVFS may be performed using Intel TurboBoost™ technology to enable one or more cores or other compute engines to operate at a higher than guaranteed operating frequency based on conditions (e.g., workload and availability).
Another power management technique that may be used in certain examples is dynamic swapping of workloads between different compute engines. For example, the processor may include asymmetric cores or other processing engines that operate at different power consumption levels, such that in a power constrained situation, one or more workloads can be dynamically switched to execute on a lower power core or other compute engine. Another exemplary power management technique is hardware duty cycling (HDC), which may cause cores and/or other compute engines to be periodically enabled and disabled according to a duty cycle, such that one or more cores may be made inactive during an inactive period of the duty cycle and made active during an active period of the duty cycle.
Referring now to
As shown in
In one or more embodiments, the processor 210 may be a hardware processing device (e.g., a central processing unit (CPU), a System on a Chip (SoC), and so forth). As shown, the processor 210 can include any number of processing engines 220A-220N (also referred to generally as processing engines 220) and a guide unit 230. Each processing engine 220 can include one or more sensors 240 to provide measurements regarding the processing engine 220 to the guide unit 230. For example, the sensors 240 may provide measurements regarding processing engine performance, efficiency, power usage, temperature, reliability, thread execution, and so forth.
In one or more embodiments, the guide unit 230 may be a hardware component of the processor 210 to provide processing engine information to guide a thread scheduler (not shown). In some embodiments, the processing engine information may include one or more rankings of processing engines (e.g., thread agnostic rankings, thread specific rankings, and so forth). Further, in some embodiments, the processing engine information may include one or more predicted characteristics of a processing engine. Various aspects of the guide unit 230 are described below.
Referring to
As shown in
In one or more embodiments, the PE monitors 310 may monitor characteristics of each PE without regard to a specific workload or thread. The monitored characteristics of each PE may include performance, efficiency, energy use, thermal, and reliability characteristics. For example, the PE monitors 310 may monitor metrics such as instructions per clock cycle, power consumed per time period, percentage of maximum performance, average power state, temperature, percentage of lifecycle that has elapsed, total number of power cycles, maximum power level, and so forth. The PE monitors 310 may be implemented using hardware counters.
In some embodiments, the PE monitors 310 may monitor and/or count system events representing PE execution characteristics (e.g., microarchitecture events, architecture events, system events, etc.). For example, the PE monitors 310 may determine the number of floating point instruction retired, the number of memory instructions retired, the number of branch mispredictions, the number of cache misses, the number of pipeline stalls, and so forth.
In one or more embodiments, the thread monitors 320 may monitor characteristics of individual threads. For example, the thread monitors 320 may monitor metrics such as instructions completed per time period, idle time, and so forth. Further, the thread monitors 320 may determine an execution profile and/or type, such as graphics processing, network processing, floating point calculation, encryption processing, and so forth. The thread monitors 320 may be implemented using hardware counters.
In some embodiments, the prediction logic 335 may use data from the PE monitors 310 and/or the thread monitors 320 to predict the performance of a thread on multiple PEs. For example, assume that a first thread is currently executing on a first PE (e.g., PE 220A shown in
In one or more embodiments, the TA rank logic 330 may use data from the PE monitors 310 and/or the prediction logic 335 to generate one or more TA rankings 350. In some embodiments, each TA ranking 350 may include a list of PEs arranged in a particular thread agnostic order. Referring now to
Referring again to
Referring again to
In one or more embodiments, the scheduling manager 380 and/or the scheduler 390 may implemented in software (e.g., the operating system, a stand-alone application, etc.). The scheduling manager 380 may control the amount and/or format of the TA rankings 350 and TS rankings 360 provided to the scheduler 390. For example, the scheduling manager 380 may sort PE rankings, may filter PE rankings according to criteria (e.g., by age, by PE group, by thread group, by type, and so forth), may combine multiple PE rankings to generate combined PE rankings, may reformat PE rankings, and so forth.
In one or more embodiments, the scheduler 390 may use the TA rankings 350 and/or the TS rankings 360 to allocate threads to PES (e.g., PEs 220 shown in
In some embodiments, the TA rankings 350 and/or the TS rankings 360 may include indications to provide specific guidance to the scheduler 390. For example, a first PE may be assigned a rank value (e.g., “0”) to indicate that the first PE is to remain offline and thus should not be assigned any threads. In some embodiments, a PE may be taken offline to improve reliability of the PE, to delay a lifecycle limit of the PE, to remain within a specified power budget, to limit power use during a particular power state, to control temperature gradients and/or hot spots in PEs, and so forth.
In some embodiments, the output of the guide logic 300 may reflect groupings of PEs according to defined criteria. For example, the PEs listed in the TA rankings 350 may be grouped into performance classes (e.g., Class A with performance metric from 0 to 2, Class B with performance metric from 3 to 7, and Class C with performance metric from 8 to 10). Such groupings may allow the scheduler 390 to manage thread allocations by groups rather than by individual PEs.
Referring now to
In some embodiments, the PE 610 may include a performance monitor 612, an energy monitor 614, and an event monitor 616. Further, the PE 610 may execute a source thread 618. The event monitor 616 may detect events of the PE 610 during execution of the source thread 618, such as memory instruction retirements, floating point instruction retirements, branch mispredictions, cache misses, pipeline stalls, and so forth. The performance monitor 612 may monitor performance characteristics of the PE 610 (e.g., instructions per clock cycle, percentage of maximum performance, etc.). The energy monitor 614 may monitor energy characteristics of the PE 610, such as power consumed per time period, power state, etc. In some embodiments, the performance monitor 612, the energy monitor 614, and/or the event monitor 616 may be implemented using hardware counters.
In one or more embodiments, the prediction logic 620 may include a weight updater 622, prediction weights 624, event vectors 626, and PE predictors 614. In some embodiments, the prediction logic 620 may receive indications of events from the event monitor 616 of PE 610, and may populate the event vectors 626 according to the received indications.
Referring now to
It is contemplated that the event vectors 626 for different PEs (or different PE types) may include fields for different event types, and may include different numbers of fields. For example, the group of vectors for PE N may include a performance vector 634 with three fields, and an energy vector 636 with three fields.
In some embodiments, the prediction weights 624 may be arranged in vectors similar to the event vectors 626. Referring now to
Referring again to
In one or more embodiment, the PE predictors 628 may use a linear predictor to multiply an event vector 626 by a weight vector of the prediction weights 624, and determine a predicted value based on a sum of the element products. For example, the linear predictor may multiply each element of performance vector 630 of PE A (shown in
In one or more embodiment, the PE predictors 628 may provide predictions as to use a linear predictor to multiply an event vector 626 by a weight vector of the prediction weights 624, and determine a predicted value based on a sum of the element products. For example, the linear predictor may multiply each element of performance vector 730 of PE A by the corresponding element of weight vector 740 of PE A, and may sum the products of all vector elements. The resulting sum may be a predicted performance value for the source thread 618 if it was executed on PE A. In some embodiments, the predicted performance may be provided to a scheduler (e.g., scheduler 390), and the scheduler may use this information to determine whether to move the source thread 618 to PE A from PE 610.
In one or more embodiment, the weight updater 622 may compare PE predictions for a given PE to measured values to adjust the prediction weights 624. For example, assume that a scheduler receives predicted performance and energy characteristics for PE A, and then reallocates the source thread 618 to PE A. Assume further that PE A includes a performance monitor 612 and an energy monitor 614 that provide measured performance and energy characteristics for the execution of the source thread 618 on PE A. In this example, the weight updater 622 may compare the predicted and measured characteristics, and may adjust the prediction weights 624 based on this comparison. In this manner, the weight updater 622 may adjust the prediction weights 624 over time to improve the accuracy of future predictions of the prediction logic 620.
When a new thread is to be executed, the embodiments described below identify the class associated with the thread (or the default class) and select the logical processor available within that class having the highest performance and/or best energy efficiency values. If the optimal logical processor is not available, one embodiment of the invention determines the next best logical processor and either schedules the new thread for execution on the next best performance or energy cores, or migrates a running thread from the optimal logical processor to make room for the new thread. In one embodiment, the decision to migrate or not migrate the running thread is based on a comparison of performance and/or energy values associated with the new thread and the running thread. In one implementation, it is up to the OS to choose the appropriate scheduling method per software thread, ether based on energy consumption (e.g., for low power environments) or best performance
As used herein, a logical processor (LP) may comprise a processor core or a specified portion of a processor core (e.g., a hardware thread on the processor core). For example, a single threaded core may map directly to one logical processor whereas an SMT core may map to multiple logical processors. If the SMT core is capable of simultaneously executing N threads, for example, then N logical processors may be mapped to the SMT core (e.g., one for each simultaneous thread). In this example, N may be any value based on the capabilities of the SMT core (e.g., 2, 4, 8, etc). Other execution resources may be associated with a logical processor such as an allocated memory space and/or portion of a cache.
In some case, the platform may include a mix of cores, some of which include SMT support and some of which do not. In some cases, the performance and energy results of a core that has SMT support may be better than results on a non-SMT core when running more than one software thread. In other cases, the non-SMT core may provide better performance/energy results. Thus, in one embodiment, the scheduling order is: (1) schedule first on the core with highest performance/energy; (2) second, scheduled on the core with the lower perf/energy capabilities; and (3) finally, schedule on the core with SMT support.
It has been observed that random scheduling of threads from different types of workloads on a set of heterogeneous cores can result in lower performance than would be possible when compared with more intelligent allocation mechanisms.
In some embodiments described below, the “small cores” are Atom processors and the “big cores” are Core i3, i5, i7, or i9 cores. These cores may be integrated on the same die and/or interconnected on the same processor package. Note, however, that the underlying principles of the invention are not limited to any particular processor architecture or any specific type of processor or core.
At the same amount of power, a small core such as an Atom processor may provide higher performance than that of a big core. This power/performance cross point is a function of the ratio of big core IPC over small core IPC (i.e., IPCB/IPCS) which is particularly impacted for single threads or a small number of threads. The different IPCB/IPCS values also impact the potential to reduce energy in order to improve battery life. As the ratio decreases, scheduling work on big cores becomes less attractive from an energy savings perspective.
In one embodiment, different classes are defined for different types of workloads. In particular, one embodiment defines a first class of workloads with an IPCB/IPCS ratio below 1.3, a second class of workloads with an IPCB/IPCS ratio below 1.5, and a third class of workloads with an IPCB/IPCS ratio above (or equal to) 1.5.
One embodiment of the invention maintains a global view of the performance and energy data associated with different workloads and core types as well as different classes of big/little IPC values. As shown in
For the purpose of illustration, two types of cores are shown in
In one embodiment, a scheduler 810 maps threads/workloads 801 to cores 851-852 and/or logical processors LP0-LP7 based on current operating conditions 841 and the performance and energy data from a global table 840 (described in greater detail below). In one embodiment, the scheduler 810 relies on (or includes) a guide/mapping unit 814 to evaluate different thread/logical processor mappings in view of the global table 840 to determine which thread should be mapped to which logical processor. The scheduler 810 may then implement the mapping. The scheduler 810, guide/mapping unit 814, table manager 845, and global table 840 may be implemented in hardware/circuitry programmed by software (e.g., by setting register values) or by a combination of hardware and software.
The currently detected operating conditions 841 may include variables related to power consumption and temperature, and may determine whether to choose efficiency values or performance values based on these conditions. For example, if the computing system is a mobile device, then the scheduler 810 may perform mapping using efficiency options more frequently, depending on whether the mobile device is currently powered by a battery or plugged into an electrical outlet. Similarly, if the battery level of the mobile computing system is low, then the scheduler 810 may tend to favor efficiency options (unless it would be more efficient to use a large core for a shorter period of time). As another example, if a significant amount of power of the overall power budget of the system is being consumed by another processor component (e.g., the graphics processing unit is performing graphics-intensive operations), then the scheduler 810 may perform an efficiency mapping to ensure that the power budget is not breached.
One embodiment of a global table 840, shown below as Table B, specifies different energy efficiency and performance values for each core 851-852 within each defined class (e.g., Eff02, Perf11, etc). The cores are associated with a logical processor number (LP0-LPn) and each logical processor may represent any type of physical core or any defined portion of a physical core, including an entire core.
In one embodiment, a table manager 845 performs updates to the global table 840 based on feedback 853 related to the execution of the different threads/workloads 801. The feedback may be stored in one or more MSRs 855 and read by the table manager 845.
The first time a thread/workload is executed, it may be assigned a default class (e.g., Class 0). The table manager 845 then analyzes the feedback results when executed in the default class, and if a more efficient categorization is available, the table manager 845 assigns this particular thread/workload to a different class. In one embodiment, the feedback 853 is used in one embodiment to generate an index into the global table 840. The classes in this embodiment are created based on ranges of IPCB/IPCS as described above.
In one embodiment, the scheduler 810 uses the global table 840 and associated information to realize a global view of the different core types and corresponding performance and energy metrics for different classes. Extensions to existing schedulers may add new columns per class type. In one embodiment, the different classes enable an operating system or software scheduler to choose different allocation mechanisms for a workload based on the class of that workload.
In one embodiment, Class 0 is defined as a default class which maintains legacy support and represents the median case of the curve. In this embodiment, the guide/mapping unit 814 and/or scheduler 810 uses this default class when no valid data has been collected for the current thread. As described above, the table manager 845 may evaluate feedback 853 related to the execution of the thread in the default class and provide an update 854 to the global table 840 if a different class is more appropriate. For example, it may categorize the thread into Class 1 if the IPCB/IPCS ratio of the thread is greater than a first specified threshold (e.g., 1.5) and categorize the thread into Class 2 if the IPCB/IPCS ratio is less than a second threshold (e.g., 1.3).
The different columns per class in the global table 840 may be specified via one or more control registers. For example, in an x86 implementation, the columns may be enumerated by CPUID[6].EDX [7:0] (e.g., for a table with 7-1 different columns per class). The operating system (OS) 813 and/or scheduler 810 can learn which line is relevant for each logical processor by one or more bits in EDX (e.g., CPUID.6.EDX [31-16]=n, where n is the index position which the logical processor's line is set) and can also determine the number of classes via a value in EDX (e.g., indicated by CPUID.6.EDX [11:8]). The OS can calculate the location of each logical processor line in the HGS table by the following technique:
The size of the HGS table can be enumerated by CPUID [6].EDX [11:8]
The OS can enumerate about the legacy HGS basic support from CPUID [6].EAX [19] and about the newer HGS+ support from CPUID [6]. EAX [23]
In one embodiment, the performance capability values are non-semantic and do not necessarily reflect actual performance.
The performance columns in the table store relative performance values between the logical processors represented in the different rows. One embodiment of the interface provides for sharing of lines with a plurality of different logical processors that belong to the same core type, thereby providing for reasonable comparisons.
For each defined class, the ratio of performance values between cores within the same column such as
provides a rough comparison but does not provide an actual performance value. Similarly, the ratio of energy efficiency values in a column such as
for each logical processor provides a relative comparison, but does not reflect the actual energy consumed.
In one embodiment, the table manager 845 updates the global table 840 when the relative performance or energy value has experienced a significant change that can impact scheduling, such as when the order between the cores or the difference between the cores changes. These changes can be specified in one or more columns and, for each column that was updated, the column header is marked to indicate that the change was made. In addition, a status bit may be set in a control register to indicate that an update occurred. For example, in some x86 implementations, the status bit is set in a particular model-specific register (MSR).
The global table 840 can be updated dynamically as a result of physical limitations such as power or thermal limitations. As a result, part or all of the performance and energy class value columns may be updated and the order in which a core with the best performance or energy is selected may be changed.
When updates like this happen, the hardware marks the column(s) that was updated in the global table 840 (e.g., in the column header field). In addition, in one embodiment, the time stamp field is updated to mark the last update of the table.
In addition, the thermal status registers may also be updated and, if permitted by the OS, the thermal interrupts. An interrupt may also be generated to notify the OS about the changes. Following the setting of the thermal updates, the table manager 845 may not update the global table 840 any more until permitted by the OS (e.g., the OS clears the log bit). This is done in order to avoid making changes while the OS is reading the table.
Given that that different classes may be impacted in a different way for different physical limitations, one embodiment of the invention provides the ability to update only selected table classes. This configurability provides for optimal results even when the physical conditions are changed. Following an indication that the order of the class performance or energy is changed, the OS may reschedule software threads in accordance with each software thread's class index.
In one embodiment, in response to detected changes, a thread-level MSR 855 reports the index into the current thread column to the OS 813 and/or scheduler 810 as well as a valid bit to indicate whether the reported data is valid. For example, for a thread-level MSR 855, the following bits may provide indications for RTC (run time characteristics):
Bit 7:0—Application class index of the table, representing the latest “Application Class” executed on this hardware thread;
Bit 63—Valid bit; if set to 1, the OS/scheduler can use it, otherwise the class index should be ignored
In one embodiment, the valid bit is set or cleared based on the current state and operational characteristics of the microarchitecture. For example, the data may not be valid following a context switch of a new thread 801 until the hardware (e.g., the table manager 845) can evaluate or otherwise determine the characteristics of the new thread. The valid bit may also be adjusted when transitioning between specific security code flows. In circumstances where the valid bit is not set, the scheduler 810 may ignore the feedback data and use the last index known to be valid.
In one embodiment, the OS 813 and/or scheduler 810 reads this MSR 855 when swapping out a context in order to have the most up-to-date information for the next context swapped in. The OS 813 and/or scheduler 810 can also read the MSR 855 dynamically during runtime of the current software thread. For example, the OS/scheduler may read the MSR 855 on each tick of the scheduler 810.
In order for the hardware (e.g., the table manager 845) to have the time required to learn about the new thread and ensure the validity of the report index after the new context is swapped in, one embodiment of the invention provides the option to save and restore the microarchitectural metadata that includes the history of the index detection. In one implementation, this is accomplished using the MSR 855 which can be ether read or written as a regular MSR or by utilizing the processor's save and restore mechanisms (e.g., such as XSAVES/XRESROS on an x86 implementation). For example:
Thread level Scope MSR (Read/Write)
In one implementation, the OS 813 and/or scheduler 810 reads this metadata when swapping in the thread and updates it during execution and/or when swapping out the same thread.
In some implementations where metadata is not supported, prediction history is still need to be reset during a context switch in order to enable valid feedback that will not be impacted from previous execution of the software thread. This reset data may be enabled if the OS is configured to “opt-in” support of history reset every time that IA32_KENTEL_GS_BASE is executed. Other OS-based context switch techniques that include H/W architecture methods may also be used in order to reset the hardware guided scheduling prediction history during context switches. In another embodiment, a specific MSR is enabled with a control bit that forces resetting the history. This control MSR can be ether saved and restored by XSAVES/XRESORS or manually used by the OS on every context switch. other option can be that every time that the value of this MSR be zero, write or restore this MSR will reset the hardware guided scheduling history, Another embodiment resets the history via a thread level config MSR (as described below) that enables the option for the OS to manually reset the history.
The OS 813 and/or scheduler 810 can enable and disable the extension of the global table 840 via an MSR control bit. This may be done, for example, to avoid conflicts with legacy implementations and/or to avoid power leakage. For example, the operating system may dynamically disable the features described herein when running on legacy systems. While disabled, the feedback MSR thread level report is invalid. Enabling can be done at the logical processor level in order to provide, for example, the VMM the option to enable the techniques described herein for part of an SoC based on each VM usage mode (including whether the VM supports these techniques).
In one particular embodiment, the thread level configuration is implemented as follows:
In one implementation, the enabling and disabling is performed via a package-level MSR. For example, in an x86 implementation the following MSR may be specified: IA32_HW_FEEDBACK_CONFIG
Bit 0—Enable. When set to 1, this bit enables the hardware feedback interface described herein. The default is 0.
Bit 1—Enable. When set to 1, this bit enables multiple class support. The extra classes columns in the global table 840 are valid only while bit 1 is set. Setting this bit enables the thread level feedback 853 sent to the MSR 855 to support valid report class indices.
As mentioned, when a new thread is to be executed, embodiments of the invention identify the class associated with the thread (or the default class) and select the logical processor (LP) available within that class having the highest performance and/or best energy efficiency values (depending on the current desired power consumption). If the optimal logical processor is not available, one embodiment of the invention determines the next best logical processor and either schedules the new thread for execution on the next best logical processor, or migrates a running thread from the optimal logical processor to make room for the new thread. In one embodiment, the decision to migrate or not migrate the running thread is based on a comparison of performance and/or energy values associated with the new thread and the running thread.
For a “High Priority” thread, the relevant column is determined based on the thread class index (k). In one embodiment, the index is provided by a feedback MSR 855. On the thread performance class column (k), a row is identified with the highest performance value. If the corresponding logical processor is free, then the thread is scheduled on this logical processor.
Alternatively, if all highest performance logical processors are occupied, the performance class column (k) is then searched for a free logical processor, working from highest to lowest performance values. When one is located, the thread may be scheduled on the free logical processor or a running thread may be migrated from the preferred logical processor and the new thread may be scheduled on the preferred logical processor.
In this embodiment, the scheduler 810 may evaluate whether to migrate an existing thread to a different logical processor to ensure a fair distribution of processing resources. In one embodiment, comparisons are made between the different performance values of the different threads and logical processors to render this decision, as described below.
Thus, in one embodiment, when a new thread must be scheduled for execution on a logical processor, the index of the new thread (I) is used to search for a free logical processor in the performance class associated with the new thread (e.g., one of the columns in the global table 840). If there is an idle logical processor with the highest performance value then the new thread is scheduled on the idle logical processor. If not, then a secondary logical processor is identified. For example, the scheduler may search down the column in the global table 840 to identify the logical processor having the second highest performance value.
An evaluation may be performed to determine whether to migrate any running threads from a logical processor which would be a highest performance LP for the new thread to a different logical processor to make room for the new thread on the highest performance logical processor. In one embodiment, this evaluation involves a comparison of the performance values of the running thread and the new thread on the highest performance logical processor and one or more alternate logical processors. For the new thread, the alternate logical processor comprises the secondary processor (i.e., which will provide the next highest performance for the new thread). For the running thread, the alternate logical processor may comprise the secondary logical processor (if it will provide the second highest performance) or another logical processor (if it will provide the second highest performance).
In one particular implementation, the ratio of the performance on highest performance LP over performance on the alternate LP for both the new thread and the running thread. If the ratio for the new thread is greater, then the running thread is migrated to its alternate logical processor. if the ratio for the running thread is greater, then the new thread will be scheduled on its alternate logical processor. The following are example ratio calculations:
New Thread Comp Value=Perfnew thread highest/Perfnew thread alternate
Running Thread Comp Value=Perfrunning thread highest/Perfrunning thread alternate
If the above ratio is greater for the new thread, then the running thread is migrated to its alternate logical processor (i.e., the LP on which it will have the second highest performance) and new thread is scheduled to execute on its highest performance logical processor. If the ratio is greater for the running thread, then the new thread is scheduled on the secondary LP (which will provide it with the second highest performance).
In one embodiment, when energy efficiency is selected as the determining factor, the same techniques as described above are implemented to determine the logical processor for the new thread but using the efficiency class data from the global table 840 instead of the performance class data. For example, the index of the new thread (I) is used to search for a free logical processor in the efficiency class associated with the new thread. If there is an idle logical processor with the highest efficiency value, then the new thread is scheduled on the idle logical processor. If not, then a secondary logical processor is identified. For example, the scheduler may search down the column in the global table 840 to identify the logical processor having the second best efficiency value. An evaluation is performed to determine whether to migrate any running threads from a logical processor which would be a highest efficiency LP for the new thread to a different logical processor to make room for the new thread. To render this decision, efficiency ratios may be determined as described above for performance:
New Thread Comp Value=Effnew thread highest/Effnew thread alternate
Running Thread Comp Value=Effrunning thread highest/Effrunning thread alternate
As with performance, the thread with the larger index is executed on the highest efficiency logical processor, while the other thread is run (or migrated) to an alternate logical processor.
The above analysis may be performed to allocate and migrate threads in the same or different performance and efficiency classes. If the new thread has a different class index as the other threads in busy logical processors, then the performance or efficiency ratio is determined using the highest performance or efficiency value over the next best performance or efficiency value for each of the threads currently running and/or new threads to be scheduled. Those threads with the highest ratios are then allocated to the highest performance or efficiency logical processors while the others are scheduled (or migrated) on the next best performance or efficiency logical processors.
In one embodiment, in order to migrate a running thread, the ratio of the new thread must be greater than the running thread by a specified threshold amount. In one embodiment, this threshold value is selected based on the amount of overhead required to migrate the running thread to the new logical processor (e.g., the processing resources, energy, and time consumed by the migration). This ensures that if the ratio of the new thread is only slightly higher than that of the running thread, then the running thread will not be migrated.
In one embodiment, the scheduler 810 performs a thread allocation analysis periodically (e.g., every 15 ms, 20 ms, etc) to perform the above performance and/or efficiency comparisons. If a higher performance or improved energy efficiency option is available, it will then migrate one or more threads between logical processors to achieve this higher performance or higher efficiency option.
Some existing scheduling implementations provide a global view of the performance and energy characteristics of different core/processor types. However, these implementations assume the same level of big/little IPCs and take the median value of all possible traces while ignoring the actual differences between different types of software threads. The embodiments of the invention address this limitation by considering these differences.
Various embodiments of the invention evaluate different types of core parking and core consolidation hints, requests, and other relevant conditions to generate a resolved hardware-guided scheduling (HGS) hint, while architecturally meeting the requirements of dynamic core parking scenarios that may mall coexist in the processor. Some embodiments coordinate with the OS scheduler to determine a specific set of cores to be parked or consolidated in view of runtime metrics such as core utilization, thread performance, memory dependencies, core topology, and voltage-frequency curves. At least one embodiment allocates a power budget to different IP blocks in the processor to deliver a desired performance, recognizing the differences in the relative priority of each type of compute block as well as the differences in the power/frequency and frequency/performance relationships in each of the compute blocks. Some implementations allocate the power budget in view of a disaggregated, heterogeneous processor architecture with separate compute tiles, SoC tiles, graphics tiles, and IO tiles.
As used herein, a “parking” hint refers to a request or recommendation to avoid using specific cores (e.g., thereby “parking” the cores). The parking hints and other types of hints described herein may be communicated via a hardware feedback interface (HFI) storage such as a register (e.g., an MSR) or memory region allocated by the operating system (OS).
Currently, parking hints have the disadvantage of hiding the performance capabilities of the parked cores from the OS. As a result, when the OS has high priority work that no longer fits within the available cores, and it wants to run that work on a high performance core, it has no information as to what core to use.
A “consolidation” hint is a request generated to consolidate efficient work to a subset of the cores on the processor. In existing implementations, the OS may erroneously interpret this hint as a request to consolidate all work on this subset of cores, even if lower priority work must be deferred. A particular type of consolidation, referred to as “below PE consolidation” (BPC) attempts to contain the number of cores to bring the per-core frequency above a limit when the system is frequency limited.
Processor “survivability” features are activated when there are thermal and/or electrical reasons to reduce the number of cores to avoid shut down of the processor. In some implementations, survivability causes cores to be parked rather than contained to ensure that the OS will not start using more cores than hinted. In some embodiments, parking starts with the most power-consuming cores. For example, in the disaggregated architectures described below, the parking order may be: highest performance big cores (e.g., ULT big cores), big cores, compute die small cores (e.g., compute die Atom cores), and SoC die small core (e.g., SoC die Atom cores). In the final stages, the SoC may run out of a single SoC die core. In one embodiment, when only a single efficient core is active, the survivability feature is deactivated. Because this feature is critical, it overrides other hints/configuration settings; at the same time this condition is not expected to occur very often.
In some embodiments, because the goal of both below BPC and survivability is to reduce the number of cores, when BPC and survivability both are active, BPC is bypassed to avoid aggressive constraining when not required.
Various hardware-based techniques may be used for optimizing active cores. For example, with Hardware Guided Scheduling (HGS) (e.g., as implemented on hardware guide unit 814 described above), hints may be provided to the OS to not schedule work on a subset of cores (core parking) and/or hints to only schedule the work on a subset of cores (core consolidation), with the goal of improving overall power and performance (PnP). Some embodiments of the invention determine a specific set of cores to be parked or consolidated in view of the disaggregated architecture of the processor, various runtime metrics (e.g., core utilization, temperature), thread performance, memory dependencies, core topology, and voltage-frequency curves.
Some embodiments implement a distributed power management architecture comprising a plurality of power management units (P-units) 930-933 distributed across the various dies 905, 910, 915, 920, respectively. In certain implementations, the P-units 930-933 are configured as a hierarchical power management subsystem in which a single P-unit (e.g., the P-unit 930 on the SoC tile 910 in several examples described herein) operates as a supervisor P-unit which collects and evaluates power management metrics provided from the other P-units 931-933 to make package-level power management decisions and determine power/performance states at which each of the tiles and/or individual IP blocks are to operate (e.g., the frequencies and voltages for each of the IP blocks).
The supervisor P-unit 930 communicates the power/performance states to the other P-units 931-933, which implement the power/performance states locally, on each respective tile. In some implementation, the package-wide power management decisions of the supervisor P-unit 930 include decisions described herein involving core parking and/or core consolidation.
An operating system (OS) and/or other supervisory firmware (FW) or software (SW) 970 may communicate with the supervisory P-unit 930 to exchange power management state information and power management requests (e.g., such as the “hints” described herein). The hardware guide unit 814 and associated tables may be implemented in the supervisor P-unit 1030 and/or the SoC tile 910. In some implementations described herein, the communication between the OS/supervisory FW/SW 970 and the P-unit 930 occurs via a mailbox register or set of mailbox registers. In some embodiments, a Baseboard Management Controller (BMC) or other system controller may exchange power control messages with the supervisory P-unit 930 via these mailbox registers or a different set of mailbox registers.
The E-cores in the E-core clusters 1010-1011 and the SoC tile 910 are physically smaller (with multiple E-cores fitting into the physical die space of a P-core), are designed to maximize CPU efficiency, measured as performance-per-watt, and are typically used for scalable, multi-threaded performance. The E-cores work in concert with P-cores 1020-1021 to accelerate tasks which tend to consume a large number of cores. The E-cores are optimized to run background tasks efficiently and, as such, smaller tasks are typically offloaded to E-cores (e.g., handling Discord or antivirus software)-leaving the P-cores 1020-1021 free to drive high performance tasks such as gaming or 3D rendering.
The P-cores 1020-1021 are physically larger, high-performance cores which are tuned for high turbo frequencies and high IPC (instructions per cycle) and are particularly suited to processing heavy single-threaded work. In some embodiments, the P-cores are also capable of hyper-threading (i.e., concurrently running multiple software threads).
In the illustrated embodiment, separate P-units 1015-1016 are associated with each E-core cluster 1010-1011, respectively, to manage power consumption within each respective E-core cluster in response to messages from the supervisor P-unit 1030 and to communicate power usage metrics to the supervisor P-unit 1030. Similarly, separate P-units 1025-1026 are associated with each P-core 1020-1021, respectively, to manage power/performance of the respective P-core in response to the supervisor P-unit 1030 and to collect and communicate power usage metrics to the supervisor P-unit 1030.
In one embodiment, the local P-units 1015-1016, 1025-1026 manage power locally by independently adjusting frequency/voltage levels to each E-core cluster 1010-1011 and P-core 1020-1021, respectively. For example, P-units 1015-1016 control digital linear voltage regulators (DLVRs) and/or fully integrated voltage regulators (FIVRs) to independently manage the frequency/voltage applied to each E-core within the E-core clusters 1010-1011. Similarly, P-units 1025-1026 control another set of DLVRs and/or FIVRs to independently manage the frequency/voltage applied to each P-core 1020-1021. The graphics cores 1007-1008 and/or E-cores 1012-1013 may be similarly controlled via DLVRs/FIVRs. In these implementations, the frequency/voltage associated with a first core may be dynamically adjusted independently—i.e., without affecting the frequencies/voltages of one or more other cores. The dynamic and independent control of individual E-cores/P-cores provides for processor-wide Dynamic Voltage and Frequency Scaling (DVFS) controlled by the supervisor P-unit 1030.
As illustrated in
In some embodiments, the P-units 1030, 1015 include microcontrollers or processors for executing firmware 1135, 1136, respectively, to perform the power management operations described herein. For example, supervisor firmware (FW) 1135 executed by supervisor p-unit 1030 specifies operations such as transmission of messages sent to TX mailbox 1030, and over the private fabric 1147 to the RX mailbox 1117 of p-unit 1015. Here, the “mailbox” may refer to a specified register or memory location, or a driver executed in kernel space. Upon receiving the message, RX mailbox 1017 may save the relevant portions of the message to a memory 1118 (e.g., a local memory or a region in system memory), the contents of which are accessible by P-unit 1015 executing its copy of the FW 1136 (which may be the same as or different from the FW 1135 executed by the supervisor P-unit 1030).
In response to receiving the message, the P-unit 1015 executing the firmware 1136 confirms reception of the message by sending an Ack message to supervisor 1030 via TX mailbox 1116. The Ack message is communicated to RX mailbox 1131 via fabric 1147 and may be stored in memory 1132 (e.g., a local memory or a region in system memory). The supervisor P-unit 1030 (executing FW 1135) accesses memory 1132 to read and evaluate pending messages to determine the next course of action.
In various embodiments, supervisor p-unit 1030 is accessible by other system components such as a global agent 1155 (e.g., a platform supervisor agent such as a BMC) via public fabric 1146. In some embodiments, public fabric 1146 and private fabric 1147 are the same fabric. In some embodiments, the supervisor p-unit 1030 is also accessible by software drivers 1150 (e.g., operable within the OS or other supervisory FW/SW 970) via a primary fabric 1145 and/or application programming interface (API) 1140. In some embodiments, a single fabric is used instead of the three separate fabrics 1145-1147 shown in
In the architectures described herein, hints may be generated by a variety of system entities. For example, overclocking and other system software entities may attempt to force parking of certain cores. In addition, workload type (WLT) hints (e.g., indicating specific workload types such as bursty, sustain, battery life, idle) can result in consolidation of performance cores or energy-efficient cores. In disaggregated architectures, for certain energy-efficient workloads, it may be preferable to shut down the compute dies 1020-1021, 1010-1011, and run out of one or more of the E-cores 1012-1013 of the SoC die 910 (“SoC die biasing”), which may be accomplished with a parking/consolidation hint to the OS 970. However, there are other instances where SoC die biasing is not the correct choice for improved power/performance (PnP).
In current implementations, as the system becomes constrained, all cores may be forced to run below the current power state (Pe) limit. In these scenarios it may be preferable to reduce the number of cores and run at a frequency which is more efficient and gradually unpark the cores as the system becomes able to run all cores at an efficient frequency. Some embodiments of the invention use below Pe consolidation (BPC) to contain the number of cores and bring the per-core frequency above a specified limit (e.g., when the system is frequency-limited). When the system is close to a survivability point, even after processor actions are taken to reduce power, the cores may be gradually brought down one after the other via core parking hints. The power is monitored periodically until the system returns to a stable power limit. There may also be gaming or other platform/OEM driver-aware implementations that require the platform to be less noisy, cooler, or higher performing. In these cases the platform software can request to moderate the core parking actions that are taken via WLT to achieve the desired end state from a platform standpoint.
All of the above features rely on target core parking and consolidation. Given the large number of potential variables and hints/requests, it would be beneficial to resolve these hints into a single unified hint to be provided to the schedule, while architecturally meeting the requirements of different dynamic parking scenarios that all coexist in the processor at any point in time. It would also be beneficial to determine the individual cores to be parked based on the scenario at hand and in accordance with the architectural intent and in view of an optimal PnP.
The table 1200 in
In this example, as indicated in the “Stage 0” row, a priority mailbox is provided for overclocking and other software (e.g., gaming apps, . . . etc) to submit parking requests which are assigned a high priority, thereby creating a boundary condition for further optimization. For example, the priority mailbox may be used to “park” or allocate a specific core or set of cores to a specific thread or group of threads (as indicated in column 1207). In some implementations, the specific cores requested via this mailbox are always be honored. Additional checks are added to avoid Security DoS, as indicated in column 1206.
The “Stage 1” row indicates workload type (WLT) and SoC die biasing requests in column 1202. In these embodiments, the biasing to use the SoC die is qualified with the specified WLT. If the WLT indicates “Bursty” or “Sustain” then work is not moved to the E-cores on the SoC die, as indicated in column 1204, whereas workload types associated with low workload requirements (e.g., BL/IDLE sub-conditions) are aligned towards moving work to the SoC die (which is capable of running independently at the lowest power states). However, in circumstances where the E-cores of the SoC Die would not be the most efficient cores (e.g., based on a dynamic analysis such as the current supply voltage of the SoC die), then idle/battery life (BL) work is consolidated to an equivalent set of E-cores cores on a compute die.
In general, the WLT indication may be used to determine whether to perform core parking or consolidation. For sustain/bursty workloads, core parking may be used (Perf=EE=0) as this allows the OS to restrict scheduling to P-cores. For battery life/idle WLTs, core consolidation may be used (EE=255) allowing the OS to expand to other cores as the utilization increases (e.g., as measured in workload queues).
In some embodiments, exceptions to the above are specified in view of survivability scenarios (described below).
Some implementations attempt to skip below the PE consolidation stage (reducing threads to improve the frequency floor) when a survivability trigger is reached (e.g., the electrical or thermal metrics reach a threshold). This will avoid duplication as both survivability and PE consolidation attempt to reduce the number of active cores to reduce power. PE consolidation does so to improve performance. While the high level operations are the same, at a lower level the core selection techniques are different (as described further below).
In the case of survivability, a parking hint may be generated regardless of whether WLT and/or other stages prior recommended core consolidation. This is required because for survivability, the OS should have the ability to restrict to a limited number of active cores. In some embodiments, survivability is incremental—gradually reducing the number of active cores. In one embodiment, the performance/EE projection is sorted and used to choose individual cores to park or consolidate. An example of the performance and EE projection data is shown in the logical processor capabilities table 1340 described below with respect to
In one embodiment, the following approach is taken. First, for survivability, the intent is to save power. As such, the cores are sorted starting with the highest performance and the top of the sorted list is used for parking.
With respect to workload type (WLT), for battery life/idle workload types, or no inference, the intent is to use the E-cores. As such, the cores are sorted starting with the highest efficiency values. The cores to contain/consolidate are then selected from the top of the sorted list.
With respect to a WLT of bursty/sustain, the intent is to use the highest performing cores. Consequently, the cores are sorted starting by performance with the highest performance at the top of the sorted list. Cores are then selected for parking from the bottom of the sorted list.
In one embodiment, the dynamic core configuration logic 1345 resolves this combination of hints 1302-1306 into a unified core parking and/or core consolidation hint 1370. In addition, the hardware guide unit 814 (sometimes referred to as the hardware guide scheduler, HGS, or HGS+) continues to generate EE/Perf updates 854 as previously described with respect to
In one embodiment, update logic 1348 updates the logical processor capabilities table 1340 based on the unified hint 1370 or the Perf/EE updates 854. In operation, the Perf/EE HGS hints 854 may be generated and populated locally. The dynamic core configuration logic 1345 consolidates and resolves the various features 1302-1306 attempting to independently override the HGS Hints 854. Once the resolution is complete, the unified parking/consolidation hint 1370 overrides the HGS updates 854 and the table update logic 1348 updates the logical processor capabilities table(s) 1340 (sometimes referred to as the hardware feedback interface or HFI table) in accordance with the unified hint 1370.
Table C provides an example of a default core parking/containment for a particular processor having 1 Big Core, 8 Compute Die E-cores, and 2 SoC Die E-cores. In this implementation, for bursty WLTs, only Big cores are enabled. in the case of battery life (BL), either 2 SoC die E-Cores or two compute die E-cores are active based on SoC die biasing. For a sustain WLT, all cores are active and for an idle WLT, two SoC die E-cores are active.
Some embodiments described herein have a disaggregated processor architecture with DLVR support as well as both compute die E-cores and SoC die E-cores, which are more efficient at certain frequencies and system states. As such, SoC die biasing is used in some embodiments in which hints consolidate operations into the SoC die E-Cores, allowing the compute die cores to be powered down and conserving power.
These Perf/EE values may be overwritten by updates generated from the priority mailbox 1302 (e.g., originating from overclocking software or other forms of software operating at the appropriate privilege level), which may indicate thread-specific parking of one or more cores. In one embodiment, the dynamic core configuration logic 1345 determines the exact set of cores to be parked and/or contained based on the various inputs (e.g., the hints described above) and creates a compressed bitmap of overrides in accordance with the class coding 1401 (i.e., indicating the specific LP# and class to be updated based on the encoding).
The various techniques described above may be implemented (a) in P-code executed by one or more of the power management units (P-units), such as P-unit 2030; (b) using a combination of P-code and driver/kernel code (executed on a core); (c) in hardware; or (d) a combination of P-code, driver/kernel code, and hardware.
In one embodiment, the OS performs classifications of active workloads on the per-application level, averaging multiple seconds. These classifications are not directly tied to the dynamic hints generated by the dynamic core configuration logic 1345 or other processor entities.
As mentioned, the guide unit 814 determines per core capabilities (Perf/EE) at a class level granularity, as reflected in the Perf/EE data 854, using various factors such as the voltage/frequency curve, thermal data, core types, and the current operating point. These per core capabilities are exposed as hints to the OS at 16 ms intervals via the LP capabilities table(s) 1340 (aka, HFI table).
In one embodiment, the utilization and scalability associated with the cores is monitored at a significantly higher granularity than the speed at which hints are provided to the OS (e.g., 1 ms granularity compared to 16 ms for hints). In particular, core threshold detection logic detects when specified utilization thresholds are crossed within each 16 ms interval. In response, one or more predefined exception patterns are detected (e.g., multi-threaded, low utilization, bursty, etc) in view of variables such as the frequency budget and WLT classifications.
In one implementation, specified thresholds are applied to determine if the current core count is in a desired range for the utilization and system scenario (e.g., such as bursty, battery life, sustain, and idle). If the core count is not within the desired range, recommended updates are generated which gradually provide hints based on the appropriate utilization level, along with the reasons associated with the hints. Operation may be scaled up or down at 16 ms intervals while keeping track of system scenarios and utilization targets.
Because reasons are provided along with the hints, the scheduler 810 learns when the parking/consolidation hint is done for PnP. As mentioned, the scheduler 810 may ignore hints when the running application needs multithreaded operation, even if it is at low utilization. This added communication to the scheduler 810 ensures that PnP will not be impacted for specific types of applications that behave differently. The exception will be a combination of utilization levels, workload types, and system frequency.
In one embodiment, a new “reason” bit is added to indicate that the parking hint is for PnP reasons. The scheduler 810 may then use this parking reason, for example, to ignore the hints for certain types of applications (e.g., such as the multithreaded applications required to run at low utilization levels).
With hybrid processor architectures, efficient scheduling is critical for compute performance. Existing scheduling techniques deliver reasonable performance on highly threaded, high load applications. In a processor such as a system-on-chip (SoC) with homogenous cores, temperature information collected by the processor can be exploited to optimize performance because cooler cores can generally achieve improved performance over warmer cores from the perspective of temperature constraints. However, for SoCs with hybrid processor cores, considering only core temperatures to determine which core can provide the best performance can lead to inefficient decisions and lower performance.
Embodiments of the invention include techniques for determining temperature-constrained performance capabilities of processor cores and communicating this information to a scheduler (e.g., an OS scheduler) to be used for performance-based workload scheduling. Temperature-based performance capability variations of the different types of cores exist for various reasons such as variations in manufacturing as well as the thermal characteristics of each workload. Some embodiments of the invention are configured to perform workload scheduling in view of these core/workload characteristics to make more efficient scheduling choices in response to temperature measurements.
Similarly, a temperature sensor 1541 associated with GPU tile 905 reports temperature readings to local P-unit 931 and a temperature sensor 1551 associated with the accelerators 1525 reports its temperature readings to local P-unit 1501. Both P-units 931, 1501 may dynamically adjust local power consumption based on these measurements and/or send the temperature measurements to the supervisor P-unit 1030 for package-wide power management decisions. In the illustrated example, a temperature sensor 1561 on the SoC tile 910 reports temperature measurements directly to the supervisor P-unit.
It should be noted, however, that the underlying principles of the invention are not limited to a disaggregated architecture or the particular disaggregated architecture illustrated in
For SoCs with hybrid processor cores, consideration of core temperatures alone for core selection can lead to ineffective decisions. Embodiments of the invention consider additional thermal and performance characteristics of each core or other IP block before making a task scheduling or migration decision-instead of simply deciding based on current temperature and thermal limits. The different thermal and performance characteristics of the different core types may be a result of the fabrication process used to produce the cores, the underlying core architectures, production variability, and potentially other variables. In some cases, the performance of a core in response to changes in thermal conditions is linked to the power specifications of the processor in which the core resides. For example, certain types of cores are capable of maintaining a defined maximum frequency at relatively higher temperatures when they are included in processors with relatively larger power specifications (e.g., 45 W processor as opposed to a 15 W processor).
By way of example, and not limitation, a first type of core (“type 1” core) may provide higher achievable performance (frequency) than a second type of core (“type 2” core), but it has an additional leakage/power cost. As a result, the type 1 core can become less performant than the type 2 core under certain power/thermally constrained scenarios and/or in processors with different base power specifications. Because the thermal characteristics and the maximum performance capabilities of these types of cores differ, it is important to evaluate these factors when making task scheduling and migration decisions (rather simply deciding based on current temperature and thermal limits). In some embodiments described herein, the type 1 cores are ULT cores and the type 2 cores are XLT cores; however, the underlying principles of the invention are not limited to these specific core types.
Embodiments of the invention consider the above variables before scheduling or migrating tasks. In one implementation, when the type 1 core is integrated in a processor with a particular base power value (e.g., a SKU with a 45 W base power specification), a type 1 core can still achieve a higher performance for certain workloads than a type 2 core even after hitting its transistor junction temperature (Tjmax) limit. However, when the type 1 core is integrated in a processor with a second, lower base power value (e.g., a SKU with, for example, a 28 W or 15 W base power specification), the type 1 core becomes less performing after hitting its Tjmax limit compared to a type 2 core under the same workloads.
In one embodiment, the temperature-constrained frequency of a core at its temperature limit is initially predicted. The performance of the core is then dynamically updated based on detected temperature changes and the core's resolved temperature-constrained frequency. This information is then provided to the scheduler so that it can optimally schedule tasks.
The temperature-constrained frequency of a core is dependent on many factors ranging from transistor layer to system cooling solutions. For example, transistors with different voltage/frequency characteristics can yield different temperature-constrained performance when operating at temperature limits. Mounting the same processor/SoC to systems with different cooling solution can also result in different temperature-constrained performance. In addition, workloads with different thermal characteristics will sometimes cause the processor/SoC to have different temperature-constrained performance.
Various techniques may be used to determine temperature-constrained frequencies. For example, one embodiment uses a constant value defined through offline calibration. Alternatively, or in addition, to accommodate the variation on the platform level, some embodiments define a set of choices associated with different platform configurations and choose one based on platform input at runtime. Alternatively, or additionally, the implementations described below perform runtime learning operations to predict the temperature-constrained frequency of a core based on observations of the behavior of the cores at runtime.
In some implementations, the relative priority for each of the logical processors/cores is inferred from energy performance preference (EPP) hints provided by the operating system for each task running in the system. Referring to
While a specific set of LPs are shown in
In one embodiment, the HWP registers 1610-1615 are 64-bit model specific registers (MSRs) and the EPP values 1600-1605 comprise 8-bit values stored within a specific range of bits within the MSRs (e.g., bits 31:24). In one particular implementation, the HWP registers 1610-1615 are separate instances of an IA32_HWP_REQUEST MSR, although the underlying principles of the invention are not limited to any particular register type.
In one implementation, when running a new task or set of tasks, the OS updates the corresponding EPP values (e.g., for the LPs used to execute the task(s)). The encoded EPP values 1600-1605 represent a scalar number from 0-255, with 0 indicating a preference to maximize performance for that task, and 255 indicating a preference to maximize energy efficiency. In some embodiments, the processor infers that the tasks that are biased the most toward performance are the highest priority tasks running on the LPs/cores. In some embodiments, when a particular IP block on the SoC is not assigned an EPP value (e.g., such as the graphics processor or media engine), these IP blocks are assigned a priority equal to the maximum priority of all of the other IP blocks in the system (e.g., the E-cores, P-cores, VPU, IPU).
Thus, the EPP values 1600-1605 provide a software notion of relative priority of each of the IP blocks. Embodiments of the invention use this information to allow software to adjust relative priority in order to optimize the user-perceived operating characteristics of the platform. To do this, these implementations rely on the notion of a relative priority input for the compute accelerators 1625. This relative priority indicator, sometimes referred to as “R weight”, is a 6 bit value that encodes relative priority, with lower values indicating higher priority, and higher values representing lower priority. The R weight value may be stored in the HWP registers 1610-1615 or in one or more different power management registers.
As illustrated in
Once the available power budget is known, and the relative priorities 1700-1705 of each of the compute IPs has been determined, a global power balancer 1720 allocates the power budget to each of the individual IP blocks 1620-1621, 1712-1713, 1721 in the form of an allowable operating frequency 1760 (and/or voltage), such that the resulting performance is optimized based on the communicated priority information. For this purpose, note that the translation between power, frequency, and performance is likely different for each of the compute IPs, and is not linear across the operating range. In general, performance of an IP is linearly proportional to IP block's operating frequency, but power consumption scales quadratically with operating frequency. Thus, one embodiment of the global power balancer 1720 is programmed with voltage-frequency tables and other power-related data for each of the IP blocks 1620-1621, 1712-1713, 1721.
In one embodiment, such as in a disaggregated architecture, the relative priority generator 1750 and global power balancer 1720 are implemented in the supervisor P-unit 1030 in the SoC tile 1010. The resulting frequency/voltage allocations 1760 are then communicated to other P-units 1031-1033 which apply the frequency allocations to their local IP blocks (e.g., P-unit 1032 on CPU tile 1015 for controlling the local P-cores and E-cores).
Existing core frequency scaling algorithms are a function of core activity, energy performance preference (EPP) values for each application thread, and the SoC power budget available for each core. The algorithm runs periodically and estimates the optimal core frequency based on the above inputs and ramps the core to the target frequency.
Existing solutions use a fixed ramp rate for core frequency changes across applications and system modes. In systems with fixed core frequency ramp rates, a foreground application that has critical performance requirements experiences a similar core frequency ramp delay as a background maintenance application that is not latency sensitive. As another example, a portable system connected to wall power burns similar core power compared to when it is running from battery power and nearly running out of charge for a given application with fixed target core frequency. These systems therefore choose ramp rates to balance between different types and priorities of applications and between the two extremes of system modes-performance vs. power. The chosen fixed ramp rate thereby leaves performance and power on the table.
To address these problems, embodiments of the invention dynamically select a core frequency ramp rate based on a number of variables including, but not limited to, workload type, power, and the performance requirements of the system. In particular, core frequency is increased at different ramp rates for different sets of applications and system modes. Higher ramp rates provide better responsiveness at the cost of power while slower ramp rates save power at the cost of performance and/or responsiveness.
By way of example, and not limitation, ramping up core frequency faster when a portable system is connected to wall power provides high performance and better responsiveness. Slowing down the core frequency ramp rate when the same system is on battery power helps prolong battery usage. Further slowdown of the core frequency ramp rate when the system is running out of battery power avoids system shutdown. Similarly, a foreground application that is critical to user experience and responsiveness will benefit from sharp core ramp rates. In contrast, background applications that are not latency sensitive can use slower core ramp rates, conserving system energy. In addition, a given application benefits from different ramp rates for its different phases throughout execution. Application load times benefit from fast ramp rates for responsiveness, while idle or low activity phases of the same application can save power with slower ramp rates. A phase of sustained activity in the same application could balance power and performance with moderate ramp rates. The embodiments of the invention vary core frequency ramp rates in the middle of workloads with changes in corresponding phases to provide an improved tradeoff between power and performance.
Dynamic voltage and frequency scaling (DVFS) is a long-established technique to balance performance with power savings and energy efficiency. The core frequency selection process plays a pivotal role in achieving a balance between performance and power across a plethora of applications supported on modern devices. The set of operations which determine core frequency run periodically and adjust the core frequency as a function of core activity levels, energy performance preferences (EPPs), and the available SoC power budget. Some hysteresis is provided to prevent oscillations in core frequency.
The power and performance impact of various core ramp rates were evaluated for a wide range of applications.
It can be seen that different applications have a different sensitivity to core ramp rate. Certain applications from the test suite show a high sensitivity to core ramp rate as these applications may have multiple phases where the core transitions from low to high frequencies. Slowing down each transition has a higher impact compared to other applications that are more stable throughout execution. In addition, applications with bursts of activity embedded in middle of large idle phases, such as Browsing and WebXprt significantly improve power savings (
Consequently, a fixed ramp rate for core frequency across all types of applications leaves power and/or performance on the table. For example, the data shows that using a fixed 5 bins/msec of ramp rate helps Bwaves performance but hurts Browsing power consumption. In contrast, limiting the ramp rate to 1 bin/msec helps save power for Browsing but hurts Bwaves performance significantly.
Embodiments of the invention incorporate a workload-based dynamic core frequency ramp rate that can be modified at runtime based, at least in part, on the application or workload type that is being executed on a given core. Some implementations categorize workloads based on the type of activity. Table D shows an example classification for a set of workloads. Video conferencing and video streaming/playback workloads are classified as battery life (BL) workloads as they do not benefit from higher core frequencies. Idle (ID) workloads similarly do not benefit from higher core frequencies. Consequently, slower ramp rates may be implemented for occasional frequency ramps. Application workloads such as video editing and video recording are classified as bursty (BU) workloads, meaning that they may periodically demand higher core performance. Gaming workloads (including gaming+videoconferencing workloads) are classified as sustained (SU), meaning that they demand continuous high performance. Both bursty and sustained workloads benefit from higher core frequencies. While sustained applications benefit from relatively slower core frequency ramp rates (as performance impact of the initial phase is amortized over time), bursty applications may require faster ramp rates to improve responsiveness to periodic bursts of high performance work.
Additionally, application types may vary over time, based on changes in the application's workload activity. For example, an application may be classified as bursty during its load time but may be treated as idle for low activity phases after the initial load and sustained during the phases where its activity stays constant for longer durations. The embodiments of the invention dynamically monitor and reclassify application workloads based on detected workload activity. These embodiments also change the core ramp rate dynamically, in accordance with the detected changes to the application's workload characteristics to achieve better power and performance trade-offs.
Applications classified as bursty and sustained that benefit from fast core ramp rates might need to compromise on performance when a system is in power savings mode. In these cases, it is beneficial to slow down the core ramp rate with some performance loss in order to improve battery usage. Consequently, in some embodiments, the core frequency ramp rate is a function of the power and performance needs of the system in addition to the workload type. Embodiments of the invention aid in optimizing performance while not compromising on energy efficiency of the system for all types of applications/workloads.
Based on the workload type 1915 and associated energy and/or performance value(s) 1950, a rate selector 1910 selects a core frequency ramp rate 1930 for a corresponding core, which may be selected from a set of possible ramp rates 1920.
In some embodiments, the rate selector 1910 selects the core frequency ramp rate 1930 based on additional variables such as the current power mode and/or thermal constraints 1970 implemented in the processor, the current frequency of the core 1971, and a specified maximum frequency 1972.
Referring to
Thus, this embodiment of the invention takes workload type 1915 and potentially one or more other variables as inputs and selects the optimal core frequency ramp rate 1930 dynamically at run time. Ramp rates for each scenario-i.e., each combination of workload and energy-performance preference-are provided as a tunable knobs that can be fine-tuned on silicon to better balance between performance and power for each application and system mode. In some embodiments, the core frequency ramp rate 1930 is specified in units of frequency bins/msec.
In some embodiments, the ramp rates are variable ramp rates, which ramp relatively more slowly for cores or other IP blocks operating at relatively higher current frequencies 1971 and ramp relatively more quickly for cores/IP blocks operating at relatively lower current frequencies 1971. In these embodiments, the ramp rate read from the table or other data structure 1990 may indicate a range of possible ramp rates, one of which is selected based on variables such as current frequency, maximum frequency, power/thermal specifications, energy/performance values, etc. In other implementations, all of these variables are incorporated into the ramp rate data structure 1990, so that the ramp rate read from the data structure is selected based on all required information.
A method for dynamic core ramp rate selection is illustrated in
At 2001, the workload type of an application (or a workload of the application) is determined based on collected workload execution metrics. For example, based on the execution metrics, the workload may be categorized a battery life (BL) workload, an idle (ID) workload, a bursty (BU) workload, or a sustained (SU) workload as described above.
At 2002, the energy performance preference (EPP) value associated with the workload is read (e.g., from an HWP register). As mentioned, the EPP value may be set by the OS or other supervisory software.
At 2003, based on the workload type and EPP value, a dynamic core frequency ramp rate is generated or identified for the workload. In one embodiment, the ramp rate may be selected from a set of possible specified ramp rates.
At 2004, the target frequency of the core is determined based on variables including, but not limited to, workload requirements, the SoC power budget, and thermal constraints. Numerous variables are described above, for example, with respect to
At 2005, the core is transitioned to a target core frequency in accordance with the dynamic core frequency ramp rate. For example, if a frequency ramp rate of 2 bins/msec is specified, then the core frequency is increased in accordance with this value (e.g., increasing the core frequency by 2 bins each millisecond).
Once the target frequency is reached, workload execution metrics continue to be collected for the application at 2006. As mentioned, different frequency transition rates may be selected for different workloads within the same application, if those workloads have sufficiently different workload characteristics. Thus, the process returns to 2001 where the workload type is reevaluated based on the most recent workload execution metrics collected at 2006.
Embodiments of the invention provide significant benefits over existing implementations which ramp the frequency of all cores up to the target frequency in a single transition (e.g., from 1.0 GHz to 5.0 GHZ). These embodiments differentiate between workloads for which a large, single transition ramping may be beneficial (e.g., applications that are latency sensitive) and those for which slower core ramp rates can be used, which reduce power consumption and do not result in a user-perceivable performance degradation.
In the foregoing specification, the embodiments of invention have been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Embodiments of the invention may include various steps, which have been described above. The steps may be embodied in machine-executable instructions which may be used to cause a general-purpose or special-purpose processor to perform the steps. Alternatively, these steps may be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
The following are example implementations of different embodiments of the invention.
Example 1. A processor comprising: a plurality of cores, a first core of the plurality of cores to execute an application comprising one or more workloads; dynamic ramp rate selection circuitry to determine a core frequency ramp rate to be used to increase a frequency of the first core to a target frequency based, at least in part, on a workload type of a first workload of the one or more workloads; and dynamic frequency scaling circuitry to increase the frequency of the first core to the target frequency in accordance with the core frequency ramp rate.
Example 2. The processor of exampl 1 wherein the dynamic ramp rate selection circuitry is to determine the core frequency ramp rate based additionally on a value associated with the application or the first workload, the value indicating a weighting between energy efficiency and performance.
Example 3. The processor of examples 1 or 2 further comprising: workload type determination logic to determine the workload type based on execution metrics associated with the first workload.
Example 4. The processor of any of examples 1-3 wherein the workload type comprises one of a plurality of workload types characterized, at least in part, based on the extent to which workload performance is affected by the core frequency ramp rate.
Example 5. The processor of any of examples 1-4 wherein for workloads of a first workload type of the plurality of workload types, the dynamic ramp rate selection circuitry is to select a relatively lower core frequency ramp rate and for workloads of a second workload type of the plurality of workload types, the dynamic ramp rate selection circuitry is to select a relatively higher core frequency ramp rate.
Example 6. The processor of any of examples 1-5 wherein the first workload type includes battery life and idle workloads and the second workload type comprises bursty and sustained workloads.
Example 7. The processor of any of examples 1-6 wherein the ramp rate comprises a number of frequency bins per unit of time.
Example 8. The processor of any of examples 1-7 wherein the value is set by an operating system or other supervisory software, the value selected from a range of possible values from a minimum value to a maximum value, the minimum value indicating a maximum preference for performance and the maximum value indicating a maximum preference for energy efficiency.
Example 9. A method comprising: executing an application on one or more cores of a plurality of cores, the application comprising one or more workloads; determining a core frequency ramp rate to be used to increase a frequency of a first core of the one or more cores to a target frequency based, at least in part, on a workload type of a first workload of the one or more workloads; and increasing the frequency of the first core to the target frequency in accordance with the core frequency ramp rate.
Example 10. The method of example 9 wherein the core frequency ramp rate is to be determined based additionally on a value associated with the application or the first workload, the value indicating a weighting between energy efficiency and performance.
Example 11. The method of examples 9-10 further comprising: determining the workload type based on execution metrics associated with the first workload.
Example 12. The method of any of examples 9-11 wherein the workload type comprises one of a plurality of workload types characterized, at least in part, based on the extent to which workload performance is affected by the core frequency ramp rate.
Example 13. The method of any of examples 9-12 wherein for workloads of a first workload type of the plurality of workload types, a relatively lower core frequency ramp rate is selected and for workloads of a second workload type of the plurality of workload types, a relatively higher core frequency ramp rate is selected.
Example 14. The method of any of examples 9-13 wherein the first workload type includes battery life and idle workloads and the second workload type comprises bursty and sustained workloads.
Example 15. The method of any of examples 9-15 wherein the ramp rate comprises a number of frequency bins per unit of time.
Example 16. The method of any of examples 9-16 wherein the value is set by an operating system or other supervisory software, the value selected from a range of possible values from a minimum value to a maximum value, the minimum value indicating a maximum preference for performance and the maximum value indicating a maximum preference for energy efficiency.
Example 17. A machine-readable medium having program code stored thereon which, when executed by a machine, causes the machine to perform the operations of: executing an application on one or more cores of a plurality of cores, the application comprising one or more workloads; determining a core frequency ramp rate to be used to increase a frequency of a first core of the one or more cores to a target frequency based, at least in part, on a workload type of a first workload of the one or more workloads; and increasing the frequency of the first core to the target frequency in accordance with the core frequency ramp rate.
Example 18. The machine-readable medium of example 17 wherein the core frequency ramp rate is to be determined based additionally on a value associated with the application or the first workload, the value indicating a weighting between energy efficiency and performance.
Example 19. The machine-readable medium of examples 17 or 18 further comprising program code to cause the machine to perform the operations of: determining the workload type based on execution metrics associated with the first workload.
Example 20. The machine-readable medium of any of examples 17-19 wherein the workload type comprises one of a plurality of workload types characterized, at least in part, based on the extent to which workload performance is affected by the core frequency ramp rate.
Example 21. The machine-readable medium of any of examples 17-20 wherein for workloads of a first workload type of the plurality of workload types, a relatively lower core frequency ramp rate is selected and for workloads of a second workload type of the plurality of workload types, a relatively higher core frequency ramp rate is selected.
Example 22. The machine-readable medium of any of examples 17-21 wherein the first workload type includes battery life and idle workloads and the second workload type comprises bursty and sustained workloads.
Example 23. The machine-readable medium of any of examples 17-22 wherein the ramp rate comprises a number of frequency bins per unit of time.
Example 24. The machine-readable medium of any of examples 18-23 wherein the value is set by an operating system or other supervisory software, the value selected from a range of possible values from a minimum value to a maximum value, the minimum value indicating a maximum preference for performance and the maximum value indicating a maximum preference for energy efficiency.
As described herein, instructions may refer to specific configurations of hardware such as application specific integrated circuits (ASICs) configured to perform certain operations or having a predetermined functionality or software instructions stored in memory embodied in a non-transitory computer readable medium. Thus, the techniques shown in the Figures can be implemented using code and data stored and executed on one or more electronic devices (e.g., an end station, a network element, etc.). Such electronic devices store and communicate (internally and/or with other electronic devices over a network) code and data using computer machine-readable media, such as non-transitory computer machine-readable storage media (e.g., magnetic disks; optical disks; random access memory; read only memory; flash memory devices; phase-change memory) and transitory computer machine-readable communication media (e.g., electrical, optical, acoustical or other form of propagated signals—such as carrier waves, infrared signals, digital signals, etc.). In addition, such electronic devices typically include a set of one or more processors coupled to one or more other components, such as one or more storage devices (non-transitory machine-readable storage media), user input/output devices (e.g., a keyboard, a touchscreen, and/or a display), and network connections. The coupling of the set of processors and other components is typically through one or more busses and bridges (also termed as bus controllers). The storage device and signals carrying the network traffic respectively represent one or more machine-readable storage media and machine-readable communication media. Thus, the storage device of a given electronic device typically stores code and/or data for execution on the set of one or more processors of that electronic device. Of course, one or more parts of an embodiment of the invention may be implemented using different combinations of software, firmware, and/or hardware. Throughout this detailed description, for the purposes of explanation, numerous specific details were set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the invention may be practiced without some of these specific details. In certain instances, well known structures and functions were not described in elaborate detail in order to avoid obscuring the subject matter of the present invention. Accordingly, the scope and spirit of the invention should be judged in terms of the claims which follow.