blob: 23f74767657cdd9dd8ff3c828c2ec6d26fb6bb5c [file] [log] [blame]
// Copyright (c) 2020 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 "third_party/blink/renderer/modules/peerconnection/thermal_resource.h"
#include "build/build_config.h"
#include "third_party/webrtc/rtc_base/ref_counted_object.h"
namespace blink {
namespace {
const int kReportIntervalSeconds = 10;
} // namespace
const base::Feature kWebRtcThermalResource {
"WebRtcThermalResource",
#if defined(OS_MAC)
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 rtc::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(
this, webrtc::ResourceUsageState::kUnderuse);
break;
case mojom::blink::DeviceThermalState::kSerious:
case mojom::blink::DeviceThermalState::kCritical:
listener_->OnResourceUsageStateMeasured(
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,
scoped_refptr<ThermalResource>(this), measurement_id),
base::TimeDelta::FromSeconds(kReportIntervalSeconds));
}
} // namespace blink