xref: /aosp_15_r20/system/update_engine/common/cpu_limiter.h (revision 5a9231315b4521097b8dc3750bc806fcafe0c72f)
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