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/command_line.h" | 11 #include "base/command_line.h" |
12 #include "base/format_macros.h" | 12 #include "base/format_macros.h" |
13 #include "base/logging.h" | 13 #include "base/logging.h" |
14 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
15 #include "base/message_loop/message_loop.h" | 15 #include "base/message_loop/message_loop.h" |
16 #include "base/observer_list.h" | 16 #include "base/observer_list.h" |
17 #include "base/power_monitor/power_monitor_device_source.h" | 17 #include "base/power_monitor/power_monitor_device_source.h" |
18 #include "base/strings/string_number_conversions.h" | 18 #include "base/strings/string_number_conversions.h" |
19 #include "base/strings/string_split.h" | 19 #include "base/strings/string_split.h" |
20 #include "base/strings/stringprintf.h" | 20 #include "base/strings/stringprintf.h" |
21 #include "base/threading/platform_thread.h" | 21 #include "base/threading/platform_thread.h" |
22 #include "base/time/time.h" | 22 #include "base/time/time.h" |
23 #include "base/timer/timer.h" | 23 #include "base/timer/timer.h" |
24 #include "chromeos/chromeos_switches.h" | 24 #include "chromeos/chromeos_switches.h" |
25 #include "chromeos/dbus/power_manager/input_event.pb.h" | 25 #include "chromeos/dbus/power_manager/input_event.pb.h" |
26 #include "chromeos/dbus/power_manager/peripheral_battery_status.pb.h" | 26 #include "chromeos/dbus/power_manager/peripheral_battery_status.pb.h" |
27 #include "chromeos/dbus/power_manager/policy.pb.h" | 27 #include "chromeos/dbus/power_manager/policy.pb.h" |
28 #include "chromeos/dbus/power_manager/power_supply_properties.pb.h" | 28 #include "chromeos/dbus/power_manager/power_supply_properties.pb.h" |
29 #include "chromeos/dbus/power_manager/suspend.pb.h" | 29 #include "chromeos/dbus/power_manager/suspend.pb.h" |
| 30 #include "chromeos/device_event_log.h" |
30 #include "dbus/bus.h" | 31 #include "dbus/bus.h" |
31 #include "dbus/message.h" | 32 #include "dbus/message.h" |
32 #include "dbus/object_path.h" | 33 #include "dbus/object_path.h" |
33 #include "dbus/object_proxy.h" | 34 #include "dbus/object_proxy.h" |
34 | 35 |
35 namespace chromeos { | 36 namespace chromeos { |
36 | 37 |
37 // Maximum amount of time that the power manager will wait for Chrome to | 38 // Maximum amount of time that the power manager will wait for Chrome to |
38 // say that it's ready for the system to be suspended, in milliseconds. | 39 // say that it's ready for the system to be suspended, in milliseconds. |
39 const int kSuspendDelayTimeoutMs = 5000; | 40 const int kSuspendDelayTimeoutMs = 5000; |
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
139 power_manager::kPowerManagerInterface, | 140 power_manager::kPowerManagerInterface, |
140 power_manager::kGetScreenBrightnessPercentMethod); | 141 power_manager::kGetScreenBrightnessPercentMethod); |
141 power_manager_proxy_->CallMethod( | 142 power_manager_proxy_->CallMethod( |
142 &method_call, | 143 &method_call, |
143 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 144 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
144 base::Bind(&PowerManagerClientImpl::OnGetScreenBrightnessPercent, | 145 base::Bind(&PowerManagerClientImpl::OnGetScreenBrightnessPercent, |
145 weak_ptr_factory_.GetWeakPtr(), callback)); | 146 weak_ptr_factory_.GetWeakPtr(), callback)); |
146 } | 147 } |
147 | 148 |
148 virtual void RequestStatusUpdate() override { | 149 virtual void RequestStatusUpdate() override { |
| 150 POWER_LOG(USER) << "RequestStatusUpdate"; |
149 dbus::MethodCall method_call( | 151 dbus::MethodCall method_call( |
150 power_manager::kPowerManagerInterface, | 152 power_manager::kPowerManagerInterface, |
151 power_manager::kGetPowerSupplyPropertiesMethod); | 153 power_manager::kGetPowerSupplyPropertiesMethod); |
152 power_manager_proxy_->CallMethod( | 154 power_manager_proxy_->CallMethod( |
153 &method_call, | 155 &method_call, |
154 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 156 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
155 base::Bind(&PowerManagerClientImpl::OnGetPowerSupplyPropertiesMethod, | 157 base::Bind(&PowerManagerClientImpl::OnGetPowerSupplyPropertiesMethod, |
156 weak_ptr_factory_.GetWeakPtr())); | 158 weak_ptr_factory_.GetWeakPtr())); |
157 } | 159 } |
158 | 160 |
159 virtual void RequestSuspend() override { | 161 virtual void RequestSuspend() override { |
| 162 POWER_LOG(USER) << "RequestSuspend"; |
160 SimpleMethodCallToPowerManager(power_manager::kRequestSuspendMethod); | 163 SimpleMethodCallToPowerManager(power_manager::kRequestSuspendMethod); |
161 } | 164 } |
162 | 165 |
163 virtual void RequestRestart() override { | 166 virtual void RequestRestart() override { |
| 167 POWER_LOG(USER) << "RequestRestart"; |
164 SimpleMethodCallToPowerManager(power_manager::kRequestRestartMethod); | 168 SimpleMethodCallToPowerManager(power_manager::kRequestRestartMethod); |
165 } | 169 } |
166 | 170 |
167 virtual void RequestShutdown() override { | 171 virtual void RequestShutdown() override { |
| 172 POWER_LOG(USER) << "RequestShutdown"; |
168 SimpleMethodCallToPowerManager(power_manager::kRequestShutdownMethod); | 173 SimpleMethodCallToPowerManager(power_manager::kRequestShutdownMethod); |
169 } | 174 } |
170 | 175 |
171 virtual void NotifyUserActivity( | 176 virtual void NotifyUserActivity( |
172 power_manager::UserActivityType type) override { | 177 power_manager::UserActivityType type) override { |
173 dbus::MethodCall method_call( | 178 dbus::MethodCall method_call( |
174 power_manager::kPowerManagerInterface, | 179 power_manager::kPowerManagerInterface, |
175 power_manager::kHandleUserActivityMethod); | 180 power_manager::kHandleUserActivityMethod); |
176 dbus::MessageWriter writer(&method_call); | 181 dbus::MessageWriter writer(&method_call); |
177 writer.AppendInt32(type); | 182 writer.AppendInt32(type); |
(...skipping 12 matching lines...) Expand all Loading... |
190 writer.AppendBool(is_fullscreen); | 195 writer.AppendBool(is_fullscreen); |
191 | 196 |
192 power_manager_proxy_->CallMethod( | 197 power_manager_proxy_->CallMethod( |
193 &method_call, | 198 &method_call, |
194 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 199 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
195 dbus::ObjectProxy::EmptyResponseCallback()); | 200 dbus::ObjectProxy::EmptyResponseCallback()); |
196 } | 201 } |
197 | 202 |
198 virtual void SetPolicy( | 203 virtual void SetPolicy( |
199 const power_manager::PowerManagementPolicy& policy) override { | 204 const power_manager::PowerManagementPolicy& policy) override { |
| 205 POWER_LOG(USER) << "SetPolicy"; |
200 dbus::MethodCall method_call( | 206 dbus::MethodCall method_call( |
201 power_manager::kPowerManagerInterface, | 207 power_manager::kPowerManagerInterface, |
202 power_manager::kSetPolicyMethod); | 208 power_manager::kSetPolicyMethod); |
203 dbus::MessageWriter writer(&method_call); | 209 dbus::MessageWriter writer(&method_call); |
204 if (!writer.AppendProtoAsArrayOfBytes(policy)) { | 210 if (!writer.AppendProtoAsArrayOfBytes(policy)) { |
205 LOG(ERROR) << "Error calling " << power_manager::kSetPolicyMethod; | 211 POWER_LOG(ERROR) << "Error calling " << power_manager::kSetPolicyMethod; |
206 return; | 212 return; |
207 } | 213 } |
208 power_manager_proxy_->CallMethod( | 214 power_manager_proxy_->CallMethod( |
209 &method_call, | 215 &method_call, |
210 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 216 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
211 dbus::ObjectProxy::EmptyResponseCallback()); | 217 dbus::ObjectProxy::EmptyResponseCallback()); |
212 } | 218 } |
213 | 219 |
214 virtual void SetIsProjecting(bool is_projecting) override { | 220 virtual void SetIsProjecting(bool is_projecting) override { |
| 221 POWER_LOG(USER) << "SetIsProjecting"; |
215 dbus::MethodCall method_call( | 222 dbus::MethodCall method_call( |
216 power_manager::kPowerManagerInterface, | 223 power_manager::kPowerManagerInterface, |
217 power_manager::kSetIsProjectingMethod); | 224 power_manager::kSetIsProjectingMethod); |
218 dbus::MessageWriter writer(&method_call); | 225 dbus::MessageWriter writer(&method_call); |
219 writer.AppendBool(is_projecting); | 226 writer.AppendBool(is_projecting); |
220 power_manager_proxy_->CallMethod( | 227 power_manager_proxy_->CallMethod( |
221 &method_call, | 228 &method_call, |
222 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 229 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
223 dbus::ObjectProxy::EmptyResponseCallback()); | 230 dbus::ObjectProxy::EmptyResponseCallback()); |
224 last_is_projecting_ = is_projecting; | 231 last_is_projecting_ = is_projecting; |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
332 private: | 339 private: |
333 // Returns true if the current thread is the origin thread. | 340 // Returns true if the current thread is the origin thread. |
334 bool OnOriginThread() { | 341 bool OnOriginThread() { |
335 return base::PlatformThread::CurrentId() == origin_thread_id_; | 342 return base::PlatformThread::CurrentId() == origin_thread_id_; |
336 } | 343 } |
337 | 344 |
338 // Called when a dbus signal is initially connected. | 345 // Called when a dbus signal is initially connected. |
339 void SignalConnected(const std::string& interface_name, | 346 void SignalConnected(const std::string& interface_name, |
340 const std::string& signal_name, | 347 const std::string& signal_name, |
341 bool success) { | 348 bool success) { |
342 LOG_IF(WARNING, !success) << "Failed to connect to signal " | 349 if (!success) |
343 << signal_name << "."; | 350 POWER_LOG(ERROR) << "Failed to connect to signal " << signal_name << "."; |
344 } | 351 } |
345 | 352 |
346 // Makes a method call to power manager with no arguments and no response. | 353 // Makes a method call to power manager with no arguments and no response. |
347 void SimpleMethodCallToPowerManager(const std::string& method_name) { | 354 void SimpleMethodCallToPowerManager(const std::string& method_name) { |
348 dbus::MethodCall method_call(power_manager::kPowerManagerInterface, | 355 dbus::MethodCall method_call(power_manager::kPowerManagerInterface, |
349 method_name); | 356 method_name); |
350 power_manager_proxy_->CallMethod( | 357 power_manager_proxy_->CallMethod( |
351 &method_call, | 358 &method_call, |
352 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 359 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
353 dbus::ObjectProxy::EmptyResponseCallback()); | 360 dbus::ObjectProxy::EmptyResponseCallback()); |
354 } | 361 } |
355 | 362 |
356 void NameOwnerChangedReceived(const std::string& old_owner, | 363 void NameOwnerChangedReceived(const std::string& old_owner, |
357 const std::string& new_owner) { | 364 const std::string& new_owner) { |
358 VLOG(1) << "Power manager restarted (old owner was " | 365 POWER_LOG(EVENT) << "Power manager restarted. Old owner: " |
359 << (old_owner.empty() ? "[none]" : old_owner.c_str()) | 366 << (old_owner.empty() ? "[none]" : old_owner.c_str()) |
360 << ", new owner is " | 367 << " New owner: " |
361 << (new_owner.empty() ? "[none]" : new_owner.c_str()) << ")"; | 368 << (new_owner.empty() ? "[none]" : new_owner.c_str()); |
362 suspend_is_pending_ = false; | 369 suspend_is_pending_ = false; |
363 pending_suspend_id_ = -1; | 370 pending_suspend_id_ = -1; |
364 suspending_from_dark_resume_ = false; | 371 suspending_from_dark_resume_ = false; |
365 if (!new_owner.empty()) { | 372 if (!new_owner.empty()) { |
366 VLOG(1) << "Sending initial state to power manager"; | 373 POWER_LOG(EVENT) << "Sending initial state to power manager"; |
367 RegisterSuspendDelays(); | 374 RegisterSuspendDelays(); |
368 SetIsProjecting(last_is_projecting_); | 375 SetIsProjecting(last_is_projecting_); |
369 FOR_EACH_OBSERVER(Observer, observers_, PowerManagerRestarted()); | 376 FOR_EACH_OBSERVER(Observer, observers_, PowerManagerRestarted()); |
370 } | 377 } |
371 } | 378 } |
372 | 379 |
373 void BrightnessChangedReceived(dbus::Signal* signal) { | 380 void BrightnessChangedReceived(dbus::Signal* signal) { |
374 dbus::MessageReader reader(signal); | 381 dbus::MessageReader reader(signal); |
375 int32_t brightness_level = 0; | 382 int32_t brightness_level = 0; |
376 bool user_initiated = 0; | 383 bool user_initiated = 0; |
377 if (!(reader.PopInt32(&brightness_level) && | 384 if (!(reader.PopInt32(&brightness_level) && |
378 reader.PopBool(&user_initiated))) { | 385 reader.PopBool(&user_initiated))) { |
379 LOG(ERROR) << "Brightness changed signal had incorrect parameters: " | 386 POWER_LOG(ERROR) << "Brightness changed signal had incorrect parameters: " |
380 << signal->ToString(); | 387 << signal->ToString(); |
381 return; | 388 return; |
382 } | 389 } |
383 VLOG(1) << "Brightness changed to " << brightness_level | 390 POWER_LOG(DEBUG) << "Brightness changed to " << brightness_level |
384 << ": user initiated " << user_initiated; | 391 << ": user initiated " << user_initiated; |
385 FOR_EACH_OBSERVER(Observer, observers_, | 392 FOR_EACH_OBSERVER(Observer, observers_, |
386 BrightnessChanged(brightness_level, user_initiated)); | 393 BrightnessChanged(brightness_level, user_initiated)); |
387 } | 394 } |
388 | 395 |
389 void PeripheralBatteryStatusReceived(dbus::Signal* signal) { | 396 void PeripheralBatteryStatusReceived(dbus::Signal* signal) { |
390 dbus::MessageReader reader(signal); | 397 dbus::MessageReader reader(signal); |
391 power_manager::PeripheralBatteryStatus protobuf_status; | 398 power_manager::PeripheralBatteryStatus protobuf_status; |
392 if (!reader.PopArrayOfBytesAsProto(&protobuf_status)) { | 399 if (!reader.PopArrayOfBytesAsProto(&protobuf_status)) { |
393 LOG(ERROR) << "Unable to decode protocol buffer from " | 400 POWER_LOG(ERROR) << "Unable to decode protocol buffer from " |
394 << power_manager::kPeripheralBatteryStatusSignal << " signal"; | 401 << power_manager::kPeripheralBatteryStatusSignal |
| 402 << " signal"; |
395 return; | 403 return; |
396 } | 404 } |
397 | 405 |
398 std::string path = protobuf_status.path(); | 406 std::string path = protobuf_status.path(); |
399 std::string name = protobuf_status.name(); | 407 std::string name = protobuf_status.name(); |
400 int level = protobuf_status.has_level() ? protobuf_status.level() : -1; | 408 int level = protobuf_status.has_level() ? protobuf_status.level() : -1; |
401 | 409 |
402 VLOG(1) << "Device battery status received " << level | 410 POWER_LOG(DEBUG) << "Device battery status received " << level << " for " |
403 << " for " << name << " at " << path; | 411 << name << " at " << path; |
404 | 412 |
405 FOR_EACH_OBSERVER(Observer, observers_, | 413 FOR_EACH_OBSERVER(Observer, observers_, |
406 PeripheralBatteryStatusReceived(path, name, level)); | 414 PeripheralBatteryStatusReceived(path, name, level)); |
407 } | 415 } |
408 | 416 |
409 void PowerSupplyPollReceived(dbus::Signal* signal) { | 417 void PowerSupplyPollReceived(dbus::Signal* signal) { |
410 VLOG(1) << "Received power supply poll signal."; | 418 POWER_LOG(DEBUG) << "Received power supply poll signal."; |
411 dbus::MessageReader reader(signal); | 419 dbus::MessageReader reader(signal); |
412 power_manager::PowerSupplyProperties protobuf; | 420 power_manager::PowerSupplyProperties protobuf; |
413 if (reader.PopArrayOfBytesAsProto(&protobuf)) { | 421 if (reader.PopArrayOfBytesAsProto(&protobuf)) { |
414 HandlePowerSupplyProperties(protobuf); | 422 HandlePowerSupplyProperties(protobuf); |
415 } else { | 423 } else { |
416 LOG(ERROR) << "Unable to decode " | 424 POWER_LOG(ERROR) << "Unable to decode " |
417 << power_manager::kPowerSupplyPollSignal << "signal"; | 425 << power_manager::kPowerSupplyPollSignal << " signal"; |
418 } | 426 } |
419 } | 427 } |
420 | 428 |
421 void OnGetPowerSupplyPropertiesMethod(dbus::Response* response) { | 429 void OnGetPowerSupplyPropertiesMethod(dbus::Response* response) { |
422 if (!response) { | 430 if (!response) { |
423 LOG(ERROR) << "Error calling " | 431 POWER_LOG(ERROR) << "Error calling " |
424 << power_manager::kGetPowerSupplyPropertiesMethod; | 432 << power_manager::kGetPowerSupplyPropertiesMethod; |
425 return; | 433 return; |
426 } | 434 } |
427 | 435 |
428 dbus::MessageReader reader(response); | 436 dbus::MessageReader reader(response); |
429 power_manager::PowerSupplyProperties protobuf; | 437 power_manager::PowerSupplyProperties protobuf; |
430 if (reader.PopArrayOfBytesAsProto(&protobuf)) { | 438 if (reader.PopArrayOfBytesAsProto(&protobuf)) { |
431 HandlePowerSupplyProperties(protobuf); | 439 HandlePowerSupplyProperties(protobuf); |
432 } else { | 440 } else { |
433 LOG(ERROR) << "Unable to decode " | 441 POWER_LOG(ERROR) << "Unable to decode " |
434 << power_manager::kGetPowerSupplyPropertiesMethod | 442 << power_manager::kGetPowerSupplyPropertiesMethod |
435 << " response"; | 443 << " response"; |
436 } | 444 } |
437 } | 445 } |
438 | 446 |
439 void OnGetScreenBrightnessPercent( | 447 void OnGetScreenBrightnessPercent( |
440 const GetScreenBrightnessPercentCallback& callback, | 448 const GetScreenBrightnessPercentCallback& callback, |
441 dbus::Response* response) { | 449 dbus::Response* response) { |
442 if (!response) { | 450 if (!response) { |
443 LOG(ERROR) << "Error calling " | 451 POWER_LOG(ERROR) << "Error calling " |
444 << power_manager::kGetScreenBrightnessPercentMethod; | 452 << power_manager::kGetScreenBrightnessPercentMethod; |
445 return; | 453 return; |
446 } | 454 } |
447 dbus::MessageReader reader(response); | 455 dbus::MessageReader reader(response); |
448 double percent = 0.0; | 456 double percent = 0.0; |
449 if (!reader.PopDouble(&percent)) | 457 if (!reader.PopDouble(&percent)) |
450 LOG(ERROR) << "Error reading response from powerd: " | 458 POWER_LOG(ERROR) << "Error reading response from powerd: " |
451 << response->ToString(); | 459 << response->ToString(); |
452 callback.Run(percent); | 460 callback.Run(percent); |
453 } | 461 } |
454 | 462 |
455 void HandlePowerSupplyProperties( | 463 void HandlePowerSupplyProperties( |
456 const power_manager::PowerSupplyProperties& proto) { | 464 const power_manager::PowerSupplyProperties& proto) { |
457 FOR_EACH_OBSERVER(Observer, observers_, PowerChanged(proto)); | 465 FOR_EACH_OBSERVER(Observer, observers_, PowerChanged(proto)); |
458 const bool on_battery = proto.external_power() == | 466 const bool on_battery = proto.external_power() == |
459 power_manager::PowerSupplyProperties_ExternalPower_DISCONNECTED; | 467 power_manager::PowerSupplyProperties_ExternalPower_DISCONNECTED; |
460 base::PowerMonitorDeviceSource::SetPowerSource(on_battery); | 468 base::PowerMonitorDeviceSource::SetPowerSource(on_battery); |
461 } | 469 } |
462 | 470 |
463 void HandleRegisterSuspendDelayReply(bool dark_suspend, | 471 void HandleRegisterSuspendDelayReply(bool dark_suspend, |
464 const std::string& method_name, | 472 const std::string& method_name, |
465 dbus::Response* response) { | 473 dbus::Response* response) { |
466 if (!response) { | 474 if (!response) { |
467 LOG(ERROR) << "Error calling " << method_name; | 475 POWER_LOG(ERROR) << "Error calling " << method_name; |
468 return; | 476 return; |
469 } | 477 } |
470 | 478 |
471 dbus::MessageReader reader(response); | 479 dbus::MessageReader reader(response); |
472 power_manager::RegisterSuspendDelayReply protobuf; | 480 power_manager::RegisterSuspendDelayReply protobuf; |
473 if (!reader.PopArrayOfBytesAsProto(&protobuf)) { | 481 if (!reader.PopArrayOfBytesAsProto(&protobuf)) { |
474 LOG(ERROR) << "Unable to parse reply from " << method_name; | 482 POWER_LOG(ERROR) << "Unable to parse reply from " << method_name; |
475 return; | 483 return; |
476 } | 484 } |
477 | 485 |
478 if (dark_suspend) { | 486 if (dark_suspend) { |
479 dark_suspend_delay_id_ = protobuf.delay_id(); | 487 dark_suspend_delay_id_ = protobuf.delay_id(); |
480 has_dark_suspend_delay_id_ = true; | 488 has_dark_suspend_delay_id_ = true; |
481 VLOG(1) << "Registered dark suspend delay " << dark_suspend_delay_id_; | 489 POWER_LOG(EVENT) << "Registered dark suspend delay " |
| 490 << dark_suspend_delay_id_; |
482 } else { | 491 } else { |
483 suspend_delay_id_ = protobuf.delay_id(); | 492 suspend_delay_id_ = protobuf.delay_id(); |
484 has_suspend_delay_id_ = true; | 493 has_suspend_delay_id_ = true; |
485 VLOG(1) << "Registered suspend delay " << suspend_delay_id_; | 494 POWER_LOG(EVENT) << "Registered suspend delay " << suspend_delay_id_; |
486 } | 495 } |
487 } | 496 } |
488 | 497 |
489 void HandleSuspendImminent(bool in_dark_resume, dbus::Signal* signal) { | 498 void HandleSuspendImminent(bool in_dark_resume, dbus::Signal* signal) { |
490 std::string signal_name = signal->GetMember(); | 499 std::string signal_name = signal->GetMember(); |
491 if ((in_dark_resume && !has_dark_suspend_delay_id_) || | 500 if ((in_dark_resume && !has_dark_suspend_delay_id_) || |
492 (!in_dark_resume && !has_suspend_delay_id_)) { | 501 (!in_dark_resume && !has_suspend_delay_id_)) { |
493 LOG(ERROR) << "Received unrequested " << signal_name << " signal"; | 502 POWER_LOG(ERROR) << "Received unrequested " << signal_name << " signal"; |
494 return; | 503 return; |
495 } | 504 } |
496 | 505 |
497 dbus::MessageReader reader(signal); | 506 dbus::MessageReader reader(signal); |
498 power_manager::SuspendImminent proto; | 507 power_manager::SuspendImminent proto; |
499 if (!reader.PopArrayOfBytesAsProto(&proto)) { | 508 if (!reader.PopArrayOfBytesAsProto(&proto)) { |
500 LOG(ERROR) << "Unable to decode protocol buffer from " << signal_name | 509 POWER_LOG(ERROR) << "Unable to decode protocol buffer from " |
501 << " signal"; | 510 << signal_name << " signal"; |
502 return; | 511 return; |
503 } | 512 } |
504 | 513 |
505 VLOG(1) << "Got " << signal_name << " signal announcing suspend attempt " | 514 POWER_LOG(EVENT) << "Got " << signal_name |
506 << proto.suspend_id(); | 515 << " signal announcing suspend attempt " |
| 516 << proto.suspend_id(); |
507 | 517 |
508 // If a previous suspend is pending from the same state we are currently in | 518 // If a previous suspend is pending from the same state we are currently in |
509 // (fully powered on or in dark resume), then something's gone a little | 519 // (fully powered on or in dark resume), then something's gone a little |
510 // wonky. | 520 // wonky. |
511 if (suspend_is_pending_ && | 521 if (suspend_is_pending_ && suspending_from_dark_resume_ == in_dark_resume) { |
512 suspending_from_dark_resume_ == in_dark_resume) { | 522 POWER_LOG(ERROR) << "Got " << signal_name |
513 LOG(WARNING) << "Got " << signal_name << " signal about pending suspend " | 523 << " signal about pending suspend attempt " |
514 << "attempt " << proto.suspend_id() << " while still " | 524 << proto.suspend_id() |
515 << "waiting on attempt " << pending_suspend_id_; | 525 << " while still waiting on attempt " |
| 526 << pending_suspend_id_; |
516 } | 527 } |
517 | 528 |
518 pending_suspend_id_ = proto.suspend_id(); | 529 pending_suspend_id_ = proto.suspend_id(); |
519 suspend_is_pending_ = true; | 530 suspend_is_pending_ = true; |
520 suspending_from_dark_resume_ = in_dark_resume; | 531 suspending_from_dark_resume_ = in_dark_resume; |
521 num_pending_suspend_readiness_callbacks_ = 0; | 532 num_pending_suspend_readiness_callbacks_ = 0; |
522 if (suspending_from_dark_resume_) | 533 if (suspending_from_dark_resume_) |
523 FOR_EACH_OBSERVER(Observer, observers_, DarkSuspendImminent()); | 534 FOR_EACH_OBSERVER(Observer, observers_, DarkSuspendImminent()); |
524 else | 535 else |
525 FOR_EACH_OBSERVER(Observer, observers_, SuspendImminent()); | 536 FOR_EACH_OBSERVER(Observer, observers_, SuspendImminent()); |
526 base::PowerMonitorDeviceSource::HandleSystemSuspending(); | 537 base::PowerMonitorDeviceSource::HandleSystemSuspending(); |
527 MaybeReportSuspendReadiness(); | 538 MaybeReportSuspendReadiness(); |
528 } | 539 } |
529 | 540 |
530 void SuspendDoneReceived(dbus::Signal* signal) { | 541 void SuspendDoneReceived(dbus::Signal* signal) { |
531 dbus::MessageReader reader(signal); | 542 dbus::MessageReader reader(signal); |
532 power_manager::SuspendDone proto; | 543 power_manager::SuspendDone proto; |
533 if (!reader.PopArrayOfBytesAsProto(&proto)) { | 544 if (!reader.PopArrayOfBytesAsProto(&proto)) { |
534 LOG(ERROR) << "Unable to decode protocol buffer from " | 545 POWER_LOG(ERROR) << "Unable to decode protocol buffer from " |
535 << power_manager::kSuspendDoneSignal << " signal"; | 546 << power_manager::kSuspendDoneSignal << " signal"; |
536 return; | 547 return; |
537 } | 548 } |
538 | 549 |
539 const base::TimeDelta duration = | 550 const base::TimeDelta duration = |
540 base::TimeDelta::FromInternalValue(proto.suspend_duration()); | 551 base::TimeDelta::FromInternalValue(proto.suspend_duration()); |
541 VLOG(1) << "Got " << power_manager::kSuspendDoneSignal << " signal:" | 552 POWER_LOG(EVENT) << "Got " << power_manager::kSuspendDoneSignal |
542 << " suspend_id=" << proto.suspend_id() | 553 << " signal:" |
543 << " duration=" << duration.InSeconds() << " sec"; | 554 << " suspend_id=" << proto.suspend_id() |
| 555 << " duration=" << duration.InSeconds() << " sec"; |
544 | 556 |
545 if (render_process_manager_delegate_) | 557 if (render_process_manager_delegate_) |
546 render_process_manager_delegate_->SuspendDone(); | 558 render_process_manager_delegate_->SuspendDone(); |
547 | 559 |
548 FOR_EACH_OBSERVER( | 560 FOR_EACH_OBSERVER( |
549 PowerManagerClient::Observer, observers_, SuspendDone(duration)); | 561 PowerManagerClient::Observer, observers_, SuspendDone(duration)); |
550 base::PowerMonitorDeviceSource::HandleSystemResumed(); | 562 base::PowerMonitorDeviceSource::HandleSystemResumed(); |
551 } | 563 } |
552 | 564 |
553 void IdleActionImminentReceived(dbus::Signal* signal) { | 565 void IdleActionImminentReceived(dbus::Signal* signal) { |
554 dbus::MessageReader reader(signal); | 566 dbus::MessageReader reader(signal); |
555 power_manager::IdleActionImminent proto; | 567 power_manager::IdleActionImminent proto; |
556 if (!reader.PopArrayOfBytesAsProto(&proto)) { | 568 if (!reader.PopArrayOfBytesAsProto(&proto)) { |
557 LOG(ERROR) << "Unable to decode protocol buffer from " | 569 POWER_LOG(ERROR) << "Unable to decode protocol buffer from " |
558 << power_manager::kIdleActionImminentSignal << " signal"; | 570 << power_manager::kIdleActionImminentSignal << " signal"; |
559 return; | 571 return; |
560 } | 572 } |
561 FOR_EACH_OBSERVER(Observer, observers_, | 573 FOR_EACH_OBSERVER(Observer, observers_, |
562 IdleActionImminent(base::TimeDelta::FromInternalValue( | 574 IdleActionImminent(base::TimeDelta::FromInternalValue( |
563 proto.time_until_idle_action()))); | 575 proto.time_until_idle_action()))); |
564 } | 576 } |
565 | 577 |
566 void IdleActionDeferredReceived(dbus::Signal* signal) { | 578 void IdleActionDeferredReceived(dbus::Signal* signal) { |
567 FOR_EACH_OBSERVER(Observer, observers_, IdleActionDeferred()); | 579 FOR_EACH_OBSERVER(Observer, observers_, IdleActionDeferred()); |
568 } | 580 } |
569 | 581 |
570 void InputEventReceived(dbus::Signal* signal) { | 582 void InputEventReceived(dbus::Signal* signal) { |
571 dbus::MessageReader reader(signal); | 583 dbus::MessageReader reader(signal); |
572 power_manager::InputEvent proto; | 584 power_manager::InputEvent proto; |
573 if (!reader.PopArrayOfBytesAsProto(&proto)) { | 585 if (!reader.PopArrayOfBytesAsProto(&proto)) { |
574 LOG(ERROR) << "Unable to decode protocol buffer from " | 586 POWER_LOG(ERROR) << "Unable to decode protocol buffer from " |
575 << power_manager::kInputEventSignal << " signal"; | 587 << power_manager::kInputEventSignal << " signal"; |
576 return; | 588 return; |
577 } | 589 } |
578 | 590 |
579 base::TimeTicks timestamp = | 591 base::TimeTicks timestamp = |
580 base::TimeTicks::FromInternalValue(proto.timestamp()); | 592 base::TimeTicks::FromInternalValue(proto.timestamp()); |
581 VLOG(1) << "Got " << power_manager::kInputEventSignal << " signal:" | 593 POWER_LOG(USER) << "Got " << power_manager::kInputEventSignal << " signal:" |
582 << " type=" << proto.type() << " timestamp=" << proto.timestamp(); | 594 << " type=" << proto.type() |
| 595 << " timestamp=" << proto.timestamp(); |
583 switch (proto.type()) { | 596 switch (proto.type()) { |
584 case power_manager::InputEvent_Type_POWER_BUTTON_DOWN: | 597 case power_manager::InputEvent_Type_POWER_BUTTON_DOWN: |
585 case power_manager::InputEvent_Type_POWER_BUTTON_UP: { | 598 case power_manager::InputEvent_Type_POWER_BUTTON_UP: { |
586 const bool down = | 599 const bool down = |
587 (proto.type() == power_manager::InputEvent_Type_POWER_BUTTON_DOWN); | 600 (proto.type() == power_manager::InputEvent_Type_POWER_BUTTON_DOWN); |
588 FOR_EACH_OBSERVER(PowerManagerClient::Observer, observers_, | 601 FOR_EACH_OBSERVER(PowerManagerClient::Observer, observers_, |
589 PowerButtonEventReceived(down, timestamp)); | 602 PowerButtonEventReceived(down, timestamp)); |
590 | 603 |
591 // Tell powerd that Chrome has handled power button presses. | 604 // Tell powerd that Chrome has handled power button presses. |
592 if (down) { | 605 if (down) { |
(...skipping 22 matching lines...) Expand all Loading... |
615 | 628 |
616 void RegisterSuspendDelayImpl( | 629 void RegisterSuspendDelayImpl( |
617 const std::string& method_name, | 630 const std::string& method_name, |
618 const power_manager::RegisterSuspendDelayRequest& protobuf_request, | 631 const power_manager::RegisterSuspendDelayRequest& protobuf_request, |
619 dbus::ObjectProxy::ResponseCallback callback) { | 632 dbus::ObjectProxy::ResponseCallback callback) { |
620 dbus::MethodCall method_call( | 633 dbus::MethodCall method_call( |
621 power_manager::kPowerManagerInterface, method_name); | 634 power_manager::kPowerManagerInterface, method_name); |
622 dbus::MessageWriter writer(&method_call); | 635 dbus::MessageWriter writer(&method_call); |
623 | 636 |
624 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { | 637 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { |
625 LOG(ERROR) << "Error constructing message for " << method_name; | 638 POWER_LOG(ERROR) << "Error constructing message for " << method_name; |
626 return; | 639 return; |
627 } | 640 } |
628 | 641 |
629 power_manager_proxy_->CallMethod( | 642 power_manager_proxy_->CallMethod( |
630 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, callback); | 643 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, callback); |
631 } | 644 } |
632 | 645 |
633 // Registers suspend delays with the power manager. This is usually only | 646 // Registers suspend delays with the power manager. This is usually only |
634 // called at startup, but if the power manager restarts, we need to create new | 647 // called at startup, but if the power manager restarts, we need to create new |
635 // delays. | 648 // delays. |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
690 delay_id = suspend_delay_id_; | 703 delay_id = suspend_delay_id_; |
691 } | 704 } |
692 | 705 |
693 if (render_process_manager_delegate_ && !suspending_from_dark_resume_) | 706 if (render_process_manager_delegate_ && !suspending_from_dark_resume_) |
694 render_process_manager_delegate_->SuspendImminent(); | 707 render_process_manager_delegate_->SuspendImminent(); |
695 | 708 |
696 dbus::MethodCall method_call( | 709 dbus::MethodCall method_call( |
697 power_manager::kPowerManagerInterface, method_name); | 710 power_manager::kPowerManagerInterface, method_name); |
698 dbus::MessageWriter writer(&method_call); | 711 dbus::MessageWriter writer(&method_call); |
699 | 712 |
700 VLOG(1) << "Announcing readiness of suspend delay " << delay_id | 713 POWER_LOG(EVENT) << "Announcing readiness of suspend delay " << delay_id |
701 << " for suspend attempt " << pending_suspend_id_; | 714 << " for suspend attempt " << pending_suspend_id_; |
702 power_manager::SuspendReadinessInfo protobuf_request; | 715 power_manager::SuspendReadinessInfo protobuf_request; |
703 protobuf_request.set_delay_id(delay_id); | 716 protobuf_request.set_delay_id(delay_id); |
704 protobuf_request.set_suspend_id(pending_suspend_id_); | 717 protobuf_request.set_suspend_id(pending_suspend_id_); |
705 | 718 |
706 pending_suspend_id_ = -1; | 719 pending_suspend_id_ = -1; |
707 suspend_is_pending_ = false; | 720 suspend_is_pending_ = false; |
708 | 721 |
709 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { | 722 if (!writer.AppendProtoAsArrayOfBytes(protobuf_request)) { |
710 LOG(ERROR) << "Error constructing message for " << method_name; | 723 POWER_LOG(ERROR) << "Error constructing message for " << method_name; |
711 return; | 724 return; |
712 } | 725 } |
713 power_manager_proxy_->CallMethod( | 726 power_manager_proxy_->CallMethod( |
714 &method_call, | 727 &method_call, |
715 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 728 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
716 dbus::ObjectProxy::EmptyResponseCallback()); | 729 dbus::ObjectProxy::EmptyResponseCallback()); |
717 } | 730 } |
718 | 731 |
719 // Origin thread (i.e. the UI thread in production). | 732 // Origin thread (i.e. the UI thread in production). |
720 base::PlatformThreadId origin_thread_id_; | 733 base::PlatformThreadId origin_thread_id_; |
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
800 | 813 |
801 virtual bool HasObserver(const Observer* observer) const override { | 814 virtual bool HasObserver(const Observer* observer) const override { |
802 return observers_.HasObserver(observer); | 815 return observers_.HasObserver(observer); |
803 } | 816 } |
804 | 817 |
805 virtual void SetRenderProcessManagerDelegate( | 818 virtual void SetRenderProcessManagerDelegate( |
806 base::WeakPtr<RenderProcessManagerDelegate> delegate) override { | 819 base::WeakPtr<RenderProcessManagerDelegate> delegate) override { |
807 } | 820 } |
808 | 821 |
809 virtual void DecreaseScreenBrightness(bool allow_off) override { | 822 virtual void DecreaseScreenBrightness(bool allow_off) override { |
810 VLOG(1) << "Requested to descrease screen brightness"; | 823 POWER_LOG(USER) << "Requested to descrease screen brightness"; |
811 SetBrightness(brightness_ - 5.0, true); | 824 SetBrightness(brightness_ - 5.0, true); |
812 } | 825 } |
813 | 826 |
814 virtual void IncreaseScreenBrightness() override { | 827 virtual void IncreaseScreenBrightness() override { |
815 VLOG(1) << "Requested to increase screen brightness"; | 828 POWER_LOG(USER) << "Requested to increase screen brightness"; |
816 SetBrightness(brightness_ + 5.0, true); | 829 SetBrightness(brightness_ + 5.0, true); |
817 } | 830 } |
818 | 831 |
819 virtual void SetScreenBrightnessPercent(double percent, | 832 virtual void SetScreenBrightnessPercent(double percent, |
820 bool gradual) override { | 833 bool gradual) override { |
821 VLOG(1) << "Requested to set screen brightness to " << percent << "% " | 834 POWER_LOG(USER) << "Requested to set screen brightness to " << percent |
822 << (gradual ? "gradually" : "instantaneously"); | 835 << "% " << (gradual ? "gradually" : "instantaneously"); |
823 SetBrightness(percent, false); | 836 SetBrightness(percent, false); |
824 } | 837 } |
825 | 838 |
826 virtual void GetScreenBrightnessPercent( | 839 virtual void GetScreenBrightnessPercent( |
827 const GetScreenBrightnessPercentCallback& callback) override { | 840 const GetScreenBrightnessPercentCallback& callback) override { |
| 841 POWER_LOG(USER) << "Requested to get screen brightness"; |
828 callback.Run(brightness_); | 842 callback.Run(brightness_); |
829 } | 843 } |
830 | 844 |
831 virtual void DecreaseKeyboardBrightness() override { | 845 virtual void DecreaseKeyboardBrightness() override { |
832 VLOG(1) << "Requested to descrease keyboard brightness"; | 846 POWER_LOG(USER) << "Requested to descrease keyboard brightness"; |
833 } | 847 } |
834 | 848 |
835 virtual void IncreaseKeyboardBrightness() override { | 849 virtual void IncreaseKeyboardBrightness() override { |
836 VLOG(1) << "Requested to increase keyboard brightness"; | 850 POWER_LOG(USER) << "Requested to increase keyboard brightness"; |
837 } | 851 } |
838 | 852 |
839 virtual void RequestStatusUpdate() override { | 853 virtual void RequestStatusUpdate() override { |
840 base::MessageLoop::current()->PostTask(FROM_HERE, | 854 POWER_LOG(USER) << "Requested status update"; |
841 base::Bind(&PowerManagerClientStubImpl::UpdateStatus, | 855 base::MessageLoop::current()->PostTask( |
842 weak_ptr_factory_.GetWeakPtr())); | 856 FROM_HERE, base::Bind(&PowerManagerClientStubImpl::UpdateStatus, |
| 857 weak_ptr_factory_.GetWeakPtr())); |
843 } | 858 } |
844 | 859 |
845 virtual void RequestSuspend() override {} | 860 virtual void RequestSuspend() override {} |
846 virtual void RequestRestart() override {} | 861 virtual void RequestRestart() override {} |
847 virtual void RequestShutdown() override {} | 862 virtual void RequestShutdown() override {} |
848 | 863 |
849 virtual void NotifyUserActivity( | 864 virtual void NotifyUserActivity( |
850 power_manager::UserActivityType type) override {} | 865 power_manager::UserActivityType type) override {} |
851 virtual void NotifyVideoActivity(bool is_fullscreen) override {} | 866 virtual void NotifyVideoActivity(bool is_fullscreen) override {} |
852 virtual void SetPolicy( | 867 virtual void SetPolicy( |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
992 // static | 1007 // static |
993 PowerManagerClient* PowerManagerClient::Create( | 1008 PowerManagerClient* PowerManagerClient::Create( |
994 DBusClientImplementationType type) { | 1009 DBusClientImplementationType type) { |
995 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) | 1010 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) |
996 return new PowerManagerClientImpl(); | 1011 return new PowerManagerClientImpl(); |
997 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); | 1012 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); |
998 return new PowerManagerClientStubImpl(); | 1013 return new PowerManagerClientStubImpl(); |
999 } | 1014 } |
1000 | 1015 |
1001 } // namespace chromeos | 1016 } // namespace chromeos |
OLD | NEW |