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

Unified Diff: chrome/browser/experiments/memory_ablation_experiment.cc

Issue 2810833002: Add memory ablation experiment. (Closed)
Patch Set: Created 3 years, 8 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 side-by-side diff with in-line comments
Download patch
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.
+ }
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698