blob: 0fe5ed926c4c57ba5520c9e9f9a78382318f5583 [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/memory/enterprise_memory_limit_pref_observer.h"
#include "base/bind.h"
#include "base/memory/memory_pressure_monitor.h"
#include "base/util/memory_pressure/multi_source_memory_pressure_monitor.h"
#include "chrome/common/pref_names.h"
namespace memory {
namespace {
const int kMinimalResidentSetLimitMb = 2048;
} // namespace
EnterpriseMemoryLimitPrefObserver::EnterpriseMemoryLimitPrefObserver(
PrefService* pref_service)
: pref_service_(pref_service) {
DCHECK(pref_service_);
DCHECK(base::MemoryPressureMonitor::Get());
evaluator_ = std::make_unique<EnterpriseMemoryLimitEvaluator>(
static_cast<util::MultiSourceMemoryPressureMonitor*>(
base::MemoryPressureMonitor::Get())
->CreateVoter());
pref_change_registrar_.Init(pref_service_);
pref_change_registrar_.Add(
prefs::kTotalMemoryLimitMb,
base::BindRepeating(&EnterpriseMemoryLimitPrefObserver::GetPref,
base::Unretained(this)));
GetPref();
}
EnterpriseMemoryLimitPrefObserver::~EnterpriseMemoryLimitPrefObserver() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
if (evaluator_->IsRunning())
evaluator_->Stop();
}
// static
void EnterpriseMemoryLimitPrefObserver::RegisterPrefs(
PrefRegistrySimple* registry) {
registry->RegisterIntegerPref(prefs::kTotalMemoryLimitMb,
kMinimalResidentSetLimitMb);
}
void EnterpriseMemoryLimitPrefObserver::GetPref() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
const PrefService::Preference* pref =
pref_service_->FindPreference(prefs::kTotalMemoryLimitMb);
if (pref->IsManaged()) {
if (!evaluator_->IsRunning())
evaluator_->Start();
evaluator_->SetResidentSetLimitMb(
std::max(pref->GetValue()->GetInt(), kMinimalResidentSetLimitMb));
} else if (evaluator_->IsRunning()) {
evaluator_->Stop();
}
}
} // namespace memory