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

Unified Diff: content/renderer/pepper/plugin_instance_throttler_impl.cc

Issue 849723002: Plugin Power Saver: Make PepperPluginInstanceThrottler interface public. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 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: content/renderer/pepper/plugin_instance_throttler_impl.cc
diff --git a/content/renderer/pepper/pepper_plugin_instance_throttler.cc b/content/renderer/pepper/plugin_instance_throttler_impl.cc
similarity index 33%
rename from content/renderer/pepper/pepper_plugin_instance_throttler.cc
rename to content/renderer/pepper/plugin_instance_throttler_impl.cc
index 81382093e84ee05fd4966e6754e7617d2a5d1aa3..ea06846f786539c2979415a4d0873229e898008b 100644
--- a/content/renderer/pepper/pepper_plugin_instance_throttler.cc
+++ b/content/renderer/pepper/plugin_instance_throttler_impl.cc
@@ -2,12 +2,12 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "content/renderer/pepper/pepper_plugin_instance_throttler.h"
+#include "content/renderer/pepper/plugin_instance_throttler_impl.h"
#include "base/metrics/histogram.h"
-#include "base/metrics/sparse_histogram.h"
#include "base/time/time.h"
#include "content/public/common/content_constants.h"
+#include "content/public/renderer/render_frame.h"
#include "content/public/renderer/render_thread.h"
#include "third_party/WebKit/public/web/WebInputEvent.h"
#include "ui/gfx/color_utils.h"
@@ -17,70 +17,13 @@ namespace content {
namespace {
-static const int kInfiniteRatio = 99999;
-
-#define UMA_HISTOGRAM_ASPECT_RATIO(name, width, height) \
- UMA_HISTOGRAM_SPARSE_SLOWLY( \
- name, (height) ? ((width)*100) / (height) : kInfiniteRatio);
-
-// Histogram tracking prevalence of tiny Flash instances. Units in pixels.
-enum PluginFlashTinyContentSize {
- TINY_CONTENT_SIZE_1_1 = 0,
- TINY_CONTENT_SIZE_5_5 = 1,
- TINY_CONTENT_SIZE_10_10 = 2,
- TINY_CONTENT_SIZE_LARGE = 3,
- TINY_CONTENT_SIZE_NUM_ITEMS
-};
-
-const char kFlashClickSizeAspectRatioHistogram[] =
- "Plugin.Flash.ClickSize.AspectRatio";
-const char kFlashClickSizeHeightHistogram[] = "Plugin.Flash.ClickSize.Height";
-const char kFlashClickSizeWidthHistogram[] = "Plugin.Flash.ClickSize.Width";
-const char kFlashTinyContentSizeHistogram[] = "Plugin.Flash.TinyContentSize";
const char kPowerSaverUnthrottleHistogram[] = "Plugin.PowerSaver.Unthrottle";
-// Record size metrics for all Flash instances.
-void RecordFlashSizeMetric(int width, int height) {
- PluginFlashTinyContentSize size = TINY_CONTENT_SIZE_LARGE;
-
- if (width <= 1 && height <= 1)
- size = TINY_CONTENT_SIZE_1_1;
- else if (width <= 5 && height <= 5)
- size = TINY_CONTENT_SIZE_5_5;
- else if (width <= 10 && height <= 10)
- size = TINY_CONTENT_SIZE_10_10;
-
- UMA_HISTOGRAM_ENUMERATION(kFlashTinyContentSizeHistogram, size,
- TINY_CONTENT_SIZE_NUM_ITEMS);
-}
-
void RecordUnthrottleMethodMetric(
- PepperPluginInstanceThrottler::PowerSaverUnthrottleMethod method) {
+ PluginInstanceThrottlerImpl::PowerSaverUnthrottleMethod method) {
UMA_HISTOGRAM_ENUMERATION(
kPowerSaverUnthrottleHistogram, method,
- PepperPluginInstanceThrottler::UNTHROTTLE_METHOD_NUM_ITEMS);
-}
-
-// Records size metrics for Flash instances that are clicked.
-void RecordFlashClickSizeMetric(int width, int height) {
- base::HistogramBase* width_histogram = base::LinearHistogram::FactoryGet(
- kFlashClickSizeWidthHistogram,
- 0, // minimum width
- 500, // maximum width
- 100, // number of buckets.
- base::HistogramBase::kUmaTargetedHistogramFlag);
- width_histogram->Add(width);
-
- base::HistogramBase* height_histogram = base::LinearHistogram::FactoryGet(
- kFlashClickSizeHeightHistogram,
- 0, // minimum height
- 400, // maximum height
- 100, // number of buckets.
- base::HistogramBase::kUmaTargetedHistogramFlag);
- height_histogram->Add(height);
-
- UMA_HISTOGRAM_ASPECT_RATIO(kFlashClickSizeAspectRatioHistogram, width,
- height);
+ PluginInstanceThrottler::UNTHROTTLE_METHOD_NUM_ITEMS);
}
// When we give up waiting for a suitable preview frame, and simply suspend
@@ -96,59 +39,61 @@ const int kMinimumConsecutiveInterestingFrames = 4;
} // namespace
-PepperPluginInstanceThrottler::PepperPluginInstanceThrottler(
+PluginInstanceThrottlerImpl::PluginInstanceThrottlerImpl(
RenderFrame* frame,
- const blink::WebRect& bounds,
- bool is_flash_plugin,
const GURL& plugin_url,
- RenderFrame::PluginPowerSaverMode power_saver_mode,
- const base::Closure& throttle_change_callback)
- : bounds_(bounds),
- throttle_change_callback_(throttle_change_callback),
- is_flash_plugin_(is_flash_plugin),
- needs_representative_keyframe_(false),
+ bool power_saver_enabled)
+ : state_(power_saver_enabled ? POWER_SAVER_ENABLED_AWAITING_KEYFRAME
+ : POWER_SAVER_DISABLED),
consecutive_interesting_frames_(0),
- has_been_clicked_(false),
- power_saver_enabled_(false),
- is_peripheral_content_(power_saver_mode !=
- RenderFrame::POWER_SAVER_MODE_ESSENTIAL),
- plugin_throttled_(false),
weak_factory_(this) {
- if (is_flash_plugin_ && RenderThread::Get()) {
- RenderThread::Get()->RecordAction(
- base::UserMetricsAction("Flash.PluginInstanceCreated"));
- RecordFlashSizeMetric(bounds.width, bounds.height);
- }
-
- power_saver_enabled_ =
- is_flash_plugin_ &&
- power_saver_mode == RenderFrame::POWER_SAVER_MODE_PERIPHERAL_THROTTLED;
-
- GURL content_origin = plugin_url.GetOrigin();
-
// To collect UMAs, register peripheral content even if power saver disabled.
if (frame) {
frame->RegisterPeripheralPlugin(
- content_origin,
- base::Bind(&PepperPluginInstanceThrottler::DisablePowerSaver,
+ plugin_url.GetOrigin(),
+ base::Bind(&PluginInstanceThrottlerImpl::MarkPluginEssential,
weak_factory_.GetWeakPtr(), UNTHROTTLE_METHOD_BY_WHITELIST));
}
- if (power_saver_enabled_) {
- needs_representative_keyframe_ = true;
+ if (power_saver_enabled) {
base::MessageLoop::current()->PostDelayedTask(
- FROM_HERE,
- base::Bind(&PepperPluginInstanceThrottler::SetPluginThrottled,
- weak_factory_.GetWeakPtr(), true /* throttled */),
+ FROM_HERE, base::Bind(&PluginInstanceThrottlerImpl::EngageThrottle,
+ weak_factory_.GetWeakPtr()),
base::TimeDelta::FromMilliseconds(kThrottleTimeout));
}
}
-PepperPluginInstanceThrottler::~PepperPluginInstanceThrottler() {
+PluginInstanceThrottlerImpl::~PluginInstanceThrottlerImpl() {
+}
+
+void PluginInstanceThrottlerImpl::AddObserver(Observer* observer) {
+ observer_list_.AddObserver(observer);
+}
+
+void PluginInstanceThrottlerImpl::RemoveObserver(Observer* observer) {
+ observer_list_.RemoveObserver(observer);
+}
+
+bool PluginInstanceThrottlerImpl::IsThrottled() const {
+ return state_ == POWER_SAVER_ENABLED_PLUGIN_THROTTLED;
+}
+
+void PluginInstanceThrottlerImpl::MarkPluginEssential(
+ PowerSaverUnthrottleMethod method) {
+ if (state_ == PLUGIN_INSTANCE_MARKED_ESSENTIAL)
+ return;
+
+ bool was_throttled = IsThrottled();
+ state_ = PLUGIN_INSTANCE_MARKED_ESSENTIAL;
+ RecordUnthrottleMethodMetric(method);
+
+ if (was_throttled)
+ FOR_EACH_OBSERVER(Observer, observer_list_, OnThrottleStateChange());
}
-void PepperPluginInstanceThrottler::OnImageFlush(const SkBitmap* bitmap) {
- if (!needs_representative_keyframe_ || !bitmap)
+void PluginInstanceThrottlerImpl::OnImageFlush(const SkBitmap* bitmap) {
+ DCHECK(needs_representative_keyframe());
+ if (!bitmap)
return;
double boring_score = color_utils::CalculateBoringScore(*bitmap);
@@ -158,10 +103,10 @@ void PepperPluginInstanceThrottler::OnImageFlush(const SkBitmap* bitmap) {
consecutive_interesting_frames_ = 0;
if (consecutive_interesting_frames_ >= kMinimumConsecutiveInterestingFrames)
- SetPluginThrottled(true);
+ EngageThrottle();
}
-bool PepperPluginInstanceThrottler::ConsumeInputEvent(
+bool PluginInstanceThrottlerImpl::ConsumeInputEvent(
const blink::WebInputEvent& event) {
// Always allow right-clicks through so users may verify it's a plug-in.
// TODO(tommycli): We should instead show a custom context menu (probably
@@ -170,52 +115,23 @@ bool PepperPluginInstanceThrottler::ConsumeInputEvent(
if (event.modifiers & blink::WebInputEvent::Modifiers::RightButtonDown)
return false;
- if (!has_been_clicked_ && is_flash_plugin_ &&
- event.type == blink::WebInputEvent::MouseDown &&
+ if (state_ != PLUGIN_INSTANCE_MARKED_ESSENTIAL &&
+ event.type == blink::WebInputEvent::MouseUp &&
(event.modifiers & blink::WebInputEvent::LeftButtonDown)) {
- has_been_clicked_ = true;
- RecordFlashClickSizeMetric(bounds_.width, bounds_.height);
- }
-
- if (is_peripheral_content_ && event.type == blink::WebInputEvent::MouseUp &&
- (event.modifiers & blink::WebInputEvent::LeftButtonDown)) {
- is_peripheral_content_ = false;
- power_saver_enabled_ = false;
- needs_representative_keyframe_ = false;
-
- RecordUnthrottleMethodMetric(UNTHROTTLE_METHOD_BY_CLICK);
-
- if (plugin_throttled_) {
- SetPluginThrottled(false /* throttled */);
- return true;
- }
+ bool was_throttled = IsThrottled();
+ MarkPluginEssential(UNTHROTTLE_METHOD_BY_CLICK);
+ return was_throttled;
}
- return plugin_throttled_;
+ return IsThrottled();
}
-void PepperPluginInstanceThrottler::DisablePowerSaver(
- PowerSaverUnthrottleMethod method) {
- if (!is_peripheral_content_)
+void PluginInstanceThrottlerImpl::EngageThrottle() {
+ if (state_ != POWER_SAVER_ENABLED_AWAITING_KEYFRAME)
return;
- is_peripheral_content_ = false;
- power_saver_enabled_ = false;
- SetPluginThrottled(false);
-
- RecordUnthrottleMethodMetric(method);
-}
-
-void PepperPluginInstanceThrottler::SetPluginThrottled(bool throttled) {
- // Do not throttle if we've already disabled power saver.
- if (!power_saver_enabled_ && throttled)
- return;
-
- // Once we change the throttle state, we will never need the snapshot again.
- needs_representative_keyframe_ = false;
-
- plugin_throttled_ = throttled;
- throttle_change_callback_.Run();
+ state_ = POWER_SAVER_ENABLED_PLUGIN_THROTTLED;
+ FOR_EACH_OBSERVER(Observer, observer_list_, OnThrottleStateChange());
}
} // namespace content

Powered by Google App Engine
This is Rietveld 408576698