1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
|
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "third_party/blink/renderer/modules/peerconnection/thermal_resource.h"
#include "base/task/sequenced_task_runner.h"
#include "base/time/time.h"
#include "build/build_config.h"
#include "third_party/webrtc/rtc_base/ref_counted_object.h"
namespace blink {
namespace {
const int kReportIntervalSeconds = 10;
} // namespace
BASE_FEATURE(kWebRtcThermalResource,
"WebRtcThermalResource",
#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_CHROMEOS)
base::FEATURE_ENABLED_BY_DEFAULT
#else
base::FEATURE_DISABLED_BY_DEFAULT
#endif
);
// static
scoped_refptr<ThermalResource> ThermalResource::Create(
scoped_refptr<base::SequencedTaskRunner> task_runner) {
return new webrtc::RefCountedObject<ThermalResource>(std::move(task_runner));
}
ThermalResource::ThermalResource(
scoped_refptr<base::SequencedTaskRunner> task_runner)
: task_runner_(std::move(task_runner)) {}
void ThermalResource::OnThermalMeasurement(
mojom::blink::DeviceThermalState measurement) {
base::AutoLock auto_lock(lock_);
measurement_ = measurement;
++measurement_id_;
ReportMeasurementWhileHoldingLock(measurement_id_);
}
std::string ThermalResource::Name() const {
return "ThermalResource";
}
void ThermalResource::SetResourceListener(webrtc::ResourceListener* listener) {
base::AutoLock auto_lock(lock_);
DCHECK(!listener_ || !listener) << "Must not overwrite existing listener.";
listener_ = listener;
if (listener_ && measurement_ != mojom::blink::DeviceThermalState::kUnknown) {
ReportMeasurementWhileHoldingLock(measurement_id_);
}
}
void ThermalResource::ReportMeasurement(size_t measurement_id) {
base::AutoLock auto_lock(lock_);
ReportMeasurementWhileHoldingLock(measurement_id);
}
// EXCLUSIVE_LOCKS_REQUIRED(&lock_)
void ThermalResource::ReportMeasurementWhileHoldingLock(size_t measurement_id) {
// Stop repeating measurements if the measurement was invalidated or we don't
// have a listtener.
if (measurement_id != measurement_id_ || !listener_)
return;
switch (measurement_) {
case mojom::blink::DeviceThermalState::kUnknown:
// Stop repeating measurements.
return;
case mojom::blink::DeviceThermalState::kNominal:
case mojom::blink::DeviceThermalState::kFair:
listener_->OnResourceUsageStateMeasured(
webrtc::scoped_refptr<Resource>(this),
webrtc::ResourceUsageState::kUnderuse);
break;
case mojom::blink::DeviceThermalState::kSerious:
case mojom::blink::DeviceThermalState::kCritical:
listener_->OnResourceUsageStateMeasured(
webrtc::scoped_refptr<Resource>(this),
webrtc::ResourceUsageState::kOveruse);
break;
}
// Repeat the reporting every 10 seconds until a new measurement is made or
// the listener is unregistered.
task_runner_->PostDelayedTask(
FROM_HERE,
base::BindOnce(&ThermalResource::ReportMeasurement,
webrtc::scoped_refptr<ThermalResource>(this),
measurement_id),
base::Seconds(kReportIntervalSeconds));
}
} // namespace blink
|