The disclosure of Japanese Patent Application No. 2018-242604 filed on Dec. 26, 2018 including the specification, drawings and abstract is incorporated herein by reference in its entirety.
The present invention relates to a semiconductor device, a temperature control device, and a method, for example, a semiconductor device including a processor for executing an application, and a temperature control device and method in such a semiconductor device.
As a related art, Xin Wang, “Intelligent Power Allocation Maximize performance in the thermal envelope”, March 2017, discloses an IPA (Intelligent Power Allocation) used for thermal generation control of a control target. IPA is a thermal control framework developed by ARM. The IPA acquires temperature information from a temperature sensor that is arbitrarily set, calculates available power consumption for a plurality of modules that are controlled by the IPA, and performs thermal generation control by adjusting a clock.
More specifically, the IPA calculates the power consumption available for PID (Proportional-Integral-Differential) control based on the temperature information acquired from the temperature sensor so that the temperature of the IPA saturates at a preset target temperature, and distributes the power consumption available to the modules to be controlled based on an arbitrary fixed coefficient (see Chapter 2.2.4 of “Intelligent Power Allocation Maximize performance in the thermal envelope”). The IPA determines the frequency by comparing the distributed power consumption with a correspondence table in which the available frequencies are registered in advance. In the IPA, dynamic power can be reduced by lowering the frequency, and thermal generation control can be performed.
As another related art, Japanese unexamined Patent Application publication 2007-109085 discloses a thermal generation control device for efficiently controlling thermal generation of computer systems. The thermal generation control device disclosed in Japanese unexamined Patent Application publication 2007-109085 acquires a thermal generation state of a target portion, which is a control target of the thermal generation state, in the hardware of the computer system. The thermal generation control device changes the operation content of the application being operated so as to change the thermal generation state in accordance with the acquired thermal generation state. Here, “changing the operation content of the application” means directly operating the application to change the operation content so that the processing capability of the hardware required by the application changes.
The device changes, for example, the operation mode of an application operating in the normal mode to a slow mode requiring a processing speed lower than that required by the normal mode. Alternatively, the thermal generation control device maintains the main functional part of the application in the normal mode, and changes the process mode of the other functions to the low-speed mode. Patent Document 1 also discloses giving priority to each function realized by an application, and suppressing the operation of a portion realizing the function as the priority becomes lower for an application in operation. Further, Japanese unexamined Patent Application publication 2007-109085 discloses that the thermal generation state of a target site is controlled by using a change in the operation content of an application and an operation adjustment of hardware such as an adjustment of an operation frequency of a processor in combination.
In the IPA disclosed in “Intelligent Power Allocation Maximize performance in the thermal envelope”, March 2017, thermal generation control (performance reduction) of a target module is performed in accordance with a fixed coefficient set in advance in accordance with a thermal generation state. While this method can suppress thermal generation, the performance is degraded in all of the functions being performed on the target module. For example, even if the function executed on the target module is a function related to the safety of the driver of the vehicle on which the target module is mounted or a function related to the user experience, the performance is degraded. The reduced performance of these functions impairs driver safety and user experience.
As a specific example, it is assumed that the DMS (Driver Monitoring System) function and the meter cluster function operate simultaneously in the in-vehicle system. Here, the meter cluster function refers to a function of operating a meter class, which is a unit in which various meters necessary for driving are assembled. In the IPA disclosed in “Intelligent Power Allocation Maximize performance in the thermal envelope”, March 2017, if the thermal generation control is performed during driving, not only the DMS having a low importance but also the meter cluster function is degraded in performance, which may hinder the driving.
On the other hand, in the thermal generation control device disclosed in Japanese unexamined Patent Application publication 2007-109085, it is possible to suppress the operation of the low-priority function according to tie priority. However, in Japanese unexamined Patent Application publication 2007-109085, for example, when the temperature of the main processor exceeds a threshold value, the operation content of the application running on the main processor is changed and the operating frequency of the main processor is adjusted. In this case, even if the operation content of the high-priority function is not changed in the change of the operation content of the application operating on the main processor, if the operation frequency of the main processor is lowered, the performance degradation of the high-priority function cannot be avoided.
Other objects and novel features will become apparent from the description of this specification and the accompanying drawings.
According to one embodiment, the semiconductor device includes: a thermal generation control unit that performs thermal generation control on a CPU including a plurality of CPU (Central Processing Unit) cores; and a control target determination unit that determines a target of the thermal generation control. The control target determination unit determines a target of thermal generation control from among the CPU cores to which execution of low-priority applications is allocated.
According to the embodiment, the thermal generation control device can reduce the amount of thermal generated by the CPUs while maintaining the performance of executing a particular application.
Embodiments to which means for solving the above problems is applied will be described in detail below with reference to the drawings. For clarity of explanation, the following description and drawings are appropriately omitted and simplified. In addition, the elements described in the drawings as functional blocks for performing various processes can be configured as a CPU, a memory, and other circuits in terms of hardware, and are realized by programs loaded into the memories in terms of software. Therefore, it is understood by those skilled in the art that these functional blocks can be realized in various forms by hardware alone, software alone, or a combination thereof, and the present invention is not limited to any of them. In the drawings, the same elements are denoted by the same reference numerals, and a repetitive description thereof is omitted as necessary.
Also, the programs described above may be stored and provided to a computer using various types of non-transitory computer readable media. Non-transitory computer readable media includes various types of tangible storage media. Examples of non-transitory computer-readable media include magnetic recording media (e.g., flexible disks, magnetic tapes, hard disks), magneto-optical recording media (e.g., magneto-optical disks), CD-ROM (Read Only Memory)CD-R, a CD-R/W, and a semiconductor memory (e.g., masked ROM, PROM(Programmable ROM), EPROM (Erasable PROM), flash ROM, RAM (Random Access Memory). The programs may also be supplied to the computer by various types of transitory computer-readable transitory computer readable media. Examples of transitory computer-readable media include an electrical signal, an optical signal, and an electromagnetic wave. The transitory computer readable media may provide the program to the computer via wired or wireless communication paths, such as an electrical wire and an optical fiber.
In the following embodiments, when required for convenience, the description will be made by dividing into a plurality of sections or embodiments, but except when specifically stated, they are not independent of each other, and one of them is related to some or all of the other modified example, applications, detailed description, supplementary description, or the like. In the following embodiments, the number of elements, etc. (including the number of elements, numerical values, quantities, ranges, etc.) is not limited to the specific number, but may be not less than or equal to the specific number, except for cases where the number is specifically indicated and is clearly limited to the specific number in principle.
Furthermore, in the following embodiments, the constituent elements (including the operation steps and the like) are not necessarily essential except in the case where they are specifically specified and the case where they are considered to he obviously essential in principle. Similarly, in the following embodiments, when referring to the shapes, positional relationships, and the like of components and the like, it is assumed that the shapes and the like are substantially approximate to or similar to the shapes and the like, except for the case in which they are specifically specified and the case in which they are considered to be obvious in principle, and the like. The same applies to the above-mentioned numbers and the like, including the number, the numerical value, the amount, the range, and the like.
The CPU11 configures a process executing unit in the semiconductor device 10, and executes various application programs as examples of tasks. The CPU11 includes a plurality of CPU cores. The CPU11 is configured to have a variable operating condition. The CPU11 is configured so that, for example, the number of operating CPU cores is variable. The CPU11 is configured such that the operating frequencies of the respective CPU cores are variable. In the CPU11, thermal generation in the CPU11 can be controlled by controlling at least one of the number of operating CPU cores and the operating frequencies of the respective CPU cores.
The ROM12 is, for example, a nonvolatile memory such as a flash memory. The ROM12 stores a program to be executed by the CPU11. The CPU11 executes application programs read from the ROM12 (hereinafter, also referred to as applications, and can also be referred to as tasks) to execute various processes. The program stored in the ROM includes a program for performing thermal generation control of the CPU11. The RAM13 is a volatile memory for storing various data.
The peripheral circuit 14 includes various peripheral circuits built in the semiconductor device 10. The peripheral circuitry 14 includes, for example, a temperature sensor (THS) 15 for measuring temperature. The temperature sensor 15 includes, for example, a resistive element for varying the output voltage in dependence on the temperature. Alternatively, the temperature sensor 15 includes an oscillator, such as a ring oscillator, which oscillates at a period dependent on temperature. As the temperature sensor 15, various types temperature sensors can be used, and the type of the temperature sensor 15 is not particularly limited. In the semiconductor device 10, the RAM13 and peripheral circuit 14 and the like are connected to the CPU11 via buses 16.
The semiconductor device 10 may include an external peripheral circuit arranged outside and an input/output port (not shown) for inputting/outputting signals to/from other devices. Although the temperature sensor 15 is included in the peripheral circuitry 14 inside the semiconductor device 10, the temperature sensor 15 is not limited to being built in the semiconductor device 10. The temperature sensor 15 may be disposed in an external peripheral circuit, and signals outputted from the temperature sensor 15 may be input to the semiconductor device 10 through an input/output port.
In recent years, in order to meet the needs of the semiconductor device markets such as large-capacity, high-performance, low-cost, and enhanced user experience, semiconductor processes have been accelerated rapidly. Semiconductor device has become a large-scale SoC (System-on-a-chip) with a plurality of high-performance and high-power hardware modules, and its importance to thermal generation countermeasures has been increasing. However, even if the thermal generation control is necessary, it is not preferable that the function related to the safety of the driver is limited or the user experience is seriously impaired by performing the thermal generation control, for example, in the in-vehicle field. The present embodiment provides a mechanism that enables fine thermal generation control while maintaining the performance of such a function.
In the semiconductor device 10, the functions of the temperature determination unit 21, the control target determination unit 22, the thermal generation control unit 23, and the app allocation unit 26 are implemented by software, for example. In other words, the functions of the temperature determination unit 21, the control target determination unit 22, the thermal generation control unit 23, and the app allocation unit 26 are realized in accordance with a program read from the ROM12 (see
The temperature determination unit 21 is connected to the temperature sensor 15, and monitors the temperature measured using the temperature sensor 15. The temperature determination unit 21 determines whether or not thermal generation control is performed on the CPU11 based on the temperature measured using the temperature sensor 15. The temperature determination unit 21 compares, for example, the temperature measured using the temperature sensor 15 with a preset threshold value, and determines that the thermal generation control is executed when the temperature is equal to or higher than the threshold value.
When the temperature determination unit 21 determines that the temperature is equal to or higher than the threshold value, the thermal generation control unit 23 performs thermal generation control on the CPU11 and controls the amount of thermal generated in the CPU11. In the thermal generation control, the thermal generation control unit 23 controls the amount of thermal generated in the CPU11 by changing the operation condition of the CPU11.
The thermal generation control unit 23 includes a power supply control unit 24 and a clock control unit 25. The power control unit 24 controls power supplied to each of the plurality of CPU cores 11a to 11d included in the CPU11 through the system controller 18. The power supply control unit 24 supplies power to the CPU core to be operated among the four CPU cores 11a to 11d, and shuts off the power of the CPU core not to be operated.
The clock control unit 25 controls the operating frequencies of the CPU cores 11a to 11d by controlling the frequencies of the clock signals supplied to the CPU cores 11a to 11d through the clock pulse generator 17. The clock control unit 25 supplies a clock signal of the determined operation frequency to the CPU core to which the power supply control unit 24 supplies power, from the four CPU cores 11a to 11d. By controlling the operation number of CPU cores to which power is supplied by the power supply control unit 24 and the frequency of clock signals supplied to the CPU cores by the clock control unit 25, the thermal generation state in the CPU11 is controlled.
The threshold value for judging whether or not the temperature judging unit 21 is in a state of performing thermal generation control may include a plurality of stages of threshold values. For example, the threshold may include a first stage threshold and a second stage threshold at a higher temperature. When the measured temperature is lower than the threshold value of the first step, the temperature determination unit 21 determines that the temperature is in a low temperature state in which thermal generation control is not necessary. When the measured temperature is equal to or higher than the threshold value of the first phase and lower than the threshold value of the second stage, the temperature determination unit 21 determines that the intermediate temperature state is a state in which the thermal generation control of the first stage is performed. When the measured temperature is equal to or higher than the threshold value of the second stage, the temperature determination unit 21 determines that the state is a high temperature state in which the second stage thermal generation control is performed. Note that the number of stages of the threshold value is not particularly limited to two, and the threshold value may include three or more stages.
When temperature determination unit 21 determines that the temperature is low, the thermal generation control unit 23 does not perform the thermal generation control of the CPU11. When the temperature determination unit 21 determines that the temperature is in the intermediate temperature state, the thermal generation control unit 23 performs the first step thermal generation control. In the first stage thermal generation control, the thermal generation control unit 23 reduces the amount of thermal generated by the CPU11 by using, for example, the clock control unit 25 to lower the operating frequencies of the specific CPU core. When the temperature determination unit 21 determines that the temperature is in the high temperature state, the thermal generation control unit 23 performs the second stage thermal generation control. The thermal generation control in the second stage has a larger amount of reduction in the amount of thermal generation than the thermal generation control in the first stage. In the thermal generation control of the second stage, for example, the thermal generation control unit 23 further uses the power supply control unit 24 in addition to the thermal generation control of the first stage to cut off the power supply to the specific CPU core, thereby further reducing the amount of thermal generated by the CPU11. Note that the thermal generation control performed by the thermal generation control unit 23 is not particularly limited to the clock control and the power supply control. For example, the thermal generation control unit 23 may control the amount of thermal generated in the CPU11 by controlling the amount of power consumed in the CPU core by controlling the magnitude of the voltages supplied to the CPU core.
Here, the priorities of the applications executed in the CPU11 are set according to the importance of the functions and the like. The priority is set according to the use case, for example. For example, the priority of an application such as a DSM, which does not cause a large problem even if the function is temporarily stopped in the operation of the vehicle, is set to a low priority. On the other hand, if the function such as the meter cluster function stops, the priority of the application of the function that hinders the driving of the vehicle is set to high priority.
The group data 28 retains a correspondence relationship between the application of each priority and the CPU core to which the execution is allocated. In the present embodiment, the group data 28 includes high priority group information and low priority group information. The high priority group information includes information specifying the CPU cores of the high priority group to which the high priority application is allocated to execute in the CPU11. The low priority group information includes information specifying CPU cores of a low priority group to which low priority applications are allocated to execute in the CPU11.
When the temperature determination unit 21 determines that the temperature is in the medium temperature state or the high temperature state, the control target determination unit 22 uses the group data 28 to determine the CPU core to be controlled by the thermal generation control unit 23. The control target determining unit 22 determines at least one of the CPU cores designated as the CPU cores of the low priority group in the group data 28 as the CPU cores to be subjected to the thermal generation control. The thermal generation control unit 23 controls at least one of the operating frequency of the CPU core determined as the control target and the power supply to the CPU core, thereby reducing the amount of thermal generated in the CPU11.
The app allocation unit 26 determines a CPU core to which the execution of the application is allocated based on the group data 28 when the application is executed. The App allocation unit 26 allocates execution of a high-priority application to any of the CPU cores of the high-priority group. On the other hand, the app allocation unit 26 allocates the execution of the low-priority application to one of the CPU cores of the low-priority group. In this way, the high priority and low priority applications can be executed by the CPU cores corresponding to the respective groups in the CPU11. The function of the app allocation unit 26 is installed in, for example, an operating system (OS) such as Linux (registered trademark) operating on the semiconductor device 10.
On the other hand, in the example of
When the group data 28 retains the information shown in
The temperature determination unit 21 acquires temperature data from the temperature sensor 15 and monitors the temperature of the semiconductor device 10 (step A1). The temperature determination unit 21 determines whether or not the temperature is equal to or higher than the threshold value (threshold value 1) of the first stage (step A2). The threshold value 1 is set to, for example, Tj=90° C., and the temperature determination unit 21 determines whether or not the temperature information acquired from the temperature sensor 15 is 90° C. or more in step A2.
When the temperature is equal to or higher than the threshold value 1, the temperature determination unit 21 determines whether or not the temperature is equal to or higher than the threshold value (threshold value 2) of the second stage (step A3). The threshold value 2 is set to, for example, Tj=110° C., and the temperature determination unit 21 determines whether or not the temperature information acquired from the temperature sensor 15 is 110° C. or more in step A3. When it is determined in step A3 that the temperature is lower than the threshold value 2, the temperature determination unit 21 determines that the temperature of the semiconductor device 10 is “medium temperature”. On the other hand, when it is determined in A3 that the temperature is equal to or higher than the threshold value 2, the temperature determination unit 21 determines that the temperature of the semiconductor device 10 is “high temperature”.
When the temperature determination unit 21 determines that the temperature is “medium temperature” or “high temperature”, the control target determination unit 22 refers to the group data 28, and determines all or part of the CPU core of the low priority group, that the CPU core associated with the group type “low priority” (see
When the temperature determination unit 21 determines “high temperature” in step A3, the thermal generation control unit 23 performs the second stage thermal generation control (thermal generation control 2) on the CPU cores of the low priority group (step A5). For example, in the thermal generation control 2, the thermal generation control unit 23 uses the power supply control unit 24 to control the power supply supplied to the CPU cores of the low priority group. After the thermal generation control 2 is performed, the process returns to step A1, and the temperature monitoring is continued.
The temperature determination unit 21 determines that the temperature of the semiconductor device 10, which is determined to be lower than the threshold value 1 in the step A2, is “low temperature (appropriate temperature)”. When the temperature determination unit 21 determines that the temperature is “low”, the thermal generation control unit 23 determines whether or not the thermal generation control is performed (step A6). In step A7, when the thermal generation control 1 in step A4 or the thermal generation control 2 in step A5 is performed, the thermal generation control unit 23 cancels the thermal generation control. After the release of the thermal generation control, the process returns to step A1, and the temperature monitoring is continued. If it is determined in step A6 that the thermal generation control is not being performed, the process returns to step A1, and the temperature monitoring is continued.
Hereinafter, an operation example will be described.
If it is determined in step A2 (see
When it is determined in step A2 that the temperature is equal to higher than the threshold value 1 and it is determined in step A3 that the temperature is lower than the threshold value 2, the temperature determination unit 21 determines that the semiconductor device 10 is “medium temperature”. In step A4, the thermal generation control unit 23 performs the thermal generation control 1, and lowers the operating frequency of the CPU cores 11c and 11d of the low priority group B from 1.5 GHz to 750 MHz. In this case, the applications D to F are executed by the CPU cores 11c and 11d which are controlled at a low speed. However, since the applications D to F are low-priority applications that do not relate to, for example, the safety of the driver or the user experience, even if the operation speed is slowed, a large problem does not occur. On the other hand, the CPU cores 11a and 11b of the group A operate at an operating frequency of 1.5 GHz, and the high-priority applications A to C are executed with normal processing capabilities. Of the four CPU cores 11a to 11d, the CPU cores 11c and 11d of the group B operate at a low speed, whereby the amount of thermal generated by the CPU11 can be reduced and the temperatures can be expected to be lowered.
When it is determined that the temperature is equal to or higher than the threshold value 2 in block A3, the temperature determination unit 21 assessments that the semiconductor device 10 is “high temperature”. In this case, the thermal generation control unit 23 performs the thermal generation control in step A5, and shuts off the power of the CPU core 11d among the CPU cores 11c and 11d of the low priority group. At this time, the CPU core 11c operates at a reduced operating frequency of 750 MHz. In this case, the applications D to F are executed only by the CPU core 11c. By shutting down one of the CPU cores 11c and 11d of the group B, the thermal generation amount in the CPU11 can be further reduced in thermal generation control 2 performed in the high-temperature state compared to the thermal generation control 1 performed in the medium-temperature state. Even in the high-temperature state, the CPU cores 11a and 11b of the group A operate at an operating frequency of 1.5 GHz, and the high-priority applications A to C are executed with normal processing capabilities.
When the temperature determination unit 21 determines that the temperature is “low temperature” and when the thermal generation control 1 or the thermal generation control 2 is being executed, the thermal generation control unit 23 cancels the thermal generation control in step A7. For example, when the operation frequency is changed to “medium temperature” or “low temperature”, the thermal generation control unit 23 changes the operation frequency of the low-priority CPU cores 11c and 11d from 750 MHz to 1.5 GHz in step A7. In the case of converting from “high temperature” to “low temperature”, the thermal generation control unit 23 restarts power supply to the CPU core 11d and changes the operating frequency of the CPU cores 11c and 11d from 750 MHz to 1.5 GHz in step A7. In this way, each of the applications A to F is executed in the CPU11 with normal throughput.
In the present embodiment, the group data 28 includes high priority group information including information specifying a CPU core to which execute of a high priority application is allocated, and low priority group information including information specifying a CPU core to which execution of a low priority application is allocated. The control target determining unit 22 refers to the group data 28 and determines the CPU core of the low priority group as the target of the thermal generation control. When the temperature determination unit 21 determines that the temperature is equal to or higher than the threshold value, the thermal generation control unit 23 performs thermal generation control on the CPU cores of the low priority group. When the thermal generation control is performed on the CPU cores of the low priority group, the function of the low priority application to which the execution is allocated to the CPU cores of the low priority group is reduced or the function is stopped. On the other hand, since the thermal generation control is not performed on the CPU cores of the high-priority group, the high-priority application to which the execution is allocated to the CPU cores of the high-priority group is not affected by the thermal generation control. Therefore, in the present embodiment, it is possible to reduce the amount of thermal generated by the CPU while maintaining the execution performance of the high-priority application.
For example, in the group data 28, the application of functions related to the safety of the driver and the user experience, such as the meter cluster function, is set to high priority. Further, in the group data 28, the priority of the application of the function not directly related to the safety of the driver such as the DSM function or the user experience is set to a low priority. When the temperature of the semiconductor device 10 rises, the performance of the DSM function is degraded or stopped by performing thermal generation control on the CPU core to which the CPU core is allocated to execute the low-priority application. However, even if the DSM function is stopped, the operation of the vehicle is not hindered, and therefore, a large problem does not occur. On the other hand, in the present embodiment, since the thermal generation control is not performed on the CPU core to which the execution of the high-priority application is allocated, the performance of the meter cluster function is not degraded. As described above, in the present embodiment, it is possible to reduce the calorific value in the CPU11 while preventing the performance deterioration of the critical functions such as the meter cluster function.
In the present embodiment, a plurality of stages of threshold values are provided in the temperature determination unit 21, and a plurality of stages of thermal generation control are performed in the thermal generation control unit 23. As the temperature increases, the temperature of the semiconductor device 10 can be effectively lowered by performing the thermal generation control in which the reduction range of the thermal generation amount is large.
Here, in the first embodiment, for example, when the execution of the high-priority application is allocated to the CPU cores 11a and 11b (see
The CPU usage information 30 holds information indicating the number of applications to which execute is allocated to each CPU core. The number of applications to which execute is allocated to each CPU core can be detected by a function of a general OS. The group-range control unit 29 refers to the CPU usage information 30, and acquires the number of high-priority applications being executed in the CPU11. The group-range control unit 29 compares the operable number of CPU cores of the high-priority group with the number of high-priority applications being executed in the CPU11, and controls the operation number of CPU cores of the low-priority group based on the result of the comparison.
In the present embodiment, for example, in the default state, in the group data 28, the CPU core of the high priority group specified by the high priority group information and the CPU core of the low priority group specified by the low priority group information overlap at least partially. The group-range control unit 29 acquires temperature information from the temperature sensor 15. When the acquired temperature information is equal to or higher than a predetermined temperature, the group-range control unit 29 controls the operation number of CPU cores in the low priority group. The “predetermined temperature” may be equal to the threshold value 1 or the threshold value 2 used for the determination by the temperature determination unit 21. In this case, the operation number of CPU cores in the low priority group is controlled when the thermal generation control 1 or the thermal generation control 2 is performed.
For example, when the temperature changes from a state in which the temperature is lower than a predetermined temperature to a state in which the temperature is equal to or higher than a predetermined temperature, the group-range control unit 29 exclusively divides the CPU core included in the CPU11 into the CPU core of the high-priority group and the CPU core of the low-priority group at a predetermined ratio, for example. When the operable number of the CPU cores of the high priority group is larger than the number of the high priority applications being executed in the CPU11, the group-range control unit 29 increases the operation number of the CPU cores of the low priority group. At this time, the group-range control unit 29 increases the operation number of CPU cores of the low priority group by overlapping at least a part of the CPU cores of the high priority group specified by the high priority group information with a part of the CPU cores of the low priority group specified by the low priority group information in the group data 28. After increasing the operation number of CPU cores of the low priority group, the group-range control unit 29 decreases the number of CPU cores of the low priority group when the number of CPU cores of the high priority group becomes equal to or less than the operation number high priority applications being executed.
[Operation Procedure]
Operating procedures are described below. The operation procedure related to the thermal generation control in the present embodiment may be the same as the procedure shown in FIG. 5.
When the group-range control unit 29 determines that the temperature is equal to or higher than the predetermined temperature in step B3, the group range control unit 29 refers to the CPU usage information 30 and acquires the CPU usage information in step B3. In step B3, the group-range control unit 29 refers to the CPU usage information, for example, and specifies the number of high-priority applications being executed in the CPU11. The group-range control unit 29 compares the operable number of high-priority applications being executed in the CPU11 with the number of CPU cores of the high-priority group, and determines whether or not the operable number of CPU cores of the high-priority group is equal to or less than the number of high-priority applications (step B4). If the operable number of CPU cores in the high priority group is less than or equal to the number of high priority applications, each CPU core in the high priority group is allocated execution of at least one application. In this case, there is no CPU core to which the execution of the application is not allocated in the CPU core of the high-priority group. On the other hand, when the operable number of CPU cores of the high priority group is larger than the number of high priority applications, the CPU cores of the high priority group include at least one CPU core to which execution of the application is not allocated.
If it is determined in step B4 that the operable number of CPU cores in the high-priority group is not equal to or smaller than the number of high-priority applications, the group range control unit 29 corrects the group data 28 and expands the range of the low-priority group in step B5. In step B5, the group range control unit 29 may expand the range of the low priority group in accordance with the difference between the operation number of CPU cores of the high priority group and the number of high priority applications being executed. In step B5, for example, the group-range control unit 29 adds a CPU core to which application execution is not allocated among the CPU cores of the high-priority group to the CPU core designated by the low-priority group information, thereby expanding the range of the low-priority group. By doing so, the execution of the low priority application can be allocated to the CPU core to which the execution of the high priority application is not allocated, which is included in the high priority group.
If it is determined in step B4 that the operable number of CPU cores in the high-priority group is equal to or less than the number of high-priority applications, the group-range control unit 29 corrects the group data 28 and reduces the range of the low-priority group in step B6. In step B6, the group-range control unit 29 may expand the range of the low priority group in accordance with the difference between the operation number of CPU cores of the high priority group and the number of high priority applications being executed. In step B6, for example, the group-range control unit 29 reduces the range of the low priority group by deleting the CPU core added to the low priority group information in step B5 from the low priority group information. By doing so, it is possible to secure a CPU core to which execute of a high-priority application is allocated in a high-priority group.
When the group data 28 is modified in step B5 or B6, the app allocation unit 26 changes the application allocation in accordance with the modified group data 28. For example, when the range of the low priority group is enlarged in step B5, if two applications are executed in one CPU core in the low priority group, the app allocation unit 26 causes one of the two applications to be executed in the enlarged CPU core. On the other hand, when the low priority group is reduced in step B6, the app allocation unit 26 causes the application executed by the reduced CPU core to be executed by the CPU core when there is a CPU core available in the low priority group. Such a function is a function of a common operating system such as the Linux.
Hereinafter, an operation example will be described.
In
In the above cases, as shown in
In the above case, it is determined in step B4 that the operable number of CPU cores of the high priority group is not equal to or less than the number of high priority applications being executed, and the group-range control unit 29 expands the range of the low priority group in step B5. For example, the group-range control unit 29 adds the CPU cores 11b (CPU1) to which the application is not allocated in the high-priority group to the “allocation CPU” of the low-priority group information shown in
Further, in the present embodiment, since the thermal generation control is performed on the CPU cores of the low priority group, in the state shown in
In
In the present embodiment, since the thermal generation control unit 23 performs the thermal generation control on the CPU core of the low priority group, there is a possibility that a high-priority application is executed in the CPU core when the CPU core overlapping between the high-priority group and the low-priority group becomes a target of the thermal generation control. In such a case, the app allocation unit 26 may cause the other CPU core of the high-priority group to execute the high-priority application executed by the CPU core which is the object of the thermal generation control. When there is a CPU core overlapping between the high priority group and the low priority group, the thermal generation control unit 23 may preferentially perform thermal generation control on a CPU core in which a high priority application is not executed among the CPU cores in the low priority group.
In the present embodiment, when the operation number of CPU cores in the high-priority group is larger than the number of high-priority applications being executed, the group-range control unit 29 enlarges the CPU cores available in the low-priority group. By doing so, the CPU core to which the execution of the application is not allocated in the high priority group can be used for the execution of the low priority application. In the present embodiment, since the CPU cores not used in the high priority group belong to the low priority group, the CPU cores can be subjected to thermal generation control. By performing the thermal generation control on the CPU core in the idle state in the high-priority group, it is possible to increase the reduction range of the thermal generation amount. Other effects are the same as those of Embodiment 1.
Although the invention made by the inventor has been specifically described based on the embodiment, the present invention is not limited to the embodiment already described, and it is needless to say that various modifications can be made without departing from the gist thereof.
Number | Date | Country | Kind |
---|---|---|---|
2018-242604 | Dec 2018 | JP | national |