Chromium Code Reviews| Index: chrome/browser/experiments/memory_ablation_experiment.cc |
| diff --git a/chrome/browser/experiments/memory_ablation_experiment.cc b/chrome/browser/experiments/memory_ablation_experiment.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..22050e15c2490439a35bb91c8a1a3e9415dd1b71 |
| --- /dev/null |
| +++ b/chrome/browser/experiments/memory_ablation_experiment.cc |
| @@ -0,0 +1,62 @@ |
| +// Copyright 2017 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/experiments/memory_ablation_experiment.h" |
| + |
|
Primiano Tucci (use gerrit)
2017/04/10 18:05:04
do you need a class at all here?
It seems all this
DmitrySkiba
2017/04/10 19:31:00
I think class is more flexible, for example we mig
Primiano Tucci (use gerrit)
2017/04/10 19:40:11
A good rule of thumb is don't introduce unnecessar
DmitrySkiba
2017/04/10 19:51:41
I mean, we might end up doing those things in this
|
| +#include "base/bind.h" |
| +#include "base/bind_helpers.h" |
| +#include "base/metrics/field_trial_params.h" |
| +#include "base/process/process_metrics.h" |
| + |
| +const base::Feature kMemoryAblationFeature{"MemoryAblation", |
| + base::FEATURE_DISABLED_BY_DEFAULT}; |
| + |
| +const char kMemoryAblationFeatureSizeParam[] = "Size"; |
| + |
| +constexpr size_t kMemoryAblationDelaySeconds = 5; |
| + |
| +MemoryAblationExperiment::MemoryAblationExperiment() |
| + : memory_(nullptr, &free) {} |
| + |
| +MemoryAblationExperiment::~MemoryAblationExperiment() {} |
| + |
| +MemoryAblationExperiment* MemoryAblationExperiment::GetInstance() { |
| + static auto* instance = new MemoryAblationExperiment(); |
| + return instance; |
| +} |
| + |
| +void MemoryAblationExperiment::MaybeStart( |
| + scoped_refptr<base::SequencedTaskRunner> task_runner) { |
| + int size = base::GetFieldTrialParamByFeatureAsInt( |
| + kMemoryAblationFeature, kMemoryAblationFeatureSizeParam, |
| + 0 /* default value */); |
| + if (size > 0) { |
| + GetInstance()->Start(task_runner, size); |
| + } |
| +} |
| + |
| +void MemoryAblationExperiment::Start( |
| + scoped_refptr<base::SequencedTaskRunner> task_runner, |
| + size_t memory_size) { |
| + task_runner->PostDelayedTask( |
| + FROM_HERE, |
| + base::Bind(&MemoryAblationExperiment::AllocateMemory, |
| + base::Unretained(this), memory_size), |
| + base::TimeDelta::FromSeconds(kMemoryAblationDelaySeconds)); |
| +} |
| + |
| +void MemoryAblationExperiment::AllocateMemory(size_t size) { |
| + memory_size_ = size; |
| + memory_.reset(static_cast<uint8_t*>(malloc(size))); |
| + TouchMemory(); |
| +} |
| + |
| +void MemoryAblationExperiment::TouchMemory() { |
| + if (memory_) { |
| + size_t page_size = base::GetPageSize(); |
| + for (size_t i = 0; i < memory_size_; i += page_size) { |
| + memory_[i]++; |
|
Primiano Tucci (use gerrit)
2017/04/10 18:05:04
two things here:
1. touching uninitialized memory
DmitrySkiba
2017/04/10 19:31:00
Yup, definitely UB. Fixed.
|
| + } |
| + } |
| +} |