Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(191)

Side by Side Diff: chrome/browser/chromeos/power/freezer_cgroup_process_manager.cc

Issue 543303002: chromeos: power: Refactor RendererFreezer and add tests (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comments. Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/chromeos/power/freezer_cgroup_process_manager.h"
6
7 #include "base/files/file_util.h"
8 #include "base/logging.h"
9
10 namespace chromeos {
11
12 namespace {
13 const char kFreezerStatePath[] =
14 "/sys/fs/cgroup/freezer/chrome_renderers/freezer.state";
15 const char kFreezeCommand[] = "FROZEN";
16 const char kThawCommand[] = "THAWED";
17
18 } // namespace
19
20 FreezerCgroupProcessManager::FreezerCgroupProcessManager()
21 : state_path_(base::FilePath(kFreezerStatePath)),
22 enabled_(base::PathIsWritable(state_path_)) {
23 }
24
25 FreezerCgroupProcessManager::~FreezerCgroupProcessManager() {
26 }
27
28 bool FreezerCgroupProcessManager::FreezeRenderers() {
29 if (!enabled_) {
30 LOG(ERROR) << "Attempting to freeze renderers when the freezer cgroup is "
31 << "not available.";
32 return false;
33 }
34
35 return base::WriteFile(state_path_, kFreezeCommand, strlen(kFreezeCommand)) ==
Daniel Erat 2014/09/12 22:53:22 nit: i don't think that WriteFile logs any details
36 static_cast<int>(strlen(kFreezeCommand));
37 }
38
39 bool FreezerCgroupProcessManager::ThawRenderers() {
40 if (!enabled_) {
41 LOG(ERROR) << "Attempting to thaw renderers when the freezer cgroup is not "
42 << "available.";
43 return false;
44 }
45
46 return base::WriteFile(state_path_, kThawCommand, strlen(kThawCommand)) ==
47 static_cast<int>(strlen(kThawCommand));
48 }
49
50 bool FreezerCgroupProcessManager::CanFreezeRenderers() {
51 return enabled_;
52 }
53
54 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698