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.
|
+ } |
+ } |
+} |