1*5a923131SAndroid Build Coastguard Worker // 2*5a923131SAndroid Build Coastguard Worker // Copyright (C) 2016 The Android Open Source Project 3*5a923131SAndroid Build Coastguard Worker // 4*5a923131SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 5*5a923131SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 6*5a923131SAndroid Build Coastguard Worker // You may obtain a copy of the License at 7*5a923131SAndroid Build Coastguard Worker // 8*5a923131SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 9*5a923131SAndroid Build Coastguard Worker // 10*5a923131SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 11*5a923131SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 12*5a923131SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*5a923131SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 14*5a923131SAndroid Build Coastguard Worker // limitations under the License. 15*5a923131SAndroid Build Coastguard Worker // 16*5a923131SAndroid Build Coastguard Worker 17*5a923131SAndroid Build Coastguard Worker #ifndef UPDATE_ENGINE_COMMON_CPU_LIMITER_H_ 18*5a923131SAndroid Build Coastguard Worker #define UPDATE_ENGINE_COMMON_CPU_LIMITER_H_ 19*5a923131SAndroid Build Coastguard Worker 20*5a923131SAndroid Build Coastguard Worker #include <brillo/message_loops/message_loop.h> 21*5a923131SAndroid Build Coastguard Worker 22*5a923131SAndroid Build Coastguard Worker namespace chromeos_update_engine { 23*5a923131SAndroid Build Coastguard Worker 24*5a923131SAndroid Build Coastguard Worker // Cgroups cpu shares constants. 1024 is the default shares a standard process 25*5a923131SAndroid Build Coastguard Worker // gets and 2 is the minimum value. We set High as a value that gives the 26*5a923131SAndroid Build Coastguard Worker // update-engine 2x the cpu share of a standard process. 27*5a923131SAndroid Build Coastguard Worker enum class CpuShares : int { 28*5a923131SAndroid Build Coastguard Worker kHigh = 2048, 29*5a923131SAndroid Build Coastguard Worker kNormal = 1024, 30*5a923131SAndroid Build Coastguard Worker kLow = 2, 31*5a923131SAndroid Build Coastguard Worker }; 32*5a923131SAndroid Build Coastguard Worker 33*5a923131SAndroid Build Coastguard Worker class CPULimiter { 34*5a923131SAndroid Build Coastguard Worker public: 35*5a923131SAndroid Build Coastguard Worker CPULimiter() = default; 36*5a923131SAndroid Build Coastguard Worker ~CPULimiter(); 37*5a923131SAndroid Build Coastguard Worker 38*5a923131SAndroid Build Coastguard Worker // Sets the cpu shares to low and sets up timeout events to stop the limiter. 39*5a923131SAndroid Build Coastguard Worker void StartLimiter(); 40*5a923131SAndroid Build Coastguard Worker 41*5a923131SAndroid Build Coastguard Worker // Resets the cpu shares to normal and destroys any scheduled timeout sources. 42*5a923131SAndroid Build Coastguard Worker void StopLimiter(); 43*5a923131SAndroid Build Coastguard Worker 44*5a923131SAndroid Build Coastguard Worker // Sets the cpu shares to |shares|. This method can be user at any time, but 45*5a923131SAndroid Build Coastguard Worker // if the limiter is not running, the shares won't be reset to normal. 46*5a923131SAndroid Build Coastguard Worker bool SetCpuShares(CpuShares shares); 47*5a923131SAndroid Build Coastguard Worker 48*5a923131SAndroid Build Coastguard Worker private: 49*5a923131SAndroid Build Coastguard Worker // The cpu shares timeout source callback sets the current cpu shares to 50*5a923131SAndroid Build Coastguard Worker // normal. 51*5a923131SAndroid Build Coastguard Worker void StopLimiterCallback(); 52*5a923131SAndroid Build Coastguard Worker 53*5a923131SAndroid Build Coastguard Worker // Current cpu shares. 54*5a923131SAndroid Build Coastguard Worker CpuShares shares_ = CpuShares::kNormal; 55*5a923131SAndroid Build Coastguard Worker 56*5a923131SAndroid Build Coastguard Worker // The cpu shares management timeout task id. 57*5a923131SAndroid Build Coastguard Worker brillo::MessageLoop::TaskId manage_shares_id_{ 58*5a923131SAndroid Build Coastguard Worker brillo::MessageLoop::kTaskIdNull}; 59*5a923131SAndroid Build Coastguard Worker }; 60*5a923131SAndroid Build Coastguard Worker 61*5a923131SAndroid Build Coastguard Worker } // namespace chromeos_update_engine 62*5a923131SAndroid Build Coastguard Worker 63*5a923131SAndroid Build Coastguard Worker #endif // UPDATE_ENGINE_COMMON_CPU_LIMITER_H_ 64