// // Copyright (C) 2016 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // #ifndef UPDATE_ENGINE_COMMON_CPU_LIMITER_H_ #define UPDATE_ENGINE_COMMON_CPU_LIMITER_H_ #include <brillo/message_loops/message_loop.h> namespace chromeos_update_engine { // Cgroups cpu shares constants. 1024 is the default shares a standard process // gets and 2 is the minimum value. We set High as a value that gives the // update-engine 2x the cpu share of a standard process. enum class CpuShares : int { kHigh = 2048, kNormal = 1024, kLow = 2, }; // Sets the current process shares to |shares|. Returns true on // success, false otherwise. bool SetCpuShares(CpuShares shares); class CPULimiter { public: CPULimiter() = default; ~CPULimiter(); // Sets the cpu shares to low and sets up timeout events to stop the limiter. void StartLimiter(); // Resets the cpu shares to normal and destroys any scheduled timeout sources. void StopLimiter(); // Sets the cpu shares to |shares|. This method can be user at any time, but // if the limiter is not running, the shares won't be reset to normal. bool SetCpuShares(CpuShares shares); private: // The cpu shares timeout source callback sets the current cpu shares to // normal. void StopLimiterCallback(); // Current cpu shares. CpuShares shares_ = CpuShares::kNormal; // The cpu shares management timeout task id. brillo::MessageLoop::TaskId manage_shares_id_{ brillo::MessageLoop::kTaskIdNull}; }; } // namespace chromeos_update_engine #endif // UPDATE_ENGINE_COMMON_CPU_LIMITER_H_