| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chromeos/dbus/power_manager_client.h" | 5 #include "chromeos/dbus/power_manager_client.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/format_macros.h" | 11 #include "base/format_macros.h" |
| 12 #include "base/memory/scoped_ptr.h" | 12 #include "base/memory/scoped_ptr.h" |
| 13 #include "base/observer_list.h" | 13 #include "base/observer_list.h" |
| 14 #include "base/stringprintf.h" | 14 #include "base/stringprintf.h" |
| 15 #include "base/time.h" | 15 #include "base/time.h" |
| 16 #include "base/timer.h" | 16 #include "base/timer.h" |
| 17 #include "chromeos/dbus/power_manager/suspend.pb.h" |
| 17 #include "chromeos/dbus/power_state_control.pb.h" | 18 #include "chromeos/dbus/power_state_control.pb.h" |
| 18 #include "chromeos/dbus/power_supply_properties.pb.h" | 19 #include "chromeos/dbus/power_supply_properties.pb.h" |
| 19 #include "chromeos/dbus/video_activity_update.pb.h" | 20 #include "chromeos/dbus/video_activity_update.pb.h" |
| 20 #include "dbus/bus.h" | 21 #include "dbus/bus.h" |
| 21 #include "dbus/message.h" | 22 #include "dbus/message.h" |
| 22 #include "dbus/object_path.h" | 23 #include "dbus/object_path.h" |
| 23 #include "dbus/object_proxy.h" | 24 #include "dbus/object_proxy.h" |
| 24 #include "third_party/cros_system_api/dbus/service_constants.h" | 25 #include "third_party/cros_system_api/dbus/service_constants.h" |
| 25 | 26 |
| 26 namespace chromeos { | 27 namespace chromeos { |
| 27 | 28 |
| 29 const int kSuspendDelayTimeoutMs = 5000; |
| 30 |
| 28 // The PowerManagerClient implementation used in production. | 31 // The PowerManagerClient implementation used in production. |
| 29 class PowerManagerClientImpl : public PowerManagerClient { | 32 class PowerManagerClientImpl : public PowerManagerClient { |
| 30 public: | 33 public: |
| 31 explicit PowerManagerClientImpl(dbus::Bus* bus) | 34 explicit PowerManagerClientImpl(dbus::Bus* bus) |
| 32 : power_manager_proxy_(NULL), | 35 : power_manager_proxy_(NULL), |
| 33 weak_ptr_factory_(this) { | 36 weak_ptr_factory_(this) { |
| 34 power_manager_proxy_ = bus->GetObjectProxy( | 37 power_manager_proxy_ = bus->GetObjectProxy( |
| 35 power_manager::kPowerManagerServiceName, | 38 power_manager::kPowerManagerServiceName, |
| 36 dbus::ObjectPath(power_manager::kPowerManagerServicePath)); | 39 dbus::ObjectPath(power_manager::kPowerManagerServicePath)); |
| 37 | 40 |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 71 weak_ptr_factory_.GetWeakPtr())); | 74 weak_ptr_factory_.GetWeakPtr())); |
| 72 | 75 |
| 73 power_manager_proxy_->ConnectToSignal( | 76 power_manager_proxy_->ConnectToSignal( |
| 74 power_manager::kPowerManagerInterface, | 77 power_manager::kPowerManagerInterface, |
| 75 power_manager::kSoftwareScreenDimmingRequestedSignal, | 78 power_manager::kSoftwareScreenDimmingRequestedSignal, |
| 76 base::Bind( | 79 base::Bind( |
| 77 &PowerManagerClientImpl::SoftwareScreenDimmingRequestedReceived, | 80 &PowerManagerClientImpl::SoftwareScreenDimmingRequestedReceived, |
| 78 weak_ptr_factory_.GetWeakPtr()), | 81 weak_ptr_factory_.GetWeakPtr()), |
| 79 base::Bind(&PowerManagerClientImpl::SignalConnected, | 82 base::Bind(&PowerManagerClientImpl::SignalConnected, |
| 80 weak_ptr_factory_.GetWeakPtr())); | 83 weak_ptr_factory_.GetWeakPtr())); |
| 84 |
| 85 power_manager_proxy_->ConnectToSignal( |
| 86 power_manager::kPowerManagerInterface, |
| 87 power_manager::kSuspendImminentSignal, |
| 88 base::Bind( |
| 89 &PowerManagerClientImpl::SuspendImminentReceived, |
| 90 weak_ptr_factory_.GetWeakPtr()), |
| 91 base::Bind(&PowerManagerClientImpl::SignalConnected, |
| 92 weak_ptr_factory_.GetWeakPtr())); |
| 93 |
| 94 // Register to powerd for suspend notifications. |
| 95 dbus::MethodCall method_call( |
| 96 power_manager::kPowerManagerInterface, |
| 97 power_manager::kRegisterSuspendDelayMethod); |
| 98 dbus::MessageWriter writer(&method_call); |
| 99 |
| 100 power_manager::RegisterSuspendDelayRequest protobuf_request; |
| 101 protobuf_request.Clear(); |
| 102 protobuf_request.set_timeout(kSuspendDelayTimeoutMs); |
| 103 |
| 104 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { |
| 105 LOG(ERROR) << "Error calling " |
| 106 << power_manager::kRegisterSuspendDelayMethod; |
| 107 return; |
| 108 } |
| 109 power_manager_proxy_->CallMethod( |
| 110 &method_call, |
| 111 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 112 dbus::ObjectProxy::EmptyResponseCallback()); |
| 113 |
| 114 power_manager::RegisterSuspendDelayReply protobuf_reply; |
| 115 delay_id_ = protobuf_reply.delay_id(); |
| 81 } | 116 } |
| 82 | 117 |
| 83 virtual ~PowerManagerClientImpl() { | 118 virtual ~PowerManagerClientImpl() { |
| 119 // Unregister from powerd for suspend notifications. |
| 120 dbus::MethodCall method_call( |
| 121 power_manager::kPowerManagerInterface, |
| 122 power_manager::kUnregisterSuspendDelayMethod); |
| 123 dbus::MessageWriter writer(&method_call); |
| 124 |
| 125 power_manager::UnregisterSuspendDelayRequest protobuf; |
| 126 protobuf.Clear(); |
| 127 protobuf.set_delay_id(delay_id_); |
| 128 |
| 129 power_manager_proxy_->CallMethod( |
| 130 &method_call, |
| 131 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 132 dbus::ObjectProxy::EmptyResponseCallback()); |
| 84 } | 133 } |
| 85 | 134 |
| 86 // PowerManagerClient overrides: | 135 // PowerManagerClient overrides: |
| 87 | 136 |
| 88 virtual void AddObserver(Observer* observer) OVERRIDE { | 137 virtual void AddObserver(Observer* observer) OVERRIDE { |
| 89 CHECK(observer); // http://crbug.com/119976 | 138 CHECK(observer); // http://crbug.com/119976 |
| 90 observers_.AddObserver(observer); | 139 observers_.AddObserver(observer); |
| 91 } | 140 } |
| 92 | 141 |
| 93 virtual void RemoveObserver(Observer* observer) OVERRIDE { | 142 virtual void RemoveObserver(Observer* observer) OVERRIDE { |
| (...skipping 362 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 456 break; | 505 break; |
| 457 case power_manager::kSoftwareScreenDimmingIdle: | 506 case power_manager::kSoftwareScreenDimmingIdle: |
| 458 state = Observer::SCREEN_DIMMING_IDLE; | 507 state = Observer::SCREEN_DIMMING_IDLE; |
| 459 break; | 508 break; |
| 460 default: | 509 default: |
| 461 LOG(ERROR) << "Unhandled screen dimming state " << signal_state; | 510 LOG(ERROR) << "Unhandled screen dimming state " << signal_state; |
| 462 } | 511 } |
| 463 FOR_EACH_OBSERVER(Observer, observers_, ScreenDimmingRequested(state)); | 512 FOR_EACH_OBSERVER(Observer, observers_, ScreenDimmingRequested(state)); |
| 464 } | 513 } |
| 465 | 514 |
| 515 void SuspendImminentReceived(dbus::Signal* signal) { |
| 516 dbus::MessageReader reader(signal); |
| 517 power_manager::SuspendImminent protobuf_imminent; |
| 518 int32 suspend_id = protobuf_imminent.suspend_id(); |
| 519 |
| 520 FOR_EACH_OBSERVER(Observer, observers_, DelaySuspend()); |
| 521 |
| 522 dbus::MethodCall method_call( |
| 523 power_manager::kPowerManagerInterface, |
| 524 power_manager::kHandleSuspendReadinessMethod); |
| 525 dbus::MessageWriter writer(&method_call); |
| 526 |
| 527 power_manager::SuspendReadinessInfo protobuf_request; |
| 528 protobuf_request.Clear(); |
| 529 protobuf_request.set_delay_id(delay_id_); |
| 530 protobuf_request.set_suspend_id(suspend_id); |
| 531 |
| 532 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { |
| 533 LOG(ERROR) << "Error calling " |
| 534 << power_manager::kHandleSuspendReadinessMethod; |
| 535 return; |
| 536 } |
| 537 power_manager_proxy_->CallMethod( |
| 538 &method_call, |
| 539 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 540 dbus::ObjectProxy::EmptyResponseCallback()); |
| 541 } |
| 542 |
| 466 dbus::ObjectProxy* power_manager_proxy_; | 543 dbus::ObjectProxy* power_manager_proxy_; |
| 467 ObserverList<Observer> observers_; | 544 ObserverList<Observer> observers_; |
| 545 std::list<SuspendImminentCallback> suspend_delay_callback_list_; |
| 546 int32 delay_id_; |
| 468 | 547 |
| 469 // Note: This should remain the last member so it'll be destroyed and | 548 // Note: This should remain the last member so it'll be destroyed and |
| 470 // invalidate its weak pointers before any other members are destroyed. | 549 // invalidate its weak pointers before any other members are destroyed. |
| 471 base::WeakPtrFactory<PowerManagerClientImpl> weak_ptr_factory_; | 550 base::WeakPtrFactory<PowerManagerClientImpl> weak_ptr_factory_; |
| 472 | 551 |
| 473 DISALLOW_COPY_AND_ASSIGN(PowerManagerClientImpl); | 552 DISALLOW_COPY_AND_ASSIGN(PowerManagerClientImpl); |
| 474 }; | 553 }; |
| 475 | 554 |
| 476 // The PowerManagerClient implementation used on Linux desktop, | 555 // The PowerManagerClient implementation used on Linux desktop, |
| 477 // which does nothing. | 556 // which does nothing. |
| (...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 634 PowerManagerClient* PowerManagerClient::Create( | 713 PowerManagerClient* PowerManagerClient::Create( |
| 635 DBusClientImplementationType type, | 714 DBusClientImplementationType type, |
| 636 dbus::Bus* bus) { | 715 dbus::Bus* bus) { |
| 637 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) | 716 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) |
| 638 return new PowerManagerClientImpl(bus); | 717 return new PowerManagerClientImpl(bus); |
| 639 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); | 718 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); |
| 640 return new PowerManagerClientStubImpl(); | 719 return new PowerManagerClientStubImpl(); |
| 641 } | 720 } |
| 642 | 721 |
| 643 } // namespace chromeos | 722 } // namespace chromeos |
| OLD | NEW |